# **TOSHIBA** 32 Bit RISC Microcontroller TX03 Series TMPM362F10FG #### **TOSHIBA CORPORATION** Semiconductor & Storage Products Company TOSHIBA TMPM362F10FG ARM, ARM Powered, AMBA, ADK, ARM9TDMI, TDMI, PrimeCell, RealView, Thumb, Cortex, Coresight, ARM9, ARM926EJ-S, Embedded Trace Macrocell, ETM, AHB, APB, and KEIL are registered trademarks or trademarks of ARM Limited in the EU and other countries. **ARM**° ## Important Notices Make sure to read read this chapter before using the product. #### Serial bus interface There are restrictions on the use of I2C bus mode when the multi-master function is used. #### 1.1 Description When the multi-master function is used in I2C bus mode, if these masters start the communications simultaneously, the following phenomena may occur: - 1. Communications may be locked up. - 2. SCL pulse widths shorten; therefore these pulses may not satisfy I2C Specifications. #### 1.2 Condition These phenomena occur only when the multi-master function is used in 12C bus mode. If a single master is used, these phenomena do not occur. #### 1.3 Workaround There is no workaround for these phenomena. Perform recovery process by software. #### 1.4 How to Recover from These Phenomena Perform recovery process by software. By using a timer, add timeout process to check whether communication is in a lock-up state. #### An example of recovery process: - 1. Start a timer count synchronously with start of the transmission. - 2. If a serial interface interrupt (INTSBIx) does not occur in a certain period, the MCU determines the timeout. - 3. If the MCU determines the timeout, communications may be locked up. Perform software reset on the serial bus interface circuit. This circuit is initialized to release communication from the lock up state. - 4. Resend transmission data. Mostly, Process 1 to 4 are enough to recovery; however if the multiple products are connected to the same bus line, add a delay time between each product's recovery process before Process 4 (resending data) is performed. This delay makes a time difference between each master; therefore bus collision can be avoided when the data is sent again. **Important Notices** Example: Recovery process after a timeout is detected. # <u>Introduction: Notes on the description of SFR (Special Function Register) under this specification</u> An SFR (Special Function Register) is a control register for periperal circuits (IP). The SFR addressses of IPs are described in the chapter on memory map, and the details of SFR are given in the chapter of each IP. Definition of SFR used in this specification is in accordance with the following rules - a. SFR table of each IP as an example - SFR tables in each chapter of IP provides register names, addresses and brief descriptions. - All registers have a 32-bit unique address and the addresses of the registers are defined as follows, with some exceptions: "Base address + (Unique) address" Base Address = 0x0000 0000 | Register name | | Address(Base+) | |------------------|-------|----------------| | Control register | SAMCR | 0x0004 | | | | 0x000C | Note: SAMCR register address is 32 bits wide from the address 0x0000\_0004 (Base Address(0x00000000) + unique address (0x0004)). Note: The register shown above is an example for explanation purpose and not for demonstration purpose. This register does not exist in this microcontroller. - b. SFR(register) - Each register basically consists of a 32-bit register (some exceptions). - The description of each register provides bits, bit symbols, types, initial values after reset and functions. #### 1.2.2 SAMCR(Control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|------|----|----|----|-------|-------|-----|-----| | bit symbol | - | - | - | - | - | - < | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 177 | 16 | | bit symbol | - | - | - | - | - | | ) | - | | After reset | 0 | 0 | 0 | 0 | 0 ^ | (0//< | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | | МС | DDE | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 10 | 0 | | bit symbol | MODE | | | | TDATA | | 4 | | | After reset | 0 | 0 | 0 | 1 | 0 | 0 | 20 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-10 | _ | R | "0" can be read. | | 9-7 | MODE[2:0] | R/W | Operation mode settings 000 : Sample mode 0 001 : Sample mode 1 010 : Sample mode 2 011 : Sample mode 3 The settings other than those above: Reserved | | 6-0 | TDATA[6:0] | W | Transmitted data | Note: The Type is divided into three as shown below. R / W READ WRITE READ WRITE c. Data descriptopn Meanings of symbols used in the SFR description are as shown below. - \ x:channel numbers/ports - n,m;bit numbers - d. Register descriptoption Registers are described as shown below. Register name <Bit Symbol> Exmaple: SAMCR<MODE>="000" or SAMCR<MODE[2:0]>="000" <MODE[2:0]> indicates bit 2 to bit 0 in bit symbol mode (3bit width). · Register name [Bit] Example: SAMCR[9:7]="000" It indicates bit 9 to bit 7 of the register SAMCR (32 bit width). # Revision History | Date | Revision | Comment | |------------|----------|------------------| | 2011/06/21 | 1 | First Release | | 2013/05/31 | 2 | Contents Revised | | 2023/07/21 | 3 | Contents Revised | # **Table of Contents** Introduction: Notes on the description of SFR (Special Function Register) under this specification TMPM362F10FG 1.1 Features. Block Diagram 4 Pin names and Functions 6 Pin Numbers and Power Supply Pins. **Processor Core** Configurable Options 17 2.3 2.3.1 2.3.2 234 2.3.5 Events 19 Exclusive access 19 **Debug Interface** 3ASW-DP 21 Pin functions 22 Peripheral Functions in Halt Mode......23 Reset Vector Break. 23 3.7 Memory Map 4.2 SFR area detail 27 | 5. | Reset | | | |----|--------------------------------------------------------------------------------|---------------------------------------------------|----------| | | 5.1 Cold reset | | 20 | | | | | | | | | $\Omega$ | | | | 5.3 After reset. | | | | | THE TESEL | | | | | | | | | 5. | Clock / Mode Control | | | | | 6.1 Features | | 33 | | | | | 33 | | | 9 | | 34<br>34 | | | 6.2.1 Register List | | | | | 6.2.3 CGOSCCR (Oscillation control register) | | | | | 6.2.4 CGSTRYCR (Standby control register) | | 37 | | | 6.2.5 CGPLLSEL (PLL Selection Register) | | 38 | | | 6.2.6 CGCKSEL (System clock selection register) | | 39 | | | 6.3 Clock control | | 40 | | | 6.3.1 Clock Type | | 40 | | | 6.3.2 Initial Values after Reset. | $\langle \langle \langle \rangle \rangle \rangle$ | 40 | | | 6.3.3 Clock system Diagram. | | 41 | | | 6.3.4 Warm-up function | <u> </u> | 42 | | | | | 45 | | | 6.3.5.1 How to configure the PLL function 6.3.5.2 Changing PLL multiplying | | | | | 6.3.5.2 Changing PLL multiplying<br>6.3.5.3 Start PLL sequence | | | | | 6.3.5.4 Multiplying value change sequence | ^ | | | | 6.3.6 System Clock | | 48 | | | 6.3.6.1 High-speed clock | | | | | 6.3.6.2 Low-speed clock<br>6.3.6.3 Setting system clock | | | | | 6.3.7 Prescaler Clock Control | | 50 | | | 6.3.8 System Clock Pin Output Function | <u> </u> | 50 | | | 6.4 Modes and Mode Transitions | // () | 51 | | | 6.4.1 Mode Transitions | | 51 | | | 6.5 Operation Mode | | 52 | | | 651 NORMAL mode | > | 52<br>52 | | | | | | | | | | | | | | | | | | 6.6.1.1 IDLE2 mode | | 55 | | | 6.6/1.2 IDLE1 mode | | | | | | | | | | | | | | _ | | EP) | | | | | | | | | | | | | | | | | | | 1 | | | | | 6.6.9.1 Transition of operation modes: NORMAL → STOP - | | 02 | | | 6.6.9.2 Transition of operation modes : NORMAL $\rightarrow$ SLEEP | | | | | 6.6.9.3 Transition of operation modes: SLOW → STOP → S | | | | | 6.6.9.4 Transition of operation modes : SLOW $\rightarrow$ SLEEP $\rightarrow$ | SLOW | | | | | | | | 7. | Exceptions | | | | • | Zieepeons | | | | | 7.1 Overview | | 65 | | 7.1. | 1 Ex | ception types | 6 | |--------------|----------------------|-----------------------------------------------------------------------------------------------|-----| | 7.1. | | andling Flowchart | 6 | | | 7.1.2.1 | Exception Request and Detection | | | | 7.1.2.2<br>7.1.2.3 | Exception Handling and Branch to the Interrupt Service Routine (Pre-emption) | | | | 7.1.2.3 | Executing an ISR Exception exit | | | 7.2 | | | | | | | 1 | | | 7.3 | Non- | -Maskable Interrupts (NMI) | | | 7.4 | SysT | lick (7/4) | | | 7.5 | Into | rupts | | | | | | | | 7.5. | | terrupt Sources | 7 | | | 7.5.1.1<br>7.5.1.2 | Interrupt route Generation | | | | 7.5.1.2 | Transmission | | | | 7.5.1.4 | Precautions when using external interrupt pins | | | | 7.5.1.5 | List of Interrupt Sources | | | 7 | 7.5.1.6 | Active level | ~ | | 7.5. | 2 In | terrupt Handling | .>7 | | | 7.5.2.1 | Flowchart | _ | | | 7.5.2.2 | Preparation | ) | | | 7.5.2.3 | Detection by Clock Generator | / | | | 7.5.2.4<br>7.5.2.5 | Detection by CPU CPU processing | | | | 7.5.2.6 | Interrupt Service Routine (ISR) | | | 7.6 | | eption / Interrupt-Related Registers | | | | | | | | 7.6. | | gister List. | 3 | | 7.6. | | VIC Registers | | | | 7.6.2.1<br>7.6.2.2 | SysTick Control and Status Register SysTick Reload Value Register | | | | 7.6.2.3 | SysTick Current Value Register | | | | 7.6.2.4 | SysTick Calibration Value Register | | | | 7.6.2.5 | Interrupt Set-Enable Register 1 | | | 7 | 7.6.2.6 | Interrupt Set-Enable Register 2 | | | | 7.6.2.7 | Interrupt Set-Enable Register 3 | | | | 7.6.2.8 | Interrupt Set-Enable Register 4 | | | | 7.6.2.9 | Interrupt Clear-Enable Register 1 | | | | 7.6.2.10<br>7.6.2.11 | Interrupt Clear-Enable Register 2 Interrupt Clear-Enable Register, 3 | | | | 7.6.2.11 | Interrupt Clear-Enable Register 4 | | | | 7.6.2.13 | Interrupt Set-Pending Register 1 | | | | 7.6.2.14 | Interrupt Set-Pending Register 2 | | | 7 | 7.6.2.15 | Interrupt Set-Pending Register 3 | | | | 7.6.2.16 | Interrupt Set-Pending Register 4 | | | | 7.6.2.17 | Interrupt Clear-Pending Register 1 | | | | 7.6.2.18 | Interrupt Clear-Pending Register 2 | | | | 7.6.2.19 | Interrupt Clear-Pending Register 3 | | | | 7.6.2.20 | Interrupt Clear-Pending Register 4 | | | | 7.6.2.21<br>7.6.2.22 | Interrupt Priority Register Vector Table Offset Register | | | _ | 7.6.2.23 | Application Interrupt and Reset Control Register | | | | 7.6.2.24 | System Handler Priority Register | | | | 7.6.2.25 | System Handler Control and State Register | | | 7.6. | // | ock generator registers | 11 | | | 7.6.3.1 | CGIMCGA (CG Interrupt Mode Control Register A) | | | | 7.6.3.2 | CGIMCGB (CG Interrupt Mode Control Register B) | | | | 7.6.3.3 | CGIMCGC (CG Interrupt Mode Control Register C) | | | | 7.6.3.4 | CGIMCGD (CG Interrupt Mode Control Register D) | | | | 7.6.3.5<br>7.6.3.6 | CGIMCGE (CG Interrupt Mode Control Register E) CGIMCGF (CG Interrupt Mode Control Register F) | | | | 7.6.3.7 | CGICRCG (CG Interrupt Mode Control Register F) CGICRCG (CG Interrupt Request Clear Register) | | | | 7.6.3.8 | CGNMIFLG (NMI Flag Register) | | | | 7.6.3.9 | CGRSTFLG (Reset Flag Register) | | | | | | | | | | | | | | | | | | Inpu | ıt / O | Output Ports | | | 0.1 | ъ | T | | | 8.1 | | Functions | | | 8.1.<br>8.1. | | nction list | | | 8.1. | | ort states in STOP Mode | | | 0.1. | ۲۵ د. | II SITUF WILLE | 13 | | 8.2 Por | functions | 133 | |--------------------|-------------------------------------------------------------------------------|--------------------------| | | ort A (PA0 to PA7) | | | 8.2.1.1 | Port A Circuit Type | | | 8.2.1.2 | Port A Register | | | 8.2.1.3 | PADATA (Port A data register) | | | 8.2.1.4 | PACR (Port A output control register) | | | 8.2.1.5 | PAFR1 (Port A function register 1) | | | 8.2.1.6 | PAOD (Port A open drain control register) | | | 8.2.1.7 | PAPUP (Port A pull-up control register) | | | 8.2.1.8 | PAIE (Port A input control register) | 120 | | | ort B (PB0 to PB7) | 138 | | 8.2.2.1<br>8.2.2.2 | Port B Circuit Type | | | 8.2.2.2 | Port B Register PBDATA (Port B data register) | | | 8.2.2.4 | PBCR (Port B output control register) | | | 8.2.2.5 | PBFR1 (Port B function register) | | | 8.2.2.6 | PBOD (Port B open drain control register) | | | 8.2.2.7 | PBPUP (Port B pull-up control register) | | | 8.2.2.8 | PBIE (Port B input control register) | | | 8.2.3 P | ort C (PC0 to PC7) | 143 | | 8.2.3.1 | Port C Circuit Type | ~ ` | | 8.2.3.2 | Port C Register | $\langle \gamma \rangle$ | | 8.2.3.3 | PCDATA (Port C data register) | ′ // | | 8.2.3.4 | PCCR (Port C output control register) | | | 8.2.3.5 | PCFR1 (Port C function register 1) | | | 8.2.3.6 | PCFR2 (Port C function register 2) | | | 8.2.3.7 | PCFR3 (Port C function register 3) PCOD (Port C open drain control reigister) | | | 8.2.3.8<br>8.2.3.9 | PCPUP (Port C pull-up control register) | | | 8.2.3.10 | | | | | ort D (PD0 to PD7) | 149 | | 8.2.4.1 | Port D Circuit Type | 177 | | 8.2.4.2 | Port Register | | | 8.2.4.3 | PDDATA (Port D data register) | | | 8.2.4.4 | PDCR (Port D output control register) | | | 8.2.4.5 | PDFR1 (Port D function register 1) | | | 8.2.4.6 | PDFR2 (Port D function register 2) | | | 8.2.4.7 | PDFR3 (Port D function register-3) | | | 8.2.4.8 | PDOD (Port D open drain control register) | | | 8.2.4.9 | PDPUP (Port D pull-up control register) | | | 8.2.4.10 | | 155 | | 8.2.5 P<br>8.2.5.1 | ort E (PE0 to PE7) Port E Circuit Type | 155 | | 8.2.5.2 | Port E register | | | 8.2.5.3 | PEDATA (Port) E data register) | | | 8.2.5.4 | PECR (Port E output control register) | | | 8.2.5.5 | PEFR1 (Port E function register 1) | | | 8.2.5.6 | PEFR2 (Port E function register 2) | | | 8.2.5.7 | PEFR3 (Port E function register 3) | | | 8.2.5.8 | PEOD (Port E open drain control register) | | | 8.2.5.9 | | | | 8.2.5.10 | | | | | ort F (PF0 to PF4) | 161 | | 8.2.6.1 | Port F Circuit Type | | | 8.2.6.2 | Port F Register | | | 8.2.6.3 | PFDATA (Port F output control register) | | | 8.2.6.4<br>8.2.6.5 | PFCR (Port F output control register) PFFR1 (Port F function register 1) | | | 8.2.6.6 | PFOD (Port F open drain control register) | | | 8.2.6.7 | | | | 8.2.6.8 | PFIE (Port F input control register) | | | | ort G (PG0 to PG7) | 166 | | 8.2.7.1 | Port G Circuit Type | | | 8.2.7.2 | Port G register | | | 8.2.7.3 | PGDATA (Port G data register) | | | 8.2.7.4 | PGCR (Port G output control register) | | | 8.2.7.5 | PGFR1 (Port G function register 1) | | | 8.2.7.6 | PGFR2 (Port G function register 2) | | | 8.2.7.7 | PGFR3 (Port G function register 3) | | | 8.2.7.8 | PGOD (Port G open drain control register) | | | 8.2.7.9 | PGPUP (Port G pull-up control register) | | | 8.2.7.10 | • | 172 | | 8.2.8 P<br>8.2.8.1 | ort H (PH0 to PH7)<br>Port H Circut Type | 1/3 | | 8.2.8.2 | Port H register | | | 3.2.3.2 | · · · · · · · · · · · · · · · · · · · | | | 8.2.8.3<br>8.2.8.4 | PHDATA (Port H data register) PHCR (Port H output control register) | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------| | 8.2.8.5 | PHFR1 (Port H function register 1) | | | 8.2.8.6 | PHFR2 (Port H function register 2) | | | 8.2.8.7 | PHOD (Port H open drain control register) | | | 8.2.8.8 | PHPUP (Port H pull-up control register) | | | 8.2.8.9 | PHIE (Port H input control register) | | | | rt I (PI0 to PI3) | | | 8.2.9.1 | Port I Circuit Type | | | 8.2.9.2 | Port I register | . (7/\ | | 8.2.9.3 | PIDATA (Port I data register) PICR (Port I output control register) | | | 8.2.9.4<br>8.2.9.5 | PIFR1 (Port I function register 1) | | | 8.2.9.6 | PIOD (Port I open drain control register) | | | 8.2.9.7 | PIPUP (Port I pull-up control register) | | | 8.2.9.8 | PIIE (Port I input control register) | | | 8.2.10 P | ort J (PJ0 to PJ7) | 185 | | 8.2.10.1 | Port J Circuit Type | | | 8.2.10.2 | Port J register | | | 8.2.10.3 | PJDATA (Port J data register) | | | 8.2.10.4 | PJFR2 (Port J function register 1) | | | 8.2.10.5 | PJPUP (Port J pull-up control register) | | | 8.2.10.6 | PJIE (Port J input control register) | 189 | | 8.2.11 P | ort K (PK0 to PK7) | 189 | | 8.2.11.1 | Port K register | | | 8.2.11.3 | PKDATA (Port K data register) | | | 8.2.11.4 | PKPUP (POrt K pull-up control register) | | | 8.2.11.5 | PKIE (Pork K input control register) | | | 8.2.12 P | ort L (PL0 to PL7) | | | 8.2.12.1 | Port L Circut Type | | | 8.2.12.2 | Port L register | | | 8.2.12.3 | PLDATA (Port L data register) | | | 8.2.12.4 | PLCR (Port L output control register) | | | 8.2.12.5 | PLFR1 (Port K function register 1) | · | | 8.2.12.6<br>8.2.12.7 | PLFR2 (Port L function register 2) PLFR3 (Port L function register 3) | | | 8.2.12.8 | PLOD (Port L open drain control register) | | | 8.2.12.9 | PLPUP (Port L pull-up control register) | | | | | | | 8.2.12.10 | PLIE (Port L input control register) | | | | ort M (PM0 to PM7) | | | | | 198 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2 | ort M (PM0 to PM7)<br>Port Circuit Type<br>Port M register | 198 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR I (Port M function register I) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data tegister) PMCR (Port M output control register) PMFR / (Port M function register 1) PMFR2 (Port M function register 2) | 198 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) | 198 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data tegister) PMCR (Port M output control register) PMFR / (Port M function register 1) PMFR2 (Port M function register 2) | 198 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.13.10<br>8.2.14 P | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) Ort N (PN0 to PN7) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data tegister) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) Ort N (PN0 to PN7) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.13.10<br>8.2.14.11<br>8.2.14.2<br>8.2.14.2 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) PORT N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1<br>8.2.14.1<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) Port N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1<br>8.2.14.1<br>8.2.14.2<br>8.2.14.4<br>8.2.14.4 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) Ort N (PN0 to PN7) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1<br>8.2.14.1<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 3) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1 P<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4<br>8.2.14.5<br>8.2.14.4<br>8.2.14.5<br>8.2.14.6<br>8.2.14.7<br>8.2.14.8 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) POTE (Port M input control register) POTE (PNO to PN7) PORT N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.9<br>8.2.13.10<br>8.2.14 P<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4<br>8.2.14.5<br>8.2.14.6<br>8.2.14.7<br>8.2.14.8 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PORT N (PN0 to PN7) Port N Circuit Type Port N Tegister PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNPUP (Port N pull-up control register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1<br>8.2.14.1<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4<br>8.2.14.5<br>8.2.14.7<br>8.2.14.8<br>8.2.14.7<br>8.2.14.9<br>8.2.14.9<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M register) PORT N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNUP (Port N pull-up control register) PNUE (Port N input control register) PNIE (Port N input control register) | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1<br>8.2.14.2<br>8.2.14.4<br>8.2.14.5<br>8.2.14.5<br>8.2.14.7<br>8.2.14.9<br>8.2.14.9<br>8.2.14.1<br>8.2.14.9<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M pull-up control register) PORT N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNUP (Port N pull-up control register) PNUE (Port N input control register) PNUE (Port N input control register) Ort O (PO0 to PO7) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1<br>8.2.14.2<br>8.2.14.4<br>8.2.14.5<br>8.2.14.7<br>8.2.14.7<br>8.2.14.7<br>8.2.14.7<br>8.2.14.7<br>8.2.14.9<br>8.2.14.7<br>8.2.14.9<br>8.2.14.1<br>8.2.14.9<br>8.2.14.1<br>8.2.14.9<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data tegister) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNPUP (Port N pull-up control register) PNPUP (Port N input control register) PNIE (Port N input control register) PNIE (Port N input control register) PNIE (POrt N input control register) PORTO (PO0 to PO7) Port O Circuit Type | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1<br>8.2.14.2<br>8.2.14.4<br>8.2.14.5<br>8.2.14.7<br>8.2.14.8<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.14.1<br>8.2.14.9<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M output control register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNFR1 (Port N output control register) PNFR2 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNPUP (Port N pull-up control register) PNPUP (Port N input control register) Ort O (PO0 to PO7) Port O Circuit Type Port O register | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1 P<br>8.2.14.4<br>8.2.14.4<br>8.2.14.4<br>8.2.14.4<br>8.2.14.5<br>8.2.14.1<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M output control register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNIUP (Port N input control register) PNIUP (Port N input control register) PNIE (Port N input control register) PNIE (Port N input control register) POIT O (PO0 to PO7) Port O Circuit Type Port O Circuit Type Port O register PODATA (Port O data register) | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1<br>8.2.14.2<br>8.2.14.4<br>8.2.14.5<br>8.2.14.7<br>8.2.14.8<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.14.1<br>8.2.14.9<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M output control register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNFR1 (Port N output control register) PNFR2 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNPUP (Port N pull-up control register) PNPUP (Port N input control register) Ort O (PO0 to PO7) Port O Circuit Type Port O register | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1 P<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4<br>8.2.14.5<br>8.2.14.5<br>8.2.14.9<br>8.2.14.1<br>8.2.14.9<br>8.2.15.1<br>8.2.15.3<br>8.2.15.3<br>8.2.15.3<br>8.2.15.3 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M output control register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) POT N (Circuit Type Port N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNPUP (Port N pull-up control register) PNIE (Port N input control register) PNIE (Port N input control register) Ort O (PO0 to PO7) Port O Circuit Type Port O register PODATA (Port O data register) POCR (Port O output control register) | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.9<br>8.2.14 P<br>8.2.14.1<br>8.2.14.2<br>8.2.14.4<br>8.2.14.5<br>8.2.14.7<br>8.2.14.5<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.14.9<br>8.2.14.1<br>8.2.14.9<br>8.2.14.1<br>8.2.14.1<br>8.2.14.5<br>8.2.14.6<br>8.2.14.7<br>8.2.14.6<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.14.1<br>8.2.14.5<br>8.2.14.1<br>8.2.14.5<br>8.2.14.6<br>8.2.14.1<br>8.2.14.6<br>8.2.14.7<br>8.2.14.6<br>8.2.14.7<br>8.2.14.1<br>8.2.14.6<br>8.2.14.1<br>8.2.14.1<br>8.2.14.6<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.14.1<br>8.2.15.1<br>8.2.15.1<br>8.2.15.1<br>8.2.15.1 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M output control register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) POT N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNFR1 (Port N output control register) PNFR2 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNPUP (Port N pull-up control register) PNPUP (Port N input control register) Ort O (PO0 to PO7) Port O circuit Type Port O register PODATA (Port O data register) POCR (Port O output control register) POFR1 (Port O function register 1) POFR2 (Port O function register 2) POFR3 (Port O function register 2) POFR3 (Port O function register 2) | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.3<br>8.2.13.4<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1<br>8.2.14.2<br>8.2.14.4<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.6<br>8.2.14.7<br>8.2.14.5<br>8.2.14.6<br>8.2.14.7<br>8.2.14.5<br>8.2.14.6<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.15.1<br>8.2.15.2<br>8.2.15.3<br>8.2.15.4<br>8.2.15.5<br>8.2.15.4<br>8.2.15.5<br>8.2.15.5<br>8.2.15.6<br>8.2.15.7<br>8.2.15.8 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M output control register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNIE (Port N input control register) PNIE (Port N input control register) PNIE (Port N input control register) PNIE (Port N input control register) POTO (PO0 to PO7) Port O Circuit Type Port O register PODATA (Port O data register) POCR (Port O output control register) POFR1 (Port O function register 1) POFR2 (Port O function register 3) POOD (Port O open drain control register) | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.6<br>8.2.13.7<br>8.2.13.6<br>8.2.13.9<br>8.2.13.10<br>8.2.14.1 P<br>8.2.14.2<br>8.2.14.4<br>8.2.14.5<br>8.2.14.6<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.14.10<br>8.2.15.1<br>8.2.15.2<br>8.2.15.3<br>8.2.15.4<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5<br>8.2.15.5 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M output control register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) Ort N (PN0 to PN7) Port N Circuit Type Port N register PNDATA (Port N data register) PNCR (Port N output control register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNIE (Port N input control register) PNIE (Port N input control register) PNIE (Port N input control register) POTO Circuit Type Port O function register 1) POFR2 (Port O output control register) POFR1 (Port O function register 3) POOD (Port O open drain control register) POFR3 (Port O function register 3) POOD (Port O open drain control register) POPUP (Port O pull-up control register) | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4<br>8.2.14.5<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.14.1<br>8.2.14.5<br>8.2.14.9<br>8.2.15.1<br>8.2.15.2<br>8.2.15.1<br>8.2.15.5<br>8.2.15.5<br>8.2.15.6<br>8.2.15.9<br>8.2.15.9<br>8.2.15.19<br>8.2.15.9<br>8.2.15.9<br>8.2.15.10 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M pull-up control register) PORT N Circuit Type Port N Circuit Type Port N Circuit Type Port N function register 1) PNFR1 (Port N function register) PNFR1 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNIE (Port N input control register) PNIE (Port N input control register) POTO (PO0 to PO7) Port O Circuit Type Port O Circuit Type Port O register PODATA (Port O data register) POCR (Port O output control register) POFR1 (Port O function register 1) POFR2 (Port O function register 2) POFR3 (Port O function register 3) POOD (Port O open drain control register) POFR3 (Port O function register 3) POOD (Port O open drain control register) POPUP (Port O pull-up control register) POPUP (Port O pull-up control register) POPUP (Port O pull-up control register) POPUE (Port O input control register) | | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.14.5<br>8.2.15.1<br>8.2.15.2<br>8.2.15.3<br>8.2.15.4<br>8.2.15.5<br>8.2.15.6<br>8.2.15.7<br>8.2.15.9<br>8.2.15.9<br>8.2.15.9<br>8.2.15.9<br>8.2.15.9<br>8.2.15.9<br>8.2.15.9<br>8.2.15.9<br>8.2.15.9<br>8.2.15.10<br>8.2.15.9<br>8.2.15.10<br>8.2.15.9<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10<br>8.2.15.10 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M input control register) PORT N Circuit Type Port N Circuit Type Port N register PNDATA (Port N data register) PNFR1 (Port N function register 1) PNFR2 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNIE (Port N input control register) PNIE (Port N input control register) PNIE (Port N input control register) POTO (PO0 to PO7) | 204 | | 8.2.13 P<br>8.2.13.1<br>8.2.13.2<br>8.2.13.3<br>8.2.13.5<br>8.2.13.6<br>8.2.13.7<br>8.2.13.8<br>8.2.13.9<br>8.2.14.1<br>8.2.14.2<br>8.2.14.3<br>8.2.14.4<br>8.2.14.5<br>8.2.14.7<br>8.2.14.8<br>8.2.14.9<br>8.2.14.1<br>8.2.14.5<br>8.2.14.9<br>8.2.15.1<br>8.2.15.2<br>8.2.15.1<br>8.2.15.5<br>8.2.15.5<br>8.2.15.6<br>8.2.15.9<br>8.2.15.9<br>8.2.15.19<br>8.2.15.9<br>8.2.15.9<br>8.2.15.10 | ort M (PM0 to PM7) Port Circuit Type Port M register PMDATA (Port M data register) PMCR (Port M output control register) PMFR1 (Port M function register 1) PMFR2 (Port M function register 2) PMFR3 (Port M function register 3) PMOD (Port M open drain control register) PMPUP (Port M pull-up control register) PMIE (Port M input control register) PMIE (Port M pull-up control register) PORT N Circuit Type Port N Circuit Type Port N Circuit Type Port N function register 1) PNFR1 (Port N function register) PNFR1 (Port N function register 2) PNFR3 (Port N function register 3) PNOD (Port N open drain control register) PNIE (Port N input control register) PNIE (Port N input control register) POTO (PO0 to PO7) Port O Circuit Type Port O Circuit Type Port O register PODATA (Port O data register) POCR (Port O output control register) POFR1 (Port O function register 1) POFR2 (Port O function register 2) POFR3 (Port O function register 3) POOD (Port O open drain control register) POFR3 (Port O function register 3) POOD (Port O open drain control register) POPUP (Port O pull-up control register) POPUP (Port O pull-up control register) POPUP (Port O pull-up control register) POPUE (Port O input control register) | 204 | | 1 | 8.2.16.3<br>8.2.16.4<br>8.2.16.5<br>8.2.16.6<br>8.2.16.6 | 4 F<br>5 F<br>6 F<br>7 F<br>8 F | PDATA (Port P data register) PCR (Port P output control register) PFR1 (Port P function register 1) PFR2 (Port P function register 2) POD (Port P open drain control register) PPUP (Port P pull-up control register) | r) | | |--------------|----------------------------------------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|------| | | 3.2.16.9 | | PIE (Port P input control register) | | 222 | | 8.3 | | | 0 | _ | 223 | | 8.3. | | | - 1 | | | | 8.3. | | - 1 | | | | | 8.3. | | - 1 | | | | | 8.3. | | - 1 | | | | | 8.3. | .5 1 | ype | 14 | (()) | 228 | | 8.3. | .6 1 | ype | 13 | | 229 | | 8.3. | | | | | | | 8.3. | | | | | | | 8.3. | | | | | | | 8.3.<br>8.3. | | | | | | | 8.3. | | | | | | | 8.3. | 12 | Type | T12 | | | | | | | | | | | 8.3.<br>8.3. | | | | | | | 8.3. | | | | | | | 8.3. | 17 | Type | T15 | | 240 | | 8.3. | | | | | | | 8.3. | 10 | Type | T10 | | 242 | | 8.3. | 20 | Type | T10 | | 2/13 | | 8.3. | | - 1 | | | | | 8.3. | 22 | Type | T21 | | 245 | | 8.3. | | | | | | | 8.3. | | - 1 | / | | | | 8.3. | | - 1 | | | | | 8.3. | | | | <i>)</i> | | | 8.3. | | | / / - | $\triangle$ | | | 8.3. | | - 1 | 11 | | | | 8.3. | | | | | | | 8.3. | .30 | Type | T29 | | 253 | | 8.3. | 31 | Type | T30 | | 254 | | 8.3. | .32 | Type | T31/ | | 255 | | 8.3. | .33 | Type | T32 | ((// \) | 256 | | 8.3. | .34 | Туре | Ţ33,, | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 257 | | 8.3. | .35 | Туре | T34 | | 258 | | 8.3. | .36 | Type | T35 | | 259 | | 8.3. | | | | \ | | | 8.3. | .38 | Туре | Т37 | | 261 | | 8.3. | | | | | | | 8.3. | | | | | | | 8.4 | Apı | oeno | lix (Port setting List) | | 264 | | 8.4. | | | | | | | 8.4. | | | | | | | 8.4. | | | | | | | 8.4. | | | | | | | 8.4. | .5 P | ort E | Setting | | 268 | | 8.4. | | | | | | | 8.4. | | | - | | | | 8.4. | <b>\</b> / | | | | | | 8.4. | | | C | | | | 8.4. | | | 2 | | | | 8.4. | | | 0 | | | | 8.4. | | | • | | | | 8.4. | | | • | | | | 8.4. | | | · · | | | | 8.4. | | | _ | | | | 8.4. | | | C | | | | O. DMA Controller(DMAC) | | |----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 9.1 Overview | 281 | | | | | 9.2 DMA transfer type | | | 9.3 Block diagram | 283 | | 9.4 Product information of TMPM362F10FG | 284 | | 9.4.1 Peripheral function supported with Peripheral to Peripheral Tran | sfer | | 9.4.2 DMA request | 284 | | 9.4.3 Interrupt request | | | 9.4.4 Base address of registers | 285 | | 9.5 Description of Registers | 286 | | 9.5.1 DMAC register list | | | 9.5.2 DMACxIntStatus (DMAC Interrupt Status Register) | | | 9.5.4 DMACxIntTCClear (DMAC Interrupt Terminal Count Clear Re | gister) 289 | | 9.5.5 DMACxIntErrorStatus (DMAC Interrupt Error Status Register) | 290 | | 9.5.6 DMACxIntErrClr (DMAC Interrupt Error Clear Register) | | | 9.5.7 DMACxRawIntTCStatus (DMAC Raw Interrupt Terminal Coun | t Status Register)292 | | 9.5.8 DMACxRawIntErrorStatus (DMAC Raw Error Interrupt Status | | | <ul><li>9.5.9 DMACxEnbldChns (DMAC Enabled Channel Register)</li><li>9.5.10 DMACxSoftBReq (DMAC Software Burst Request Register)</li></ul> | 294 | | <ul><li>9.5.10 DMACxSoftBReq (DMAC Software Burst Request Register)</li><li>9.5.11 DMACxSoftSReq (DMAC Software Single Request Register)</li></ul> | 293 | | 9.5.12 DMACxConfiguration (DMAC Configuration Register) | 299 | | 9.5.13 DMACxCnSrcAddr (DMAC Channelx Source Address Registe | er) | | 9.5.14 DMACxCnDestAddr (DMAC Channelx Destination Address R | egister)301 | | 9.5.15 DMACxCnLLI (DMAC Channelx Linked List Item Register) | | | 9.5.16 DMACxCnControl (DMAC Channeln Control Register) | | | 9.5.17 DMACxCnConfiguration (DMAC Channel n Configuration Re | | | 9.6 Special Functions | 307 | | 9.6.1 Scatter/gather function | 307 | | 9.6.2 Linked list operation | | | (0/4) | \ ~ | | | <del>\</del> | | 0. Static Memory Controller | | | | | | 10.1 Function Overview | 311 | | 10.2 Block diagram | 312 | | 10.3 Description of Registers | | | 10.3.1 SFR List | | | 10.3.2 SMCMDMODE (Mode Register) | | | 10.3.3 smc memif_cfg (SMC Memory Interface Configuration Regist | | | 10.3.4 smc_direct_cmd (SMC Direct Command Register) | | | 10.3.5 smc_set_cycles (SMC Set Cycles Register) | | | 10.3.6 smc_set_opmode (SMC Set Opmode Register) | | | 10.3.7 smc_sram_cycles0_0 (SMC SRAM Cycles Registers 0 <0>)<br>10.3.8 smc_sram_cycles0_1 (SMC SRAM Cycles Registers 0 <1>) | | | 10.3.9 smc_sram_cycles0_2 (SMC SRAM Cycles Registers 0 <2>) | | | 10.3.10 smc_sram_cycles0_3 (SMC SRAM Cycles Registers 0 <3>) | | | 10.3.11 smc_opmode0_0 (SMC Opmode Registers 0<0>) | 323 | | 10.3.12 smc_opmode0_1 (SMC Opmode Registers 0<1>) | 324 | | 10.3.13 smc_opmode0_2 (SMC Opmode Registers 0<2>) | 325 | | 10.3.14 smc_opmode0_3 (SMC Opmode Registers 0<3>) | | | 10.4 External Bus Cycle | | | 10.4.1 Separate bus mode | 327 | | 10.4.1.1 tRC / tCEOE setting example<br>10.4.1.2 tWC / tWP setting example | | | 10.4.1.2 twC / twF setting example<br>10.4.1.3 tRC / tCEOE / tPC setting example | | | 10.4.1.4 tTR setting example | | | 10.4.2 Multiplex mode | 331 | | 10.4.2.1 tRC / tCEOE setting example | | | 16_hi | Timer / Event Counters (TMRB) | | |-------------------------|------------------------------------------------------------------------------------------------------|----------| | | , , | <u>)</u> | | 11.1 | Outline | | | <b>11.2</b> ] | Differences in the Specifications | | | 11.5 | Configuration | | | <b>11.4</b> 1 | Registers | | | 11.4.1 | Register list according to channel. | 342 | | 11.4.2 | TBRING (Enable register) | 343 | | 11.4.3<br>11.4.4 | TBxRUN (RUN register) TBxCR (Control register) | 3/4 | | 11.4.4 | | | | 11.4.6 | TBxFFCR (Flip-flop control register) | 348 | | 11.4.7 | TBxST (Status register) | 349 | | 11.4.8 | TBxIM (Interrupt mask register) | 350 | | 11.4.9<br>11.4.10 | TBxDC (Up counter capture register) | 35 | | 11 4 11 | TBvRG1 (Timer register 1) | 352 | | 11.4.12 | TBxCP0 (Capture register 0) | 353 | | 11.4.13 | TBxCP1 (Capture register 1) | 353 | | 11.5 l | TBxCP0 (Capture register 0) TBxCP1 (Capture register 1) Description of Operations for Each Circuit. | | | 11.5.1 | Prescaler | 354 | | 11.5.2 | Up-counter (UC) | 360 | | 11.5.3<br>11.5.4 | Timer registers (TBxRG0, TBxRG1) | 300 | | 11.5.5 | Capture registers (TBxCP0, TBxCP1) | 36 | | 11.5.6 | Capture registers (TBxCP0, TBxCP1) | 361 | | 11.5.7 | Comparators (CP0, CP1) | 361 | | 11.5.8 | Timer Flip-flop (TBxFF0) | 361 | | 11.5.9<br><b>11</b> 6 1 | Description of Operations for Each Mode | | | 11.6.1 | 16 bit interval Tempr Mada | 26 | | 11.6.1 | 16-bit interval Timer Mode | 362 | | 11.6.3 | 16-bit PPG (Programmable Pulse Generation) Output Mode | 363 | | 11.6.4 | Timer synchronous mode | | | 11.7 A | Applications using the Capture Function | | | 11.7.1 | One-shot pulse output triggered by an external pulse | | | | Frequency measurement | | | 11.7.3<br>11.7.4 | Pulse width measurement | 308 | | 11.7.4 | Third product vicustivitient. | | | | | | | | CL (CIO/II (DT) | | | Serial | Channel (SIO/UART) | | | 12,1 | Overview | | | | | | | | Difference in the Specification of SIO Modules | | | | Configuration | | | 12.4 l | Registers Description | | | 12.4.1 | Registers List in Each Channel | | | 12.4.2 | SCxEN (Enable Register) | | | 12.4.3<br>12.4.4 | SCxBUF (Buffer Register) | | | 12.4.4 | SCXMOD0 (Mode Control Register 0) | | | | SCxMOD1 (Mode Control Register 1) | | | 12.4.6 | SCAWODI (Wode Collifor Register 1) | | | 12.4.9 | 9 SCxFCNF (FIFO Configuration Register) | | 384 | |--------|----------------------------------------------------------------------------|------------------------------------|-----| | 12.4.1 | 10 SCxRFC (RX FIFO Configuration Register) | | 386 | | 12.4.1 | | | 387 | | 12.4.1 | 12 SCxRST (RX FIFO Status Register) | | 388 | | 12.4.1 | | | | | 12.5 | Operation in Each Mode | | 390 | | | Data Farmat | (( )) | 201 | | | Data Format | | 391 | | 12.6.1 | | | | | 12.6.2 | | (-\(\sigma'/\sigma')-) | 392 | | | 2.6.2.1 Transmission | | | | 12.6.3 | 2.6.2.2 Receiving Data 3 STOP Bit Length | | 202 | | | | | | | 12.7 | Clock Control | | | | 12.7.1 | | | | | 12.7.2 | 2 Serial Clock Generation Circuit. | · | 399 | | | 2.7.2.1 Baud Rate Generator | | , | | 12. | 2.7.2.2 Clock Selection Circuit | 32 | | | 12.8 | Transmit / Receive Buffer and FIFO. | | 403 | | 12.8.1 | | $\Diamond$ $(\bigcirc)$ $\bigcirc$ | 403 | | 12.8.2 | | ~ ~ ~ ~ ~ / / )) | 403 | | 12.8.3 | | | | | 12.9 | Status Flag | | | | | Status Flag | | 404 | | 12.10 | Error Flag | | 404 | | 12.10 | 0.1 OERR Flag | $\supset$ | 404 | | 12.10 | 0.2 PERR Flag | /./ | 405 | | 12.10 | | ′.().) | 405 | | 12.11 | Receive | | 406 | | 12.11 | | \ | 406 | | 12.11 | | | | | | 2.11.2.1 I/O interface mode | / | | | 12. | 2.11.2.2 UART Mode | | | | 12.11 | 1.3 Receive Operation | | 406 | | 12. | 2.11.3.1 Receive Buffer | | | | | 2.11.3.2 Receive FIFO Operation | | | | | 2.11.3.3 I/O interface mode with SCLK output | | | | | 2.11.3.4 Read Received Data | | | | | 2.11.3.5 Wake-up Function 2.11.3.6 Overrup Error | | | | | | | 411 | | 12.12 | Transmission | | 411 | | 12.12 | | | | | 12.12 | | | 411 | | | 2.12.2.1 I/O interface Mode | | | | | 2.12.2.2 UART Mode | | 412 | | 12.12 | | | 412 | | | 2.12.3.1 Operation of Transmission Buffer 2.12.3.2 Transmit FIFO Operation | | | | | 2.12.3.3 I/O interface Mode/Transmission by SCLK Output | | | | | 2.12.3.4 Underrun Error | | | | 12.13 | Handshake Function | | 415 | | / \ | | | | | 12.14 | | | | | 12.14 | | | 416 | | | 2.14.1.1 Single Buffer Double Buffer | | | | | 2.14.1.2 FIFO | | 415 | | 12.14 | | | 41/ | | | 2.14.2.1 Single Buffer / Double Buffer<br>1.14.2.2 FIFO | | | | 12.14 | | | /1Q | | | 2.14.3.1 UART Mode | | +10 | | | 2.14.3.1 UART Mode 2.14.3.2 I/O Interface Mode | | | | | | | /10 | | 12.15 | | | | | 12.16 | Operation in Each Mode | | 419 | | 12.16 | • | | | | | 2.16.1.1 Transmitting Data | | | | | 2.16.1.2 Receive | | | | | 2.16.1.3 Transmit and Receive (Full duplex) | | | | 12 16 | 6.2 Mode 1 (7-bit HART Mode) | | 430 | | | 12.16.3<br>12.16.4 | , | | |----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------| | | | 6.4.1 Wake-up Function<br>6.4.2 Protocol | | | | | | | | 3. | Synch | aronous Serial Port (SSP) | | | | 13.1 | Overview | 433 | | | 13.2 | Block Diagram | 434 | | | 13.3 | Register | 434 | | | 13.3.1 | Register List. | 435 | | | 13.3.2 | SSPCR0(Control register 0) | 436 | | | 13.3.3 | SSPCR1(Control register1) | 437 | | | 13.3.4 | SSPDR(Data register) | 438 | | | 13.3.5<br>13.3.6 | SSPDR(Bata Tegister) SSPSR(Status register) SSPCPSR (Clock prescale register) SSPINSC (Interrupt enable/disable register) | 439 | | | 13.3.7 | SSPIMSC (Interrupt enable/disable register) | 440 | | | 13.3.8 | SSPRIS (Pre-enable interrupt status register). | 442 | | | 13.3.9 | SSPRIS (Pre-enable interrupt status register) | 443 | | | 13.3.10 | SSPICR (Interrupt clear register) | 444 | | | 13.3.11 | SSPICR (Interrupt clear register) | 444 | | | 13.4 | Overview of SSP Clock prescaler. | 44; | | | 13.4.1 | Clock prescaler | 445 | | | 13.4.2<br>13.4.3 | Transmit FIFO Receive FIFO Interrupt generation logic | 445 | | | 13.4.3 | Interrupt generation logic | 446 | | | 12 4 5 | DMA interfece | 110 | | | 13.5 | SSP operation Initial setting for SSP | 449 | | | 13.5.1 | Initial setting for SSP | 449 | | | 13.5.2 | Enabling SSP | 449 | | | 13.5.3 | Clock ratios | | | | <b>13.6</b> | Frame Format | 450 | | | 13.6.1 | SSI frame format. | 451 | | | 13.6.2 | SPI frame format | 452 | | | 13.6.3 | Microwire frame format | 454 | | | | | | | | | | | | | Seria | Rus Interface (I2C/SIO) | | | 4. | | Bus Interface (I2C/SIO) | | | 4. | 14.1 | Configuration | | | 4. | 14.1 | Configuration | | | 4. | 14.1<br>14.2<br>14.2.1 | Configuration Register Registers for each channel | 459 | | 4. | 14.1<br>14.2<br>14.2.1 | Configuration | 459 | | 4. | 14.1 (14.2.1 14.3 ) | Configuration Register Registers for each channel 2C Bus Mode Data Format | 459<br>459 | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1 | Configuration Register Registers for each channel 2C Bus Mode Data Format Control Registers in the I2C Bus Mode. SBIxCR0(Control register 0) | 459<br>460<br>461 | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.2 | Configuration Register Registers for each channel 2C Bus Mode Data Format Control Registers in the I2C Bus Mode SBIxCR0(Control register 0) SBIxCR1(Control register 1) | 459<br>460<br>46<br>461<br>462 | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.2<br>14.4.3 | Configuration Register Registers for each channel 2C Bus Mode Data Format Control Registers in the I2C Bus Mode SBIxCR0(Control register 0) SBIxCR1(Control register 1) SBIxCR2(Control register 2) | | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.2<br>14.4.3<br>14.4.4 | Configuration Register Registers for each channel 2C Bus Mode Data Format Control Registers in the I2C Bus Mode SBIxCR0(Control register 0) SBIxCR1(Control register 1) SBIxCR2(Control register 2) SBIxSR (Status Register) | | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.2<br>14.4.3<br>14.4.4<br>14.4.5 | Configuration Register Registers for each channel 2C Bus Mode Data Format. Control Registers in the I2C Bus Mode. SBIxCR0(Control register 0). SBIxCR1(Control register 1) | | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.2<br>14.4.3<br>14.4.4 | Configuration Register Registers for each channel 2C Bus Mode Data Format. Control Registers in the I2C Bus Mode. SBIxCR0(Control register 0). SBIxCR1(Control register 1). SBIxCR2(Control register 2). SBIxCR2(Control register 2). SBIxBR (Status Register). SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). | | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.2<br>14.4.3<br>14.4.4<br>14.4.5<br>14.4.6<br>14.4.7 | Configuration Register Registers for each channel 2C Bus Mode Data Format. Control Registers in the I2C Bus Mode. SBIxCR0(Control register 0). SBIxCR1(Control register 1). SBIxCR2(Control register 2). SBIxSR (Status Register). SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). SBIxDBR (I2Cbus address register). | | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.2<br>14.4.3<br>14.4.4<br>14.4.5<br>14.4.6<br>14.4.7 | Configuration Register Registers for each channel 2C Bus Mode Data Format. Control Registers in the I2C Bus Mode. SBIxCR0(Control register 0). SBIxCR1(Control register 1). SBIxCR2(Control register 2). SBIxCR2(Control register 2). SBIxBR (Status Register). SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). | | | 4. | 14.1 14.2 14.2.1 14.3 14.4.1 14.4.2 14.4.3 14.4.6 14.4.7 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 14.5.1 1 | Configuration Register Registers for each channel 2C Bus Mode Data Format. Control Registers in the I2C Bus Mode. SBIxCR0(Control register 0). SBIxCR1(Control register 1) SBIxCR2(Control register 2) SBIxSR (Status Register) SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). SBIxI2CAR (I2Cbus address register). Control in the I2C Bus Mode. Serial Clock 1.1 Clock source | | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.2<br>14.4.3<br>14.4.4<br>14.4.5<br>14.4.6<br>14.4.7<br>14.5.1<br>14.5.1<br>14.5.1<br>14.5.1 | Configuration Register Registers for each channel 2C Bus Mode Data Format Control Registers in the I2C Bus Mode SBIxCR0(Control register 0). SBIxCR1(Control register 1). SBIxCR2(Control register 2). SBIxSR (Status Register). SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). SBIxDBR (I2Cbus address register). Control in the I2C Bus Mode Serial Clock. 1.1 Clock source 1.2 Clock Synchronization | | | 4. | 14.1 14.2 14.2.1 14.3 14.4.1 14.4.2 14.4.3 14.4.6 14.4.7 14.5.1 14.5.1 14.5.1 14.5.1 14.5.2 14.5.2 | Configuration Register Registers for each channel 2C Bus Mode Data Format Control Registers in the I2C Bus Mode SBIxCR0(Control register 0). SBIxCR1(Control register 1). SBIxCR2(Control register 2). SBIxSR (Status Register). SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). SBIxI2CAR (I2Cbus address register). Control in the I2C Bus Mode. Serial Clock 1.1 Clock Synchronization Setting the Acknowledgement Mode. | | | 4. | 14.1<br>14.2<br>14.2.1<br>14.3<br>14.4<br>14.4.1<br>14.4.3<br>14.4.4<br>14.4.5<br>14.4.6<br>14.4.7<br>14.5.1<br>14.5.1<br>14.5.1<br>14.5.2<br>14.5.3 | Configuration Register Registers for each channel. 2C Bus Mode Data Format. Control Registers in the I2C Bus Mode. SBIxCR0(Control register 0). SBIxCR1(Control register 1). SBIxCR2(Control register 2). SBIxRR (Status Register). SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). SBIxI2CAR (I2Cbus address register). Control in the I2C Bus Mode. Serial Clock. 1.1 Clock Synchronization Setting the Acknowledgement Mode. Setting the Number of Bits per Transfer. | | | 4. | 14.1 14.2 14.2.1 14.3 14.4.1 14.4.2 14.4.3 14.4.6 14.4.7 14.5.1 14.5.1 14.5.1 14.5.1 14.5.2 14.5.2 | Configuration Register Registers for each channel 2C Bus Mode Data Format Control Registers in the I2C Bus Mode SBIxCR0(Control register 0). SBIxCR1(Control register 1). SBIxCR2(Control register 2). SBIxSR (Status Register). SBIxBR0(Serial bus interface baud rate register 0). SBIxDBR (Serial bus interface data buffer register). SBIxI2CAR (I2Cbus address register). Control in the I2C Bus Mode. Serial Clock 1.1 Clock Synchronization Setting the Acknowledgement Mode. | | | 14.5.7<br>14.5.8 | | | 4/0 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------| | | Generating Start and Stop Conditions | | | | 14.5.9 | Interrupt Service Request and Release | | | | 14.5.10 | Arbitration Lost Detection Monitor | | | | 14.5.11 | Slave Address Match Detection Monitor | | | | 14.5.12 | General-call Detection Monitor | | | | 14.5.12 | Last Received Bit Monitor | | | | 14.5.14 | Data Buffer Register (SBIxDBR) | | 4/3 | | 14.5.14 | Baud Rate Register (SBIxBR0) | | | | | Software Poset | | 4/4 | | 14.3.10 | Software Reset Pata Transfer Procedure in the I2C Bus Mo | 1 100 | 4/4 | | 14.6 L | Data Transfer Procedure in the I2C Bus Mo | del2C | 475 | | 14.6.1 | Device Initialization. | | 475 | | 14.6.2 | Generating the Start Condition and a Slave Address | (/_ )/ | 475 | | 14.6.2 | | | | | 14.6.2 | | | | | 14.6.3 | Transferring a Data Word | | 477 | | 14.6.1<br>14.6.1 | , | | ~ | | 14.6.4 | 3.2 Slave mode ( <mst> = "0") Generating the Stop Condition</mst> | | 482 | | 14.6.5 | Restart Procedure | | 482 | | | Restart Freedure. | | | | | Control register of SIO mode | | 484 | | 14.7.1 | SBIxCR0(control register 0) | | 484 | | 14.7.2 | SBIxCR1(Control register 1) | | 485 | | 14.7.3 | SBIxDBR (Data buffer register). | | 486 | | 14.7.4 | SBIxCR2(Control register 2) | | 487 | | 14.7.5 | SBIxCR2(Control register 2)SBIxSR (Status Register) | V (7)A | 488 | | 14.7.6 | SBIxBR0 (Baud rate register 0). | | 489 | | 14.8 | Control in SIO mode | | 490 | | 14.8.1 | Serial Clock | | 490 | | 14.8. | | | | | 14.8. | .2 Shift Edge | | | | 14.8.2 | Transfer Modes | | 492 | | 14.8.2 | | | | | 14.8.2 | // / | | | | 14.8.2<br>14.8.2 | | ~ \\ | | | 14.0.2 | 2.4 Data retention time of the last off at the end of transmission | | | | | | | | | | | | | | | | | | | 15. Consu | mer Electronics Control (CEC) | | | | 15. Consu | mer Electronics Control (CEC) | | | | | | | 407 | | 15.1 | Outline | | | | <b>15.1</b> ( | Outline | | 497 | | 15.1 (<br>15.1.1<br>15.1.2 | Outline Reception Transmission | | 497<br>497 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3 | Dutline Reception Transmission Precautions | | 497<br>497<br>497 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3 | Outline Reception Transmission | | 497<br>497<br>497 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 F | Dutline Reception Transmission Precautions Block Diagram | | 497<br>497<br>497<br>498 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F | Dutline Reception Transmission Precautions Block Diagram Registers | | 497<br>497<br>497<br>498 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F<br>15.3.1 | Dutline Reception Transmission Precautions Block Diagram Registers Register List | | 497<br>497<br>497<br>498<br>499 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F<br>15.3.1<br>15.3.2 | Putline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) | | 497<br>497<br>497<br>498<br>499<br>499 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F<br>15.3.1<br>15.3.2<br>15.3.3 | Precautions. Block Diagram. Registers. Register List. CECEN (CEC Enable Register). CECADD (Logical Address Register). | | 497<br>497<br>498<br>499<br>499<br>500 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F<br>15.3.1<br>15.3.2<br>15.3.3<br>15.3.4 | Precautions. Block Diagram. Registers. Register List. CECEN (CEC Enable Register). CECADD (Logical Address Register). CECRESET (Software Reset Register). | | 497<br>497<br>498<br>499<br>500<br>501 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F<br>15.3.1<br>15.3.2<br>15.3.3<br>15.3.4<br>15.3.5 | Putline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) | | 497<br>497<br>498<br>499<br>500<br>501<br>502 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F<br>15.3.1<br>15.3.2<br>15.3.3<br>15.3.4<br>15.3.5<br>15.3.6 | Dutline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECRBUF (Receive Buffer Register) | | 497<br>497<br>498<br>498<br>499<br>500<br>501<br>502<br>503 | | 15.1 (<br>15.1.1<br>15.1.2<br>15.1.3<br>15.2 E<br>15.3 F<br>15.3.1<br>15.3.2<br>15.3.3<br>15.3.4<br>15.3.5<br>15.3.6<br>15.3.7 | Dutline Reception. Transmission. Precautions. Block Diagram Registers. Register List. CECEN (CEC Enable Register). CECADD (Logical Address Register). CECRESET (Software Reset Register). CECREN (Receive Enable Register). CECRBUF (Receive Buffer Register). CECRBUF (Receive Buffer Register). CECRCR1 (Receive Control Register). | | 497<br>497<br>497<br>498<br>499<br>500<br>501<br>502<br>503<br>504 | | 15.1 (15.1.1 15.1.2 15.1.3 15.2 F 15.3.1 15.3.2 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 | Dutline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECRBUF (Receive Buffer Register) CECRCR1 (Receive Buffer Register) CECRCR1 (Receive Control Register) CECRCR2 (Receive Control Register 1) CECRCR2 (Receive Control Register 2) | | 497<br>497<br>497<br>498<br>499<br>500<br>501<br>502<br>503<br>504 | | 15.1 (15.1.1 15.1.2 15.1.3 15.2 F 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 | Dutline Reception. Transmission. Precautions. Block Diagram Registers. Register List. CECEN (CEC Enable Register). CECADD (Logical Address Register). CECRESET (Software Reset Register). CECREN (Receive Enable Register). CECRBUF (Receive Buffer Register). CECRCR1 (Receive Gontrol Register). CECRCR2 (Receive Control Register 1). CECRCR3 (Receive Control Register 2). CECRCR3 (Receive Control Register 3). | | | | 15.1 (15.1.1 15.1.2 15.1.3 15.2 F 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 | Dutline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECRBUF (Receive Buffer Register) CECRCR1 (Receive Buffer Register) CECRCR2 (Receive Control Register 1) CECRCR2 (Receive Control Register 2) CECRCR3 (Receive Control Register 3) CECTEN (Transmit Enable Register) | | | | 15.1 (15.1.1 15.1.2 15.1.3 15.2 F 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 | Dutline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECREN (Receive Buffer Register) CECRBUF (Receive Buffer Register) CECRCR1 (Receive Control Register) CECRCR2 (Receive Control Register 2) CECRCR3 (Receive Control Register 3) CECTEN (Transmit Enable Register) CECTEN (Transmit Enable Register) | | | | 15.1 (15.1.1 15.1.2 15.1.3 15.2 F 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 15.3.12 | Dutline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECREN (Receive Buffer Register) CECRBUF (Receive Buffer Register) CECRCR1 (Receive Control Register) CECRCR2 (Receive Control Register 1) CECRCR3 (Receive Control Register 2) CECRCR3 (Receive Control Register 3) CECTEN (Transmit Enable Register) CECTBUF (Transmit Buffer Register) CECTBUF (Transmit Buffer Register) CECTCR (Transmit Control Register) | | | | 15.1 ( 15.1.1 15.1.2 15.1.3 15.2 E 15.3 F 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 15.3.12 15.3.12 | Dutline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECREN (Receive Buffer Register) CECRCR1 (Receive Buffer Register) CECRCR1 (Receive Control Register) CECRCR2 (Receive Control Register 1) CECRCR3 (Receive Control Register 2) CECRCR3 (Receive Control Register 3) CECTEN (Transmit Enable Register) CECTEN (Transmit Enable Register) CECTEN (Transmit Buffer Register) CECTCR (Transmit Control Register) CECTCR (Transmit Control Register) CECTCR (Transmit Control Register) CECRSTAT (Receive Interrupt Status Register) | | | | 15.1 ( 15.1.1 15.1.2 15.1.3 15.2 E 15.3 F 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 15.3.12 15.3.13 15.3.14 | Dutline Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECADD (Logical Address Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECREN (Receive Enable Register) CECRENI (Receive Control Register) CECRCR1 (Receive Control Register) CECRCR3 (Receive Control Register) CECRCR3 (Receive Control Register) CECTEN (Transmit Enable Register) CECTEN (Transmit Enable Register) CECTEN (Transmit Enable Register) CECTEN (Transmit Control Register) CECTTOR (Transmit Control Register) CECTSTAT (Receive Interrupt Status Register) | | | | 15.1 ( 15.1.1 15.1.2 15.1.3 15.2 E 15.3 F 15.3.1 15.3.2 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 15.3.12 15.3.13 15.3.14 15.3.14 | Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECRESET (Software Reset Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECREN (Receive Buffer Register) CECRCRI (Receive Control Register) CECRCRI (Receive Control Register) CECRCRI (Receive Control Register) CECRCRI (Receive Control Register) CECRCRI (Transmit Enable Register) CECTEN (Transmit Enable Register) CECTEN (Transmit Enable Register) CECTSTAT (Receive Interrupt Status Register) CECTSTAT (Transmit Interrupt Status Register) CECTSTSEL(CEC Sampling Clock Select Register) | | | | 15.1 (15.1.1 15.1.2 15.1.3 15.2 F 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 15.3.12 15.3.13 15.3.14 15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.4 (15.3.15 15.3.15 15.4 (15.3.15 15.3.15 15.4 (15.3.15 15.3.15 15.4 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 15.3.15 (15.3.15 | Reception. Transmission. Precautions. Block Diagram Registers. Register List. CECEN (CEC Enable Register). CECRESET (Software Reset Register). CECREN (Receive Enable Register). CECRBUF (Receive Buffer Register). CECRCR1 (Receive Control Register). CECRCR2 (Receive Control Register). CECRCR3 (Receive Control Register). CECRCR4 (Receive Control Register). CECRCR5 (Receive Control Register). CECRCR6 (Receive Control Register). CECRCR7 (Transmit Enable Register). CECTEN (Transmit Enable Register). CECTEN (Transmit Control Register). CECTSTAT (Transmit Control Register). CECRSTAT (Receive Interrupt Status Register). CECTSTAT (Transmit Interrupt Status Register). CECFSSEL(CEC Sampling Clock Select Register). | | | | 15.1 ( 15.1.1 15.1.2 15.1.3 15.2 E 15.3 F 15.3.1 15.3.2 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 15.3.12 15.3.13 15.3.14 15.3.14 | Reception Transmission Precautions Block Diagram Registers Register List CECEN (CEC Enable Register) CECRESET (Software Reset Register) CECRESET (Software Reset Register) CECREN (Receive Enable Register) CECREN (Receive Buffer Register) CECRCRI (Receive Control Register) CECRCRI (Receive Control Register) CECRCRI (Receive Control Register) CECRCRI (Receive Control Register) CECRCRI (Transmit Enable Register) CECTEN (Transmit Enable Register) CECTEN (Transmit Enable Register) CECTSTAT (Receive Interrupt Status Register) CECTSTAT (Transmit Interrupt Status Register) CECTSTSEL(CEC Sampling Clock Select Register) | | | | 15.1 (15.1.1 15.1.2 15.1.3 15.2 IF 15.3.1 15.3.2 15.3.3 15.3.4 15.3.5 15.3.6 15.3.7 15.3.8 15.3.9 15.3.10 15.3.11 15.3.12 15.3.13 15.3.14 15.3.15 15.4 (15.4.1 | Reception. Transmission. Precautions. Block Diagram. Registers. Register List. CECEN (CEC Enable Register). CECADD (Logical Address Register). CECRESET (Software Reset Register). CECREN (Receive Enable Register). CECREN (Receive Buffer Register). CECREN (Receive Buffer Register). CECRCR1 (Receive Control Register 1). CECRCR2 (Receive Control Register 2). CECRCR3 (Receive Control Register 3). CECTEN (Transmit Enable Register). CECTEN (Transmit Enable Register). CECTEN (Transmit Ontrol Register). CECTSTAT (Receive Interrupt Status Register). CECTSTAT (Transmit Interrupt Status Register). CECTSSEL(CEC Sampling Clock Select Register). | | | | | 15.4.2.2 Preconfiguration | | |-------------|---------------------------------------------------------------------------|-----| | | 15.4.2.3 Enabling Reception | | | | 15.4.2.4 Detecting Error Interrupt 15.4.2.5 Details of reception error | | | | 15.4.2.6 Stopping Reception | | | | 15.4.3 Transmission | 527 | | | 15.4.3.1 Basic Operation | | | | 15.4.3.2 Preconfiguration | | | | 15.4.3.3 Detecting Transmission Error | | | | 15.4.3.4 Details of Transmission Error | | | | 15.4.3.5 Stopping Transmission | | | | 15.4.3.6 Retransmission | | | | 15.4.4 Software Reset. | 532 | | | | | | | | | | 16. | Remote control signal preprocessor(RMC) | | | | 210more conversingum proprocessor(20:20) | > | | | 16.1 Basic operation | 533 | | | 16.1 Basic operation. 16.1.1 Reception of Remote Control Signal. | | | | 10.11 Reception of Remote Control Signal | | | | | 533 | | | 16.3 Registers | 534 | | | 16.3.1 Register List | 534 | | | 16.3.2 RMCxEN(Enable Register). | 535 | | | 16.3.2 RMCxEN(Enable Register) | 536 | | | 16.3.4 RMCxRBUF1(Receive Data Buffer Register 1) | 537 | | | 16.3.5 RMCxRBUF2(Receive Data Buffer Register 2) | 537 | | | 16.3.6 RMCxRBUF3(Receive Data Buffer Register 3) | 538 | | | 16.3.7 RMCxRCR1(Receive Control Register 1). | 539 | | | 16.3.7 RMCxRCR1(Receive Control Register 1) | 540 | | | 16.3.9 RMCxRCR3(Receive Control Register 3) | 541 | | | 16.3.10 RMCxRCR4(Receive Control Register 4) | 542 | | | 16.3.11 RMCxRSTAT(Receive Status Register) | 543 | | | 16.3.12 RMCxEND1(Receive End bit Number Register 1) | 544 | | | 16.3.13 RMCxEND2(Receive End bit Number Register 2) | 544 | | | 16.3.14 RMCxEND3(Receive End bit Number Register 3) | 545 | | | 16.3.15 RMCxFSSEL(Source Clock selection Register) | 546 | | | 16.4 Operation Description | 547 | | | 10.4 Operation Description | 347 | | | 16.4.1 Reception of Remote Control Signal | 547 | | | 16.4.1.1 Sampling clock<br>16.4.1.2 Basic operation | | | | 16.4.1.3 Preparation | | | | 16.4.1.4 Enabling Reception | | | | 16.4.1.5 Stopping Reception | | | | 16.4.1.6 Receiving Remote Control Signal without Leader in Waiting Leader | | | | 16.4.1.7 A Leader only with Low Width | | | | 16.4.1.8 Receiving a Remote Control Signal in a Phase Method | | | | | | | | | | | <u> 17.</u> | Watchdog Timer(WDT) | | | | | | | ( | 17.1 Configuration | | | | 17.2 Register | 558 | | | 17.2.1 WDMOD(Watchdog Timer Mode Register) | | | | 17.2.2 WDCR (Watchdog Timer Control Register) | | | | 17.3 Operations. | | | | • | | | | 1 | | | | 1 | | | | 17.4 Operation when malfunction (runaway) is detected | | | | 17.4.1 INTWDT interrupt generation | | | | 17.4.2 Internal reset generation | | | | 17.5 Control register | 564 | | | 17.5.1 Watchdog Timer Mode Register (WDMOD) | | | | 17.5.2 Watchdog Timer Control Register(WDCR) | | | | 17.5.3 Setting example | | | | 3 . | | | | 17.5.3.1 Disabling control 17.5.3.2 Enabling control 17.5.3.3 Watchdog timer clearing control | | |-----|----------------------------------------------------------------------------------------------------|-----| | | 17.5.3.4 Detection time of watchdog timer | | | 18. | . Key-on Wakeup | | | 10. | v 1 | | | | 18.1 Outline | | | | 18.2 Block Diagram | _ \ | | | 18.3 Register in detail. | | | | 18.3.1 Register list | | | | 18.3.3 KWUPCR1 (Control register 1) | 569 | | | 18.3.4 KWUPCR2 (Control register 2) | | | | 18.3.5 KWUPCR3 (Control register 3) | 571 | | | 18.3.6 KWUPPKEY (Port monitor register) | 573 | | | 18 3 8 KWI PCLR (All interrupt request clear register) | 574 | | | 18.3.9 KWUPINT (Interrupt monitor register) | 575 | | | 18.39 KWUPINT (Interrupt monitor register). 18.4 Key-on Wakeup Operation. 18.5 Pull-up Function. | 576 | | | 18.5 Pull-up Function. | 577 | | | 18.5.1 In case of using KWUP inputs with pull-up enabled | 577 | | | 18.5.2 In case of using KWUP inputs with pull-up disabled | | | | 18.6 KWUP input Detection Timing | | | | | \ | | 19. | Backup module | ) | | | 19.1 Features | 501 | | | | | | | 19.2 Block Diagram | | | | 19.3 BACKUP Mode Operation | | | | 19.3.1.1 Transition to the BACKUP mode | 362 | | | 19.3.1.2 Backup Transition Flow<br>19.3.1.3 Transition Flowchart | | | | 19.3.1.4 BACKUP Mode/Timing Chart | | | | | | | | | | | 20. | Analog / Digital Converter (ADC) | | | | 20.1 0.45 | 507 | | | 20.1 Outline | | | | 20.2 Configuration | | | | 20.3 Registers | | | _ | 20.3.1 Register list | | | | 20.3.3 ADCLK (Conversion Clock Setting Register) | | | | 20.3.4 ADMOD0 (Mode Control Register 0) | 593 | | | 20.3.5 ADMOD1 (Mode Control Register 1) | | | | 20.3.6 ADMOD2 (Mode Control Register 2) | | | | 20.3.8 ADMOD4 (Mode Control Register 4) | | | | 20.3.9 ADMOD5 (Mode Control Register 5) | | | | 20.3.10 ADREG08 (Conversion Result Register 08) | | | | 20.3.11 ADREG19 (AD Conversion Result Register 19) | | | | 20.3.13 ADREG3B (AD Conversion Result Register 3B) | | | | 20.3.14 ADREG4C (AD Conversion Result Register 4C) | | | | 20.3.15 ADREG5D (AD Conversion Result Register 5D) | | | | 20.3.16 ADREG6E (AD Conversion Result Register 6E) | 006 | | | 20.3.17 ADREG7F (AD Conversion Result Register 7F) | | |-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | 20.3.18 ADREGSP (AD Conversion Result Register SP) | | | | 20.3.19 ADCMP0 (AD Conversion Result Comparison Register 0) | 609 | | | 20.3.20 ADCMP1 (AD Conversion Result Comparison Register 1) | | | | 20.4 Description of Operations | 610 | | | 20.4.1 Analog Reference Voltage | 610 | | | 20.4.2 AD Conversion Mode | 610 | | | 20.4.2.1 Normal AD conversion | | | | 20.4.2.2 Top-priority AD conversion 20.4.3 AD Monitor Function | C1.1 | | | 20.4.3 AD Monitor Function. | 611 | | | 20.4.4 Selecting the Input Channel | 612 | | | 20.4.5 AD Conversion Details | 612 | | | 20.4.5.1 Starting AD Conversion 20.4.5.2 AD Conversion | | | | 20.4.5.3 Top-priority AD conversion during normal AD conversion | | | | 20.4.5.4 Stopping Repeat Conversion Mode | | | | 20.4.5.5 Reactivating normal AD conversion | | | | 20.4.5.6 Conversion completion | | | | 20.4.5.7 Interrupt generation timings and AD conversion result storage register | | | | $(\vee)$ | | | | | | | 1 | Deal Time Class (DTC) | | | 21. | Real Time Clock (RTC) | | | | | | | | 21.1 Function | 619 | | | 21.2 Block Diagram | 619 | | | 212 Block Diagram | 017 | | | 21.3 Detailed Description Register | 620 | | | 21.3.1 Register List | 620 | | | 21.3.2 Control Register | 620 | | | 21.3.3 Detailed Description of Control Register | 622 | | | 21.3.3.1 RTCSECR (Second column register (for PAGE0 only)) | | | | 21.3.3.2 RTCMINR (Minute column register (PAGE0/1)) | | | | 21.3.3.3 RTCHOURR (Hour column register(PAGE0/1)) 21.3.3.4 RTCDAYR (Day of the week column register(PAGE0/1)) | | | | 21.3.3.5 RTCDATER (Day of the week contains register (for PAGE0/1 only)) | | | | 21.3.3.6 RTCMONTHR (Month column register (for PAGE0 only)) | | | | 21.3.3.7 RTCMONTHR (Selection of 24-hour clock or 12-hour clock (for PAGE1 only)) | | | | 21.3.3.8 RTCYEARR (Year column register (for PAGE0 only)) | | | | 21.3.3.9 RTCYEARR (Leap year register (for PAGE1 only)) | | | | 21.3.3.10 RTCPAGER(PAGE register(PAGE0/1)) | | | | 21.3.3.11 RTCRESTR (Reset register (for PAGE0/1)) 21.4 Operational Description 21.4.1 Reading clock data | | | | 21.4 Operational Description | 629 | | | 21.4.1 Reading clock data | | | | 21.4.1 Reduing clock data | 629 | | | 21.4.2 Writing clock data | 629 | | | 21.4.2 Writing clock data | 629<br>631 | | | 21.4.2 Writing clock data | 629<br>631 | | | 21.4.2 Writing clock data | 629<br>631<br>632 | | | 21.4.2 Writing clock data | 629<br>631<br>632 | | | 21.4.2 Writing clock data 21.4.3 Entering the Low Power Consumption Mode 21.5 Alarm function 21.5.1 "Low" pulse (when the alarm register corresponds with the clock) 21.5.2 IHz cycle "Low" pulse | 629<br>631<br>632<br>633 | | | 21.4.2 Writing clock data | 629<br>631<br>632<br>633 | | 4 | 21.4.2 Writing clock data 21.4.3 Entering the Low Power Consumption Mode 21.5 Alarm function 21.5.1 "Low" pulse (when the alarm register corresponds with the clock) 21.5.2 IHz cycle "Low" pulse | 629<br>631<br>632<br>633 | | 4 | 21.4.2 Writing clock data 21.4.3 Entering the Low Power Consumption Mode 21.5 Alarm function 21.5.1 "Low" pulse (when the alarm register corresponds with the clock) 21.5.2 IHz cycle "Low" pulse | 629<br>631<br>632<br>633 | | 4 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. | 629<br>631<br>632<br>633 | | 22. | 21.4.2 Writing clock data 21.4.3 Entering the Low Power Consumption Mode 21.5 Alarm function 21.5.1 "Low" pulse (when the alarm register corresponds with the clock) 21.5.2 IHz cycle "Low" pulse | 629<br>631<br>632<br>633 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. Flash | 629<br>631<br>632<br>633<br>633 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. Flash 22.1 Flash Memory. | 629<br>631<br>632<br>633<br>633 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 1Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. Flash 22.1 Flash Memory. 22.1 Features. | 629<br>631<br>632<br>633<br>633 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 I6Hz cycle "Low" pulse. 21.5.3 I6Hz cycle "Low" pulse. 22.1 Flash Memory. 22.1 Features. 22.1.2 Block Diagram of the Flash Memory Section. | 629<br>631<br>632<br>633<br>633<br>635<br>635 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 1Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. Flash 22.1 Flash Memory. 22.1 Features. | 629<br>631<br>632<br>633<br>633<br>635<br>635 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 I6Hz cycle "Low" pulse. 21.5.3 I6Hz cycle "Low" pulse. 22.1 Flash Memory. 22.1 Features. 22.1.2 Block Diagram of the Flash Memory Section. | 629<br>631<br>632<br>633<br>633<br>635<br>637<br>638 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 I6Hz cycle "Low" pulse. 21.5.3 I6Hz cycle "Low" pulse. 21.5.3 IFlash Memory. 22.1 Flash Memory. 22.1 Block Diagram of the Flash Memory Section. 22.2 Operation Mode. | 629<br>631<br>632<br>633<br>633<br>635<br>635<br>637<br>638 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 1Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 22.1 Flash Memory. 22.1 Features. 22.1.2 Block Diagram of the Flash Memory Section. 22.2 Operation Mode. 22.2.1 Reset Operation. 22.2.2 User Boot Mode (Single chip mode). 22.2.2 User Boot Mode (Single chip mode). 22.2.1 (1-A) Method 1: Storing a Programming Routine in the Flash Memory | 629<br>631<br>632<br>633<br>633<br>635<br>635<br>637<br>638 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 22.1 Flash Memory. 22.1.1 Features. 22.1.2 Block Diagram of the Flash Memory Section. 22.2 Operation Mode. 22.2.1 Reset Operation. 22.2.2 User Boot Mode (Single chip mode). 22.2.2 User Boot Mode (Single chip mode). 22.2.2 (1-A) Method 1: Storing a Programming Routine in the Flash Memory 22.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host | 629<br>631<br>632<br>633<br>633<br>635<br>635<br>637<br>638<br>639 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 IGHz cycle "Low" pulse. 21.5.3 IGHz cycle "Low" pulse. 21.5.4 Features. 22.1.5 Features. 22.1.2 Block Diagram of the Flash Memory Section. 22.2 Operation Mode. 22.2.1 Reset Operation. 22.2.2 User Boot Mode (Single chip mode). 22.2.2 User Boot Mode (Single chip mode). 22.2.3 (1-A) Method 1: Storing a Programming Routine in the Flash Memory 22.2.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host 22.2.3 Single Boot Mode. | 629<br>631<br>632<br>633<br>633<br>635<br>635<br>637<br>638<br>639 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode. 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse | 629631632633633635635637638639639 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 22.1.4 Flash Memory. 22.1.5 Features. 22.1.2 Block Diagram of the Flash Memory Section. 22.2 Operation Mode. 22.2.1 Reset Operation. 22.2.2 User Boot Mode (Single chip mode). 22.2.2 User Boot Mode (Single chip mode). 22.2.2 (1-B) Method 1: Storing a Programming Routine in the Flash Memory 22.2.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host 22.2.3 Single Boot Mode. 22.2.3.1 (2-A) Using the Program in the On-Chip Boot ROM 22.2.4 Configuration for Single Boot Mode. | 629631632633633635637638639639 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 1Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 21.5.4 Features. 22.1.7 Features. 22.1.2 Block Diagram of the Flash Memory Section. 22.2.2 Operation Mode. 22.2.1 Reset Operation. 22.2.2 User Boot Mode (Single chip mode). 22.2.2 User Boot Mode (Single chip mode). 22.2.2 (1-B) Method 1: Storing a Programming Routine in the Flash Memory 22.2.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host 22.2.3 Single Boot Mode. 22.2.3 Single Boot Mode. 22.2.4 Configuration for Single Boot Mode. 22.2.5 Memory Map. | 629631632633633635635639639639 | | 22 | 21.4.2 Writing clock data. 21.4.3 Entering the Low Power Consumption Mode 21.5 Alarm function. 21.5.1 "Low" pulse (when the alarm register corresponds with the clock). 21.5.2 IHz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 21.5.3 16Hz cycle "Low" pulse. 22.1.4 Flash Memory. 22.1.5 Features. 22.1.2 Block Diagram of the Flash Memory Section. 22.2 Operation Mode. 22.2.1 Reset Operation. 22.2.2 User Boot Mode (Single chip mode). 22.2.2 User Boot Mode (Single chip mode). 22.2.2 (1-B) Method 1: Storing a Programming Routine in the Flash Memory 22.2.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host 22.2.3 Single Boot Mode. 22.2.3.1 (2-A) Using the Program in the On-Chip Boot ROM 22.2.4 Configuration for Single Boot Mode. | 629631632633633635635639639639 | | | 22.2.7 Data Transfer Format | 654 | |-------------|--------------------------------------------------------------------------------------------|------| | | 22.2.8 Restrictions on internal memories. | | | | 22.2.9 Transfer Format for Boot Program | 654 | | | 22.2.9.2 Show Flash Memory SUM | | | | 22.2.9.3 Transfer Format for the Show Product Information | | | | 22.2.9.4 Chip Erase and Protect Bit Erase 22.2.10 Operation of Boot Program | 661 | | | 22.2.10.1 RAM Transfer Command | 001 | | | 22.2.10.2 Show Flash Memory SUM Command | | | | 22.2.10.3 Show Product Information Command 22.2.10.4 Chip and Protection Bit Erase Command | | | | 22.2.10.5 Acknowledge Responses | | | | 22.2.10.6 Determination of a Serial Operation Mode | | | | 22.2.10.7 Password 22.2.10.8 Calculation of the Show Flash Memory Sum Command | | | | 22.2.10.9 Checksum Calculation | | | | 22.2.11 General Boot Program Flowchart. | | | | 22.3 On-board Programming of Flash Memory (Rewrite/Erase) | 676 | | | | 676 | | | 22.3.1.1 Block Configuration | | | | 22.3.1.2 Basic Operation 22.3.1.3 Reset (Hardware reset) | | | | 22.3.1.4 Commands | | | | 22.3.1.5 Flash control / status register | | | | 22.3.1.6 List of Command Sequences | 606 | | | 22.3.2 Address bit configuration for bus write cycles | 686 | | | 22.5.2.1 Howellat | | | | | | | 22 | DOM 4 C | | | <u>23.</u> | ROM protection | | | | | 601 | | | 23.1 Outline | 691 | | | 23.2 Features | 691 | | | 23.2.1 Write/ erase-protection function | 691 | | | 23.2.2 Security function. 23.3 Register. 23.3.1 FCFLCS (Flash control register). | 691 | | | 23.3 Register | 692 | | | 23.3.1 FCFLCS (Flash control register) | 693 | | | 23.3.2 FCSECBIT(Security bit register) | 694 | | | 23.4 Writing and erasing 23.4.1 Protection bits | 695 | | | 23.4.1 Protection bits | 695 | | | 23.4.2 Security bit | 695 | | | | | | | | | | 24. | RAM Interface | | | | | | | | 24.1 Register List | 697 | | | 24.1.1 (RCWAIT(RAM Interface Register) | | | | | | | | | | | <u> </u> | | | | <u> 25.</u> | Port Section Equivalent Circuit Schematic | | | | ASA DAGA B DDGA B DDGA B | 600 | | | 25.1 PA0 to 7, PB0 to 7, PP1, PP3 to 5 | 699 | | | 25.2 PC0 to 7, PD0 to 7, PE0 to 7, PF0 to 4, PG0 to 7, PH0 to 7, PI0, PL0 to 7, PM0 to | o 7, | | | PN0 to 7, PO0 to 7, PP0, PP2, PP6 | 699 | | | 25.3 PI1 | | | | 25.4 PI2, PI3 | | | | | | | | 25.5 PJ0 to 7, PK0 to 7 | | | | 25.6 RESET, NMI | 701 | | | 25.7 MODE, SWCLK | 701 | | | | | | | 25.8 SWDIO | 701 | | 25.9 X1, X2 | 702 | |------------------------------------------------------|-------| | 25.10 XT1, XT2 | 702 | | 25.11 VREFH, AVSS | 702 | | | | | 26. Electrical Characteristics | | | 26.1 Absolute Maximum Ratings | 703 | | 26.2 DC Electrical Characteristics (1/3) | | | 26.3 DC Electrical Characteristics (2/3) | 705 | | 26.4 DC Electrical Characteristics (3/3) | 706 | | 26.5 10-bit ADC Electrical Characteristics. | 707 | | | /4/ | | 26.6 AC Electrical Characteristics | /08 | | 26.6.1 AC measurement condition | 708 | | 26.6.2.1 Basic Bus cycle (Read) | /09 | | 26.6.2.2 BASIC Bus Cycle (Write) | ~~(// | | 26.6.2.3 Example of Read / Write cycle | 715 | | 26.6.3 Serial Interface (SIO/UART) | 715 | | 26.6.4 Serial Bus Interface (I2C/SIO) | 718 | | 26.6.4.1 I2C Mode | | | 26.6.4.2 Clock-Synchronous 8-Bit SIO mode | 721 | | 26.6.5 SSP Controller (SSP) | 721 | | 26.6.5.2 SSP SPI mode (Slave) | | | | 725 | | 26.6.6.1 Event counter<br>26.6.6.2 Capture | | | 26.67 External Interrupt | | | 26.6.9 SCOUT Pin AC Characteristic. | | | 26.6.10 Debug communication | | | 26.6.11 ETM Trace | | | 26.7 Flash Characteristics | | | 26.7.1 Erase / Write Characteristics | 728 | | 26.7.1 Erase / Write Characteristics | 720 | | 26.8.1 Ceramic oscillator | 729 | | 26.8.2 Crystal oscillator. | | | 26.8.3 Precaution for designing printed circuit boad | | | 26.9 Handling Precaution | 731 | | 26.9.1 Notice of Power Supply | | | 26.9.1.1 Notice of Power on | | | 26.9.1.2 Notice of Power on again | | | | | ## 27. Package Dimensions ## TMPM362F10FG The TMPM362F10FG is a 32-bit RISC microprocessor series with an ARM Cortex-M3 microprocessor core. | Product name | ROM<br>(FLASH) | RAM | Package | |--------------|----------------|----------|----------------------| | TMPM362F10FG | 1024 Kbyte | 64 Kbyte | P-LQFP144-2020-0.50E | Features of the TMPM362F10FG are as follows: #### 1.1 Features - 1. ARM Cortex-M3 microprocessor core - a. Improved code efficiency has been realized through the use of Thumb-2 instruction. - · New 16-bit Thumb instructions for improved program flow - New 32-bit Thumb instructions for improved performance - New Thumb mixed 16-/32-bit instruction set can produce faster, more efficient code. - b. Both high performance and low power consumption have been achieved. [High performance] - · Both high performance and low power consumption have been achieved. - · Division takes between 2 and 12 cycles depending on dividend and devisor [Low Power consumption] - · Optimized design using a low power consumption library - · Standby function that stops the operation of the micro controller core - c. High-speed interrupt response suitable for real-time control - An interruptible long instruction - · Stack push automatically handled by hardware - 2. On Chip program memory and data memory - On chip RAM : 64Kbyte - On chip Flash ROM: 1024Kbyte - 3. Static memory controller (SMC) - Up to 16Mbytes access area (Program / Data) - External data bus (Separate bus / Multiplex bus) : 16-bit data bus width - Chip select / Wait controller : 4 channels - 4. DMA controller (DMAC): 2 channels Transfer can support on chip Memory / Peripheral I/O / External memory 1.1 Features TMPM362F10FG 5. 16-bit timer / event counter (TMRB): 16 channels - · 16-bit interval timer mode - · 16-bit event counter mode - 16-bit PPG output (4channel timer can start synchronously) - · Input capture function - 6. Watchdog timer (WDT): 1 channel Watchdog timer generates a reset or a non-maskable interrupt (NMI). 7. Serial channnel (SIO/UART): 12 channels Either UART mode or I/O interface can be selected (4byte FIFO equipped) 8. Serial bus interface (I2C/SIO): 5 channels Either I2C bus mode or synchronous 8-bit SIO mode can be selected. - 9. Synchronous serial port (SSP): 1 channel - · Communication protocol that includes SPI: 3 types (SPI/SSI/Microwire) - Baud rate: Master mode: 16Mbps (max.), Slave mode: 5.3Mbps (max.) - 10. CEC function (CEC): 1 channel Transmision and reception per 1 byte 11. Remote control signal preprocessor (RMC): 2 channels Can receive up to 72bit data at a time - 12. 10-bit AD converter (ADC): 16 channels - · Start up with 16-bit timer - · Fixed channel / scan mode - · Single / repeat mode - AD monitoring 2 channels - Conversion time 1.15 $\mu$ sec (@ fsys = 40 MHz) - 13. Key-on wake-up (KWUP): 4 channels Dynamic pull-up - 14. Real time clock (RTC): 1channel - Clock (hour, minute and second) - · Calendar (month, week, date and leap year) - Alarm (Alarm output) - · Alarm interrupt - 15. BACKUP module (BUPMD) Low power consumption can be realized by shutdown the power supply except specific part. - BACKUP RAM: 8KB - Port keep (Keep port status when BACKUP mode is set) - CEC Function - Remote control signal preprocessor function - Key-on wake-up function - Real time clock function - 16. Interrupt source - Internal 80 factors: The order of precedence can be set over 7 levels (except the watchdog timer interrupt) - External 16 factors: The order of precedence can be set over 7 levels, - 17. Non-maskable interrupt (NMI) Non-maskable interrupt (NMI) is generated by a watchdog timer or a NMI pin. 18. Input / output ports (PORT): 120 pins I/O pin: 104 pins Input pin: 16 pins 19. Low power consumption mode IDLE2, IDLE1, SLEEP, STOP, SLOW, BACKUP (BACKUP SLEEP, BACKUP STOP) - 20. Clock generator (CG) - On chip PLL (Quadrupled or octuple can be selected.) - Clock gear function: The high-speed clock can be divided into 1/1, 1/2, 1/4 or 1/8. - 21. Endian Little endian 22. Debug interface SWD / SWV / TRACE (DATA 4bit) - 23. Maximum operating frequency: 64MHz - 24. Operating voltage range 2.7 V to 3.6 V (with on-chip regulator) - 25. Temperature range - -20 degrees to 85 degrees (except Flash writing / erasing) - 0 degrees to 70 degrees (during Flash writing / erasing) - 26. Package P-LQFP144-2020-0.50E (20 mm x 20 mm, 0.5 mm pitch) 1.2 Block Diagram TMPM362F10FG ## 1.2 Block Diagram #### 1.3 Pin layout (Top view) Figure 1-2 shows the pin layout of TMPM362F10FG. Page 5 2023/07/21 1.4 Pin names and Functions TMPM362F10FG ## 1.4 Pin names and Functions Table 1-1 sort input and output pins of TMPM362F10FG by pin or port. Table 1-1 Pin Names and Functions Sorted by Pin (1/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |----------|------------|--------------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------| | Function | 1 | PK6<br>AIN14 | Input<br>Input | Input port Analog input | | Function | 2 | PK7<br>AIN15 | Input<br>Input | Input port Analog input | | PS | 3 | AVSS | - | GND pin for AD converter (note) AVSS must be connected to GND even if the AD converter is not used. | | PS | 4 | VREFH | - | Power supply pin for AD converter (note) VREFH must be connected to power supply even if AD converter is not used. | | Function | 5 | RESET | Input | Reset input pin (note) With a pull-up and a noise filter (about 30 ns (typ.)) | | Control | 6 | MODE | Input | Mode pin (note) MODE pin must be connected to GND. | | Function | 7 | PL0<br>SDA0/SO0<br>TB0OUT | I/O<br>I/O<br>Output | I/O port Data in I2C mode / Data in SIO mode 16-bit timer / event counter output | | Function | 8 | PL1<br>SCL0/SI0<br>TB1OUT | I/O<br>I/O<br>Output | I/O port Clock in I2C mode / Data in SIO mode 16-bit timer / event counter output | | Function | 9 | PL2<br>SCK0<br>TB2OUT | I/O<br>I/O<br>Output | I/O port Ctock in SIO mode 16-bit timer / event counter output | | Function | 10 | PL3<br>INT0<br>TB3OUT | I/O<br>Input<br>Output | I/O port External interrupt pin 16-bit timer / event counter output | | Function | 11 | PL4<br>TXD1<br>TB4OUT | I/O<br>Output<br>Output | I/O port Serial channel sending serial data 16-bit-timer / event counter output | | Function | 12 | PL5<br>RXD1<br>TB5OUT | I/O<br>Input<br>Output | I/O port Serial channel receiving serial data 16-bit timer / event counter output | | Function | 13 | PL6<br>SCLK1<br>TB6OUT<br>CTS1 | I/O<br>I/O<br>Output<br>Input | 1/O port Serial channel clock pin 16-bit timer / event counter output Serial channel handshake input pin | | Function | 4 | PL7<br>INT1<br>TB7OUT | I/O<br>Input<br>Output | 1/O port External interrupt pin 16-bit timer / event counter output | | PS | 15 | DVSS | - | GND pin | Table 1-1 Pin Names and Functions Sorted by Pin (2/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |----------|------------|--------------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------| | Function | 16 | PM0<br>SCLK2<br>TB1IN0<br>CTS2 | I/O<br>I/O<br>Input<br>Input | I/O port Serial channel clock pin Inputting the 16-bit timer / event countercapture trigger Serial channel handshake input pin | | Function | 17 | PM1<br>TXD2<br>TB1IN1 | I/O<br>Output<br>Input | I/O port Serial channel sending serial data Inputting the 16-bit timer / event countercapture trigger | | Function | 18 | PM2<br>RXD2<br>ALARM | I/O<br>Input<br>Output | I/O port Serial channel receiving serial data Alarm output | | Function | 19 | PM3<br>INT2<br>TB3OUT | I/O<br>Input<br>Output | I/O port External interrupt pin 16-bit timer / event counter output | | Function | 20 | PM4<br>SCLK3<br>CTS3 | I/O<br>I/O<br>Input | I/O port Serial channel clock pin Serial channel handshake input pin | | Function | 21 | PM5<br>TXD3 | I/O<br>Output | I/O port<br>Serial channel sending serial data | | Function | 22 | PM6<br>RXD3 | I/O<br>Input | I/O port Serial channel receiving serial data | | Function | 23 | PM7<br>INT3 | I/O<br>Input | I/O port External interrupt pin | | Function | 24 | PN0<br>TXD4 | I/O<br>Output | VO port<br>Serial channel sending serial data | | Function | 25 | PN1<br>RXD4 | I/O<br>Input | I/O port<br>Serial channel receiving serial data | | Function | 26 | PN2<br>SCLK4<br>TB2IN0<br>CTS4 | I/O<br>I/O<br>Input<br>Input | N/O port Serial channel clock pin Inputting the 16-bit timer / event countercapture trigger Serial channel handshake input pin | | Function | 27 | PN3<br>INT4<br>TB2IN1<br>RMC0 | I/O<br>Input<br>Input<br>Input | I/O port External interrupt pin Inputting the 16-bit timer / event countercapture trigger Inputting signal to remote controller | | Function | 28 | PN4<br>TXD5 | I/O<br>Output | I/O port<br>Serial channel sending serial data | | Function | 29 | PN5<br>RXD5 | I/O<br>Input | 1/O port<br>Serial channel receiving serial data | | Function | 30 | PN6<br>SCLK5<br>TBFIN0<br>CTS5 | I/O<br>I/O<br>Input<br>Input | I/O port Serial channel clock pin Inputting the 16-bit timer / event countercapture trigger Serial channel handshake input pin | Page 7 2023/07/21 1.4 Pin names and Functions TMPM362F10FG Table 1-1 Pin Names and Functions Sorted by Pin (3/10) | Туре | Pin<br>No. | Pln Name | Input /<br>Output | Function | |----------|------------|--------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | Function | 31 | PN7<br>INT8<br>TBFIN1<br>RMC1 | I/O<br>Input<br>Input<br>Input | I/O port External interrupt pin Inputting the 16-bit timer / event countercapture trigger Inputting signal to remote controller | | Function | 32 | PO0<br>TXD6<br>TB8OUT | I/O<br>Output<br>Output | I/O port Serial channel sending serial data 16-bit timer / event counter output | | Function | 33 | PO1<br>RXD6<br>TB9OUT | I/O<br>Input<br>Output | I/O port Serial channel receiving serial data 16-bit timer / event counter output | | Function | 34 | PO2<br>SCLK6<br>TBAOUT<br>CTS6 | I/O<br>I/O<br>Output<br>Input | I/O port Serial channel clock pin 16-bit timer / event counter output Serial channel handshake input pin | | Function | 35 | PO3<br>INT9<br>TBBOUT | I/O<br>Input<br>Output | I/O port External interrupt pin 16-bit timer / event counter output | | Function | 36 | PO4<br>TXD7<br>TBCOUT | I/O<br>Output<br>Output | I/O port Serial channel sending serial data 16-bit timer / event counter output | | Function | 37 | PO5<br>RXD7<br>TBDOUT | I/O<br>Input<br>Output | I/O port Serial channel receiving serial data 16-bit timer / event counter output | | Function | 38 | PO6<br>SCLK7<br>TBEOUT<br>CTS7 | I/O<br>I/O<br>Output<br>Input | NO port Serial channel clock pin 16-bit timer / event counter output Serial channel handshake input pin | | Function | 39 | PO7<br>INTA<br>TBFOUT | I/O<br>Input<br>Output | I/O port External interrupt pin 16-bit timer / event counter output | | Function | 40 | PP0<br>CS2 | I/O<br>Output | I/O port Chip select pin | | Function | 41 | PP1 | I/O | I/O port | | Function | 42 | PP2<br>BLS0<br>SPD0 | I/O<br>Output<br>Output | WO port Byte lane pin SSP data output pin | | Function | 43 | PP3<br>BLS1<br>SPDI | I/O<br>Output<br>Input | I/O port Byte lane pin SSP data input pin | | Function | 44 | PP4<br>WE<br>SPCLK | I/O<br>Output<br>I/O | I/O port Write strobe pin SSP clock pin | Table 1-1 Pin Names and Functions Sorted by Pin (4/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |----------|------------|--------------------|----------------------|---------------------------------------------------------| | Function | 45 | PP5<br>OE<br>SPFSS | I/O<br>Output<br>I/O | I/O port Output enable pin SSP frame / slave select pin | | Function | 46 | PP6<br>ALE | I/O<br>Output | I/O port Address latch enable pin | | PS | 47 | DVDD3B | - | Power supply pin | | PS | 48 | DVSS | - | GND pin | | Function | 49 | PA0<br>D0<br>AD0 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 50 | PA1<br>D1<br>AD1 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 51 | PA2<br>D2<br>AD2 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 52 | PA3<br>D3<br>AD3 | I/O<br>I/O<br>I/O | I/O port<br>data bus<br>Address and data bus | | Function | 53 | PA4<br>D4<br>AD4 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 54 | PA5<br>D5<br>AD5 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 55 | PA6<br>D6<br>AD6 | 1/0<br>1/0 | I/O port data bus Address and data bus | | Function | 56 | PA7<br>D7<br>AD7 | I/O<br>I/O | I/O port data bus Address and data bus | | Function | 57 | PB0<br>D8<br>AD8 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 58 | PB1<br>D9<br>AD9 | I/O<br>I/O<br>I/O | I/O port<br>data bus<br>Address and data bus | | Function | 59 | PB2<br>D10<br>AD10 | 1/0<br>1/0<br>1/0 | I/O port data bus Address and data bus | Page 9 2023/07/21 1.4 Pin names and Functions TMPM362F10FG Table 1-1 Pin Names and Functions Sorted by Pin (5/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |----------|------------|----------------------------|-------------------------------|----------------------------------------------------------------------------------| | Function | 60 | PB3<br>D11<br>AD11 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 61 | PB4<br>D12<br>AD12 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 62 | PB5<br>D13<br>AD13 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 63 | PB6<br>D14<br>AD14 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 64 | PB7<br>D15<br>AD15 | I/O<br>I/O<br>I/O | I/O port data bus Address and data bus | | Function | 65 | PC0<br>A1<br>TXD8 | I/O<br>Output<br>Output | I/O port Address bus Serial channel sending serial data | | Function | 66 | PC1<br>A2<br>RXD8 | I/O<br>Output<br>Input | I/O port Address bus Serial channel receiving serial data | | Function | 67 | PC2<br>A3<br>SCLK8<br>CTS8 | I/O<br>Output<br>I/O<br>Input | I/O port Address bus Serial channel clock pin Serial channel handshake input pin | | Function | 68 | PC3<br>A4 | I/O<br>Output | NO port<br>Address bus | | Function | 69 | PC4<br>A5<br>TXD9 | I/O<br>Output<br>Output | I/O port<br>Address bus<br>Serial channel sending serial data | | Function | 70 | PC5<br>A6<br>RXD9 | I/O<br>Output<br>Input | I/O port Address bus Serial channel receiving serial data | | Function | 71 | PC6<br>A7<br>SCLK9<br>CTS9 | I/O<br>Output<br>I/O<br>Input | MO port Address bus Serial channel clock pin Serial channel handshake input pin | | Function | 72 | PC7<br>A8 | I/O<br>Output | I/O port<br>Address bus | | Function | 73 | PD0<br>A9<br>TXD10 | I/O<br>Output<br>Output | I/O port Address bus Serial channel sending serial data | Table 1-1 Pin Names and Functions Sorted by Pin (6/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |----------|------------|-------------------------------|-------------------------------|----------------------------------------------------------------------------------| | Function | 74 | PD1<br>A10<br>RXD10 | I/O<br>Output<br>Input | I/O port Address bus Serial channel receiving serial data | | Function | 75 | PD2<br>A11<br>SCLK10<br>CTS10 | I/O<br>Output<br>I/O<br>Input | I/O port Address bus Serial channel clock pin Serial channel handshake input pin | | Function | 76 | PD3<br>A12 | I/O<br>Output | I/O port Address bus | | Function | 77 | PD4<br>A13<br>TXD11 | I/O<br>Output<br>Output | I/O port Address bus Serial channel sending serial data | | Function | 78 | PD5<br>A14<br>RXD11 | I/O<br>Output<br>Input | I/O port Address bus Serial channel receiving serial data | | Function | 79 | PD6<br>A15<br>SCLK11<br>CTS11 | I/O<br>Output<br>I/O<br>Input | I/O port Address bus Serial channel clock pin Serial channel handshake input pin | | Function | 80 | PD7<br>A16<br>INTB | I/O<br>Output<br>Input | I/O port Address bus External interrupt pin | | Function | 81 | PE0<br>A17<br>TB5IN0 | I/O<br>Output<br>Input | I/O port Address bus Inputting the 16-bit timer / event countercapture trigger | | Function | 82 | PE1<br>A18<br>TB5IN1 | I/O<br>Output<br>Input | I/O port Address bus Inputting the 16-bit/timer / event countercapture trigger | | Function | 83 | PE2<br>A19<br>TB6IN0 | 1/O<br>Output<br>Input | I/O port Address bus Inputting the 16-bit timer / event countercapture trigger | | Function | 84 | PE3<br>A20<br>TB6IN1 | I/O<br>Output<br>Input | I/O port Address bus Inputting the 16-bit timer / event countercapture trigger | | Function | 85 | PE4<br>A21<br>TXD0 | I/O<br>Output<br>Output | I/O port Address bus Serial channel sending serial data | | Function | 86 | PE5<br>A22<br>RXD0 | I/O<br>Output<br>Input | I/O port Address bus Serial channel receiving serial data | Page 11 2023/07/21 1.4 Pin names and Functions TMPM362F10FG Table 1-1 Pin Names and Functions Sorted by Pin (7/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |--------------------|------------|-----------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------| | Function | 87 | PE6<br>A23<br>SCLK0<br>CTS0 | I/O<br>Output<br>I/O<br>Input | I/O port Address bus Serial channel clock pin Serial channel handshake input pin | | Function | 88 | PE7<br>INT5<br>SCOUT | I/O<br>Input<br>Output | I/O port External interrupt pin Internal clock output pin | | PS | 89 | DVDD3B | - | Power supply pin | | PS | 90 | DVSS | - | GND pin | | Debug | 91 | SWDIO | I/O | Debug pin | | Debug | 92 | SWCLK | I/O | Debug pin | | Function/<br>Debug | 93 | PF0<br>TRACECLK | I/O<br>Output | I/O port Debug pin | | Function/<br>Debug | 94 | PF1<br>TRACEDATA0<br>SWV | I/O<br>Output<br>Output | I/O port Debug pin Debug pin | | Function/<br>Debug | 95 | PF2<br>TRACEDATA1 | I/O<br>Output | I/O port Debug pin | | Function/<br>Debug | 96 | PF3<br>TRACEDATA2 | I/O<br>Output | I/O port Debug pin | | Function/<br>Debug | 97 | PF4<br>TRACEDATA3 | I/O<br>Output | I/O port Debug pin | | Function | 98 | PG0<br>SDA1/SO1<br>TB7IN0 | I/O<br>I/O<br>Input | I/O port Data-in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 99 | PG1<br>SCL1/SI1<br>TB7IN1 | I/O<br>Input | I/O port Clock in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 100 | PG2<br>SCK1<br>CS0 | I/O<br>I/O<br>Output | I/O port Clock in SIO mode Chip select pin | | Function | 101 | PG3<br>INT6<br>CS1 | I/O<br>Input<br>Output | I/O port External interrupt pin Chip select pin | | Function | 102 | PG4<br>SDA2/SO2<br>TB9IN0 | I/O<br>I/O<br>Input | I/O port Data in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 103 | PG5<br>SCL2/SI2<br>TB9IN1 | I/O<br>I/O<br>Input | I/O port Clock in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | Table 1-1 Pin Names and Functions Sorted by Pin (8/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |----------|------------|---------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | Function | 104 | PG6<br>SCK2<br>CS3 | I/O<br>I/O<br>Output | I/O port Clock in SIO mode Chip select pin | | Function | 105 | PG7<br>INT7<br>WDTOUT | I/O<br>Input<br>Output | I/O port External interrupt pin Watchdog timer output pin | | Function | 106 | PH0<br>SDA3/SO3<br>TBAIN0 | I/O<br>I/O<br>Input | I/O port Data in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 107 | PH1<br>SCL3/SI3<br>TBAIN1 | I/O<br>I/O<br>Input | I/O port Clock in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 108 | PH2<br>SCK3<br>TBBIN0 | I/O<br>I/O<br>Input | I/O port Inputting and outputting a clock if the serial bus interface operates in the SIO mode. Inputting the 16-bit timer / event countercapture trigger | | Function | 109 | PH3<br>INTC<br>TBBIN1 | I/O<br>Input<br>Input | I/O port External interrupt pin Inputting the 16-bif timer / event countercapture trigger | | Function | 110 | PH4<br>SDA4/SO4<br>TBDIN0 | I/O<br>I/O<br>Input | I/O port Data in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 111 | PH5<br>SCL4/SI4<br>TBDIN1 | I/O<br>I/O<br>Input | I/O port Clock in I2C mode / Data in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 112 | PH6<br>SCK4<br>TBEIN0 | I/O<br>I/O<br>Input | I/O port Clock in SIO mode Inputting the 16-bit timer / event countercapture trigger | | Function | 113 | PH7<br>INTD<br>TBEIN1 | I/O<br>Input<br>Input | I/O port External interrupt pin Inputting the 16-bit timer / event countercapture trigger | | PS | 114 | RVDD3 | | Power supply pin | | Clock | 115 | XII | Input | Connected to a low-speed oscillator. | | Clock | 116 | XT2 | Output | Connected to a low-speed oscillator. | | PS | 117 | DVDD3A | - | Power supply pin | | Clock | 118 | X1 / | Input | Connected to a high-speed oscillator. | | PS | 119 | DVSS | <u> </u> | GND pin | | Clock | 120 | X2 | Output | Connected to a high-speed oscillator. | | PS | 121 | DVDD3B | - | Power supply pin | Page 13 2023/07/21 1.4 Pin names and Functions TMPM362F10FG Table 1-1 Pin Names and Functions Sorted by Pin (9/10) | Туре | Pin<br>No. | PIn Name | Input /<br>Output | Function | |------------|------------|----------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------| | PS | 122 | DVSS | - | GND pin | | Function | 123 | PI2<br>INTE | I/O<br>Input | I/O port External interrupt pin | | Function | 124 | PI3<br>INTF | I/O<br>Input | I/O port External interrupt pin | | Control | 125 | NMI | Input | Non-maskable interrupt (note) With a noise filter (about 30ns (typical value)) | | Control | 126 | TEST1 | - | TEST pin (note) TEST pin must be left OPEN. | | Control | 127 | TEST2 | - | TEST pin (note) TEST pin must be left OPEN | | Function | 128 | PI0<br>BOOT | I/O<br>Input | I/O port Setting boot pin TMPM362F10FG goes into single boot mode by sampling "Low" at the rising edge of a RESET pin. | | Function | 129 | PI1<br>CEC | I/O<br>I/O | I/O port CEC pin (note) Nch open drain port | | PS | 130 | AVDD3 | - | Power supply pin for the AD converter (note) AVDD3 must be connected to power supply even if AD converter is not used. | | Function | 131 | PJ0<br>AIN0 | Input<br>Input | Input port<br>Analog input | | Function | 132 | PJ1<br>AIN1 | Input<br>Input | Input port Analog input | | Function | 133 | PJ2<br>AIN2 | Input<br>Input | Input port Analog input | | Function | 134 | PJ3<br>AIN3<br>ADTRG | Input<br>Input<br>Input | Input port Analog input External trigger input for AD converter | | Function | 135 | PJ4<br>AIN4<br>KWUP0 | Input<br>Input<br>Input | Input port Analog input Key-on wake-up pin | | Function ( | 136 | PJ5<br>AIN5<br>KWUP1 | Input<br>Input<br>Input | Input port Analog input Key-on wake-up pin | | Function | 137 | PJ6<br>AIN6<br>KWUP2 | Input<br>Input<br>Input | Input port Analog input Key-on wake-up pin | | Function | 138 | PJ7<br>AIN7<br>KWUP3 | Input<br>Input<br>Input | Input port Analog input Key-on wake-up pin | Table 1-1 Pin Names and Functions Sorted by Pin (10/10) | Туре | Pin<br>No. | Pln Name | Input /<br>Output | Function | |----------|------------|--------------|-------------------|-------------------------| | Function | 139 | PK0<br>AIN8 | Input<br>Input | Input port Analog input | | Function | 140 | PK1<br>AIN9 | Input<br>Input | Input port Analog input | | Function | 141 | PK2<br>AIN10 | Input<br>Input | Input port Analog input | | Function | 142 | PK3<br>AIN11 | Input<br>Input | Input port Analog input | | Function | 143 | PK4<br>AIN12 | Input<br>Input | Input port Analog input | | Function | 144 | PK5<br>AIN13 | Input<br>Input | Input port Analog input | | | | | | | # 1.5 Pin Numbers and Power Supply Pins Table 1-2 PIn Numbers and Power Supplies | Power supply | Voltage range | Pin No. | Pln mane | |--------------|---------------|-----------|---------------------------------------------------------------------| | DVDD3B | | 47,89,121 | PA,PB,PC,PD,PE,PF,PG,PH,PI,PL,PM<br>PN,PO,PP,XT1,XT2,RESET,NMI,MODE | | DVDD3A | 2.7 to 3.6V | 117 | X1,X2 | | AVDD3 | | 130 | PJ,PK | | RVDD3 | | 114 | | # 2. Processor Core The TX03 series has a high-performance 32-bit processor core (the ARM Cortex-M3 processor core). For information on the operations of this processor core, please refer to the "Cortex-M3 Technical Reference Manual" issued by ARM Limited. This chapter describes the functions unique to the TX03 series that are not explained in that document. ## 2.1 Information on the processor core The following table shows the revision of the processor core in the TMPM362F10FG. Refer to the detailed information about the CPU core and architecture, refer to the ARM manual "Cortex-M series processors" in the following URL: http://infocenter.arm.com/help/index.jsp | Product Name | Core Revision | |--------------|---------------| | TMPM362F10FG | r2p0 | # 2.2 Configurable Options The Cortex-M3 core has optional blocks. The optional blocks of the revision r2p0 are ETM™, MPU and WIC. The following table shows the configurable options in the TMPM362F10FG. | Configurable Options | Implementation | |-------------------------------|-----------------------------------------------------| | FPB | Two literal comparators Six instruction comparators | | DWT | Four comparators | | ITM | Present | | MPU | Absent | | ETM | Present | | AHB-AP | Present | | AHB Trace Macrocell Interface | Absent | | TRIU | Present | | WIC | Absent | | Debug Port | Serial wire | | | | Page 17 2023/07/21 TMPM362F10FG #### 2.3 Exceptions/ Interruptions ### 2.3 Exceptions/ Interruptions Exceptions and interruptions are described in the following section. #### 2.3.1 Number of Interrupt Inputs The number of interrupt inputs can optionally be defined from 1 to 240 in the Cortex-M3 core. TMPM362F10FG has 96 interrupt inputs. The number of interrupt inputs is reflected in <INTLINESNUM [4:0]> bit of NVIC register. In this product, if read <INTLINESNUM[4:0]> bit, 0x01 is read out. #### 2.3.2 Number of Priority Level Interrupt Bits The Cortex-M3 core can optionally configure the number of priority level interrupt bits from 3 bits to 8 bits. TMPM362F10FG has 3 priority level interrupt bits. The number of priority level interrupt bits is used for assigning a priority level in the interrupt priority registers and system handler priority registers. #### 2.3.3 SysTick The Cortex-M3 core has a SysTick timer which can generate SysTick exception. For the detail of SysTick exception, refer to the section of "SysTick" in the exception and the register of SysTick in the NVIC register. #### 2.3.4 SYSRESETREQ The Cortex-M3 core outputs SYSRESETREQ signal when <SYSRESETREQ> bit of Application Interrupt and Reset Control Register are set. TMPM362F10FG provides the same operation when SYSRESETREQ signal are output. Note: The reset operation by <SYSRESETREQ> can not used while in SLOW mode. #### 2.3.5 LOCKUP When irreparable exception generates, the Cortex-M3 core outputs LOCKUP signal to show a serious error included in software. TMPM362F10FG does not use this signal. To return from LOCKUP status, it is necessary to use non-mask-able interruput (NMI) or reset. #### 2.3.6 Auxiliary Fault Status register The Cortex-M3 core provides auxiliary fault status registers to supply additional system fault information to software. However, TMPM362F10FG is not defined this function. If auxiliary fault status register is read, always "0x0000 0000" is read out. TMPM362F10FG #### 2.4 Events The Cortex-M3 core has event output signals and event input signals. An event output signal is output by SEV instruction execution. If an event is input, the core returns from low-power consumption mode caused by WFE instruction. TMPM362F10FG does not use event output signals and event input signals. Please do not use SEV instruction and WFE instruction. ## 2.5 Power Management The Cortex-M3 core provides power management system which uses SLEEPING signal and SLEEPDEEP signal. SLEEPDEEP signals are output when <SLEEPDEEP> bit of System Control Register is set. These signals are output in the following circumstances: - -Wait-For-Interrupt (WFI) instruction execution - -Wait-For-Event (WFE) instruction execution -the timing when interrupt-service-routine (ISR) exit in case that <SLEEPONEXIT> bit of System Control Register is set. TMPM362F10FG does not use SLEEPDEEP signal so that <SLEEPDEEP> bit must not be set. And also event signal is not used so that please do not use WFE instruction. For detail of power management, refer to the Chapter "Clock/Mode control." ### 2.6 Exclusive access In Cortex-M3 core, the DCode bus system supports exclusive access. However TMPM362F10FG does not use this function. 2.6 Exclusive access TMPM362F10FG TOSHIBA TMPM362F10FG # 3. Debug Interface # 3.1 Specification Overview The TMPM362F10FG contains the Serial Wire Debug Port (SW-DP) unit for interfacing with the debugging tools and the Embedded Trace Macrocell<sup>TM</sup> (ETM) unit for instruction trace output. Trace data output to the dedicated pins (TRACEDATA[3:0]) via the on-chip Trace Port Interface Unit (TPIU). For details about SW-DP, ETM and TPIU, refer to "Cortex-M3 Technical Reference Manual". ### 3.2 SW-DP SW-DP supports the two-pin Serial Wire Debug Port (SWCLK, SWDIO) ## 3.3 ETM ETM supports four data signal pin (TRACEDATA[3:0]), one clock signal pin (TRACECLK) and trace output from SWV. Page 21 2023/07/21 3. Debug Interface 3.4 Pin functions TMPM362F10FG #### 3.4 Pin functions The debug interface pin can also be used as general purpose port (PF0 to PF4). Table 3-1 SW-DP,ETM Debug Function | SW-DP | Dark resus | SV | V debug function | |------------------|------------|----------|---------------------------------------------------| | pin name | Port name | 1/0 | Comments | | SWDIO | - | 1/0 | Serial Wire Data Input/Output<br>(Always pull-up) | | SWCLK | - | Input | Serial Wire Clock<br>(Always pull-down) | | TRACECLK | PF0 | Output | TRACE Clock Output | | TRACEDATA0 / SWV | PF1 | Output | TRACE DATA Output0 /<br>Serial Wire Viewer Output | | TRACEDATA1 | PF2 | Output | TRACE DATA Output1 | | TRACEDATA2 | PF3 | Output | TRACE DATA Output2 | | TRACEDATA3 | PF4 | Output ( | TRACE DATA Output3 | After reset, PF0 to PF4 pins are configured as general purpose ports. The functions of the debug interface pins need to be programmed as required. Table 3-2 summarizes the debug interface pin functions and related port settings after reset. Table 3-2 The Debug Interface Pins functions and Related Port Setting after Reset | Dort Name | | Value of related port setting after reset | | | | | |-------------------------|------------------|-------------------------------------------|-----------------|------------------|--------------------|----------------------| | Port Name<br>(Bit Name) | Debug Function | Function<br>(PxFR) | Input<br>(PxIE) | Output<br>(PxCR) | Pull-up<br>(PxPUP) | Pull-down<br>(PxPDN) | | PF0 | TRACECLK | <i></i> | 0/ | 0 | 0 | - | | PF1 | TRACEDATA0 / SWV | 0 | 0 | 0 | 0 | - | | PF2 | TRACEDATA1 | 0 | 0 | 0 | 0 | - | | PF3 | TRACEDATA2 | 0 | (V_0) | 0 | 0 | - | | PF4 | TRACEDATA3 | _ 0 | 0 | 0 | 0 | _ | <sup>- :</sup> Don't care TMPM362F10FG ## 3.5 Peripheral Functions in Halt Mode When the Cortex-M3 core enters in the halt mode, the watch-dog timer (WDT) automatically stops. Other peripheral functions continue operate. #### 3.6 Reset Vector Break TMPM330FDFG/FYFG/FWFG is prohibited from transmission with debug tools while reset caused by RESET pin is effective. When setting a stop by using reset vector, set the following procedure after reset; set break points from the debug tools, then set the application interrupt and the <SYSRESETREQ> bit of the reset control register to reset again. Note: Do not reset with <SYSRESETREQ> in SLOW mode. # 3.7 Connection with a Debug Tool Concerning a connection with debug tools, refer to manufactures recommendations. Debug interface pins contain a pull-up resistor and a pull-down resistor. When debug interface pins are connected with external pull-up or pull-down, please pay attention to input level. Page 23 2023/07/21 TOSHIBA TMPM362F10FG # 4. Memory Map ## 4.1 Memory Map The memory maps for the TMPM362F10FG are based on the ARM Cortex-M3 processor core memory map. The internal ROM is mapped to the code of the Cortex-M3 core memory, the internal RAM is mapped to the SRAM region and the special function register (SFR) is mapped to the peripheral region respectively. The special function register (SFR) indicates I/O ports and control registers for the peripheral function. The SRAM and SFR regions are all included in the bit-band region. The CPU register region is the processor core's internal register region. For more information on the each region, see the "Cortex-M3 Technical Reference Manual". Note that access to regions indicated as "Fault" causes a memory fault if memory faults are enabled or a hard fault if memory faults are disabled. Do not access the vendor-specific region. Page 25 2023/07/21 4. Memory Map 4.1 Memory Map TMPM362F10FG ## 4.1.1 Memory map of the TMPM362F10FG Figure 4-1 shows the memory map of the TMPM362F10FG. ### 4.2 SFR area detail This section contains the list of addresses in the SFR are $(0x4000\_0000 \text{ to } 0x4000\_5FFF, 0x4004\_0000 \text{ to } 0x4004\_1FFF, 0x400C\_0000 \text{ to } 0x400F\_4FFF, 0x41FF\_F000 \text{ to } 0x41FF\_FFFF)$ assigned to peripheral function. Access to the Reserved areas in the Table 4-1 is prohibited. As for the SFR area, reading the areas not described in the Table 4-1 yields undefined value. Writing these area is ignored. Table 4-1 SFR area detail | Start Address | End Address | Peripheral | Reserved | |---------------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x4000_0000 | 0x4000_0FFF | DMAC | 0x4000_0028 to 0x4000_002F<br>0x4000_0034 to 0x4000_0037<br>0x4000_0500 to 0x4000_050F<br>0x4000_0FE0 to 0x4000_0FFF | | 0x4000_1000 | 0x4000_1FFF | SMC | 0x4000_1000 to 0x4000_1003<br>0x4000_1008 to 0x4000_100F<br>0x4000_1020 to 0x4000_1023<br>0x4000_1200 to 0x4000_1207<br>0x4000_1E00 to 0x4000_1E0B<br>0x4000_1FE0 to 0x4000_1FFF | | 0x4000_2000 | 0x4000_2FFF | Reserved | | | 0x4000_3000 | 0x4000_3FFF | Reserved | 0x4000_3058 to 0x4000_305F | | 0x4000_4000 | 0x4000_5FFF | Reserved | | | 0x4004_0000 | 0x4004_0FFF | SSP | 0x4004_0028 to 0x4004_0FFF | | 0x4004_1000 | 0x4004_1FFF | Reserved | | | 0x400C_0000 | 0x400C_FFFF | Port | | | 0x400D_0000 | 0x400D_FFFF | Timer B (16ch) | | | 0x400E_0000 | 0x400E_04FF | I2C/SIO(5ch) | | | 0x400E_1000 | 0x400E_1BFF | SIO/UART(12ch) | | | 0x400E_2000 | 0x400E_203F | CEC | 7 | | 0x400E_3000 | 0x400E_31FF | RMC(2ch) | | | 0x400F_0000 | 0x400F_005B | ADC(16ch) | 0x400F_001C to 0x400F_001F<br>0x400F_0024 to 0x400F_002F | | 0x400F_1000 | 0x400F_108F | KWUP | 0x400F_1010 to 0x400F_107F | | 0x400F_2000 | 0x400F_2007 | WDT | | | 0x400F_3000 | 0x400F_300F | RTC | 0x400F_300D | | 0x400F_4000 | 0x400F_4037 | CG | 0x400F_4036 to 0x4000_4FFF | | 0x41FF_F000 | 0x41FF_F03F | ><br>FLASH | 0x41FF_F000 to 0x41FF_F007<br>0x41FF_F014 to 0x41FF_F017<br>0x41FF_F018 to 0x41FF_F01B<br>0x41FF_F024 to 0x41FF_F02C | | | | | 0x41FF_F033 to 0x41FF_F037 | | 0x41FF_F040 | 0x41FF_F057 | Reserved | | | 0x41FF_F058 | 0x41FF_F05B | RAMWAIT | | | 0x41FF_F060 | 0x41FF_F093 | Reserved | | | 0x41FF_F0A0 | 0x41FF_F0BB | Reserved | | | 0x41FF_F100 | 0x41FF_F103 | SMCMOD | | 4.2 SFR area detail TMPM362F10FG ### 5. Reset The TMPM362F10FG has three reset sources: an external reset pin (RESET), a watchdog timer (WDT) and the setting <SYSRESETREQ> in the Application Interrupt and Reset Control Register. For reset from the WDT, refer to the chapter on the WDT. For reset from <SYSRESETREQ>, refer to "Cortex-M3 Technical Reference Manual" Note: Do not reset with <SYSRESETREQ> in SLOW mode. #### 5.1 Cold reset The power-on sequence must consider the time for the internal regulator and oscillator to be stable. In the TMPM362F10FG, the internal regulator requires at least 700 µs to be stable. The time required to achieve stable oscillation varies with system. At cold reset, the external reset pin must be kept "Low" for a duration of time sufficiently long enough for the internal regulator and oscillator to be stable. After the external reset (RESET) signal is released, the internal reset signal remains asserted for a further 400µs. Figure 5-1 Cold Reset Sequence Page 29 2023/07/21 5.1 Cold reset TMPM362F10FG Note 1: The power supply must be raised (from 0V to 2.7V) at a speed of 0.1ms/V or slower. Note 2: Turn on the power while the RESET pin is fixed to "Low". When all the power supplies are stabilized within operating voltage, release the reset. TOSHIBA TMPM362F10FG #### 5.2 Warm reset #### 5.2.1 Reset period As a precondition, ensure that the power supply voltage is within the operating range and the internal high-frequency oscillator is providing stable oscillation. To reset the TMPM362F10FG, assert the $\overline{RESET}$ signal (active low) for a minimum duration of 12 system clocks. After the external reset (RESET) signal is released, the internal reset signal remains asserted for a further 400us. ### 5.3 After reset A warm reset initializes the majority of the Cortex-M3 processor core's system control registers and internal function registers. The processor core's system debug components (FPB, DWT, ITM) register, the clock generator's CGRSTFLG register and the FCSECBIT register are initialized by a only cold reset. After reset, the PLL multiplication circuit is inactive and must be enabled in the CGPLLSEL register if needed. When the reset exception handling is completed, the program branches to the reset interrupt service routine. Note: The reset operation may alter the internal RAM state. 5.3 After reset TMPM362F10FG TOSHIBA TMPM362F10FG # 6. Clock / Mode Control #### 6.1 Features The clock/mode control block enables to select clock gear, prescaler clock and warm-up of the PLL clock multiplication circuit and oscillator. There is also the low power consumption mode which can reduce power consumption by mode transitions. This chapter describes how to control clock operating modes and mode transitions. The clock/mode control block has the following functions: - · Controls the system clock - · Controls the prescaler clock - · Controls the PLL multiplication circuit - · Controls the warm-up timer In addition to NORMAL mode, the TMPM362F10FG can operate low power mode to reduce power consumption according to its usage conditions. Page 33 2023/07/21 6.2 Registers TMPM362F10FG # 6.2 Registers ## 6.2.1 Register List The following table shows the CG-related registers and addresses. | Base Address = 0x400F_4000 | Base | Address = | = 0x400F_ | _4000 | |----------------------------|------|-----------|-----------|-------| |----------------------------|------|-----------|-----------|-------| # 6.2.2 CGSYSCR (System control register) | | 31 | 30 | 29 | 28 | 27 | 26 🚫 | 25 | 24 | |-------------|----|----|--------|--------|----------|------|------|-----| | bit symbol | - | - | - | - | - | - | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | FCSTOP | | (7/3 | sco | SEL | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 1 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | FPSEL1 | FPSEL0 | - | | PRCK | | | After reset | 0 | 0 | 0 | 0 | 0 | 9 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | - | - | - | 1 | | | GEAR | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|-------|--------------------------------------------------------------------------------------------------------------------| | 31-24 | _ | R | Read as "0". | | 23 | _ | R/W | Write as "0". | | 22-21 | _ | R | Read as "0". | | 20 | FCSTOP | R/W | Stops AD converter clock | | | | | 0: Operated | | | | | 1: Stopped | | | | | It is possible to stop AD converter clock. After reset, AD converter clock is operated. If this bit is set to "1", | | | | | make sure to confirm that AD conversion is finished or stopped. | | 19-18 | - | R | Read as "0". | | 17-16 | SCOSEL[1:0] | R/W | SCOUT output | | | | | 00: fs | | | | | 01: fsys/2<br>10: fsys | | | | | 11: $\phi$ T0 | | | <u> </u> | | Enables to output the specified clock from SCOUT pin. | | 15-14 | - | R | Read as "0". | | 13 | FPSEL1 | R/W | Selects φT0 source clock | | | ^ ^ | | 0: clock selected by <fpsel0></fpsel0> | | | >'< | | 1: fs | | 12 | FPSEL0 | R/W | Selects fperiph source clock | | | | | 0: fgear | | | | ) | 1: fc | | 11 | | R | Read as "0". | | 10-8 | PRCK[2:0] | R/W \ | Prescaler clock | | | | | 000: fperiph 100: fperiph/16 | | | | | 001: fperiph/2 101: fperiph/32 | | | | | 010: fperiph/4 | | | | | Specifies the prescaler clock to peripheral I/O. | | 7-3 | _ | R | Read as "0". | | 2-0 | GEAR[2:0] | R/W | High-speed gear clock (fgear) | | - 0 | | | 000: fc 100: fc/2 | | | | | 001: Reserved 101: fc/4 | | | | | 010: Reserved 110: fc/8 | | | | | 011: Reserved 111: Reserved | Page 35 2023/07/21 6.2 Registers TMPM362F10FG # 6.2.3 CGOSCCR (Oscillation control register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|-----|-----|----|----------|-------|-------|-------| | bit symbol | | | | WL | JPT | | 2 | | | After reset | 1 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | WL | JPT | | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | WU | PTL | ı | - | - | (()) | XTEN | XEN | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | WUPSEL | PLLON | WUEF | WUEON | | After reset | 0 | 0 | 1 | 1 | ((/o/ \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-20 | WUPT[11:0] | R/W | Specifies count time of the warm-up timer. Warm-up counter value for high-speed Warm-up counter value for low-speed (Upper 12 bits) The warm-up counter for high-speed is 16-bit counter and one for low-speed is 18-bit counter. Lower 4 bits of the both counter are masked. Upper 12 bits for high-speed, lower 14 bits for low-speed are compared with warm-up counter. | | 19-16 | _ | R | Read as "0". | | 15-14 | WUPTL[1:0] | R/W | Specifies count time of the warm-up timer. Warm-up counter value for low-speed (Lower 2 bits) | | 13-12 | - | R/W | Write as "0". | | 11-10 | - | R | Read as "0". | | 9 | XTEN | R/W | Low-speed oscillator 0: Stop 1:Oscillation | | 8 | XEN | R/W | High-speed oscillator 0: Stop 1:Oscillation | | 7-4 | - | R/W | Write as "0011". | | 3 | WUPSEL | R/W | Warm-up counter 0: High-speed (fosc) 1: Low-speed (fs) Specifies the oscillator to warm-up. A clock generated by the specified oscillator is used for the warm-up timer count. | | 2 | PLLON | R/W ( | PLL operation 0: Stop 1: Oscillation | | 1 | WUEF | R | Status of warm-up timer (WUP) 0: Warm-up completed. 1: Warm-up operation Enable to monitor the status of the warm-up timer. | | 0 | WUEON | W | Operation of warm-up timer 0: don't care 1: Starting warm-up Enables to start the warm-up timer. Read as "0". | Note 1: Regarding to warm-up time, refer to "6.3.4 Warm-up function". Note 2: After setting PLL multiplying value, to keep CGOSCCR<PLLON> = "0" (PLL stop) over 100 $\mu$ s is needed as the PLL initializing stable time. # 6.2.4 CGSTBYCR (Standby control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-----|-------|--------|------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | PTKEEP | DRVE | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | - | | RXTEN | RXEN | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | - | - ( | | STBY | | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | 4( | 1 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|------------------------------------------------------------------------------------| | 31-18 | - | R | Read as "0". | | 17 | PTKEEP | R/W | I/O port control in the Backup mode. | | | | | 0: Output the contents of output latch. | | | | | 1: Hold the port state when CGSTBYCR <ptkeep> is changed from "0" to "1".</ptkeep> | | 16 | DRVE | R/W | Pin status in STOP mode (note) | | | | | 0: Inactive | | | | | 1: Active | | 15-10 | - | R | Read as "0". | | 9 | RXTEN | R/W | Low-speed oscillator operation after releasing the STOP mode. | | | | | 0: Stop | | | | | 1: Oscillation | | 8 | RXEN | R/W | High-speed oscillator operation after releasing the STOP mode. | | | | | 0: Stop | | | | | 1: Oscillation | | 7-3 | - | R | Read as "0". | | 2-0 | STBY[2:0] | R/W | Low power consumption mode | | | 4 | | 000: Reserved | | | | | 001: STOP | | | | | 010; SLEEP | | | $\wedge$ | , | 011: IDLE2 | | | >,< | | 100: Reserved | | | | | 101: BACKUP STOP | | | | | 110: BACKUP SLEEP 111: IDLE1 | | | | \ | TIT. IDLET | Note 1: I/O Ports which hold their state when CGSTBYCR<PTKEEP> is changed from "0" to "1" are all port except for port I, J, L, M and N. In regarding to release CGSTBYCR<PTKEEP>, refer to section of "Backup module". Note 2: The value which is shown reserved in above table must be not set. Page 37 2023/07/21 6.2 Registers TMPM362F10FG # 6.2.5 CGPLLSEL (PLL Selection Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|------|----|------|---------|------|--------| | bit symbol | - | - | - | - | - | - > | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | R | RS . | | - | ( ) Y I | S | C2S | | After reset | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | ND | | | · - | 2-// | PLLSEL | | After reset | 0 | 0 | 0 | 1 | ((// | 1_ | | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|----------------------------------------------------------------------------------| | 31-16 | _ | R | Read as "0". | | 15-12 | RS[3:0] | R/W | Clock multiplied by PLL | | | | | 0111: 4 times | | | | | 1010: 8 times | | | 1 | | Others: Reserved | | 11 | _ | R | Read as "0". | | 10-9 | IS[1:0] | R/W | Clock multiplied by PLL | | | | | 00: 8 times | | | | | 01: 4 times | | | | - | Others: Reserved | | 8 | C2S | R/W | Clock multiplied by PLL | | | | | 0: 4 times | | | 1 | | 1: 8\times | | 7-3 | ND[4:0] | R/W | Clock multiplied by PLL | | | | | 00011: 4 times<br>00111: 8 times | | | | | Others: Reserved | | 2-1 | | R/W | Write as "1". | | 0 | PLLSEL | R/W | Use PLL | | ľ | FLLSEL | | 0: fosc | | | | | 1: f <sub>PLL</sub> | | | (() | | Specifies use or disuse of the clock multiplied by the PLL. | | | | / | fosc is automatically set after reset. Resetting is required when using the PLL. | | | | | | Note 1: Select PLL multiplying value which is shown Table 6-1. Note 2: Select PLL multiplying value when CGOSCCR<PLLON> = "0" (PLL stop). Note 3: After setting PLL multiplying value, to keep (CGOSCCR<PLLON> = "0" (PLL stop) over 100 $\mu$ s is needed as the PLL initializing stable time. # 6.2.6 CGCKSEL (System clock selection register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-----|----------|-------|----------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | _ | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | - | - ( | <u> </u> | SYSCK | SYSCKFLG | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | _ | R | Read as "0". | | 1 | SYSCK | R/W | System clock (fsys) 0: fgear 1: fs Enable to specify the system clock. Before modifying <sysck>, fgear and fs must be stable.</sysck> | | 0 | SYSCKFLG | R | System clock status 0: fgear 1: fs Shows the status of the system clock. Switching the oscillator with <sysck> generates time lag to complete. If the output of the oscillator specified in <sysck> is read out by <sysclkflg>, the switching has been completed.</sysclkflg></sysck></sysck> | Page 39 2023/07/21 6.3 Clock control TMPM362F10FG #### 6.3 Clock control #### 6.3.1 Clock Type Each clock is defined as follows: fosc : Clock input from the X1 and X2 pins fs : Clock input from the XT1 and XT2 pins (low-speed clock) f<sub>PLL</sub> : Clock quadrupled or octupled by PLL fc : Clock specified by CGPLLSEL<PLLSEL> (high-speed clock) fgear : Clock specified by CGSYSCR<GEAR[2:0]> (gear clock) fsys : Clock specified by CGCKSEL<SYSCK> (system clock) fperiph : Clock specified by CGSYSCR<FPSEL0> φT0 : Clock specified by CGSYSCR<FPSEL1> (Prescaler clock) The gear clock fgear and the prescaler clock φT0 are dividable as follows: Gear clock : fc, fc/2, fc/4, fc/8 Prescaler clock : fs, fperiph/2, fperiph/4, fperiph/8, fperiph/16, fperiph/32 #### 6.3.2 Initial Values after Reset Reset operation initializes the clock configuration as follows. High-speed oscillator : oscillating Low-speed oscillator : oscillating PLL (Phase locked loop circuit) High-speed clock gear : fc (no frequency dividing) Reset operation causes all the clock configurations excluding the low-speed clock (fs) to be the same as fosc. fc = fosc fsys = fosc φT0 = fosc ### 6.3.3 Clock system Diagram Figure 6-1 shows the clock system diagram. Figure 6-1 Clock Block Diagram Page 41 2023/07/21 6.3 Clock control TMPM362F10FG #### 6.3.4 Warm-up function The warm-up function secures the stability time for the oscillator and the PLL with the warm-up timer. Refer to "6.6.8 Warm-up" for more detail. How to use the warm-up function is described. 1. Specify the count up clock Specify the count up clock for the warm-up counter in the CGOSCCR<WUPSEL>. 2. Specify the warm-up counter value The warm-up time can be calculated by following formula with round 4 bit off, set to bit of <WUPT [11:0]><WUPTL[1:0]> Number of warm-up cycles = Warm-up time Warm-up clock cycle 3. Start warm-up function and confirm the completion of warm-up When CGOSCCR<WUEON> is set to "1", the warm-up start a count up. The CGOSCCR <WUEF> is used to confirm the start and completion of warm-up. <WUEF>=1 shows under warm-up and <WUEF>=0 shows completion of warm-up. For the clock changing, current system clock can be monitored in CGCKSEL<SYSCKFLG>. The following shows the warm-up setting and example. 1. In transition from SLOW mode to NORMAL mode, set 5ms for warm-up time when using 8MHz oscillator for high-frequency The value of warm-up conter is shown below. $$\frac{\text{Warm-up time}}{\text{Warm-up clock cycle}} = \frac{5\text{ms}}{1/8\text{MHz}} = 40,000 \text{ cycles} = 0x9040$$ The warm-up counter for high-frequency is 16 bits and the lower 4 bits of these is ignored. Therefore, the upper 12 bits of 0x9C40, 0x9C4 is set to CGOSCCR<WUPT[11:0]>. #### <example> Transition from SLOW mode to NORMAL mode CGOSCCR<WUPT[11:0]> = "0x9C4" : Warm-up time setting Read CGOSCCR<WUPT[11:0]> : Confirm warm-up time reflecting CGOSCCR<XEN>="1" : Enable high-speed oscillation (fosc) CGOSCCR<WUEON>="1" : Enable warm-up counting (WUP) Read CGOSCCR<WUEF> CGOSCCR<XTEN>="0" CGOSCCR<SYSCK>="0" : system clock changed to high-speed (fgear) Read CGOSCCR<SYSCKFLG> : Wait for "0" (the current clock is fgear) Wait for "0" (end of WUP) 2. Intransition from NORMAL mode to SLOW mode, set 1s for warm-up time when using 32.768kHz oscillator for low-frequency The value of warm-up conter is shown below. $$\frac{\text{Warm-up time}}{\text{Warm-up clock cycle}} = \frac{1s}{1/32.768\text{kHz}} = 32,768 \text{ cycles} = 0x8000$$ The warm-up counter for low-frequency is 18 bits and the lower 4 bits of these is ignored. Therefore, the upper 14 bits of 0x8000, 0x0800 is set to CGOSCCR<WUPT[11:0]><WUPTL[1:0]>. : Disable the low-speed oscillation (fs) (In dual clock mode, it's not required.) 2023/07/21 6.3 Clock control TMPM362F10FG #### <example> Transmission from NORMAL mode to SLOW mode CGOSCCR<WUPT[11:0]> = "0x200": Warm-up time setting (Upper 12 bits) CGOSCCR<WUPTL[1:0]> = "00" : Warm-up time setting (Lower 2 bits) Read CGOSCCR<WUPT><WUPTL> : Check warm-up time setting CGOSCCR<XTEN>="1" : Enable low-speed oscillation (fs) CGOSCCR<WUPSEL>="1" : Select XT1 for warm-up clock CGOSCCR<WUEON>="1" : Enable warm-up counting (WUP) Read CGOSCCR<WUEF> : Wait for "0" (end of WUP) CGOSCCR<SYSCK>="1" : system clock changed to low-speed (fs) Read CGOSCCR<SYSCKFLG> : Wait for "1" (the current clock is fs) CGOSCCR<XEN>="0" : Disable the high-speed oscillation (fc) - Note 1: It is not required the warm-up time in using the external clock to be stabled. - Note 2: The warm-up timer operates according to the oscillation clock, and it may contain errors if there is any fluctuation in the oscillation frequency. Therefore, the warm-up time should be taken as approximate time. (In dual clock mode, it's not required.) Note 3: After setting warm-up count value to OSCCR<WUPT><WUPTL>, wait until confirming of the value to be reflected, then change to the standby mode by WFI instruction. Note 4: When switching the system clock, ensure that the switching has been completed by reading the CGCKSEL<SYSCKFLG>. #### 6.3.5 Clock Multiplication Circuit (PLL) This circuit outputs the $f_{PLL}$ clock that is quadruple / octuple of the high-speed oscillator output clock (fosc). As a result, the input frequency to oscillator can be low, and the internal clock be made high-speed. #### 6.3.5.1 How to configure the PLL function The PLL is disabled after reset. To enable the PLL, set CGPLLSEL<RS[3:0]><IS[1:0]><C2S><ND[4:0]> to multiplying value when CGOSCCR<PLLON> is "0". And set <PLLON> to "1" after 100µs for initialize time of PLL. After 200µs for lock-up time elapses, set CGPLLSEL<PLLSEL> to "1", f<sub>PLL</sub> which is multipupied by 4 or 8 from fosc is used. The PLL requires a certain amount of time to be stabilized, which should be secured using the warm-up function or other methods. As for the 4 or 8 multiplying value, only the following setting are permitted | Multiplying | <rs[3:0]></rs[3:0]> | <is[1:0]></is[1:0]> | <c2s></c2s> | <nd[4:0]></nd[4:0]> | |-------------|---------------------|---------------------|-------------|---------------------| | 4 | 0111 | 00 | 0 | 0_0011 | | 8 | 1010 | 01 | 1 | 0_0111 | #### 6.3.5.2 Changing PLL multiplying When number of multiplication is changed, firstly set "0" to CGPLLSEL<PLLSEL>. Secondly read CGPLLSEL<PLLSEL> to check the setting in which multiplication clock is not used (CGPLLSEL<PLLSEL>="0). Thirdly, set "0" to <PLLON>. Modify CGPLLSEL<RS[3:0]><IS[1:0]><C2S><ND[4:0]> to multiplying value. And set <PLLON> to "1" after 100µs for initilize time of PLL. After 200µs for lock-up time elapses, Set CGPLLSEL> to "1". 6. Clock / Mode Control 6.3 Clock control TMPM362F10FG #### 6.3.5.3 Start PLL sequence ## 6.3.5.4 Multiplying value change sequence Page 47 2023/07/21 6.3 Clock control TMPM362F10FG ### 6.3.6 System Clock The TMPM362F10FG offers two selectable system clocks: low-speed or high-speed. #### 6.3.6.1 High-speed clock The high-speed clock is used by multiplying. | Source | ce clock | Frequency | Using PLL | |-------------|----------------|------------|-----------------------------| | High-speed | Oscillator | 8 to 16MHz | Net up 0 a Mint in a | | oscillation | External clock | 8 to 16MHz | Not use, 4 or 8 multiplying | Note: Regarding PLL multiplying and the frequency of high-speed oscillation, refer to Table 6-1. The clock devided by CGSYSCR<GEAR[2:0]> is used for a system clock. CGSYSCR<GEAR[2:0]> can be modified in operation, a several time is needed for changing the clock. The setting example of operation frequency depended on PLL multiplying and the clock gear setting is shown bellow. Table 6-1 The setting example of operation frequency depended on PLL multiplying and the clock gear setting (Unit: MHz) | Input freq. | PII Min oper- | | PLL Min. oper- Max. operat- After reset | | Clock | Clock gear (CG) PLL = @ ON | | | Clock gear (CG) PLL = @ OFF | | | | |-------------|---------------|-------------|-----------------------------------------|--------------------------|-------|----------------------------|------|------|-----------------------------|------|------|------| | X1, X2 | Multiplying | ating freq. | ing freq. | (PLL = OFF,<br>CG = 1/1) | 1/1 | 1/2 | 1/4 | 1/8 | 1/1 | 1/2 | 1/4 | 1/8 | | 8 | | | 32 ( | 8 | 32 | 16 | 8 | 4 | 8 | 4 | 2 | 1 | | 9 | | | 36 | 9 | 36 | 18 | 9 | 4.5 | 9 | 4.5 | 2.25 | 1.13 | | 10 | 4 | 1 — | (40/ \ | 10 | 40 | 20 | 10 | 5 | 10 | 5 | 2.5 | 1.25 | | 12 | 4 | | 48 | 12 | 48 | 24 | 12 | 6 | 12 | 6 | 3 | 1.5 | | 13.5 | | | 54 | 13.5 | 54 | 27 | 13.5 | 6.75 | 13.5 | 6.75 | 3.37 | 1.69 | | 16.0 | | 64 | 16.0 | 64 | 32 | 16 | 8 | 16 | 8 | 4 | 2 | | | 8 | 8 | 1 | 64 | 8 | 64 | 32 | 16 | 8 | 8 | 4 | 2 | 1 | Note 1: When ADC is used, ADCLK shold be equal or less than 40MHz by setting ADCLK<ADCLK>. #### 6.3.6.2 Low-speed clock The frequency which can be inputted from XT1 and XT2 shown below. Table 6-2 Range of Low Speed Frequency | Input frequency range | Minimum operating frequency | Maximum operating frequency | |-----------------------|-----------------------------|-----------------------------| | 30 to 34 (kHz) | 30 kHz | 34 kHz | Note: CEC uses fs for a sampling clock. If CEC is used, fs must be within 32.768kHz±4%. #### 6.3.6.3 Setting system clock To select system clock is used by CGOSCCR and CGCKSEL. After selecting system clock, set CGPLLSEL and CGOSCCR for PLL and CGSYSCR for clock gear. Page 49 2023/07/21 6.3 Clock control TMPM362F10FG #### 6.3.7 Prescaler Clock Control Peripheral I/O has a prescaler for dividing a clock. As the clock $\phi$ T0 to be input to each prescaler, the "fperiph" clock specified in the CGSYSCR<FPSEL0> can be divided according to the setting in the CGSYSCR<PRCK[2:0]>. After the controller is reset, fperiph/1 is selected as $\phi$ T0. Note:To use the clock gear, ensure that you make the time setting such that prescaler output φTn from each peripheral function is slower than fsys (φTn ≤ fsys). Do not switch the clock gear while the timer counter or other peripheral function is operating. ## 6.3.8 System Clock Pin Output Function TMPM362F10FG enables to output the system clock from a pin. The SCOUT pin can output the low speed clock fs, the system clock fsys and fsys/2, and the prescaler input clock for peripheral I/O $\phi$ T0. - Note 1: The phase difference (AC timing) between the system clock output by the SCOUT and the internal clock is not guaranteed. - Note 2: When fsys is output from SCOUT pin, SCOUT pin outputs the unexpected waveform just after changing clock gear. In the case of influencing to system by the unexpected waveform, the output of SCOUT pin shold be disabled when changing the clock gear. The output clock is selected by setting the CGSYSCR<SCOSEL[1:0] The setting to use as SCOUT pin, refer to "Input/Output port". Table 6-3 shows the pin status in each mode when the SCOUT pin is set to the SCOUT output. Table 6-3 SCOUT Output Status in Each Mode | Mode | | Low p | ower consumption | n mode | |------------------------------------|----------------------|-----------------|------------------|-------------| | SCOUT selection<br>CGSYSCR | NORMAL SLOW | IDLE2,1 | SLEEP | STOP/BACKUP | | <scosel[1:0]> = "00"</scosel[1:0]> | Outp | ut the fs clock | | | | <scosel[1:0]> = "01"</scosel[1:0]> | Output the fsys/ | 2 clock | | | | <scosel[1:0]> = "10"</scosel[1:0]> | Output the fsys | clock | | | | <scosel[1:0]> = "11"</scosel[1:0]> | Output the φT0 clock | Fixed " | 0" or "1" | | TOSHIBA TMPM362F10FG #### 6.4 Modes and Mode Transitions #### 6.4.1 Mode Transitions The NORMAL mode and the SLOW mode use the high-speed and low-speed clocks for the system clock respectively. The IDLE2/1, SLEE, STOP and BACKUP modes can be used as the low power consumption mode that enables to reduce power consumption by halting processor core operation. When the low-speed clock is not used, the SLOW, SLEEP and BACKUP SLEEP modes cannot be used. TMPM362F10FG has a BACKUP mode. This mode can reduce power consumption of full width by shutdown main power supply of almost function except particular one. Figure 6-2 shows mode transition diagram. For a detail of sleep-on-exit, refer to "Cortex-M3 Technical Reference Manual". Figure 6-2 Mode Transition Diagram - Note 1: The warm-up is needed. The warm-up time must be set in NORMAL or SLOWmodes before changing to STOP, SLEEP and BACKUP modes. Regarding warm-up time, refer to "6.6.8 Warm-up". - Note 2: When the low-speed clock is not used, the SLOW, SLEEP and BACKUP SLEEP modes can not be used. - Note 3: Transition from SLOW mode to IDLE2 and IDLE1 mode is not available. Page 51 2023/07/21 6.5 Operation Mode TMPM362F10FG ## 6.5 Operation Mode NORMAL mode and SLOW mode are available. The features of each mode are described in the following section. #### 6.5.1 NORMAL mode This mode is to operate the CPU core and the peripheral hardware by using the high-speed clock. It is shifted to the NORMAL mode after reset. The low-speed clock can also be used. #### 6.5.2 SLOW mode This mode is to operate the CPU core and the peripheral hardware by using the low-speed clock with high-speed clock stopped. The SLOW mode reduces power consumption compared to the NORMAL mode. This mode allows some peripheral functions to operate. Ther peripheral functions which can be operated are shown in Table 6-6. Note: In the SLOW mode, be sure not to perform reset using the Application Interrupt and Reset Control Register <SYSRESETREQ> of the Cortex-M3 NVIC register. ## 6.6 Low Power Consumption Modes The TMPM362F10FG has low power consumption modes: IDLE1, IDLE2, SLEEP, STOP and BACKUP. To shift to the low power consumption mode, specify the mode in the system control register CGSTBYCR<STBY[2:0] > and execute the WFI (Wait For Interrupt) instruction. In this case, execute reset (Except BACKUP mode) or generate the interrupt to release the mode. Releasing by the interrupt requires settings in advance. See the chapter "Exceptions" for details. - Note 1: The TMPM362F10FG does not offer any event for releasing the low power consumption mode. Transition to the low power consumption mode by executing the WFE (Wait For Event) instruction is prohibited. - Note 2: The TMPM362F10FG does not support the low power consumption mode configured with the SLEEPDEEP bit in the Cortex-M3 core. Setting the <SLEEPDEEP> bit of the system control register is prohibited. - Note 3: Do not release BACKUP mode by reset. The features of each mode are described as follows. #### 6.6.1 IDLE Mode (IDLE2, IDLE1) CPU is stopped in this mode. Each peripheral function has one bit in its control register for enabling or disabling operation in the IDLE mode. When the IDLE mode is enabled, peripheral functions for which operation in the IDLE mode is disabled stop operation and hold the state at that time. The following peripheral functions can be enabled or disabled in the IDLE mode. For setting details, see the chapter on each peripheral function. - 16-bit timer / event counter (TMRB) - · Serial channel (SIO/UART) - · Serial bus interface (I2C/SIO) - · AD converter (ADC) - Watchdog timer (WDT) Note: Pay attention that the counter of watch dog timer function can not be cleared by CPU while in IDLE mode. #### 6.6.1.1 IDLE2 mode In the IDLE2 mode, CPU stops Operation frequency range and the peripherals performance are equivalent for the normal mode besides power consumption is reduced compared to the NOMAL mode. #### 6.6.1.2 IDLE1 mode The IDLE1 mode is decreased power supply ability than IDEL2 to realize low power consumption. Using the IDLE1 mode, the conditions are refer to "Table 6-6 Operational Status in Each Mode" and Operation frequency must be set as follows; fsys=1MHz (fosc=8MHz, PLL multiplier circuit stop, clock gear 1/8). Page 53 2023/07/21 #### 6.6.2 SLEEP mode In the SLEEP mode, the external low-speed oscillator, RTC, CEC, RMC and key-on wakeup can be operated. By releasing the SLEEP mode, the device returns to the preceding mode of the SLEEP mode and starts operation. #### 6.6.3 STOP mode All the internal circuits including the internal oscillator are brought to a stop in the STOP mode. By releasing the STOP mode, the device returns to the preceding mode of the STOP mode and starts operation. The STOP mode enables to select the pin status by setting the CGSTBYCR<DRVE>. Table 6-4 shows the pin status in the STOP mode. Table 6-4 Pin States in the STOP mode | | Pin name | I/O | <drve> = 0</drve> | <drve> = 1</drve> | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------|---------------------| | | X1, XT1 | Input only | × | × | | Not<br>port | X2, XT2 | Output only | "High" level output | "High" level output | | , F | RESET, NMI, MODE | Input only | 0 | 0 | | | PL3, PL7, PM3, PM7, PN3, PE7, PG3, | Input | | ) ) o | | | PG7, PN7, PO3, PO7, PD7, PH3, PH7, PI2, PI3 (When used as interrupt pin PxFRn <pxmfn>=1 and input is enabled PxIE<pxmie>=1) (note)</pxmie></pxmfn> | Output | * | Depends on PxCR[m] | | | PJ4,PJ5, PJ6, PJ7 | Input | 0 | 0 | | | (When used as KWUP pin PxFRn <pxmfn>=1 and input is enabled PxIE<pxmie>=1) (note)</pxmie></pxmfn> | Output | × | Depends on PxCR[m] | | Port | PF0, PF1, PF2, PF3, PF4 | Input | × | Depends on PxIE[m] | | | (When used as trace data output pin xFRn <pxmfn>=1) (note)</pxmfn> | Output | Depends or | n (PxCR[m]) | | | PA7 to PA0, PB7 to PB0, PC7 to PC0, PD7 | Input | <i>O</i> | 0 | | | to PD0, PE6 to PE0, PP6 to PP2, PP0 (When used as external bus pin PxFRn <pxmfn>=1. Only data bus pin and in- put is enabled PxIE <pxmie>=1) (note)</pxmie></pxmfn> | Output | Depends on (PxCR[m]) | | | | ather port sin | Input | × | Depends in PxIE[m] | | | other port pin | Output | × | Depends in PxCR[m] | o : Input or output enabled. Note:x : port number / m : corresponding bit / n: function register number <sup>× :</sup> Input or output disabled. ## 6.6.4 BACKUP mode (BACKUP STOP, BACKUP SLEEP) BACKUP mode realizes the lowest power consumption by cutting off the internal power regulator. About more details, refer to the BACKUP module. ## 6.6.5 Low power Consumption Mode Setting The low power consumption mode is specified by the setting of the CGSTBYCR <STBY[2:0]>. Table 6-5 shows the mode setting in the <STBY[2:0]>. Table 6-5 Low power consumption mode setting | Mode | CGSTBYCR<br><stby[2;0]></stby[2;0]> | |--------------|-------------------------------------| | STOP | (001) | | SLEEP | 010 | | IDLE2 | 0)1 | | BACKUP STOP | 101 | | BACKUP SLEEP | 110 | | IDLE1 | 111 | Note: Except setting above is prohibited. ## 6.6.6 Operational Status in Each Mode Table 6-6 shows the operational status in each mode. Table 6-6 Operational Status in Each Mode | Block | NORMAL | SLOW | IDLE2 | IDLE1<br>(note 1) | SLEEP | STOP | BACKUP<br>SLEEP | BACKUP<br>STOP | |--------------------------------|--------|------------|--------------------------------|-------------------|------------|-------------------------|-----------------|----------------| | Processor core | 0 | 0 | - | - | - < | $((\sqrt{-}/\sqrt{3}))$ | × | × | | DMAC | 0 | _ | 0 | _ | - > | | × | × | | SMC | 0 | - | 0 | - | - (( | 12 | × | × | | I/O port | 0 | 0 | o (note 6) | o (note 6) | o (note 6) | o (note 2) | Δ (note 3) | Δ (note 2 / 3) | | ADC | 0 | # (note 5) | Δ | # (note 5) | - (note 5) | - (note 5) | × | × | | SIO/UART | 0 | # | Δ | # | | _ | X | × | | I2C/SIO | 0 | # | Δ | # ( | 7/5 | _ ( | × | × | | TMRB | 0 | 0 | Δ | # | | Q \ | (×/) | × | | WDT | 0 | # | Δ | # | - | - | \\ | × | | SSP | 0 | # | - | | _ | (E) | × | × | | KWUP | 0 | 0 | o (note 4) | o (note 4) | 0 | o (note 4) | Δ | Δ (note 4) | | CEC | 0 | 0 | Δ ( | Δ | 0 ( | $7/\sqrt{1}$ | Δ | ı | | RMC | 0 | 0 | Δ | Δ | 0 | $(\underline{)}$ | Δ | ı | | RTC | 0 | 0 | 0 | o | 0 | _ | Δ | ı | | CG | 0 | 0 | 0 | 0 | 0 | О О | 0 | 0 | | PLL | 0 | * | ( <u>(</u> <u>\(\delta\)</u> ) | # | # | # | # , × | # , × | | High-speed oscillator (fc) | 0 | Δ | 7 % | 0 < | - | - | - | - | | Low-speed oscilla-<br>tor (fs) | 0 | | <u>).</u> | | 0 | - | 0 | - | | Main RAM | 0 | (6//) | ) o | 0 | <b>)</b> 0 | 0 | × | × | | BACKUP RAM (note 2) | 0 | | <u> </u> | | 0 | o | 0 | 0 | - o : Operating - -: Clock stopped automatically after the setting mode. (note7) - $\boldsymbol{\Delta}$ : Operating / stopped can be selected by software. - #: Before enter the setting mode, must stop these module operations by software. - × : After transition the setting mode, power down these module automatically. - \* : After transition the setting mode, must stop these module operations by software. - · : Before enter the setting mode, operating / stopped can be selected by software. - Note 1: In IDLE1 and \$LOW mode, the particuler peripheral function shown in Table 6-6 must be stopped. In IDLE1 mode, TMPM362F10FG must be operated on maximam frequency of fsys = 1MHz (fosc=8MHz, PLL stopped, clock gear 1/8). - Note 2: It depends on CGSTBYCR<DRVE>. - Note 3: It depends on CGSTBYCR<PTKEEP>. - Note 4: When low-speed oscillator is stopped or stopped automatically, only static pull-up will be valid. - Note 5: Before transition the setting mode, clear ADMO1D<VREFON> to "0". - Note 6: Port state before transition the low power consumption mode is kept. - Note 7: The clock supplied to the module is stopped automatically after transition the setting mode. Therefore, transit the setting mode after comfirming the stop of the each module. ## 6.6.7 Releasing the Low Power Consumption Mode The low power consumption mode except BACKUP mode can be released by an interrupt request, Non-Maskable Interrupt (NMI) or reset. The release source that can be used is determined by the low power consumption mode selected. Details are shown in Table 6-7. Page 57 2023/07/21 Table 6-7 Release Source in Each Mode | | Low p | ower consumption mode | IDLE2 | IDLE1<br>(note 1) | SLEEP | STOP | BACKUP<br>SLEEP<br>(note 2) | BACKUP<br>STOP<br>(note 2) | |-------------------|-------------------|--------------------------------------------|-------|-------------------|--------|--------------|-----------------------------|----------------------------| | | | INT0 to 4,8,E,F (note 3) | 0 | 0 | 0 | 0 | 0 | 0 | | | | INT5 to 7,9 to D (note 3) | 0 | 0 | 0 | (0 | × | × | | | | INTRTC | 0 | 0 | 0 | × | 0 | × | | | | INTTB0 to F | 0 | × | × (( | 7/x\ | × | × | | | | INTCAP10 to 20,50 to 70, 90 to B0,D0 to F0 | 0 | × | X | ( <u>x</u> ) | × | × | | | Interrupt | INTCAP 11 to 21,51 to 71,91 to B1,D1 to F1 | 0 | × | × | × | × | × | | | | INTRX0 to B, INTTX0 to B | 0 | × ( | × | × | × | × | | Release<br>source | | INTSBI0 to 4 | 0 | × | × | × | 4 ( x ) | × | | | | INTCECRX, INTCECTX | 0 | 0 | | × \$2 | o (note 5) | × | | | | INTRMCRX0, 1 | 0 | 0// | )) o . | > ×(C | | × | | | | INTAD / INTADHP / INTADM0, 1 | 0 | × | × | × | S() | × | | | | INTKWUP | 0 | 0 | 0 | 0 | > 0 | 0 | | | SysTick int | SysTick interrupt | | 6 | × | × | × | × | | | NMI (INTW | NMI (INTWDT) | | × | × | × | × | × | | | NMI (NMI | pin) | 0 | × | d (// | 0 | × | × | | | RESET (RESET pin) | | (0) | 0 | 8 | 0 | × | × | - o: Starts the interrupt handling after the mode is released. (The reset initializes the LSI) - × : Unavailable - Note 1: Refer to "6.6.8 Warm-up" about warm-up time. - Note 2: After releasing BACKUP mode, initialize the circuit except BACKUP module. - Note 3: To release the low power consumption mode by using the level mode interrupt, keep the level until the interrupt handling is started. Changing the level before then will prevent the interrupt handling from starting properly. - Note 4: For shifting to the low power consumption mode, set the CPU to prohibit all the interrupts other than the release source. If not, releasing may be executed by an unspecified for wake up. - Note 5: INTCECRX (CEC reception interrupt) is source trigger for wake up in the BACKUP SLEEP mode. But INTCECTX (CEC transmission interrupt) is not trigger for wake up in the BACKUP SLEEP mode. - Note 6: To shift from NORMAL mode to IDLE1 mode, Warm-up time requires more than 100µs. If not, recovery time of MCU internal system is not done when the return from IDLE1 mode. - · Release by interrupt request To release the low power consumption mode by an interrupt, the CPU must be set in advance to detect the interrupt. In addition to the setting in the CPU, the clock generator must be set to detect the interrupt to be used to release the SLEEP and STOP modes. Release by Non-Maskable Interrupt (NMI) There are two kinds of NMI sources: WDT interrupt (INTWDT) and NMI pin. INTWDT can only be used in the IDLE2 mode. The NMI pin can be used to release all the lower power consumption modes except BACKUP and IDLE1 mode. · Release by reset Any low power consumption mode except BACKUP mode can be released by reset from the $\overline{\text{RE-}}$ $\overline{\text{SET}}$ pin. After that, the mode switches to the NORMAL mode and all the registers are initialized as is the case with normal reset. Note that releasing from the STOP mode by reset does not induce the automatic warm-up. Keep the reset signal valid until the oscillator operation becomes stable. · Release by SysTick interrupt SysTick interrupt can only be used in the IDLE mode. Note: Do not release BACKUP mode by reset. Page 59 2023/07/21 #### 6.6.8 Warm-up Mode transition may require the warm-up so that the internal oscillator provides stable oscillation. In the mode transition from STOP to the NORMAL / SLOW or from IDLEI / SLEEP to NORMAL, the warm-up counter is activated automatically. And then the system clock output is started after the elapse of configured warm-up time. It is necessary to select a oscillator to be used for warm-up in the CGOSCCR<WUPSEL> and to set a warm-up time in the CGOSCCR<WUPT[11:0]><WUPTL[1:0]> before executing the instruction to enter the STOP / IDLE1 / SLEEP mode. In the transition from NORMAL to SLOW / SLEEP, the warm-up is required so that the internal oscillator to stabilize if the low-speed clock is disabled. Enable the low-speed clock and then activate the warm-up by software. In the transition from SLOW to NORMAL when the high-speed clock is disabled, enable the high-speed clock and then activate the warm-up. Table 6-8 shows whether the warm-up setting of each mode transition is required or not. Table 6-8 Warm-up setting in mode transition | Mode transition | Warm-up setting | |---------------------------|------------------------------------------------------------------------| | NORMAL → IDLE2, 1 | Not required | | NORMAL → SLEEP | Not required (note 1) | | NORMAL → SLOW | Not required (note 1) | | NORMAL → STOP | Not required | | NORMAL → BACKUP SLEEP | Not required (note 1) | | NORMAL → BACKUP STOP | Not required | | $SLOW \rightarrow NORMAL$ | Not required (note 2) | | $SLOW \to SLEEP$ | Not required | | $SLOW \rightarrow STOP$ | Not required | | SLOW → BACKUP SLEEP | Not required | | $SLOW \to BACKUP\;STOP$ | Not required | | $IDLE2 \to NORMAL$ | Not required | | IDLE1 → NORMAL | Auto-warm-up (note 3) High-speed oscillator : equal or more than 100µs | | SLEEP → NORMAL | Auto-warm-up High-speed oscillator : Setting value of warm-up time | | SLEEP → SLOW | Not required | | STOP → NORMAL | Auto-warm-up High-speed oscillator : Setting value of warm-up time | | STOP → SLOW | Auto-warm-up Low-speed oscillator :Setting value of warm-up time | | BACKUP SLEEP → NORMAL | Auto-warm-up (note 3) High-speed oscillator : equal or more than 500µs | | BACKUP STOP → NORMAL | Auto-warm-up (note 3) High-speed oscillator : equal or more than 500µs | | BACKUP SLEEP → SLOW | Auto-warm-up (note 3) Low-speed oscillator : equal or more than 2.5ms | | BACKUP STOP SLOW | Auto-warm-up (note 3) Low-speed oscillator : equal or more than 2.5ms | Note 1: If the low-speed clock is disabled, enable the low-speed clock and then activate the warm-up by software. Note 2: If the high-speed clock is disabled, enable the high-speed clock and then activate the warm-up by software. Note 3: Do not set value of warm-up time less than the specified value. Note 4: Returning to normal mode by reset does not induce the automatic warm-up. Keep the reset signal valid until the oscillator operation becomes stable. Page 61 2023/07/21 #### 6.6 Low Power Consumption Modes #### 6.6.9 Clock Operation in Mode Transition The clock operation in mode transition are described Chapter 6.6.9.1 to 6.6.9.4. #### 6.6.9.1 Transition of operation modes : NORMAL $\rightarrow$ STOP $\rightarrow$ NORMAL When returning to the NORMAL mode from the STOP mode, the warm-up is activated automatically. It is necessary to set the warm-up time before entering the STOP mode. Returning to the NORMAL mode by reset does not induce the automatic warm-up. Keep the reset signal asserted until the oscillator operation becomes stable. #### 6.6.9.2 Transition of operation modes: NORMAL → SLEEP → NORMAL When returning the NORMAL mode from the SLEEP mode, the warm-up is activated automatically. It is necessary to set the warm-up time before entering the SLEEP mode. Returning to the NORMAL mode by reset does not induce the automatic warm-up. Keep the reset signal asserted until the operation becomes stable. ## 6.6.9.3 Transition of operation modes : SLOW $\rightarrow$ STOP $\rightarrow$ SLOW The warm-up is activated automatically. It is necessary to set the warm-up time before entering the STOP mode. ## 6.6.9.4 Transition of operation modes : SLOW $\rightarrow$ SLEEP $\rightarrow$ SLOW The low-speed clock continues oscillation in the SLEEP mode. There is no need to make a warm-up setting. Page 63 2023/07/21 TMPM362F10FG ## 7. Exceptions This chapter describes features, types and handling of exceptions. Exceptions have close relation to the CPU core. Refer to "Cortex-M3 Technical Reference Manual" if needed. ## 7.1 Overview Exceptions have close relation to the CPU core. Refer to "Cortex-M3 Technical Reference Manual" if needed. There are two types of exceptions: those that are generated when some error condition occurs or when an instruction to generate an exception is executed; and those that are generated by hardware, such as an interrupt request signal from an external pin or peripheral function. All exceptions are handled by the Nested Vectored Interrupt Controller (NVIC) in the CPU according to the respective priority levels. When an exception occurs, the CPU stores the current state to the stack and branches to the corresponding interrupt service routine (ISR). Upon completion of the ISR, the information stored to the stack is automatically restored. ## 7.1.1 Exception types The following types of exceptions exist in the Cortex-M3. For detailed descriptions on each exception, refer to "Cortex-M3 Technical Reference Manual". - Reset - Non-Maskable Interrupt (NMI) - · Hard Fault - · Memory Management - · Bus Fault - · Usage Fault - SVCall (Supervisor Call) - · Debug Monitor - · PendSV - · SysTick - External Interrupt Page 65 2023/07/21 7. Exceptions 7.1 Overview TMPM362F10FG # Handling Flowchart 7.1.2 The following shows how an exception/interrupt is handled. In the following descriptions, indicates hardware handling. indicates software handling. Each step is described later in this chapter. Processing Description Detection by CG/CPU Section 7.1.2.1 The CG/CPU detects the exception request. Handling by CPU The CPU handles the exception request. Section 7.1.2.2 The CPU branches to the corresponding interrupt service routine (ISR) Branch to ISR Execution of ISR Necessary processing is executed. Section 7.1.2.4 The CPU branches to another ISR or returns to the previous program. Return from exception Section 7.1.2.4 #### 7.1.2.1 Exception Request and Detection #### (1) Exception occurrence Exception sources include instruction execution by the CPU, memory accesses, and interrupt requests from external interrupt pins or peripheral functions. An exception occurs when the CPU executes an instruction that causes an exception or when an error condition occurs during instruction execution. An exception also occurs by an instruction fetch from the Execute Never (XN) region or an access violation to the Fault region. An interrupt request is generated from an external interrupt pin or peripheral function. For interrupts that are used for releasing a standby mode, relevant settings must be made in the clock generator. For details, refer to "7.5 Interrupts". #### (2) Exception detection If multiple exceptions occur simultaneously, the CPU takes the exception with the highest priority. Table 7-1 shows the priority of exceptions. "Configurable" means that you can assign a priority level to that exception. Memory Management, Bus Fault and Usage Fault exceptions can be enabled or disabled. If a disabled exception occurs, it is handled as Hard Fault. Table 7-1 Exception Types and Priority | No. | Exception type | Priority | Description | |------|------------------------|--------------|---------------------------------------------------------------------------------------------------------------| | 1 | Reset | -3 (highest) | Reset pin, WDT or SYSRETREQ | | 2 | Non-Maskable Interrupt | -2 | NMI pin or WDT | | 3 | Hard Fault | 7 | Fault that cannot activate because a higher-priority fault is being handled or it is disabled | | 4 | Memory Management | Configurable | Exception from the Memory Protection Unit (MPU) (Note 1) Instruction fetch from the Execute Never (XN) region | | 5 | Bus Fault | Configurable | Access violation to the Hard Fault region of the memory map | | 6 | Usage Fault | Configurable | Undefined instruction execution or other faults related to instruction execution | | 7~10 | Reserved | - | | | 11 | SVCall | Configurable | System service call with SVC instruction | | 12 | Debug Monitor | Configurable | Debug monitor when the CPU is not faulting | | 13 ( | Reserved | - | | | 14 | PendSV | Configurable | Pendable system service request | | 15 | SysTick | Configurable | Notification from system timer | | 16~ | External interrupt | Configurable | External interrupt pin or peripheral function (Note2) | Note 1: This product does not contain the MPU. Note 2: External interrupts have different sources and numbers in each product. For details, see"7.5.1.5 List of Interrupt Sources". Page 67 2023/07/21 7.1 Overview TMPM362F10FG #### (3) Priority setting #### · Priority level The external interrupt priority is set to the interrupt priority register and other exceptions are set to <PRI\_n> bit in the system handler priority register. The configuration <PRI\_n> can be changed, and the number of bits required for setting the priority varies from 3 bits to 8 bits depending on products. Thus, the range of priority values you can specify is different depending on products. In the case of 8-bit configuration, the priority can be configured in the range from 0 to 255. The highest priority is "0". If multiple elements with the same priority exist, the smaller the number, the higher the priority becomes. Note: <PRI\_n> bit is defined as a 3-bit configuration with this product. #### · Priority grouping The priority group can be split into groups. By setting the <PRIGROUP> of the application interrupt and reset control register, <PRI\_n> can be divided into the pre-emption priority and the sub priority. A priority is compared with the pre-emption priority. If the priority is the same as the preemption priority, then it is compared with the sub priority. If the sub priority is the same as the priority, the smaller the exception number, the higher the priority. The Table 7-2 shows the priority group setting. The pre-emption priority and the sub priority in the table are the number in the case that <PRI n is defined as an 8-bit configuration. Table 7-2 Priority grouping setting | <prigroup[2:0]> setting</prigroup[2:0]> | <pri_i field<="" pre-emption="" th=""><th>n[7:0]&gt;<br/>Subpriority<br/>field</th><th>Number of pre-emption priorities</th><th>Number of subpriorities</th></pri_i> | n[7:0]><br>Subpriority<br>field | Number of pre-emption priorities | Number of subpriorities | |-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|----------------------------------|-------------------------| | 000 | [7:1] | [0] | 128 | 2 | | 001 | [7:2] | [1:0] | 64 | 4 | | 010 | [7:3] | [2:0] | 32 | 8 | | 01/1 | [7:4] | [3:0] | 16 | 16 | | 100 | [7:5] | [4:0] | 8 | 32 | | 101 | [7:6] | [5:0] | <b>4</b> | 64 | | 110 | [7] | [6:0] | 2 | 128 | | 111 | None | [7:0] | 1 | 256 | Note: If the configuration of <PRI\_n> is less than 8 bits, the lower bit is "0". For the example, in the case of 3-bit configuration, the priority is set as <PRI\_n[7:5]> and <PRI\_n[4:0] > is "00000". #### 7.1.2.2 Exception Handling and Branch to the Interrupt Service Routine (Pre-emption) When an exception occurs, the CPU suspends the currently executing process and branches to the interrupt service routine. This is called "pre-emption". #### (1) Stacking When the CPU detects an exception, it pushes the contents of the following eight registers to the stack in the following order: - Program Counter (PC) - · Program Status Register (xPSR) - r0 to r3 - · r12 - · Link Register (LR) The SP is decremented by eight words by the completion of the stack push. The following shows the state of the stack after the register contents have been pushed. #### (2) fetching an ISR The CPU enables instruction to fetch the interrupt processing with data store to the register. Prepare a vector table containing the top addresses of ISRs for each exception. After reset, the vector table is located at address 0x0000\_0000 in the Code area. By setting the Vector Table Offset Register, you can place the vector table at any address in the Code or SRAM space. The vector table should also contain the initial value of the main stack. #### (3) Late-arriving If the CPU detects a higher priority exception before executing the ISR for a previous exception, the CPU handles the higher priority exception first. This is called "late-arriving". A late-arriving exception causes the CPU to fetch a new vector address for branching to the corresponding ISR, but the CPU does not newly push the register contents to the stack. #### (4) Vector table The vector table is configured as shown below. TMPM362F10FG You must always set the first four words (stack top address, reset ISR address, NMI ISR address, and Hard Fault ISR address). Set ISR addresses for other exceptions if necessary. | Offset | Exception | Contents | Setting | |--------------|------------------------|---------------------------------|----------| | 0x00 | Reset | Initial value of the main stack | Required | | 0x04 | Reset | ISR address | Required | | 0x08 | Non-Maskable Interrupt | ISR address | Required | | 0x0C | Hard Fault | ISR address | Required | | 0x10 | Memory Management | ISR address | Optional | | 0x14 | Bus Fault | ISR address | Optional | | 0x18 | Usage Fault | ISR address | Optional | | 0x1C to 0x28 | Reserved | | | | 0x2C | SVCall | ISR address | Optional | | 0x30 | Debug Monitor | ISR address | Optional | | 0x34 | Reserved | | 2 | | 0x38 | PendSV | ISR address | Optional | | 0x3C | SysTick | ISR address | Optional | | 0x40 | External Interrupt | ISR address | Optional | ## 7.1.2.3 Executing an ISR An ISR performs necessary processing for the corresponding exception. ISRs must be prepared by the user. An ISR may need to include code for clearing the interrupt request so that the same interrupt will not occur again upon return to normal program execution. For details about interrupt handling, see "7.5 Interrupts". If a higher priority exception occurs during ISR execution for the current exception, the CPU abandons the currently executing ISR and services the newly detected exception. #### 7.1.2.4 Exception exit #### (1) Execution after returning from an ISR When returning from an ISR, the CPU takes one of the following actions: · Tail-chaining If a pending exception exists and there are no stacked exceptions or the pending exception has higher priority than all stacked exceptions, the CPU returns to the ISR of the pending exception. In this case, the CPU skips the pop of eight registers and push of eight registers when exiting one ISR and entering another. This is called "tail-chaining". · Returning to the last stacked ISR If there are no pending exceptions or if the highest priority stacked exception is of higher priority than the highest priority pending exception, the CPU returns to the last stacked ISR. · Returning to the previous program If there are no pending or stacked exceptions, the CPU returns to the previous program. #### (2) Exception exit sequence When returning from an ISR, the CPU performs the following operations: · Pop eight registers Pops the eight registers (PC, xPSR, r0 to r3, r12 and LR) from the stack and adjust the SP. · Load current active interrupt number Loads the current active interrupt number from the stacked xPSR. The CPU uses this to track which interrupt to return to. · Select SP If returning to an exception (Handler Mode), SP is SP\_main. If returning to Thread Mode, SP can be SP main or SP process. 7.2 Reset Exceptions TMPM362F10FG ## 7.2 Reset Exceptions Reset exceptions are generated from the following three sources. Use the Reset Flag (CGRSTFLG) Register of the Clock Generator to identify the source of a reset. · External reset pin A reset exception occurs when an external reset pin changes from "Low" to "High". · Reset exception by WDT The watchdog timer (WDT) has a reset generating feature. For details, see the chapter on the WDT. · Reset exception by SYSRESETREQ A reset can be generated by setting the SYSRESETREQ bit in the NVIC's Application Interrupt and Reset Control Register. Note: Do not reset with <SYSRESETREQ> in SLOW mode. ## 7.3 Non-Maskable Interrupts (NMI) Non-maskable interrupts are generated from the following two sources. Use the NMI Flag (CGNMIFLG) Register of the clock generator to identify the source of a non-maskable interrupt. External NMI pin A non-maskable interrupt is generated when an external NMI pin changes from "High" to "Low". Non-maskable interrupt by WDT The watchdog timer (WDT) has a non-maskable interrupt generating feature. For details, see the chapter on the WDT. ## 7.4 SysTick SysTick provides interrupt features using the CPU's system timer. When you set a value in the SysTick Reload Value Register and enable the SysTick features in the SysTick Control and Status Register, the counter loads with the value set in the Reload Value Register and begins counting down. When the counter reaches "0", a SysTick exception occurs. You may be pending exceptions and use a flag to know when the timer reaches "0". The SysTick Calibration Value Register holds a reload value for counting 10 ms with the system timer. The count clock frequency varies with each product, and so the value set in the SysTick Calibration Value Register also varies with each product. Note: In this product, fosc by 32 is used as external reference clock. TMPM362F10FG ## 7.5 Interrupts This chapter describes routes, sources and required settings of interrupts. The CPU is notified of interrupt requests by the interrupt signal from each interrupt source. It sets priority on interrupts and handles an interrupt request with the highest priority. Interrupt requests for clearing a standby mode are notified to the CPU via the clock generator. Therefore, appropriate settings must be made in the clock generator. ## 7.5.1 Interrupt Sources #### 7.5.1.1 Interrupt route Figure 7-1 shows an interrupt request route. The interrupts issued by the peripheral function that is not used to release standby are directly input to the CPU (route1). The peripheral function interrupts used to release standby (route 2) and interrupts from the external interrupt pin (route 3) are input to the clock generator and are input to the CPU through the logic for releasing standby (route 4 and 5). If interrupts from the external interrupt pins are not used to release standby, they are directly input to the CPU, not through the logic for standby release (route 6). Figure 7-1 Interrupt Route #### 7.5.1.2 Generation An interrupt request is generated from an external pin or peripheral function assigned as an interrupt source or by setting the NVIC's Interrupt Set-Pending Register. Page 73 2023/07/21 7.5 Interrupts TMPM362F10FG From external pin Set the port control register so that the external pin can perform as an interrupt function pin. · From peripheral function Set the peripheral function to make it possible to output interrupt requests. See the chapter of each peripheral function for details. • By setting Interrupt Set-Pending Register (forced pending) An interrupt request can be generated by setting the relevant bit of the Interrupt Set-Pending Register. #### 7.5.1.3 Transmission An interrupt signal from an external pin or peripheral function is directly sent to the CPU unless it is used to exit a standby mode. Interrupt requests from interrupt sources that can be used for clearing a standby mode are transmitted to the CPU via the clock generator. For these interrupt sources, appropriate settings must be made in the clock generator in advance. External interrupt sources not used for exiting a standby mode can be used without setting the clock generator. #### 7.5.1.4 Precautions when using external interrupt pins If you use external interrupts, be aware the followings not to generate unexpected interrupts. If input disabled (PxIE<PxmIE>="0"), inputs from external interrupt pins are "High". Also, if external interrupts are not used as a trigger to release standby (route 6 of Figure 7-1), input signals from the external interrupt pins are directly sent to the CPU. Since the CPU recognizes "High" input as an interrupt, interrupts occur if corresponding interrupts are enabled by the CPU as inputs are being disabled. To use the external interrupt without setting it as a standby trigger, set the interrupt pin input as "Low" and enable it. Then, enable interrupts on the CPU. ## 7.5.1.5 List of Interrupt Sources Table 7-3 shows the list of interrupt sources. Table 7-3 List of Interrupt Sources | No. | | Interrupt Source | active level (Releasing standby and interrupt) | CG interrupt mode control register | |-----|-----------|---------------------------------------------------------|------------------------------------------------|------------------------------------| | 0 | INT0 | Interrupt pin 0 | | | | 1 | INT1 | Interrupt pin 1 | (070 | 0004004 | | 2 | INT2 | Interrupt pin 2 | | CGIMCGA | | 3 | INT3 | Interrupt pin 3 | | | | 4 | INT4 | Interrupt pin 4 | | | | 5 | INT5 | Interrupt pin 5 | | CGIMCGB | | 6 | INT6 | Interrupt pin 6 | 4( >> | CGINICGB | | 7 | INT7 | Interrupt pin 7 | Selectable | $\mathcal{L}$ | | 8 | INT8 | Interrupt pin 8 | Selectable | 0) | | 9 | INT9 | Interrupt pin 9 | | 100000 | | 10 | INTA | Interrupt pin A | | GGIMCGC | | 11 | INTB | Interrupt pin B | | | | 12 | INTC | Interrupt pin C | | / | | 13 | INTD | Interrupt pin D | $(\langle // \rangle)$ | CCIMCCD | | 14 | INFE | Interrupt pin E | | CGIMCGD | | 15 | INTF | Interrupt pin F | | | | 16 | INTRX0 | Serial channel reception 0 interrupt | | | | 17 | INTTX0 | Serial channel transmission 0 interrupt | <b>\</b> | | | 18 | INTRX1 | Serial channel reception 1 interrupt | | | | 19 | INTTX1 | Serial channel transmission 1 interrupt | | | | 20 | INTRX2 | Serial channel reception 2 interrupt | ✓ | | | 21 | INTTX2 | Serial channel transmission 2 interrupt | | | | 22 | INTRX3 | Serial channel reception 3 interrupt | | | | 23 | INTTX3 | Serial channel transmission 3 interrupt | | | | 24 | INTRX4 | Serial channel reception 4 interrupt | | | | 25 | INTTX4 | Serial channel transmission 4 interrupt | | | | 26 | INTSBI0 | Serial bus interface 0 interrupt | | | | 27 | INTSBI1 | Serial bus interface 1 interrupt | | | | 28 | INTCECRX | CEC reception interrupt | | | | 29 | INTCECTX | CEC transmission interrupt | Rising edge | CGIMCGE | | 30 | INTRMCRX0 | Remote control signal reception 0 interrupt | Tabiling dage | COMMODE | | 31 | INTRMCRX1 | Remote control signal reception 1 interrupt | | | | 32 | INTRTC | RTC interrupt | Falling edge | CGIMCGF | | 33 | INTKWUP | Key-on wake-up interrupt | High level | 30.171001 | | 34 | INTSBI2 | Serial bus interface 2 interrupt | | | | 35 | INTSBI3 | Serial bus interface 3 interrupt | | | | 36 | INTSBI4 | Serial bus interface 4 interrupt | | | | 37 | INTADHP | Highest priority AD conversion complete interrupt | | | | 38 | INTADM0 | AD conversion monitoring function 0 interrupt | | | | 39 | INTADM1 | AD conversion monitoring function 1 interrupt | | | | 40 | INTTB0 | 16-bit timer /event counter 0 match detection interrupt | | | | 41 | INTTB1 | 16-bit timer /event counter 1 match detection interrupt | | | Table 7-3 List of Interrupt Sources | | | | active level | 00 1414 1 | |-----|----------|--------------------------------------------------------------|-----------------------------------|------------------------------------| | No. | | Interrupt Source | (Releasing standby and interrupt) | CG interrupt mode control register | | 42 | INTTB2 | 16-bit timer /event counter 2 match detection interrupt | | | | 43 | INTTB3 | 16-bit timer /event counter 3 match detection interrupt | | ) P | | 44 | INTTB4 | 16-bit timer /event counter 4 match detection inter-<br>rupt | ~ (7/1) | | | 45 | INTTB5 | 16-bit timer /event counter 5 match detection inter-<br>rupt | | | | 46 | INTTB6 | 16-bit timer /event counter 6 match detection interrupt | | | | 47 | INTTB7 | 16-bit timer /event counter 7 match detection inter-<br>rupt | | | | 48 | INTTB8 | 16-bit timer /event counter 8 match detection inter-<br>rupt | 75) ~ ( | 5 | | 49 | INTTB9 | 16-bit timer /event counter 9 match detection inter-<br>rupt | | 30) | | 50 | INTTBA | 16-bit timer /event counter A match detection inter-<br>rupt | | | | 51 | INTTBB | 16-bit timer /event counter B match detection interrupt | | | | 52 | INTTBC | 16-bit timer /event counter C match detection interrupt | | | | 53 | INTTBD | 16-bit timer /event counter D match detection interrupt | | | | 54 | INTTBE | 16-bit timer /event counter E match detection interrupt | | | | 55 | INTTBF | 16-bit timer /event counter F match detection interrupt | | | | 56 | Reserved | | $\rightarrow$ | | | 57 | Reserved | | | | | 58 | INTAD | AD conversion completion interrupt | | | | 59 | INTSSPO | SSP interrupt | | | | 60 | INTRX5 | Serial channel 5 reception interrupt | | | | 61 | INTTX5 | Serial channel 5 transmission interrupt | | | | 62 | INTRX6 | Serial channel 6 reception interrupt | | | | 63 | INTTX6 | Serial channel 6 transmission interrupt | | | | 64 | INTRX7 | Serial channel 7 reception interrupt | | | | 65 | INTIX7 | Serial channel 7 transmission interrupt | | | | 66 | INTRX8 | Serial channel 8 reception interrupt | | | | 67 | INTTX8 | Serial channel 8 transmission interrupt | | | | 68 | INTRX9 | Serial channel 9 reception interrupt | | | | 69 | INTTX9 | Serial channel 9 transmission interrupt | | | | 70 | INTRX10 | Serial channel 10 reception interrupt | | | | 71 | INTTX10 | Serial channel 10 transmission | | | | 72 | INTRX11 | Serial channel 11 reception | | | | 73 | INTTX11 | Serial channel 11 transmission | | | | 74 | INTCAP10 | 16-bit timer /event counter 1 input capture interrupt 0 | | | | 75 | INTCAP11 | 16-bit timer /event counter 1 input capture interrupt 1 | | | | 76 | INTCAP20 | 16-bit timer /event counter 2 input capture interrupt 0 | | | Table 7-3 List of Interrupt Sources | No. | | Interrupt Source | active level<br>(Releasing standby and<br>interrupt) | CG interrupt mode control register | |-----|------------|---------------------------------------------------------|------------------------------------------------------|------------------------------------| | 77 | INTCAP21 | 16-bit timer /event counter 2 input capture interrupt 1 | | | | 78 | Reserved | - | | 75 | | 79 | Reserved | - | | | | 80 | INTCAP50 | 16-bit timer /event counter 5 input capture interrupt 0 | | | | 81 | INTCAP51 | 16-bit timer /event counter 5 input capture interrupt 1 | | | | 82 | INTCAP60 | 16-bit timer /event counter 6 input capture interrupt 0 | | | | 83 | INTCAP61 | 16-bit timer /event counter 6 input capture interrupt 1 | | 24 | | 84 | INTCAP70 | 16-bit timer /event counter 7 input capture interrupt 0 | $()$ $\Diamond$ $($ | | | 85 | INTCAP71 | 16-bit timer /event counter 7 input capture interrupt | | | | 86 | INTCAP90 | 16-bit timer /event counter 9 input capture interrupt 0 | | | | 87 | INTCAP91 | 16-bit timer /event counter 9 input capture interrupt | | | | 88 | INTCAPA0 | 16-bit timer /event counter A input capture interrupt 0 | | | | 89 | INTCAPA1 | 16-bit timer /event counter A input capture interrupt | | | | 90 | INTCAPB0 | 16-bit timer /event counter B input capture interrupt 0 | | | | 91 | INTCAPB1 | 16-bit timer /event counter B input capture interrupt | | | | 92 | INTCAPD0 | 16-bit timer /event counter D input capture interrupt 0 | ~ | | | 93 | INTCAPD1 | 16-bit timer /event counter D input capture interrupt | | | | 94 | INTCAPE0 | 16-bit timer /event counter E input capture interrupt 0 | | | | 95 | INTCAPE1 | 16-bit timer /event counter E input capture interrupt 1 | | | | 96 | INTCAPF0 | 16-bit timer /event counter F input capture interrupt 0 | | | | 97 | INTCAPF1 | 16-bit timer /event counter F input capture interrupt 1 | | | | 98 | INTDMACERR | DMA error status interrupt | | | | 99 | INTDMACTC0 | DMA terminal count status interrupt | | | Page 77 2023/07/21 7.5 Interrupts TMPM362F10FG #### 7.5.1.6 Active level The active level indicates which change in signal of an interrupt source triggers an interrupt. The CPU recognizes interrupt signals in "High" level as interrupt. Interrupt signals directly sent from peripheral functions to the CPU are configured to output "High" to indicate an interrupt request. Active level is set to the clock generator for interrupts which can be a trigger to release standby. Interrupt requests from peripheral functions are set as rising-edge or falling-edge triggered. Interrupt requests from interrupt pins can be set as level-sensitive ("High" or "Low") or edge-triggered (rising or falling). If an interrupt source is used for clearing a standby mode, setting the relevant clock generator register is also required. Enable the CGIMCGx<INTxEN> bit and specify the active level in the CGIMCGx<EMCGx> bits. You must set the active level for interrupt requests from each peripheral function as shown in Table 7-3 An interrupt request detected by the clock generator is notified to the CPU with a signal in "High" level. Note: For the CEC reception / transmission, remote control signal reception and real time clock interrupts, set the <INTxEN> bit to "1" and specify the active level, even when they are not used for clearing a standby mode. TMPM362F10FG ## 7.5.2 Interrupt Handling ## 7.5.2.1 Flowchart The following shows how an interrupt is handled. The following shows how an exception/interrupt is handled. In the following descriptions, indicates hardware handling. indicates software handling. Processing Details See Set the relevant NVIC registers for detecting interrupts. Set the clock generator as well if each interrupt source is used to clear a standby mode. o Common setting Setting for detection **NVIC** registers o setting to clear standby mode Clock generator 7.5.2.2 Preparation" Execute an appropriate setting to send the interrupt signal depending on the interrupt type. o Setting for interrupt from external pin setting for sending interrupt signal o Setting for interrupt from peripheral function Peripheral function (See the chapter of each peripheral function for details.) Interrupt generation An interrupt request is generated. Not clearing standby mode Clearing standby mode "7.5.2.3 Detection by Interrupt lines used for clearing a standby mode are connected to the CPU via CG detects interrupt Clock Generator" (clearing standby mode) the clock generator. The CPU detects the interrupt. "7.5.2.4 Detection by CPU detects interrupt CPU" If multiple interrupt requests occur simultaneously, the interrupt request with the highest priority is detected according to the priority order. The CPU handles the interrupt. "7.5.2.5 CPU process-CPU handles interrupt. ing" The CPU pushes register contents to the stack before entering the ISR. Page 79 2023/07/21 7. Exceptions 7.5 Interrupts TMPM362F10FG #### 7.5.2.2 Preparation When preparing for an interrupt, you need to pay attention to the order of configuration to avoid any unexpected interrupt on the way. Initiating an interrupt or changing its configuration must be implemented in the following order basically. Disable the interrupt by the CPU. Configure from the farthest route from the CPU. Then enable the interrupt by the CPU. To configure the clock generator, you must follow the order indicated here not to cause any unexpected interrupt. First, configure the precondition. Secondly, clear the data related to the interrupt in the clock generator and then enable the interrupt. The following sections are listed in the order of interrupt handling and describe how to configure them. - 1. Disabling interrupt by CPU - 2. CPU registers setting - 3. Preconfiguration (1) (Interrupt from external pin) - 4. Preconfiguration (2) (Interrupt from peripheral function) - 5. Preconfiguration (3) (Interrupt Set-Pending Register) - 6. Configuring the clock generator - 7. Enabling interrupt by CPU #### (1) Disabling interrupt by CPU To make the CPU for not accepting any interrupt, write "1" to the corresponding bit of the PRI-MASK Register, All interrupts and exceptions other than non-maskable interrupts and hard faults can be masked. Use "MSR" instruction to set this register. | / | Interrupt mask register | | | |----|-------------------------|---|-------------------------| | | PRIMASK | ← | "1"(Interrupt disabled) | | b, | | | | Note 1: PRIMASK register cannot be modified by the user access level. Note 2: If a fault causes when "1" is set to the PRIMASK register, it is treated as a hard fault. #### (2) CPU registers setting You can assign a priority level by writing to <PRI\_n> field in an Interrupt Priority Register of the NVIC register. Each interrupt source is provided with eight bits for assigning a priority level from 0 to 255, but the number of bits actually used varies with each product. Priority level 0 is the highest priority level. If multiple sources have the same priority, the smallest-numbered interrupt source has the highest priority. Page 81 2023/07/21 7.5 Interrupts TMPM362F10FG You can assign grouping priority by using the <PRIGROUP> in the Application Interrupt and Reset Control Register. | NVIC register | | | | | |-----------------------|----------|------------------------------------------------------|--|--| | <pri_n></pri_n> | <b>—</b> | "prioryty" | | | | <prigroup></prigroup> | <b>←</b> | "group priority" (This is configurable if required.) | | | Note: "n" indicates the corresponding exceptions/interrupts. This product uses three bits for assigning a priority level. #### (3) Preconfiguration (1) (Interrupt from external pin) Set "1" to the port function register of the corresponding pin. Setting PxFRn[m] allows the pin to be used as the function pin. Setting PxIE[m] allows the pin to be used as the input port. | Port register | | | \$ \(\frac{1}{2}\) | |-----------------------|----------|-----|--------------------| | PxFRn <pxmfn></pxmfn> | <b>—</b> | "1" | | | PxIE <pxmie></pxmie> | <b>←</b> | "1" | | Note:x: port number / m: corresponding bit / n: function register number in modes other than STOP mode, setting PxIE to enable input enables the corresponding interrupt input regardless of the PxFR setting. Be careful not to enable interrupts that are not used. Also, be aware of the description of "7.5.1.4 Precautions when using external interrupt pins". ## (4) Preconfiguration (2) (Interrupt from peripheral function) The setting varies depending on the peripheral function to be used. See the chapter of each peripheral function for details. ## (5) Preconfiguration (3) (Interrupt Set-Pending Register) To generate an interrupt by using the Interrupt Set-Pending Register, set "1" to the corresponding bit of this register. | NVIC register | 7 | | |---------------------|--------------|-----| | Interrupt Set-Pendi | ng [m] 🔶 " | '1" | Note:m: corresponding bit #### (6) Configuring the clock generator For an interrupt source to be used for exiting a standby mode, you need to set the active level and enable interrupts in the CGIMCG register of the clock generator. The CGIMCG register is capable of configuring each source. Before enabling an interrupt, clear the corresponding interrupt request already held. This can avoid unexpected interrupt. To clear corresponding interrupt request, write a value corresponding to the interrupt to be used to the CGICRCG register. See "7.6.3.7 CGICRCG (CG Interrupt Request Clear Register)" for each value. Interrupt requests from external pins can be used without setting the clock generator if they are not used for exiting a standby mode. However, an "High" pulse or "High"-level signal must be input so that the CPU can detect it as an interrupt request. Also, be aware of the description of "7.5.1.4 Precautions when using external interrupt pins". | Clock generator register | | | |---------------------------|----------|-------------------------------------------------| | CGIMCGn <emcgm></emcgm> | ← | active level | | CGICRCG <icrcg></icrcg> | <b>←</b> | Value corresponding to the interrupt to be used | | CGIMCGn <intmen></intmen> | ← | "1" (interrupt enabled) | Note:n: register number / m: number assigned to interrupt source ### (7) Enabling interrupt by CPU Enable the interrupt by the CPU as shown below. Clear the suspended interrupt in the Interrupt Clear-Pending Register. Enable the intended interrupt with the Interrupt Set-Enable Register. Each bit of the register is assigned to a single interrupt source. Writing "1" to the corresponding bit of the Interrupt Clear-Pending Register clears the suspended interrupt. Writing "1" to the corresponding bit of the Interrupt Set-Enable Register enables the intended interrupt. To generate interrupts in the Interrupt Set-Pending Register setting, factors to trigger interrupts are lost if pending interrupts are cleared. Thus, this operation is not necessary. At the end, PRIMASK register is zero cleared. | NVIC register | | | |-----------------------------|---------------|-----| | Interrupt Clear-Pending [m] | Ţ | "1" | | Interrupt Set-Pending [m] | <b>←</b> | "1" | | Interrupt mask register | | | | PRIMASK | $/\downarrow$ | "0" | Note 1: m: corresponding bit Note 2: PRIMASK register cannot be modified by the user access level. ### 7.5.2.3 Detection by Clock Generator If an interrupt source is used for exiting a standby mode, an interrupt request is detected according to the active level specified in the clock generator, and is notified to the CPU. An edge-triggered interrupt request, once detected, is held in the clock generator. A level-sensitive interrupt request must be held at the active level until it is detected, otherwise the interrupt request will cease to exist when the signal level changes from active to inactive. When the clock generator detects an interrupt request, it keeps sending the interrupt signal in "High" level to the CPU until the interrupt request is cleared in the CG Interrupt Request Clear (CGICRCG) Register. If a standby mode is exited without clearing the interrupt request, the same interrupt will be detected again when normal operation is resumed. Be sure to clear each interrupt request in the ISR. 7. Exceptions 7.5 Interrupts TMPM362F10FG ### 7.5.2.4 Detection by CPU The CPU detects an interrupt request with the highest priority. ### 7.5.2.5 CPU processing On detecting an interrupt, the CPU pushes the contents of PC, PSR, r0-r3, r12 and LR to the stack then enter the ISR. ### 7.5.2.6 Interrupt Service Routine (ISR) An ISR requires specific programming according to the application to be used. This section describes what is recommended at the service routine programming and how the source is cleared. ### (1) Pushing during ISR An ISR normally pushes register contents to the stack and handles an interrupt as required. The Cortex-M3 core automatically pushes the contents of PC, PSR, r0-r3, r12 and LR to the stack. No extra programming is required for them. Push the contents of other registers if needed. Interrupt requests with higher priority and exceptions such as NMI are accepted even when an ISR is being executed. We recommend you to push the contents of general-purpose registers that might be rewritten. ### (2) Clearing an interrupt source If an interrupt source is used for clearing a standby mode, each interrupt request must be cleared with the CG Interrupt Request Clear (CGICRCG) Register. If an interrupt source is set as level-sensitive, an interrupt request continues to exist until it is cleared at its source. Therefore, the interrupt source must be cleared. Clearing the interrupt source automatically clears the interrupt request signal from the clock generator. If an interrupt is set as edge-sensitive, clear an interrupt request by setting the corresponding value in the CGICRCG register. When an active edge occurs again, a new interrupt request will be detected 2023/07/21 Page 84 # 7.6 Exception / Interrupt-Related Registers The CPU's NVIC registers and clock generator registers described in this chapter are shown below with their respective addresses. # 7.6.1 Register List | NVIC registers | Base Address = 0xE000_E000 | |----------------|----------------------------| | NVIO registers | Dase Address - OxLood_Lood | | NVIC registers | Base Address = 0xE000_E000 | |--------------------------------------------------|----------------------------| | Register name | Address | | SysTick Control and Status Register | 0x0010 | | SysTick Reload Value Register | 0x0014 | | SysTick Current Value Register | 0x0018 | | SysTick Calibration Value Register | 0x001C | | Interrupt Set-Enable Register 1 | 0x0100 | | Interrupt Set-Enable Register 2 | 0x0104 | | Interrupt Set-Enable Register 3 | 0x0108 | | Interrupt Set-Enable Register 4 | 0x010C | | Interrupt Clear-Enable Register 1 | 0x0180 | | Interrupt Clear-Enable Register 2 | 0x0184 | | Interrupt Clear-Enable Register 3 | 0x0188 | | Interrupt Clear-Enable Register 4 | 0x018C | | Interrupt Set-Pending Register 1 | 0x0200 | | Interrupt Set-Pending Register 2 | 0x0204 | | Interrupt Set-Pending Register 3 | 0x0208 | | Interrupt Set-Pending Register 4 | 0x020C | | Interrupt Clear-Pending Register 1 | 0x0280 | | Interrupt Clear-Pending Register 2 | 0x0284 | | Interrupt Clear-Pending Register 3 | 0x0288 | | Interrupt Clear-Pending Register 4 | 0x028C | | Interrupt Priority Register | 0x0400 to 0x0460 | | Vector Table Offset Register | 0x0D08 | | Application Interrupt and Reset Control Register | 0x0D0C | | System Handler Priority Register | 0x0D18, 0x0D1C, 0x0D20 | | System Handler Control and State Register | 0x0D24 | Clock generator register Base Address = 0x400F\_4000 | Register name | | Address | |--------------------------------------|----------|---------| | CG Interrupt Request Clear Register | CGICRCG | 0x0014 | | NMI Flag Register | CGNMIFLG | 0x0018 | | Reset Flag Register | CGRSTFLG | 0x001C | | CG Interrupt Mode Control Register A | CGIMCGA | 0x0020 | | CG Interrupt Mode Control Register B | CGIMCGB | 0x0024 | | CG Interrupt Mode Control Register C | CGIMCGC | 0x0028 | | CG Interrupt Mode Control Register D | CGIMCGD | 0x002C | | CG Interrupt Mode Control Register E | CGIMCGE | 0x0030 | | CG Interrupt Mode Control Register F | CGIMCGF | 0x0034 | | Reserved | - | 0x0038 | | Reserved | - | 0x003C | Note: Access to the "Reserved" areas is prohibited. Page 85 2023/07/21 ### **NVIC Registers** 7.6.2 ### SysTick Control and Status Register 7.6.2.1 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|------|-------|-----------|---------|-----------| | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 < | 0// | ) 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | ((-)> | - | COUNTFLAG | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 1,1 | 10 | 9 | 8 | | bit symbol | - | - | - | 1 | | - | 0-1 | - | | After reset | 0 | 0 | 0 | 0 | (0/\) | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | (3) | 2 | 3 | 0 | | bit symbol | - | - | - | - (( | | CLKSOURCE | TICKINT | ENABLE | | After reset | 0 | 0 | 0 | 0 | V | 9/7/ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | - | R | Read as 0. | | 16 | COUNTFLAG | R/W | 0: Timer not counted to 0 1: Timer counted to 0 Returns "1" if timer counted to "0" since last time this was read. Clears on read of any part of the SysTick Control and Status Register. | | 15-3 | - | R | Read as 0. | | 2 | CLKSOURCE | R/W | 0: External reference clock (fosc/32) (Note) 1: CPU clock (fsys) | | 1 | TICKINT | R/W | 0: Do not pend SysTick 1: Pend SysTick | | 0 | ENABLE | R/W | 0: Disable 1: Enable If "1" is set, it reloads with the value of the Reload Value Register and starts operation. | Note: In this product, fosc by 32 is used as external reference clock. Page 86 2023/07/21 ## 7.6.2.2 SysTick Reload Value Register | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | |-------------|----|--------|----|------|-----------|--------|------------|----|--|--|--| | bit symbol | - | - | - | - | - | - \ | - | - | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>1</b> 7 | 16 | | | | | bit symbol | | RELOAD | | | | | | | | | | | After reset | | | | Unde | efined | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | bit symbol | | | | REL | OAD | (( ))> | | | | | | | After reset | | | | Unde | efined | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | | | | bit symbol | | RELOAD | | | | | | | | | | | After reset | | | | Unde | efined // | · . | | > | | | | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|--------------------------------------------------------------------------------------------------------| | 31-24 | _ | R | Read as 0, | | 23-0 | RELOAD | R/W | Reload value Set the value to load into the SysTick Current Value Register when the timer reaches "0". | # 7.6.2.3 SysTick Current Value Register | | | | | | 1 1 2 | | | | | | | |---------------------------|---------|-------------------|-------------|-------|-------|----|----|----|--|--|--| | | 31 | 30 | 29 | 28 < | 27 | 26 | 25 | 24 | | | | | bit symbol | - | | ( ) ) - | | 7 | - | 1 | - | | | | | After reset | 0 | 0 | <<br>o<br>) | (6/// | 0 | 0 | 0 | 0 | | | | | | 23 | 22 | 7 21 | 20 | 19 | 18 | 17 | 16 | | | | | bit symbol | | CURRENT | | | | | | | | | | | After reset | | | | Unde | fined | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | bit symbol | | J) | $\wedge$ | CURI | RENT | | | | | | | | After reset | | | d | Unde | fined | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | CURRENT | | | | | | | | | | | | bit symbol | $\Big)$ | $\langle \rangle$ | | CURI | RENT | | | | | | | | bit symbol<br>After reset | | | | | RENT | | | | | | | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | - | R | Read as 0. | | 23-0 | CURRENT | R/W | [Read] Current SysTick timer value [Write] Clear Writing to this register with any value clears it to 0. Clearing this register also clears the <countflag> bit of the SysTick Control and Status Register.</countflag> | ### 7.6 Exception / Interrupt-Related Registers ## 7.6.2.4 SysTick Calibration Value Register | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|------|----|-----|-------|--------|-----------|----| | bit symbol | NOREF | SKEW | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | | | | TEN | MS | (0) | ^ | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | TEN | MS | (( ))> | | | | After reset | 0 | 0 | 0 | 0 | 1 | | 0 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | | | | TEN | NMS | | | | | After reset | 1 | 1 | 0 | 0 | (0/0) | 1 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-----------------------------------------------------------------------------------------------------| | 31 | NOREF | R | 0: Reference clock provided 1: No reference clock | | 30 | SKEW | R | 0: Calibration value is 10 ms. 1: Calibration value is not 10ms. | | 29-24 | - | R | Read as 0. | | 23-0 | TENMS | R | Calibration value Reload value to use for 10 ms timing (0x9C4) by external reference clock (Note). | 2023/07/21 Page 88 ## 7.6.2.5 Interrupt Set-Enable Register 1 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------| | bit symbol | SETENA<br>(Interrupt 31) | SETENA<br>(Interrupt 30) | SETENA<br>(Interrupt 29) | SETENA<br>(Interrupt 28) | SETENA<br>(Interrupt 27) | SETENA<br>(Interrupt 26) | SETENA<br>(Interrupt 25) | SETENA<br>(Interrupt 24) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) þ | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | SETENA<br>(Interrupt 23) | SETENA<br>(Interrupt 22) | SETENA<br>(Interrupt 21) | SETENA<br>(Interrupt 20) | SETENA (Interrupt 19) | SETENA<br>(Interrupt 18) | SETENA<br>(Interrupt 17) | SETENA<br>(Interrupt 16) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 _ | 10 | 9 | 8 | | | | | | | | 2 | Ů . | 0 | | bit symbol | SETENA<br>(Interrupt 15) | SETENA<br>(Interrupt 14) | SETENA<br>(Interrupt 13) | SETENA<br>(Interrupt 12) | SETENA<br>(Interrupt 11) | SETENA<br>(Interrupt 10) | SETENA<br>(Interrupt 9) | SETENA<br>(Interrupt 8) | | bit symbol After reset | | _ | _ | _ | SETENA | SETENA | SETENA | SETENA | | - | (Interrupt 15) | (Interrupt 14) | (Interrupt 13) | (Interrupt 12) | SETENA<br>(Interrupt 11) | SETENA<br>(Interrupt 10) | SETENA<br>(Interrupt 9) | SETENA<br>(Interrupt 8) | | - | (Interrupt 15) | (Interrupt 14) | (Interrupt 13) | (Interrupt 12) | SETENA<br>(Interrupt 11) | SETENA<br>(Interrupt 10) | SETENA<br>(Interrupt 9) | SETENA<br>(Interrupt 8) | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | SETENA | R/W | Interrupt number [31:0] [Write] 1: Enable [Read] 0: Disabled 1: Enabled Each bit corresponds to the specified number of interrupts. Writing "1" to a bit in this register enables the corresponding interrupt. Writing "0" has no effect. Reading the bits can see the enable/disable condition of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 89 2023/07/21 ### 7.6.2.6 Interrupt Set-Enable Register 2 | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------|--------------------------|-------------------------------|-------------------------------| | bit symbol | SETENA<br>(Interrupt 63) | SETENA<br>(Interrupt 62) | SETENA<br>(Interrupt 61) | SETENA<br>(Interrupt 60) | SETENA<br>(Interrupt 59) | SETENA<br>(Interrupt 58) | 1 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) þ | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | SETENA<br>(Interrupt 55) | SETENA<br>(Interrupt 54) | SETENA<br>(Interrupt 53) | SETENA<br>(Interrupt 52) | SETENA (Interrupt 51) | SETENA<br>(Interrupt 50) | SETENA<br>(Interrupt 49) | SETENA<br>(Interrupt 48) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 15<br>SETENA<br>(Interrupt 47) | 14<br>SETENA<br>(Interrupt 46) | 13<br>SETENA<br>(Interrupt 45) | 12<br>SETENA<br>(Interrupt 44) | SETENA<br>(Interrupt 43) | SETENA<br>(Interrupt 42) | 9<br>SETENA<br>(Interrupt 41) | 8<br>SETENA<br>(Interrupt 40) | | bit symbol After reset | SETENA | | SETENA<br>(Interrupt 47) | SETENA<br>(Interrupt 46) | SETENA<br>(Interrupt 45) | SETENA<br>(Interrupt 44) | SETENA<br>(Interrupt 43) | SETENA<br>(Interrupt 42) | SETENA<br>(Interrupt 41) | SETENA<br>(Interrupt 40) | | | SETENA<br>(Interrupt 47) | SETENA<br>(Interrupt 46) | SETENA<br>(Interrupt 45) | SETENA<br>(Interrupt 44) | SETENA<br>(Interrupt 43) | SETENA<br>(Interrupt 42) | SETENA<br>(Interrupt 41) | SETENA<br>(Interrupt 40) | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------| | 31-26 | SETENA | R/W | Interrupt number [63:58] [Write] | | | | | 1: Enable | | | | | [Read] | | | | | 0: Disabled | | | | | 1: Enabled | | | | | Each bit corresponds to the specified number of interrupts. | | | | | Writing "1" to a bit in this register enables the corresponding interrupt. Writing "0" has no effect. | | | | | Reading the bits can see the enable/disable condition of the corresponding interrupts. | | 25-24 | - / | R/W | Write as 0. | | 23-0 | SETENA | R/W | Interrupt number [55:32] | | | | | [Write] | | | | | 1: Enable | | | | | [Read] | | | Z/\ | N | 0: Disabled | | | | | 1: Enabled | | | | \ | Each bit corresponds to the specified number of interrupts. | | | | ) | Writing "1" to a bit in this register enables the corresponding interrupt. Writing "0" has no effect. | | | | | Reading the bits can see the enable/disable condition of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 90 2023/07/21 ## 7.6.2.7 Interrupt Set-Enable Register 3 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------| | bit symbol | SETENA<br>(Interrupt 95) | SETENA<br>(Interrupt 94) | SETENA<br>(Interrupt 93) | SETENA<br>(Interrupt 92) | SETENA<br>(Interrupt 91) | SETENA<br>(Interrupt 90) | SETENA<br>(Interrupt 89) | SETENA<br>(Interrupt 88) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) o | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | SETENA<br>(Interrupt 87) | SETENA<br>(Interrupt 86) | SETENA<br>(Interrupt 85) | SETENA<br>(Interrupt 84) | SETENA (Interrupt 83) | SETENA<br>(Interrupt 82) | SETENA<br>(Interrupt 81) | SETENA<br>(Interrupt 80) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | | bit symbol | - | - | SETENA<br>(Interrupt 77) | SETENA<br>(Interrupt 76) | SETENA<br>(Interrupt 75) | SETENA<br>(Interrupt 74) | SETENA<br>(Interrupt 73) | SETENA<br>(Interrupt 72) | | bit symbol After reset | - 0 | - 0 | | _ | $\sim$ | <u> </u> | | | | | -<br>0<br>7 | 0 6 | (Interrupt 77) | (Interrupt 76) | (Interrupt 75) | (Interrupt 74) | (Interrupt 73) | (Interrupt 72) | | | - | - | (Interrupt 77) | (Interrupt 76) | (Interrupt 75) | (Interrupt 74) | (Interrupt 73) | (Interrupt 72) | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------| | 31-16 | SETENA | R/W | Interrupt number [95:80] | | | | | [Write] | | | | | 1: Enable | | | | | [Read] | | | | | 0: Disabled | | | | | 1: Enabled | | | | | Each bit corresponds to the specified number of interrupts. | | | | | Writing "1" to a bit in this register enables the corresponding interrupt. Writing "0" has no effect. | | | | | Reading the bits can see the enable/disable condition of the corresponding interrupts. | | 15-14 | - / | R/W | Write as 0. | | 13-0 | SETENA | R/W | Interrupt number [77:64] | | | | | [Write] | | | | | 1: Enable | | | | | [Read] | | | 7/ | N | 0: Disabled | | | | | 1: Enabled | | | | \ | Each bit corresponds to the specified number of interrupts. | | | | ) | Writing "1" to a bit in this register enables the corresponding interrupt. Writing "0" has no effect. | | | | | Reading the bits can see the enable/disable condition of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 91 2023/07/21 ### 7.6.2.8 Interrupt Set-Enable Register 4 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|--------------------------|--------------------------|--------------------------|--------------------------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | SETENA<br>(Interrupt 99) | SETENA<br>(Interrupt 98) | SETENA<br>(Interrupt 97) | SETENA<br>(Interrupt 96) | | After reset | 0 | 0 | 0 | 0 | | 0 | 9 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | - | R | Read as 0, | | 3-0 | SETENA | R/W | Interrupt number [99:96] [Write] 1: Enable [Read] 0: Disabled 1: Enabled Each bit corresponds to the specified number of interrupts. Writing "1" to a bit in this register enables the corresponding interrupt. Writing "0" has no effect. Reading the bits can see the enable/disable condition of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". ## 7.6.2.9 Interrupt Clear-Enable Register 1 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|-------------------------------|------------------------------|------------------------------| | bit symbol | CLRENA<br>(Interrupt 31) | CLRENA<br>(Interrupt 30) | CLRENA<br>(Interrupt 29) | CLRENA<br>(Interrupt 28) | CLRENA<br>(Interrupt 27) | CLRENA<br>(Interrupt 26) | CLRENA<br>(Interrupt 25) | CLRENA<br>(Interrupt 24) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) þ | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | CLRENA<br>(Interrupt 23) | CLRENA<br>(Interrupt 22) | CLRENA<br>(Interrupt 21) | CLRENA<br>(Interrupt 20) | CLRENA (Interrupt 19) | CLRENA<br>(Interrupt 18) | CLRENA<br>(Interrupt 17) | CLRENA<br>(Interrupt 16) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 15<br>CLRENA<br>(Interrupt 15) | 14<br>CLRENA<br>(Interrupt 14) | 13<br>CLRENA<br>(Interrupt 13) | 12<br>CLRENA<br>(Interrupt 12) | 11<br>CLRENA<br>(Interrupt 11) | 10<br>CLRENA<br>(Interrupt 10 | 9<br>CLRENA<br>(Interrupt 9) | 8<br>CLRENA<br>(Interrupt 8) | | bit symbol After reset | CLRENA | | CLRENA<br>(Interrupt 15) | CLRENA<br>(Interrupt 14) | CLRENA<br>(Interrupt 13) | CLRENA<br>(Interrupt 12) | CLRENA<br>(Interrupt 11) | CLRENA<br>(Interrupt 10 | CLRENA<br>(Interrupt 9) | CLRENA<br>(Interrupt 8) | | | CLRENA<br>(Interrupt 15) | CLRENA<br>(Interrupt 14) | CLRENA<br>(Interrupt 13) | CLRENA<br>(Interrupt 12) | CLRENA<br>(Interrupt 11) | CLRENA<br>(Interrupt 10 | CLRENA<br>(Interrupt 9) | CLRENA<br>(Interrupt 8) | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | CLRENA | R/W | Interrupt number [31:0] [Write] 1: Disabled [Read] 0: Disabled 1: Enable Each bit corresponds to the specified number of interrupts. It can be performed to enable interrupts and to check if interrupts are disabled. Writing "1" to a bit in this register disables the corresponding interrupt. Writing "0" has no effect. Reading the bits can see the enable/disable condition of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 93 2023/07/21 ### 7.6.2.10 Interrupt Clear-Enable Register 2 | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------|-------------------------------|-------------------------------| | bit symbol | CLRENA<br>(Interrupt 63) | CLRENA<br>(Interrupt 62) | CLRENA<br>(Interrupt 61) | CLRENA<br>(Interrupt 60) | CLRENA<br>(Interrupt 59) | CLRENA<br>(Interrupt 58) | 1 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) þ | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | CLRENA<br>(Interrupt 55) | CLRENA<br>(Interrupt 54) | CLRENA<br>(Interrupt 53) | CLRENA<br>(Interrupt 52) | CLRENA (Interrupt 51) | CLRENA<br>(Interrupt 50) | CLRENA<br>(Interrupt 49) | CLRENA<br>(Interrupt 48) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 15<br>CLRENA<br>(Interrupt 47) | 14<br>CLRENA<br>(Interrupt 46) | 13<br>CLRENA<br>(Interrupt 45) | 12<br>CLRENA<br>(Interrupt 44) | 11<br>CLRENA<br>(Interrupt 43) | CLRENA<br>(Interrupt 42) | 9<br>CLRENA<br>(Interrupt 41) | 8<br>CLRENA<br>(Interrupt 40) | | bit symbol After reset | CLRENA | | CLRENA<br>(Interrupt 47) | CLRENA<br>(Interrupt 46) | CLRENA<br>(Interrupt 45) | CLRENA<br>(Interrupt 44) | CLRENA<br>(Interrupt 43) | CLRENA<br>(Interrupt 42) | CLRENA<br>(Interrupt 41) | CLRENA<br>(Interrupt 40) | | | CLRENA<br>(Interrupt 47) | CLRENA<br>(Interrupt 46) | CLRENA<br>(Interrupt 45) | CLRENA<br>(Interrupt 44) | CLRENA<br>(Interrupt 43) | CLRENA<br>(Interrupt 42) | CLRENA<br>(Interrupt 41) | CLRENA<br>(Interrupt 40) | | Bit | Bit Symbol | Туре | Function | |-------|-----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 31-26 | CLRENA | R/W | Interrupt number [63:58] | | | | | [Write] | | | | | 1: Disabled | | | | | [Read] | | | | | 0: Disabled | | | | | 1: Enable | | | | | Each bit corresponds to the specified number of interrupts. It can be performed to enable interrupts and to check if interrupts are disabled. | | | | | Writing "1" to a bit in this register disables the corresponding interrupt. Writing "0" has no effect. | | | | | Reading the bits can see the enable/disable condition of the corresponding interrupts. | | 25-24 | - | R/W | Write as 0. | | 23-0 | CLRENA | R/W | Interrupt number [55:32] | | | | ] | [Write] | | | $\wedge \wedge$ | | 1: Disabled | | | >,< | | [Read] | | | | | 0: Disabled | | | | | 1: Enable | | < | | ) | Each bit corresponds to the specified number of interrupts. It can be performed to enable interrupts and to check if interrupts are disabled. | | | | / | Writing "1" to a bit in this register disables the corresponding interrupt. Writing "0" has no effect. | | | | | Reading the bits can see the enable/disable condition of the corresponding interrupts. | | | | | | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 94 2023/07/21 ### 7.6.2.11 Interrupt Clear-Enable Register 3 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------------------|----------------| | hit aymahal | CLRENA | bit symbol | (Interrupt 95) | (Interrupt 94) | (Interrupt 93) | (Interrupt 92) | (Interrupt 91) | (Interrupt 90) | (Interrupt 89) | (Interrupt 88) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | hit aymahal | CLRENA | CLRENA | CLRENA | CLRENA | CLRENA < | CLRENA | CLRENA | CLRENA | | bit symbol | (Interrupt 87) | (Interrupt 86) | (Interrupt 85) | (Interrupt 84) | (Interrupt 83) | (Interrupt 82) | (Interrupt 81) | (Interrupt 80) | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | hit aymbal | | | CLRENA | CLRENA | CLRENA | CLRENA | CLRENA | CLRENA | | bit symbol | - | - | (Interrupt 77) | (Interrupt 76) | (Interrupt 75) | (Interrupt 74) | (Interrupt 73) | (Interrupt 72) | | After reset | 0 | 0 | 0 | 0 | 9 | <b>O</b> | 0 | , 0 | | | | | | | | | | | | | 7 | 6 | 5 | 4 | ( \ \ ,3 ) ) | 2 | $(\bigcirc 1)$ | 0 | | hit aymbal | 7<br>CLRENA | 6<br>CLRENA | 5<br>CLRENA | 4<br>CLRENA | CLRENA | 2<br>CLRENA | CLRENA | 0<br>CLRENA | | bit symbol | | - | - | | | | CLRENA<br>(Interrupt 65) | | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | CLRENA | R/W | Interrupt number [95:80] [Write] 1: Disabled [Read] 0: Disabled 1: Enable Each bit corresponds to the specified number of interrupts. It can be performed to enable interrupts and to check if interrupts are disabled. Writing "1" to a bit in this register disables the corresponding interrupt. Writing "0" has no effect. | | | | | Reading the bits can see the enable/disable condition of the corresponding interrupts. | | 15-14 | - < | R/W | Write as 0. | | 13-0 | CLRENA | R/W | Interrupt number [77:64] [Write] 1: Disabled | | | | | [Read] | | | | | 0: Disabled | | < | | | Enable Each bit corresponds to the specified number of interrupts. It can be performed to enable interrupts and to check if interrupts are disabled. | | | | / | Writing "1" to a bit in this register disables the corresponding interrupt. Writing "0" has no effect. | | < | | \ | Reading the bits can see the enable/disable condition of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 95 2023/07/21 ### 7.6.2.12 Interrupt Clear-Enable Register 4 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|--------------------------|--------------------------|--------------------------|--------------------------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>J</u> 7 | 16 | | bit symbol | - | - | - | - | - | (-0) | ) <u>-</u> | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | CLRENA<br>(Interrupt 99) | CLRENA<br>(Interrupt 98) | CLRENA<br>(Interrupt 97) | CLRENA<br>(Interrupt 96) | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | - | R | Read as 0, | | 3-0 | CLRENA | R/W | Interrupt number [99:96] [Write] 1: Disabled [Read] 0: Disabled 1: Enable Each bit corresponds to the specified number of interrupts. It can be performed to enable interrupts and to check if interrupts are disabled. Writing "1" to a bit in this register disables the corresponding interrupt. Writing "0" has no effect. Reading the bits can see the enable/disable condition of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". ## 7.6.2.13 Interrupt Set-Pending Register 1 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------------------|----------------------------|---------------------------|----------------------------|----------------------------|---------------------------|----------------------------|--------------------------|---------------------------| | bit symbol | SETPEND | Dit Gymae. | (Interrupt 31) | (Interrupt 30) | (Interrupt 29) | (Interrupt 28) | (Interrupt 27) | (Interrupt 26) | (Interrupt 25) | (Interrupt 24) | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | SETPEND | bit Syllibol | (Interrupt 23) | (Interrupt 22) | (Interrupt 21) | (Interrupt 20) | (Interrupt 19) | (Interrupt 18) | (Interrupt 17) | (Interrupt 16) | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | | hit overhol | SETPEND | bit symbol | SETPEND<br>(Interrupt 15) | SETPEND<br>(Interrupt 14) | SETPEND (Interrupt 13) | SETPEND<br>(Interrupt 12) | SETPEND<br>(Interrupt 11) | SETPEND<br>(Interrupt 10 | SETPEND<br>(Interrupt 9) | SETPEND<br>(Interrupt 8) | | bit symbol After reset | - | | | _ | $\sim$ | \ <u>`</u> | | | | | (Interrupt 15) | (Interrupt 14) | (Interrupt 13) | (Interrupt 12) | (Interrupt 11) | (Interrupt 10 | (Interrupt 9) | (Interrupt 8) | | After reset | (Interrupt 15) Undefined | (Interrupt 14) Undefined | (Interrupt 13) Undefined | (Interrupt 12) Undefined | (Interrupt 11) Undefined | (Interrupt 10<br>Undefined | (Interrupt 9) | (Interrupt 8) Undefined | | | (Interrupt 15) Undefined 7 | (Interrupt 14) Undefined | (Interrupt 13) Undefined 5 | (Interrupt 12) Undefined 4 | (Interrupt 11) Undefined | (Interrupt 10<br>Undefined | (Interrupt 9) Undefined | (Interrupt 8) Undefined 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | SETPEND | R/W | Interrupt number [31:0] | | | | | [Write] | | | | | 1: Pend | | | | | [Read] | | | | | 0: Not pending | | | | | 1: Pending | | | | | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | | | | Writing "1" to a bit in this register pends the corresponding interrupt. However, writing "1" has no effect on an interrupt that is already pending or is disabled. Writing "0" has no effect. | | | < | $(\langle \ \rangle$ | Reading the bit returns the current state of the corresponding interrupts. | | | | | Writing "1" to a corresponding bit in the Interrupt Clear-Pending Register clears the bit in this register. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". ### 7.6.2.14 Interrupt Set-Pending Register 2 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------------------|---------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|--------------------------------|----------------------------------------| | bit symbol | SETPEND<br>(Interrupt 63) | SETPEND<br>(Interrupt 62) | SETPEND<br>(Interrupt 61) | SETPEND<br>(Interrupt 60) | SETPEND<br>(Interrupt 59) | SETPEND<br>(Interrupt 58) | 1 | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | SETPEND<br>(Interrupt 55) | SETPEND<br>(Interrupt 54) | SETPEND<br>(Interrupt 53) | SETPEND<br>(Interrupt 52) | SETPEND (Interrupt 51) | SETPEND<br>(Interrupt 50) | SETPEND<br>(Interrupt 49) | SETPEND<br>(Interrupt 48) | | After reset | Undefined | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 15<br>SETPEND<br>(Interrupt 47) | 14<br>SETPEND<br>(Interrupt 46) | 13<br>SETPEND<br>(Interrupt 45) | 12<br>SETPEND<br>(Interrupt 44) | SETPEND (Interrupt 43) | SETPEND (Interrupt 42) | 9<br>SETPEND<br>(Interrupt 41) | 8<br>SETPEND<br>(Interrupt 40) | | bit symbol After reset | SETPEND | | SETPEND<br>(Interrupt 47) | SETPEND<br>(Interrupt 46) | SETPEND<br>(Interrupt 45) | SETPEND<br>(Interrupt 44) | SETPEND<br>(Interrupt 43) | SETPEND<br>(Interrupt 42) | SETPEND<br>(Interrupt 41) | SETPEND<br>(Interrupt 40) | | | SETPEND<br>(Interrupt 47) | SETPEND<br>(Interrupt 46)<br>Undefined | SETPEND<br>(Interrupt 45)<br>Undefined | SETPEND<br>(Interrupt 44)<br>Undefined | SETPEND<br>(Interrupt 43)<br>Undefined | SETPEND<br>(Interrupt 42)<br>Undefined | SETPEND<br>(Interrupt 41) | SETPEND<br>(Interrupt 40)<br>Undefined | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-26 | SETPEND | R/W | Interrupt number [63:58] | | | | | [Write] | | | | | 1: Pend | | | | | [Read] | | | | | 0: Not pending | | | | | 1: Pending | | | | | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | | | | Writing "1" to a bit in this register pends the corresponding interrupt. However, writing "1" has no effect on an interrupt that is already pending or is disabled. Writing "0" has no effect. | | | / | | Reading the bit returns the current state of the corresponding interrupts. | | | | | Writing "1" to a corresponding bit in the Interrupt Clear-Pending Register clears the bit in this register. | | 25-24 | - | R/W | Write as 0. | | 23-0 | SETPEND | R/W | Interrupt number [55:32] | | | | | [Write] | | | | | 1: Pend | | | | | [Read] | | | | ) | 0: Not pending | | | | / | 1: Pending | | | | ( | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | | | | Writing "1" to a bit in this register pends the corresponding interrupt. However, writing "1" has no effect on an interrupt that is already pending or is disabled. Writing "0" has no effect. | | | | | Reading the bit returns the current state of the corresponding interrupts. | | | | | Writing "1" to a corresponding bit in the Interrupt Clear-Pending Register clears the bit in this register. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 98 2023/07/21 ## 7.6.2.15 Interrupt Set-Pending Register 3 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------------------|---------------------------|---------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|---------------------------|----------------------------------------| | bit symbol | SETPEND<br>(Interrupt 95) | SETPEND<br>(Interrupt 94) | SETPEND<br>(Interrupt 93) | SETPEND<br>(Interrupt 92) | SETPEND<br>(Interrupt 91) | SETPEND<br>(Interrupt 90) | SETPEND<br>(Interrupt 89) | SETPEND<br>(Interrupt 88) | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | SETPEND<br>(Interrupt 87) | SETPEND<br>(Interrupt 86) | SETPEND<br>(Interrupt 85) | SETPEND<br>(Interrupt 84) | SETPEND (Interrupt 83) | SETPEND<br>(Interrupt 82) | SETPEND<br>(Interrupt 81) | SETPEND<br>(Interrupt 80) | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 _ | 40) | 0 | • | | | 10 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | SETPEND (Interrupt 77) | SETPEND (Interrupt 76) | SETPEND<br>(Interrupt 75) | SETPEND (Interrupt 74) | SETPEND<br>(Interrupt 73) | SETPEND (Interrupt 72) | | bit symbol After reset | -<br>Undefined | -<br>Undefined | SETPEND | SETPEND | SETPEND | SETPEND | SETPEND | SETPEND | | | - | - | SETPEND<br>(Interrupt 77) | SETPEND<br>(Interrupt 76) | SETPEND<br>(Interrupt 75) | SETPEND<br>(Interrupt 74) | SETPEND<br>(Interrupt 73) | SETPEND<br>(Interrupt 72) | | | -<br>Undefined | -<br>Undefined | SETPEND<br>(Interrupt 77)<br>Undefined | SETPEND<br>(Interrupt 76)<br>Undefined | SETPEND<br>(Interrupt 75)<br>Undefined | SETPEND<br>(Interrupt 74)<br>Undefined | SETPEND<br>(Interrupt 73) | SETPEND<br>(Interrupt 72)<br>Undefined | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | SETPEND | R/W | Interrupt number [95:80] | | | | | [Write] | | | | | 1: Pend | | | | | [Read] | | | | | 0: Not pending | | | | | 1: Pending | | | | | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | | | | Writing "1" to a bit in this register pends the corresponding interrupt. However, writing "1" has no effect on an interrupt that is already pending or is disabled. Writing "0" has no effect. | | | / | | Reading the bit returns the current state of the corresponding interrupts. | | | | | Writing "1" to a corresponding bit in the Interrupt Clear-Pending Register clears the bit in this register. | | 15-14 | - | R/W | Write as 0. | | 13-0 | SETPEND | R/W | Interrupt number [77:64] | | | | | [Write] | | | | | 1: Pend | | | | | [Read] | | | | | 0: Not pending | | | | / | 1: Pending | | | | ( | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | | | | Writing "1" to a bit in this register pends the corresponding interrupt. However, writing "1" has no effect on an interrupt that is already pending or is disabled. Writing "0" has no effect. | | | | | Reading the bit returns the current state of the corresponding interrupts. | | | | | Writing "1" to a corresponding bit in the Interrupt Clear-Pending Register clears the bit in this register. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 99 2023/07/21 ### 7.6.2.16 Interrupt Set-Pending Register 4 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|---------------------------|---------------------------|---------------------------|---------------------------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-07) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | SETPEND<br>(Interrupt 99) | SETPEND<br>(Interrupt 98) | SETPEND<br>(Interrupt 97) | SETPEND<br>(Interrupt 96) | | After reset | 0 | 0 | 0 | 0 | Undefined | Undefined | Undefined | Undefined | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | - | R | Read as 0, | | 3-0 | SETPEND | R/W | Interrupt number [99:96] [Write] 1: Pend [Read] 0: Not pending 1: Pending Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. Writing "1" to a bit in this register pends the corresponding interrupt. However, writing "1" has no effect on an interrupt that is already pending or is disabled. Writing "0" has no effect. Reading the bit returns the current state of the corresponding interrupts. Writing "1" to a corresponding bit in the interrupt Clear-Pending Register clears the bit in this register. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 100 2023/07/21 ## 7.6.2.17 Interrupt Clear-Pending Register 1 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|---------------------------------------|---------------------------------------| | bit symbol | CLRPEND | | (Interrupt 31) | (Interrupt 30) | (Interrupt 29) | (Interrupt 28) | (Interrupt 27) | (Interrupt 26) | (Interrupt 25) | (Interrupt 24) | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | CLRPEND | bit symbol | (Interrupt 23) | (Interrupt 22) | (Interrupt 21) | (Interrupt 20) | (Interrupt 19) | (Interrupt 18) | (Interrupt 17) | (Interrupt 16) | | After reset | Undefined | | 15 | 14 | 13 | 40 | 44 | 14) | 0 | • | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | hit aymbal | CLRPEND | bit symbol | - | | | | | | | | | bit symbol After reset | CLRPEND | | CLRPEND<br>(Interrupt 15) | CLRPEND<br>(Interrupt 14) | CLRPEND<br>(Interrupt 13) | CLRPEND<br>(Interrupt 12) | CLRPEND<br>(Interrupt 11) | CLRPEND<br>(Interrupt 10) | CLRPEND<br>(Interrupt 9) | CLRPEND<br>(Interrupt 8) | | After reset | CLRPEND<br>(Interrupt 15)<br>Undefined | CLRPEND<br>(Interrupt 14)<br>Undefined | CLRPEND<br>(Interrupt 13)<br>Undefined | CLRPEND<br>(Interrupt 12)<br>Undefined | CLRPEND<br>(Interrupt 11)<br>Undefined | CLRPEND<br>(Interrupt 10)<br>Undefined | CLRPEND<br>(Interrupt 9) | CLRPEND<br>(Interrupt 8)<br>Undefined | | | CLRPEND<br>(Interrupt 15)<br>Undefined | CLRPEND<br>(Interrupt 14)<br>Undefined | CLRPEND<br>(Interrupt 13)<br>Undefined | CLRPEND<br>(Interrupt 12)<br>Undefined | CLRPEND<br>(Interrupt 11)<br>Undefined | CLRPEND<br>(Interrupt 10)<br>Undefined | CLRPEND<br>(Interrupt 9)<br>Undefined | CLRPEND (Interrupt 8) Undefined | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | CLRPEND | R/W | Interrupt number [31:0] [Write] 1: Clear pending interrupt [Read] 0: Not pending 1: Pending | | | < | | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. Writing "1" to a bit in this register clears the corresponding pending interrupt. However, writing "1" has no effect on an interrupt that is already being serviced. Writing "0" has no effect. Reading the bit returns the current state of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 101 2023/07/21 ### 7.6.2.18 Interrupt Clear-Pending Register 2 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|--------------------------------|----------------------------------------| | bit symbol | CLRPEND<br>(Interrupt 63) | CLRPEND<br>(Interrupt 62) | CLRPEND<br>(Interrupt 61) | CLRPEND<br>(Interrupt 60) | CLRPEND<br>(Interrupt 59) | CLRPEND<br>(Interrupt 58) | 1 | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | CLRPEND<br>(Interrupt 55) | CLRPEND<br>(Interrupt 54) | CLRPEND<br>(Interrupt 53) | CLRPEND<br>(Interrupt 52) | CLRPEND<br>(Interrupt 51) | CLRPEND<br>(Interrupt 50) | CLRPEND<br>(Interrupt 49) | CLRPEND<br>(Interrupt 48) | | After reset | Undefined | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 15<br>CLRPEND<br>(Interrupt 47) | 14<br>CLRPEND<br>(Interrupt 46) | 13<br>CLRPEND<br>(Interrupt 45) | 12<br>CLRPEND<br>(Interrupt 44) | CLRPEND (Interrupt 43) | CLRPEND (Interrupt 42) | 9<br>CLRPEND<br>(Interrupt 41) | 8<br>CLRPEND<br>(Interrupt 40) | | bit symbol After reset | CLRPEND | | CLRPEND<br>(Interrupt 47) | CLRPEND<br>(Interrupt 46) | CLRPEND<br>(Interrupt 45) | CLRPEND<br>(Interrupt 44) | CLRPEND<br>(Interrupt 43) | CLRPEND<br>(Interrupt 42) | CLRPEND<br>(Interrupt 41) | CLRPEND<br>(Interrupt 40) | | | CLRPEND<br>(Interrupt 47)<br>Undefined | CLRPEND<br>(Interrupt 46)<br>Undefined | CLRPEND<br>(Interrupt 45)<br>Undefined | CLRPEND<br>(Interrupt 44)<br>Undefined | CLRPEND<br>(Interrupt 43)<br>Undefined | CLRPEND<br>(Interrupt 42)<br>Undefined | CLRPEND<br>(Interrupt 41) | CLRPEND<br>(Interrupt 40)<br>Undefined | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-26 | CLRPEND | R/W | Interrupt number [63:58] | | | | | [Write] | | | | | 1: Clear pending interrupt | | | | | [Read] | | | | | 0: Not pending | | | | | 1: Pending | | | | | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | | | | Writing "1" to a bit in this register clears the corresponding pending interrupt. However, writing "1" has no ef- | | | | | fect on an interrupt that is already being serviced. Writing "0" has no effect. | | | < | | Reading the bit returns the current state of the corresponding interrupts. | | 25-24 | _ | R/W | Write as 0. | | 23-0 | CLRPEND | R/W | Interrupt number [55:32] | | | ^ ^ | | [Write] | | | | | 1: Clear pending interrupt | | | 4 | | [Read] | | | | | 0: Not pending | | ^ | (() | ) | 1: Pending | | | | / | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | ( | | ( | Writing "1" to a bit in this register clears the corresponding pending interrupt. However, writing "1" has no effect on an interrupt that is already being serviced. Writing "0" has no effect. | | | | | Reading the bit returns the current state of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 102 2023/07/21 ## 7.6.2.19 Interrupt Clear-Pending Register 3 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |------------------------|---------------------|---------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------| | hit oumbal | CLRPEND | bit symbol | (Interrupt 95) | (Interrupt 94) | (Interrupt 93) | (Interrupt 92) | (Interrupt 91) | (Interrupt 90) | (Interrupt 89) | (Interrupt 88) | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | hit aymahal | CLRPEND | bit symbol | (Interrupt 87) | (Interrupt 86) | (Interrupt 85) | (Interrupt 84) | (Interrupt 83) | (Interrupt 82) | (Interrupt 81) | (Interrupt 80) | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 _ | 10 | 9 | 8 | | | 13 | 14 | 13 | 12 | | TU | 9 | 0 | | hit aymhal | 13 | 14 | CLRPEND | CLRPEND | CLRPEND | CLRPEND | CLRPEND | CLRPEND | | bit symbol | - | - | - | | | | | | | bit symbol After reset | -<br>Undefined | -<br>Undefined | CLRPEND | CLRPEND | CLRPEND | CLRPEND | CLRPEND | CLRPEND | | - | - | - | CLRPEND<br>(Interrupt 77) | CLRPEND<br>(Interrupt 76) | CLRPEND<br>(Interrupt 75) | CLRPEND<br>(Interrupt 74) | CLRPEND<br>(Interrupt 73) | CLRPEND<br>(Interrupt 72) | | After reset | -<br>Undefined | -<br>Undefined | CLRPEND<br>(Interrupt 77)<br>Undefined | CLRPEND<br>(Interrupt 76)<br>Undefined | CLRPEND<br>(Interrupt 75)<br>Undefined | CLRPEND<br>(Interrupt 74)<br>Undefined | CLRPEND<br>(Interrupt 73) | CLRPEND<br>(Interrupt 72)<br>Undefined | | | -<br>Undefined<br>7 | -<br>Undefined<br>6 | CLRPEND<br>(Interrupt 77)<br>Undefined | CLRPEND<br>(Interrupt 76)<br>Undefined | CLRPEND<br>(Interrupt 75)<br>Undefined | CLRPEND<br>(Interrupt 74)<br>Undefined | CLRPEND<br>(Interrupt 73)<br>Undefined | CLRPEND<br>(Interrupt 72)<br>Undefined | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | CLRPEND | R/W | Interrupt number [95:80] | | | | | [Write] | | | | | 1: Clear pending interrupt | | | | | [Read] | | | | | 0: Not pending | | | | | 1: Pending | | | | | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | | | | Writing "1" to a bit in this register clears the corresponding pending interrupt. However, writing "1" has no effect on an interrupt that is already being serviced. Writing "0" has no effect. | | | < | | Reading the bit returns the current state of the corresponding interrupts. | | 15-14 | _ | R/W | Write as 0. | | 13-0 | CLRPEND | R/W | Interrupt number [77:64] | | | ^ ^ | | [Write] | | | | | 1: Clear pending interrupt | | | 4 | | [Read] | | | | | 0: Not pending | | _ | | ) | 1: Pending | | | | 1 | Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. | | ( | | | Writing "1" to a bit in this register clears the corresponding pending interrupt. However, writing "1" has no effect on an interrupt that is already being serviced. Writing "0" has no effect. | | | | | Reading the bit returns the current state of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". Page 103 2023/07/21 # 7.6.2.20 ### Interrupt Clear-Pending Register 4 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|---------------------------|---------------------------|---------------------------|---------------------------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-07) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | CLRPEND<br>(Interrupt 99) | CLRPEND<br>(Interrupt 98) | CLRPEND<br>(Interrupt 97) | CLRPEND<br>(Interrupt 96) | | After reset | 0 | 0 | 0 | 0 | Undefined | Undefined | Undefined | Undefined | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | - | R | Read as 0, | | 3-0 | CLRPEND | R/W | Interrupt number [99:96] [Write] 1: Clear pending interrupt [Read] 0: Not pending 1: Pending Each bit corresponds to the specified number can force interrupts into the pending state and determines which interrupts are currently pending. Writing "1" to a bit in this register clears the corresponding pending interrupt. However, writing "1" has no effect on an interrupt that is already being serviced. Writing "0" has no effect. Reading the bit returns the current state of the corresponding interrupts. | Note: For descriptions of interrupts and interrupt numbers, see Section "7.5.1.5 List of Interrupt Sources". ### 7.6.2.21 Interrupt Priority Register Each interrupt is provided with eight bits of an Interrupt Priority Register. The following shows the addresses of the Interrupt Priority Registers corresponding to interrupt numbers. | | 31 24 | 23 16 | 15 8 | 7 ) | |-------------|--------|----------|-------------|--------| | 0xE000_E400 | PRI_3 | PRI_2 | PRI_1 | PRI_0 | | 0xE000_E404 | PRI_7 | PRI_6 | PRI_5 | PRI_4 | | 0xE000_E408 | PRI_11 | PRI_10 | PRI_9 | PRI_8 | | 0xE000_E40C | PRI_15 | PRI_14 | PRI_13 | PRI_12 | | 0xE000_E410 | PRI_19 | PRI_18 | PRI_17 | PRI_16 | | 0xE000_E414 | PRI_23 | PRI_22 | PRI_21 | PRI_20 | | 0xE000_E418 | PRI_27 | PRI_26 | PRI_25 | PRI_24 | | 0xE000_E41C | PRI_31 | PRI_30 / | PRI_29 | PRI_28 | | 0xE000_E420 | PRI_35 | PRI_34 | PRI_33 🔷 | PRI_32 | | 0xE000_E424 | PRI_39 | PRI_38 | PRI_37 | PRI_36 | | 0xE000_E428 | PRI_43 | PRI_42 | PRI_41 | PRI_40 | | 0xE000_E42C | PRI_47 | PRI_46 | PRI_45 | PRI_44 | | 0xE000_E430 | PRI_51 | PRI_50 | PRI_49 | PRI_48 | | 0xE000_E434 | PRI_55 | PRI_54 | PRI_53 // 🔷 | PRI_52 | | 0xE000_E438 | PRI_59 | PRI_58 | -(0) | - | | 0xE000_E43C | PRI_63 | PRI_62 | PRI_61 | PRI_60 | | 0xE000_E440 | PRI_67 | PRI_66 | PRI_65 | PRI_64 | | 0xE000_E444 | PRI_71 | PRI_70 | PRI_69 | PRI_68 | | 0xE000_E448 | PRI_75 | PRI_74 | PRI_73 | PRI_72 | | 0xE000_E44C | - (( | | PRI_77 | PRI_76 | | 0xE000_E450 | PRI_83 | PRI_82 | PRI_81 | PRI_80 | | 0xE000_E454 | PRI_87 | PRI_86 | PRI_85 | PRI_84 | | 0xE000_E458 | PRL91 | PRI_90 | PRI_89 | PRI_88 | | 0xE000_E45C | PRI_95 | PRI_94 | PRI_93 | PRI_92 | | 0xE000_E460 | PRI_99 | PRI_98 | PRI_97 | PRI_96 | The number of bits to be used for assigning a priority varies with each product. This product uses three bits for assigning a priority. The following shows the fields of the Interrupt Priority Registers for interrupt numbers 0 to 3. The Interrupt Priority Registers for all other interrupt numbers have the identical fields. Unused bits return "0" when read, and writing to unused bits has no effect. Page 105 2023/07/21 | | | | _ | |-----|-------------|-------------------|-----------| | 7.6 | Exception / | Interrupt-Related | Registers | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|----|----|----|------------------------------------------|----|----| | bit symbol | | PRI_3 | | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 🔨 | 17 | 16 | | bit symbol | | PRI_2 | | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | | 8 | | bit symbol | | PRI_1 | | - | - | (7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | \ \\ \( \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | PRI_0 | | _ | - | (( )) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|--------------------------------| | 31-29 | PRI_3 | R/W | Priority of interrupt number 3 | | 28-24 | _ | R | Read as 0. | | 23-21 | PRI_2 | R/W | Priority of interrupt number 2 | | 20-16 | _ | R | Read as 0. | | 15-13 | PRI_1 | R/W | Priority of interrupt number 1 | | 12-8 | _ | R | Read as 0. | | 7-5 | PRI_0 | R/W | Priority of interrupt number 0 | | 4-0 | _ | R | Read as 0. | 2023/07/21 Page 106 ## 7.6.2.22 Vector Table Offset Register | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|--------|----|---------|-----|-----|--------|--------------|----| | bit symbol | - | - | TBLBASE | | | TBLOFF | 2 | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>1</b> 77 | 16 | | bit symbol | | | | TBL | OFF | (0) | ^ | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | TBL | OFF | (( ))> | | | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | TBLOFF | - | - | - | | - | <b>⊘-</b> // | - | | After reset | 0 | 0 | 0 | 0 | (0/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | _ | R | Read as 0, | | 29 | TBLBASE | R/W | Table base The vector table is in: 0: Code space 1: SRAM space | | 28-7 | TBLOFF | R/W | Offset value Set the offset value from the top of the space specified in TBLBASE. The offset must be aligned based on the number of exceptions in the table. This means that the minimum alignment is 32 words that you can use for up to 16 interrupts. For more interrupts, you must adjust the alignment by rounding up to the next power of two. | | 6-0 | _ | R | Read as 0. | Page 107 2023/07/21 ### 7.6.2.23 Application Interrupt and Reset Control Register | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | |-------------|-----------|---------------------|----|------------|-----------|-----------------|-------------------|-----------|--|--|--|--| | bit symbol | | VECTKEY/VECTKEYSTAT | | | | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | | | | | bit symbol | | | | VECTKEY/VE | CTKEYSTAT | (0) | 1 | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | bit symbol | ENDIANESS | - | - | - | - | (( )) | PRIGROUP | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | | | | | bit symbol | - | - | - | - | | SYSRESET<br>REQ | VECTCLR<br>ACTIVE | VECTRESET | | | | | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | | | | Bit | Bit Symbol | Туре | Function | |-------|----------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | VECTKEY (Written) / VECTKEYSTAT (Read) | R/W | Register key [Write] Writing to this register requires 0x5FA in the <vectkey> field. [Read] Read as 0xFA05.</vectkey> | | 15 | ENDIANESS | R/W | Endianness bit: (Note1) 1: Big endian 0: Little endian | | 14-11 | _ | R | Read as 0, | | 10-8 | PRIGROUP | RW | Interrupt priority grouping 000: seven bits of pre-emption priority, one bit of subpriority 001: six bits of pre-emption priority, two bits of subpriority 010: five bits of pre-emption priority, three bits of subpriority 011: four bits of pre-emption priority, four bits of subpriority 100: three bits of pre-emption priority, six bits of subpriority 101: two bits of pre-emption priority, six bits of subpriority 110: one bit of pre-emption priority, seven bits of subpriority 111: no pre-emption priority, eight bits of subpriority The bit configuration to split the interrupt priority register <pri_n> into pre-emption priority and sub priority.</pri_n> | | 7-3 | - | R | Read as 0, | | 2 < | SYSRESET<br>REQ | R/W | System Reset Request 1=CPU outputs a SYSRESETREQ signal. (note2) | | 1 | VECTCLR<br>ACTIVE | R/W ( | Clear active vector bit 1: clear all state information for active NMI, fault, and interrupts. 0: do not clear. This bit self-clears. It it the responsibility of the application to reinitialize the stack. | | 0 | VECTRESET | R/W | System Reset bit 1: reset system. 0: do not reset system. Resets the system, with the exception of debug components (FPB, DWT and ITM) by setting "1" and this bit is also zero cleared. | Note 1: Little-endian is the default memory format for this product. Note 2: When SYSRESETREQ is output, warm reset is performed on this product. <SYSRESETREQ> is cleared by warm reset. Page 108 2023/07/21 ### 7.6.2.24 System Handler Priority Register Each exception is provided with eight bits of a System Handler Priority Register. The following shows the addresses of the System Handler Priority Registers corresponding to each exception. | | 31 24 | 23 16 | 15 8/ | 7 0 | |-------------|-----------|---------------|-------------|---------------------| | 0xE000 ED18 | PRI_7 | PRI_6 | PRI_5 | PRI_4 | | 0XE000_ED16 | | (Usage Fault) | (Bus Fault) | (Memory Management) | | 0E000 ED40 | PRI_11 | PRI_10 | PRI_9 (// | PRI_8 | | 0xE000_ED1C | (SVCall) | | | 7) | | 0 F000 FD00 | PRI_15 | PRI_14 | PRI_13 | PRI_12 | | 0xE000_ED20 | (SysTick) | (PendSV) | (( )) | (Debug Monitor) | The number of bits to be used for assigning a priority varies with each product. This product uses three bits for assigning a priority. The following shows the fields of the System Handler Priority Registers for Memory Management, Bus Fault and Usage Fault. Unused bits return "0" when read, and writing to unused bits has no effect. | | 31 | 30 | 29 | 28 | 27 | 26 | )) 25 | 24 | |-------------|-----|-------|------|-------|---------------|--------------------|-------|----| | bit symbol | | PRI_7 | | | - | (0-7) | - | - | | After reset | 0 | 0 | 0 | | 0 | (V <sub>0</sub> )) | 0 | 0 | | | 23 | 22 | 21 < | 20 | /19 | 18 | 17 | 16 | | bit symbol | | PRI_6 | | | | - | - | - | | After reset | 0 | 0 | 0 ( | 0 | 0 | // 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | PRI_5 | | - | \\ - | - | - | - | | After reset | 0 | 0 | 9 | 0 | 79 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 < | 3 | 2 | 1 | 0 | | bit symbol | | PRI_4 | | | $\rightarrow$ | - | - | - | | After reset | 0 / | / )0 | 0 < | (6/// | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Type | Function | |-------|------------|------|-------------------------------| | 31-29 | PRI_7 | R/W | Reserved | | 28-24 | - | R | Read as 0, | | 23-21 | PRI_6 | R/W | Priority of Usage Fault | | 20-16 | - (( ) | R | Read as 0, | | 15-13 | PRI_5 | R/W | Priority of Bus Fault | | 12-8 | - | R ( | Read as 0, | | 7-5 | PRI_4 | R/W | Priority of Memory Management | | 4-0 | 7 | R | Read as 0, | ### . ## 7.6.2.25 System Handler Control and State Register | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|------------------|--------------------|--------------------|--------------------|-----------------|-----------------|-----------------|-----------------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - < | USGFAULT<br>ENA | BUSFAULT<br>ENA | MEMFAULT<br>ENA | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | SVCALL<br>PENDED | BUSFAULT<br>PENDED | MEMFAULT<br>PENDED | USGFAULT<br>PENDED | SYSTICKACT | PENDSVACT | -(( | MONITOR<br>ACT | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | (3) | 2 | 4 | 0 | | bit symbol | SVCALLACT | - | - | - ( | USGFAULT<br>ACT | | BUSFAULT<br>ACT | MEMFAULT<br>ACT | | After reset | 0 | 0 | 0 | 0 / | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|--------------------|------|---------------------------------| | 31-19 | - | R | Read as 0, | | 18 | USGFAULT | R/W | Usage Fault | | | ENA | | 0: Disabled | | | | | 1: Enabled | | 17 | BUSFAUL | R/W | Bus Fault | | | TENA | | 0: Disable | | | | | 1: Enable | | 16 | MEMFAULT | R/W | Memory Management | | | ENA | | 0: Disable | | | | | 1: Enable | | 15 | SVCALL | R/W | SVCall | | | PENDED ( | | 0. Not pended | | | | | 1: Pended | | 14 | BUSFAULT | R/W | Bus Fault | | | PENDED | | 0: Not pended<br>1: Pended | | | | | | | 13 | MEMFAULT<br>PENDED | R/W | Memory Management 0: Not pended | | | PENDED | | 1: Pended | | 12 | USGFAULT | R/W | Usage Fault | | 12 | PENDED | 1000 | 0: Not pended | | < | | ( | 1: Pended | | 11 | SYSTICKACT | R/W | SysTick | | | | | 0: Inactive | | | | | 1: Active | | 10 | PENDSVACT | R/W | PendSV | | | | | 0: Inactive | | | | | 1: Active | | 9 | - | R | Read as 0, | | 8 | MONITORACT | R/W | Debug monitor | | | | | 0: Inactive | | | | | 1: Active | | 7 | SVCALLACT | R/W | SVCall | | | | | 0: Inactive | | | | | 1: Active | | 6-4 | - | R | Read as 0, | 2023/07/21 Page 110 | Bit | Bit Symbol | Туре | Function | |-----|------------|------|-------------------| | 3 | USGFAULT | R/W | Usage Fault | | | ACT | | 0: Inactive | | | | | 1: Active | | 2 | _ | R | Read as 0, | | 1 | BUSFAULT | R/W | Bus Fault | | | ACT | | 0: Inactive | | | | | 1: Active | | 0 | MEMFAULT | R/W | Memory management | | | ACT | | 0: Inactive | | | | | 1: Active | Page 111 2023/07/21 # 7.6.3 Clock generator registers ## 7.6.3.1 CGIMCGA (CG Interrupt Mode Control Register A) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|-------|----|---------|-----|-----------|--------| | bit symbol | - | | EMCG3 | | EM | ST3 | 1 | INT3EN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | | EMCG2 | | EM | ST2 | ) - | INT2EN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | EMCG1 | - | EM | ST1 | | INT1EN | | After reset | 0 | 0 | 1 | 0 | 9( | 0 | Undefined | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 21 | 0 | | bit symbol | - | | EMCG0 | | ( // EM | ST0 | | INT0EN | | After reset | 0 | 0 | 1 | 0 | | 0 | Undefined | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|--------|-------------------------------------------------------------------------------------------------------| | 31 | - | R | Read as 0, | | 30-28 | EMCG3[2:0] | R/W | active level setting of INT3 standby clear request. (101 to 111: setting prohibited) 000: "Low" level | | | | | 001: "High" level 010: Falling edge | | | | | 011: Rising edge 100: Both edge | | 27-26 | EMST3[1:0] | R | active level of INT3 standby clear request 00: - 01: Rising edge | | | | | 10: Falling edge 11: Both edge | | 25 | - | R | Reads as undefined. | | 24 | INT3EN < | R/W | INT3 clear input | | | | \\\\\. | 0: Disable | | | | | 1: Enable | | 23 | - | R | Read as 0, | | 22-20 | EMCG2[2:0] | R/W | active level setting of INT2 standby clear request. (101 to 111: setting prohibited) | | | | | 000: "Low" level | | | | \ | 001: "High" level 010: Falling edge | | | | ) | 011: Rising edge | | | | 1 / | 100: Both edge | | 19-18 | EMST2[1:0] | R | active level of INT2 standby clear request | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | _ | 11: Both edge | | 17 | - | R | Reads as undefined. | | 16 | INT2EN | R/W | INT2 clear input | | | | | 0:Disable | | 45 | | _ | 1: Enable | | 15 | - | R | Read as 0, | 2023/07/21 Page 112 | Bit | Bit Symbol | Туре | Function | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14-12 | EMCG1[2:0] | R/W | active level setting of INT1 standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge 100: Both edge | | 11-10 | EMST1[1:0] | R | active level of INT1 standby clear request 00: - 01: Rising edge 10: Falling edge 11: Both edge | | 9 | - | R | Reads as undefined. | | 8 | INT1EN | R/W | INT1 clear input 0: Disable 1: Enable | | 7 | _ | R | Read as 0, | | 6-4 | EMCG0[2:0] | R/W | active level setting of INT0 standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge 100: Both edge | | 3-2 | EMST0[1:0] | R | active level of INT0 standby clear request 00: - 01: Rising edge 10: Falling edge 11: Both edge | | 1 | _ | R | Reads as undefined. | | 0 | INT0EN | R/W | INTO clear input 0: Disable 1: Enable | Note 1: <EMSTx> is effective only when <EMCGx[2:0]> is set to "100" for both rising and falling edge. The active level used for the reset of standby can be checked by referring <EMSTx>. If interrupts are cleared with the CGICRCG register, <EMSTx> is also cleared. Note 2: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is pro- Page 113 2023/07/21 ### CGIMCGB (CG Interrupt Mode Control Register B) 7.6.3.2 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|-------|----|----|-----|-----------|--------| | bit symbol | - | | EMCG7 | | EM | ST7 | - | INT7EN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 _ | Undefined | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | | EMCG6 | | EM | ST6 | | INT6EN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 15 | 14 | 13 | 12 | 11 | 197 | 9 | 8 | | bit symbol | - | | EMCG5 | | ÉM | ST5 | ) - | INT5EN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | | EMCG4 | | EM | ST4 | - | INT4EN | | After reset | 0 | 0 | 1 | 0 | 0/ | 0 | Undefined | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | | R | Read as 0, | | 30-28 | EMCG7[2:0] | R/W | active level setting of INT7 standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge | | 27-26 | EMST7[1:0] | R | 100: Both edge active level of INT7 standby clear request 00: - 01: Rising edge 10: Falling/edge | | | | | 11: Both edge | | 25 | - | R | Reads as undefined. | | 24 | INT7EN | R/W | INT7 cléar input 0: Disable 1: Enable | | 23 | - | R | Read as 0, | | 22-20 | EMCG6[2:0] | R/W | active level setting of INT6 standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge 100: Both edge | | 19-18 | EMST6[1:0] | R ( | active level of INT6 standby clear request 00: - 01; Rising edge 10: Falling edge 11: Both edge | | 17 | - | R | Reads as undefined. | | 16 | INT6EN | R/W | INT6 clear input 0:Disable 1: Enable | | 15 | - | R | Read as 0, | | 14-12 | EMCG5[2:0] | R/W | active level setting of INT5 standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge | | | | | 100: Both edge | Page 114 2023/07/21 | Bit | Bit Symbol | Туре | Function | |-------|------------|------|--------------------------------------------------------------------------------------| | 11-10 | EMST5[1:0] | R | active level of INT5 standby clear request | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 9 | - | R | Reads as undefined. | | 8 | INT5EN | R/W | INT5 clear input | | | | | 0: Disable | | | | | 1: Enable | | 7 | - | R | Read as 0, | | 6-4 | EMCG4[2:0] | R/W | active level setting of INT4 standby clear request. (101 to 111: setting prohibited) | | | | | 000: "Low" level | | | | | 001: "High" level | | | | | 010: Falling edge | | | | | 011: Rising edge | | | | | 100: Both edge | | 3-2 | EMST4[1:0] | R | active level of INT4 standby clear request | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 1 | - | R | Reads as undefined. | | 0 | INT4EN | R/W | INT4 clear input | | | | | 0: Disable | | | | | 1: Enable | Note 1: <EMSTx> is effective only when <EMCGx[2:0]> is set to "100" for both rising and falling edge. The active level used for the reset of standby can be checked by referring <EMSTx>. If interrupts are cleared with the CGICRCG register, <EMSTx> is also cleared. Note 2: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is pro- Page 115 2023/07/21 ### 7.6.3.3 CGIMCGC (CG Interrupt Mode Control Register C) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|-------|----|----|-------|-----------|--------| | bit symbol | - | | EMCGB | | EM | STB | - | INTBEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 _ | Undefined | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | | EMCGA | | EM | STA ( | | INTAEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 15 | 14 | 13 | 12 | 11 | 197 | 9 | 8 | | bit symbol | - | | EMCG9 | | ÉM | ST9 | ) - | INT9EN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | | EMCG8 | | EM | ST8 | - | INT8EN | | After reset | 0 | 0 | 1 | 0 | 0/ | 0 | Undefined | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | _ | R | Read as 0, | | 30-28 | EMCGB[2:0] | R/W | active level setting of INTB standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge | | | | | 011: Rising edge<br>100: Both edge | | 27-26 | EMSTB[1:0] | R | active level of INTB standby clear request 00: - 01: Rising edge 10: Falling edge 11: Both edge | | 25 | - | R | Reads as undefined. | | 24 | INTBEN | R/W | INTB clear input 0; Disable 1: Enable | | 23 | - | R | Read as 0, | | 22-20 | EMCGA[2:0] | R/W | active level setting of INTA standby clear request. (101 to 111: setting prohibited) 000: "Low" level | | | | <b>S</b> | 001: "High" level 010: Falling edge 011: Rising edge 100: Both edge | | 19-18 | EMSTA[1:0] | ) R ( | active level of INTA standby clear request 00: - 01; Rising edge 10: Falling edge 11: Both edge | | 17 | - | R | Reads as undefined. | | 16 | INTAEN | R/W | INTA clear input 0:Disable 1: Enable | | 15 | _ | R | Read as 0, | | 14-12 | EMCG9[2:0] | R/W | active level setting of INT9 standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge | | | | | 100: Both edge | Page 116 2023/07/21 | Bit | Bit Symbol | Туре | Function | |-------|------------|------|--------------------------------------------------------------------------------------| | 11-10 | EMST9[1:0] | R | active level of INT9 standby clear request | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 9 | - | R | Reads as undefined. | | 8 | INT9EN | R/W | INT9 clear input | | | | | 0: Disable | | | | | 1: Enable | | 7 | _ | R | Read as 0, | | 6-4 | EMCG8[2:0] | R/W | active level setting of INT8 standby clear request. (101 to 111: setting prohibited) | | | | | 000: "Low" level | | | | | 001: "High" level | | | | | 010: Falling edge | | | | | 011: Rising edge | | | | | 100: Both edge | | 3-2 | EMST8[1:0] | R | active level of INT8 standby clear request | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | _ | 11: Both edge | | 1 | - | R | Reads as undefined. | | 0 | INT8EN | R/W | INT8 clear input | | | | | 0: Disable | | | | | 1: Enable | Note 1: <EMSTx> is effective only when <EMCGx[2:0]> is set to "100" for both rising and falling edge. The active level used for the reset of standby can be checked by referring <EMSTx>. If interrupts are cleared with the CGICRCG register, <EMSTx> is also cleared. Note 2: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is pro- Page 117 2023/07/21 ### 7.6.3.4 CGIMCGD (CG Interrupt Mode Control Register D) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|-------|----|----|--------|-----------|--------| | bit symbol | - | | EMCGF | | EM | STF | - | INTFEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 _ | Undefined | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | | EMCGE | | EM | STE (( | | INTEEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | EMCGD | | EM | STD | ) - | INTDEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | | EMCGC | | EM | STC | - | INTCEN | | After reset | 0 | 0 | 1 | 0 | 0/ | 0 | Undefined | 0 | | Bit Symbol | Туре | Function | |------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | - | R | Read as 0, | | EMCGF[2:0] | R/W | active level setting of INTF standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge | | EMSTF[1:0] | R | 100: Both edge active level of INTF standby clear request 00: - 01: Rising edge 10: Falling edge 11: Both edge | | _ | R | Reads as undefined. | | INTFEN | R/W | INTF clear input 0; Disable 1: Enable | | - | R | Read as 0, | | EMCGE[2:0] | R/W | active level setting of INTE standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge 100: Both edge | | EMSTE[1:0] | R ( | active level of INTE standby clear request 00: - 01; Rising edge 10: Falling edge 11: Both edge | | - | R | Reads as undefined. | | INTEEN | R/W | INTE clear input 0: Disable 1: Enable | | _ | R | Read as 0, | | EMCGD[2:0] | R/W | active level setting of INTD standby clear request. (101 to 111: setting prohibited) 000: "Low" level 001: "High" level 010: Falling edge 011: Rising edge | | | - EMCGF[2:0] EMSTF[1:0] - INTFEN - EMCGE[2:0] EMSTE[1:0] - INTEEN | - R EMCGF[2:0] R/W EMSTF[1:0] R - R INTFEN R/W - R EMCGE[2:0] R/W - R INTEEN R/W | Page 118 2023/07/21 | Bit | Bit Symbol | Туре | Function | |-------|------------|------|--------------------------------------------------------------------------------------| | 11-10 | EMSTD[1:0] | R | active level of INTD standby clear request | | | | | 00: – | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 9 | - | R | Reads as undefined. | | 8 | INTDEN | R/W | INTD clear input | | | | | 0: Disable | | | | | 1: Enable | | 7 | - | R | Read as 0, | | 6-4 | EMCGC[2:0] | R/W | active level setting of INTC standby clear request. (101 to 111: setting prohibited) | | | | | 000: "Low" level | | | | | 001: "High" level | | | | | 010: Falling edge | | | | | 011: Rising edge | | | | | 100: Both edge | | 3-2 | EMSTC[1:0] | R | active level of INTC standby clear request | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 1 | - | R | Reads as undefined. | | 0 | INTCEN | R/W | INTC clear input | | | | | 0: Disable | | | | | 1: Enable | Note 1: <EMSTx> is effective only when <EMCGx[2:0]> is set to "100" for both rising and falling edge. The active level used for the reset of standby can be checked by referring <EMSTx>. If interrupts are cleared with the CGICRCG register, <EMSTx> is also cleared. Note 2: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is pro- Page 119 2023/07/21 #### CGIMCGE (CG Interrupt Mode Control Register E) 7.6.3.5 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|-------|----|----|---------|-----------|--------| | bit symbol | - | | EMCGJ | | EM | EMSTJ | | INTJEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 _ | Undefined | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | | EMCGI | | EM | ISTI (( | | INTIEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | | EMCGH | | EM | STH | ) - | INTHEN | | After reset | 0 | 0 | 1 | 0 | 0 | | Undefined | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | EMCGG | | | EM | STG | - | INTGEN | | After reset | 0 | 0 | 1 | 0 | 0/ | 0 | Undefined | 0 | | | | | $(\vee)$ | |-------|-----------------|------|----------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31 | _ | R | Read as 0, | | 30-28 | EMCGJ[2:0] | R/W | active level setting of INTRMCRX1 standby clear request. | | | | | Set it as shown below. | | | | | 011: Rising edge | | 27-26 | EMSTJ[1:0] | R | R active level of INTRMCRX1 standby clear request. | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 25 | _ | R | Read as undefined. | | 24 | INTJEN | R/W | INTRMCRX1 clear input | | | | | 0:Disable | | | | | 1: Enable | | 23 | _ | R | Read as 0, | | 22-20 | EMCGI[2:0] | R/W | active level setting of INTRMCRX0 standby clear request. | | | < | | Set it as shown below. | | | | | 011: Rising edge | | 19-18 | EMSTI[1:0] | R | R active level of INTRMCRX0 standby clear request. | | | $\wedge \wedge$ | | 00: - | | | >,< | | 01: Rising edge | | | | | 10: Falling edge | | | | | | | 17 | - (( ) | R | Read as undefined. | | 16 | INTIEN | R/W | INTRMCRX0 clear input | | | | ( | (0:Disable | | | | _ | 1; Enable | | 15 | - | R | Read as 0, | | 14-12 | EMCGH[2:0] | R/W | active level setting of INTCECTX standby clear request. | | | | | Set it as shown below. | | 44.40 | E140E144 01 | | 011: Riseing edge | | 11-10 | EMSTH[1:0] | R | active level of INTCECTX standby clear request. | | | | | 00: - 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 9 | _ | R | Read as undefined | | 8 | INTHEN | R/W | INTCECTX Clear input | | - | - | | 0:Disable | | 1 | | | 1: Enable | | | | | | Page 120 2023/07/21 | Bit | Bit Symbol | Туре | Function | |-----|------------|------|----------------------------------------------------------------------------------------------------------| | 7 | - | R | Read as 0, | | 6-4 | EMCGG[2:0] | R/W | active level setting of INTCECRX standby clear request. Set it as shown below. 011: Rising edge | | 3-2 | EMSTG[1:0] | R | active level of INTCECRX standby clear request. 00: - 01: Rising edge 10: Falling edge 11: Both edge | | 1 | - | R | Read as undefined. | | 0 | INTGEN | R/W | INTCECRX Clear input 0:Disable 1: Enable | Note 1: <EMSTx> is effective only when <EMCGx[2:0]> is set to "100" for both rising and falling edge. The active level used for the reset of standby can be checked by referring <EMSTx>. If interrupts are cleared with the CGICRCG register, <EMSTx> is also cleared. Page 121 2023/07/21 #### 7.6.3.6 CGIMCGF (CG Interrupt Mode Control Register F) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|-------|----|----|-------|-----------|--------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 _ | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | 1 | | EMCGL | | EM | STL | ) - | INTLEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | | EMCGK | | EM | STK | - | INTKEN | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | Undefined | 0 | | | * | | $(\checkmark)$ | |-------|------------|------|-------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-15 | _ | R | Read as 0, | | 14-12 | EMCGL[2:0] | R/W | active level setting of INTKWUP standby clear request | | | | | Set it as shown below. | | | | | 001: "H" level | | 11-10 | EMSTL[1:0] | R | active level of INTKWUP standby clear request | | | | | 00: - | | | | | 01: Rising edge | | | | | 10: Falling edge | | | | | 11: Both edge | | 9 | - | R | Read as undefined. | | 8 | INTLEN | R/W | INTKWUP clear input | | | | | 0: Disable | | - | | | 1: Enable | | 7 | _ | R | Read as 0, | | 6-4 | EMCGK[2:0] | R/W | active level setting of INTRTC standby clear request | | | < | | Set it as shown below. | | | | 1 | 010: Falling edge | | 3-2 | EMSTK[1:0] | R | active level of INTRTC standby clear request | | | \ \ \ \ \ | | 00: - | | | | | 01: Rising edge | | | | ( | 10: Falling edge | | | | | 11: Both edge | | 1 ( | - (( ) | R | Read as undefined. | | 0 | INTKEN | R/W | INTRTC clear input | | (= | | ( | (0: Disable | | | | | 1. Enable | Note 1: <EMSTx> is effective only when <EMCGx[2:0]> is set to "100" for both rising and falling edge. The active level used for the reset of standby can be checked by referring <EMSTx>. If interrupts are cleared with the CGICRCG register, <EMSTx> is also cleared. Note 2: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is pro- Page 122 2023/07/21 # 7.6.3.7 CGICRCG (CG Interrupt Request Clear Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-----|-------|-----|----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 _ | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | - < | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | | | ICRCG | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------| | 31-5 | - | R | Read as 0, | | 4-0 | ICRCG[4:0] | w | Clear interrupt requests. 0_0000:INT0 | | | | | Read as 0. | #### CGNMIFLG (NMI Flag Register) 7.6.3.8 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-------|---------|------------|---------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | S | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | 1 | | - | NMIFLG1 | NMIFLG0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------| | 31-2 | - | R | Read as 0, | | 1 | NMIFLG1 | R | NMI source generation flag 0: not applicable 1:generated from NMI pin. | | 0 | NMIFLG0 | R | NMI source generation flag 0: not applicable 1: generated from WDT | #### 7.6.3.9 CGRSTFLG (Reset Flag Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-----------------|----|----|----|---------|---------|----------------------------------------|---------|---------| | bit symbol | - | - | - | - | - | - / | - | - | | After pin reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 9 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | (0) | | - | | After pin reset | 0 | 0 | 0 | 0 | 0 | \\\(\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | ( )} | - | - | | After pin reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | (3) | 2 | 1 | 0 | | bit symbol | - | - | 1 | SYSRSTF | BUPRSTF | WDTRSTF | PINRSTF | PONRSTF | | After pin reset | 0 | 0 | 0 | 0 | (//0 | 0 | | 1 | | Bit | Bit Symbol | Туре | Function | |------|------------|-------|-----------------------------------| | 31-5 | _ | R | Read as 0, | | 4 | SYSRSTF | R/W | Debug reset flag (Note1) | | | | | 0: "0" is written | | | | | 1: Reset from SYSRESETREQ | | 3 | BUPRSTF | R/W | BACKUP reset flag | | | | | 0: "0" is written | | | | | 1: Reset from BACKUP mode release | | 2 | WDTRSTF | R/W | WDT reset flag | | | WDIKSIF | IK/VV | | | | | | 0: "0" is written | | | | | 1: Reset from WDT | | 1 | PINRSTF | R/W | RESET pin flag | | | | | 0: "0" is written | | | | | 11: Reset from RESET pin | | 0 | PONRSTF | R/W | Power-on flag | | | | | 0: "0" is written | | | | | 1: Reset from power-on reset | Note 1: This flag indicates a reset generated by the SYSRESETREQ bit of the Application Interrupt and Reset Control Register of the CPU's NVIC. Note 2: This product has power-on reset circuit and this register is initialized only by power-on reset. Therefore, "1" is set to the <PONRSTF> bit in initial reset state right after power-on. Note that this bit is not set by the second and subsequent resets and this register is not cleared automatically. Write "0" to clear the register. Page 125 2023/07/21 TMPM362F10FG # 8. Input / Output Ports ### 8.1 Port Functions #### 8.1.1 Function list TMPM362F10FG has 120 ports. Besides the ports function, these ports can be used as I/O pins for peripheral functions. Table 8-1 shows the port function table. Table 8-1 Port Function List | | | Input / | Program-<br>mable Pull- | Schmitt | Noise | Program- | | |---------------|-----|------------|-------------------------|-----------------------------------------------|------------|---------------------|----------------------| | Port | Pln | Output | up<br>Pull-down | Input | Filter | mable<br>Open-drain | Function pin | | Port A | | | | | | | | | | PA0 | I/O | Pull-up | - ( | - | 0 | D0 / AD0 | | | PA1 | I/O | Pull-up | - </td <td></td> <td>0</td> <td>D1 / AD1</td> | | 0 | D1 / AD1 | | | PA2 | I/O | Pull-up | | <b>\_</b> | 0 ( | D2 / AD2 | | | PA3 | I/O | Pull-up | | - | · (V | D3 / AD3 | | | PA4 | I/O | Pull-up | ( - ) | -// | 0 | D4 / AD4 | | | PA5 | I/O | Pull-up | | - | 0 | D5 / AD5 | | | PA6 | I/O | Pull-up | ))- | - | 0// | D6 / AD6 | | | PA7 | I/O | Pull-up | <i>-</i> | | 0 | D7 / AD7 | | Port B | | ( | ((5) | | | | | | | PB0 | 1/0 | Pull-up | - | (E) | 0 | D8 / AD8 | | | PB1 | 10// | Pull-up | - < | 77/ | 0 | D9 / AD9 | | | PB2 | 1/0 | Pull-up | -(7 | 7^- | 0 | D10 / AD10 | | | PB3 | 1/0 | Pull-up | / - // | <i>))-</i> | 0 | D11 / AD11 | | | PB4 | 1/0 | Pull-up | 1- | - | 0 | D12 / AD12 | | | PB5 | 1/0 | Pull-up | $\overline{}$ | - | 0 | D13 / AD13 | | | PB6 | I/O | Pull-up | \ <u>\</u> - | - | 0 | D14 / AD14 | | | PB7 | I/O | Pull-up | _ | - | 0 | D15 / AD15 | | Port C | | | d | | | | | | | PC0 | 1/0 | Pull-up | 0 | - | О | A1 , TXD8 | | | PC1 | /> I/O ( ( | Pull-up | 0 | - | 0 | A2 , RXD8 | | $\overline{}$ | PC2 | 110 | Pull-up | 0 | - | 0 | A3 , SCLK8 , CTS8 | | | PC3 | 1/0 | Pull-up | 0 | - | 0 | A4 | | | PC4 | I/O | Pull-up | 0 | - | 0 | A5 , TXD9 | | | PC5 | I/O | Pull-up | 0 | - | 0 | A6 , RXD9 | | | PC6 | I/O | Pull-up | 0 | - | 0 | A7 , SCLK9 , CTS9 | | | PC7 | I/O | Pull-up | 0 | - | 0 | A8 | | Port D | | <u>'</u> | <u>'</u> | | | • | | | | PD0 | I/O | Pull-up | 0 | - | 0 | A9 , TXD10 | | | PD1 | I/O | Pull-up | 0 | - | 0 | A10 , RXD10 | | | PD2 | I/O | Pull-up | 0 | _ | 0 | A11 , SCLK10 , CTS10 | | | PD3 | I/O | Pull-up | 0 | - | 0 | A12 | | | PD4 | I/O | Pull-up | 0 | _ | 0 | A13 , TXD11 | Page 127 2023/07/21 Table 8-1 Port Function List | Port | Pln | Input /<br>Output | Program-<br>mable Pull-<br>up<br>Pull-down | Schmitt<br>Input | Noise<br>Filter | Program-<br>mable<br>Open-drain | Function pin | |--------|-------------|-------------------|--------------------------------------------|------------------|-----------------|---------------------------------|----------------------| | | PD5 | I/O | Pull-up | 0 | - | О | A14 , RXD11 | | | PD6 | I/O | Pull-up | 0 | _ | 0 | A15 , SCLK11 , CTS11 | | | PD7 | I/O | Pull-up | 0 | o(INTB only) | 0 | A16 , INTB | | Port E | | | | | | ^ | $(7/\land)$ | | | PE0 | I/O | Pull-up | 0 | _ | 0 | A17 , TB5IN0 | | | PE1 | I/O | Pull-up | 0 | - | 6 | A18 , TB5IN1 | | | PE2 | I/O | Pull-up | 0 | - | 0 | A19 , TB6IN0 | | | PE3 | I/O | Pull-up | 0 | - , | 0 | A20 , TB6IN1 | | | PE4 | I/O | Pull-up | 0 | - | 0 | A21 , TXD0 | | | PE5 | I/O | Pull-up | 0 | 10 | 700 | A22 , RXD0 | | | PE6 | I/O | Pull-up | 0 | -// | <i>)</i> | A23 , SCLK0 , CTS0 | | | PE7 | I/O | Pull-up | 0 | o(INT5 only) | 0 | INT5 , SCOUT | | Port F | | | | | | | | | | PF0 | I/O | Pull-up | 0 | 7 | О | TRACECLK | | | PF1 | I/O | Pull-up | 0 | <b>\</b> - | 0 ( | TRACEDATA0 , SWV | | | PF2 | I/O | Pull-up | | \ \ - | | TRACEDATA1 | | | PF3 | I/O | Pull-up | ( ) | -// | 0 | TRACEDATA2 | | | PF4 | I/O | Pull-up | 0 | -<< | 0 | TRACEDATA3 | | Port G | | | | )) <u> </u> | | | <u>'</u> | | | PG0 | I/O | Pull-up | <i>O</i> • | _ | 0 | SDA1/ SO1, TB7IN0 | | | PG1 | I/O | Pull-up | 0 | / | 0 | SCL1/ SI1, TB7IN1 | | | PG2 | I/O | Pull-up | 0 | (b-7) | 0 | SCK1, CS0 | | | PG3 | 1/0// | Pull-up | 0 | o(INT6 only) | 0 | INT6, CS1 | | | PG4 | 1/0 | Pull-up | 0 | 7^- | 0 | SDA2/ SO2 , TB9IN0 | | | PG5 | 1/0 | Pull-up | 0 | ( ) )- | 0 | SCL2/ SI2 , TB9IN1 | | | PG6 | 1/0 | Pull-up | 0 | - | 0 | SCK2, CS3 | | | PG7 | 1//0 | Pull-up | 0 | o(INT7 only) | 0 | INT7 , WDTOUT | | Port H | $\sim \sim$ | | | | • | <u> </u> | | | | PHQ ) | I/O | Pull-up | o | _ | О | SDA3/ SO3 , TBAIN0 | | | RH1 | I/O | Pull-up | 0 | - | 0 | SCL3/ SI3 , TBAIN1 | | | PH2 | 1/0 | Pull-up | 0 | - | 0 | SCK3, TBBIN0 | | | ₽Н3 | √ I/O (( | Pull-up | 0 | o(INTC only) | 0 | INTC , TBBIN1 | | | PH4 | NO | Pull-up | 0 | - | 0 | SDA4/ SO4 , TBDIN0 | | | PH5 | 170 | Pull-up | 0 | - | 0 | SCL4/ SI4 , TBDIN1 | | | PH6 | 1/0 | Pull-up | 0 | - | 0 | SCK4 , TBEIN0 | | | PH7 | I/O | Pull-up | 0 | o(INTD only) | 0 | INTD , TBEIN1 | | Port I | | | | | | | | | | PI0 | I/O | Pull-up | О | - | О | BOOT | | | PI1 | I/O | - | 0 | - | o(Note3) | CEC | | | PI2 | I/O | Pull-up<br>(Note2) | 0 | 0 | 0 | INTE | | | PI3 | I/O | Pull-up<br>(Note2) | 0 | 0 | 0 | INTF | | Port J | | | | | | | | | | PJ0 | Input | Pull-up | 0 | _ | - | AIN0 | Table 8-1 Port Function List | Port | Pln | Input /<br>Output | Program-<br>mable Pull-<br>up<br>Pull-down | Schmitt<br>Input | Noise<br>Filter | Program-<br>mable<br>Open-drain | Function pin | |--------|------|-------------------|--------------------------------------------|------------------|--------------------|---------------------------------|----------------------------------------| | | PJ1 | Input | Pull-up | 0 | - | - | AIN1 | | | PJ2 | Input | Pull-up | 0 | - | - | AIN2 | | | PJ3 | Input | Pull-up | 0 | - | - | AIN3, ADTRG | | | PJ4 | Input | Pull-up | 0 | o(KWUP0 only) | _ | AIN4, KWUP0 | | | PJ5 | Input | Pull-up | 0 | o(KWUP1 only) | -// | AIN5 , KWUP1 | | | PJ6 | Input | Pull-up | 0 | o(KWUP2 only) | +( | AIN6 , KWUP2 | | | PJ7 | Input | Pull-up | 0 | o(KWUP3 only) | | AIN7 , KWUP3 | | Port K | | | | | | | | | | PK0 | Input | Pull-up | 0 | - | <u> </u> | AIN8 | | | PK1 | Input | Pull-up | 0 | 10 | 7/-> | AIN9 | | | PK2 | Input | Pull-up | 0 | -/// | ))- | AIN10 | | | PK3 | Input | Pull-up | 0 | (-) | - | AIN11 | | | PK4 | Input | Pull-up | 0 ( | <u> </u> | - | AIN12 | | | PK5 | Input | Pull-up | 0 | | - | AlN13 | | | PK6 | Input | Pull-up | 0 | <b>\</b> - | - ( | AIN14 | | | PK7 | Input | Pull-up | | <b>\rightarrow</b> | ( | AIN15 | | Port L | | - | < | 1 | // | | | | | PL0 | I/O | Pull-up | 0 | _<< | 0 | SDA0/ SO0 , TB0OUT | | | PL1 | I/O | Pull-up | 0 | - | 0// | SCL0/ SI0 , TB1OUT | | | PL2 | I/O | Pull-up | <i>O</i> . | _ | 0 | SCK0, TB2OUT | | | PL3 | I/O | Pull-up | 0 | o(INT0 only) | 0 | INT0 , TB3OUT | | • | PL4 | 1/0 | Pull-up | 0 | (6) | 0 | TXD1, TB4OUT | | | PL5 | 1/0 | Rull-up | 0 | 77/ | 0 | RXD1 , TB5OUT | | | PL6 | 1/0 | Pull-up | 0 | · | 0 | SCLK1, TB6OUT, CTS1 | | | RL7 | 1/0 | Pull-up | | o(INT1 only) | 0 | INT1 , TB7OUT | | Port M | | | | | | | , | | | PM0 | 1//0 | Pull-up | 0 | _ | 0 | SCLK2, TB1IN0, CTS2 | | | /PM1 | I/O | Pull-up | 0 | _ | О | TXD2 , TB1IN1 | | | PM2 | I/O | Pull-up | 0 | _ | 0 | RXD2 . ALARM | | | PM3 | I/O | Rull-up | 0 | o(INT2 only) | 0 | INT2 , TB3OUT | | _ (( | PM4 | 1/0 | Pull-up | 0 | - | 0 | SCLK3, CTS3 | | | PM5 | >1/0 | Pull-up | 0 | _ | 0 | TXD3 | | | PM6 | 1/0 | Pull-up | 0 | _ | 0 | RXD3 | | | PM7 | 1/0 | Pull-up | 0 | 0 | 0 | INT3 | | Port N | | 14 | > | | | | | | | PN0 | I/O | Pull-up | 0 | _ | 0 | TXD4 | | | PN1 | I/O | Pull-up | 0 | _ | 0 | RXD4 | | | PN2 | 1/0 | Pull-up | 0 | _ | 0 | SCLK4, TB2IN0, CTS4 | | | PN3 | 1/0 | Pull-up | 0 | o(INT4 only) | - | INT4 , TB2IN1 , RMC0 | | | PN4 | 1/0 | Pull-up | 0 | | 0 | TXD5 | | | PN5 | 1/0 | Pull-up | 0 | _ | 0 | RXD5 | | I | | . ,,, | i uii-up | ı | | ļ | 1000 | | | | | Pull-up | _ | _ | _ | SCLK5 TREING CTS5 | | | PN6 | I/O<br>I/O | Pull-up<br>Pull-up | 0 | o(INT8 only) | 0 | SCLK5, TBFIN0, CTS5 INT8, TBFIN1, RMC1 | Page 129 2023/07/21 Table 8-1 Port Function List | Port | Pln | Input /<br>Output | Program-<br>mable Pull-<br>up<br>Pull-down | Schmitt<br>Input | Noise<br>Filter | Program-<br>mable<br>Open-drain | Function pin | |--------|-----|-------------------|--------------------------------------------|-------------------------------------------------|-----------------|---------------------------------|-----------------------| | | PO0 | I/O | Pull-up | 0 | - | 0 | TXD6, TB8OUT | | | PO1 | I/O | Pull-up | 0 | - | 0 | RXD6, TB9OUT | | | PO2 | I/O | Pull-up | 0 | - | 0 | SCLK6, TBAOUT, CTS6 | | | PO3 | I/O | Pull-up | 0 | o(INT9 only) | <u> </u> | INT9, TBBOUT | | | PO4 | I/O | Pull-up | 0 | - | 0 | TXD7 , TBCOUT | | | PO5 | I/O | Pull-up | 0 | - | 0 | RXD7 , TBDOUT | | | P06 | I/O | Pull-up | 0 | - | o | SCLK7 , TBEOUT , CTS7 | | | PO7 | I/O | Pull-up | 0 | o(INTA only) | 0 | INTA , TBFOUT | | Port P | | | | | | | | | | PP0 | I/O | Pull-up | 0 | (0) | <b>7</b> 0 | CS2 | | | PP1 | I/O | Pull-up | - | _/\/ | <i>))</i> 。 | 4 | | | PP2 | I/O | Pull-up | 0 | ( | 0 | BLSO, SPDO | | | PP3 | I/O | Pull-up | ( | - | 0 | BLS1, SPDI | | | PP4 | I/O | Pull-up | - </td <td></td> <td>0</td> <td>WE , SPCLK</td> | | 0 | WE , SPCLK | | | PP5 | I/O | Pull-up | | <b>&gt;-</b> | 0 | OE , SPFSS | | | PP6 | I/O | Pull-up | | > - | 0 | ALE | o : Exist - : Not exist Note 1: The noise elimination width of the noise filter is approximately 30 ns under typical conditions. Note 2: The port is always pulled-up in spite of PIPUP. Note 3: N-ch open drain port #### 8.1.2 Port Registers Outline The following registers need to be configured to use ports. PxDATA: Port x data register To read / write port data. • PxCR: Port x output control register To control output. PxIE needs to be configured to control input. • PxFRn: Port x function register n To set function. An assigned function can be activated by setting "1" • PxOD: Port x open drain control register To control the programmable open drain. Programmable open drain is function to be materialized pseudo-open-drain by setting the PxOD. When PxOD is set "1", output buffer is disabled and pseudo-open-drain is materialized. • PxPUP: Port x pull-up control register To control programmable pull ups. PxPDN: Port x pull-down control register To control programmable pull downs. • PxIE : Port x input control register To control inputs. For avoided through current, default setting prohibits inputs. #### 8.1.3 Port states in STOP Mode Input and output in STOP mode are enabled / disabled by the CGSTBYCR<DRVE> . If PxIE or PxCR is enabled with <DRVE>=1, input or output is enabled respectively in STOP mode.If <DRVE>=0, both input and output are disabled in STOP mode except for some ports even if PxIE or PxCR are enabled. Table 8-2 shows the pin conditions in STOP mode. Table 8-2 Port conditions in STOP mode | | Pin name | I/O | <drve> = 0</drve> | <pre>// <drve> = 1</drve></pre> | |---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------|---------------------------------| | | X1, XT1 | Input only | A * | × | | Exclud-<br>ing port | X2, XT2 | Output only | "High" Level Output | "High"Level Output | | 3 | RESET, NMI, MODE | Input only | 0 | 0 | | | PL3, PL7, PM3, PM7, PN3, PE7, PG3, | Input | | | | | PG7, PN7, PO3, PO7, PD7, PH3, PH7, PI2, PI3 (When used for interrupt (PxFRn <pxmfn>=1) and input is enabled (PxIE<pxmie>=1)) (Note)</pxmie></pxmfn> | Output | × | Depend on PxCR[m] | | | PJ4,PJ5, PJ6, PJ7 | Input | 0 | 0 | | | (When used for KWUP (PxFRn <pxmfn>=1) and input is enabled (PxIE<pxmie>=1)) (Note)</pxmie></pxmfn> | Output | X | Depend on PxCR[m] | | Port | PF0, PF1, PF2, PF3, PF4 | Input | × | Depend on PxCR[m] | | | (When used for trace data output (PxFRn <pxmfn>=1)) (Note)</pxmfn> | Output | Depend or | n PxCR[m] | | | PA7-PA0, PB7-PB0, PC7-PC0, PD7-PD0, | Input | 0 | 0 | | | PE6-PE0, PP6-PP2, PP0 (When used for external bus (PxFRn <pxmfn>=1) and input is enabled for data bus (PxIE<pxmie>=1)) (Note)</pxmie></pxmfn> | Output | Depend or | n PxCR[m] | | | Other parts | Input | × | Depend on PxCR[m] | | | Other ports | Output | × × | Depend on PxCR[m] | o : Input or output enabled Note: "x" indicates a port number, "m" a corresponding bit and "n" a function register number. <sup>× :</sup> Input or output disabled #### 8.2 Port functions This chapter describes the port registers detail. This chapter describes only "circuit type" reading circuit configuration. For detailed circuit diagram, refer to "8.3 Block Diagrams of Ports". #### 8.2.1 Port A (PA0 to PA7) The port A is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port A performs the external bus interface. Reset initializes all bits of the port A as general-purpose ports with input, output and pull-up disabled. If this port is used for the external bus function, PACR, PAFR1 and PAIE must be set to "1". The port A has a types of function register. If you use the port A as a general-purpose port, set "0" to the corresponding bit of the a registers. If you use the port A as other than a general-purpose port, set "1" to the corresponding bit of the function register. #### 8.2.1.1 Port A Circuit Type | | 7 | 6 | 5 4 | 3 2 | 1 | 0 | |------|----|----|-------|--------|----|----| | Туре | T1 | T1 | T1 T1 | /T1 T1 | T1 | T1 | #### 8.2.1.2 Port A Register Base Address = 0x400C\_0000 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port A data register | PADATA | 0x0000 | | Port A output control register | PACR | 0x0004 | | Port A function register 1 | PAFR1 | 0x0008 | | Port A open drain control register | PAOD | 0x0028 | | Port A pull-up control register | PAPUP | 0x002C | | Port A input control register | PAIE | 0x0038 | Page 133 2023/07/21 8.2 Port functions ### 8.2.1.3 PADATA (Port A data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|----------|------------|-----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PA7 | PA6 | PA5 | PA4 | PA3 | PA2 | PA1 | PA0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PA7 to PA0 | R/W | Port A data register | ## 8.2.1.4 PACR (Port A output control register) | | | | | | | ~ | | | |-------------|------|-----------------------------|------------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7/ | - | - | - | | After reset | 0 | 0 | 0 | 0 < | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | ) <u> </u> | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PA7C | PA6C | PA5C | PA4C | PA3C | PA2C | PA1C | PA0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PA7C to PA0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | ## 8.2.1.5 PAFR1 (Port A function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|---------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PA7F1 | PA6F1 | PA5F1 | PA4F1 | PA3F1 | PA2F1 | PA1F1 | PA0F1 | | After reset | 0 | 0 | 0 | 0 | (0/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PA7F1 | R/W | 0 : PORT | | | | | 1 : D7, AD7 | | 6 | PA6F1 | R/W | 0: PORT | | | | | 1: D6, AD6 | | 5 | PA5F1 | R/W | 0: PORT | | | | | 1: D5, AD5 | | 4 | PA4F1 | R/W | 0: PORT | | | | | 1: D4, AD4 | | 3 | PA3F1 | R/W | 0: PORT | | | | | 1: D3, AD3 | | 2 | PA2F1 | R/W | 0: PORT | | | | | 1; D2, AD2 | | 1 | PA1F1 | R/W | 0: PORT | | | | | 1: D1, AD1 | | 0 | PA0F1 | R/W | 0; PORT | | | | | 1: D0, AD0 | #### 8.2.1.6 PAOD (Port A open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|------------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PA7OD | PA6OD | PA5OD | PA4OD | PA3OD | PA2OD | PA10D | PA0OD | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |---------|-------------------|------|----------------------------| | 31 to 8 | - | R | Read as "0". | | 7 to 0 | PA7OD to<br>PA0OD | R/W | 0 : CMOS<br>1 : Open-drain | #### 8.2.1.7 PAPUP (Port A pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----------------|-------------------|-------|----------|-------|-------|-------|-------| | bit symbol | - | - | | - < | | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | 6 | 0 | 0 | 0 | | | 23 | 22 | ))21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ ) \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | | <u>-</u> | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | <del>/</del> /\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PA7UP | PA6UP | PA5UP | PA4UP | PA3UP | PA2UP | PA1UP | PA0UP | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|------------------------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PA7UP to<br>PA0UP | R/W | Pull-Up 0: Disable 1: Enable | ## 8.2.1.8 PAIE (Port A input control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------------------|-------------|-------| | bit symbol | - | - | - | 1 | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>J</u> 77 | 16 | | bit symbol | - | - | - | - | - | $\overline{\Omega}$ | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PA7IE | PA6IE | PA5IE | PA4IE | PA3IE | PA2IE | PA1IE | PA0IE | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|----------------|------|----------------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PA7IE to PA0IE | R/W | Input<br>0: Disable<br>1: Enable | | | | | | | | #### 8.2.2 Port B (PB0 to PB7) The port B is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port B performs the external bus interface. Reset initializes all bits of the port B as general-purpose ports with input, output and pull-up disabled. The port B has a types of function register. If you use the port B as a general-purpose port, set "0" to the corresponding bit of the a registers. If you use the port B as other than a general-purpose port, set "1" to the corresponding bit of the function register. #### 8.2.2.1 Port B Circuit Type | | 7 | 6 | 5 | 4 | (73) | 2 | | 0 | |------|----|----|----|----|------|-----|-----|----| | Туре | T1 | T1 | T1 | T1 | (T1) | T1> | TI/ | T1 | #### 8.2.2.2 Port B Register Base Address = 0x400C\_0100 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port B data register | PBDATA | 0x0000 | | Port B output control register | PBCR | 0x0004 | | Port B function register 1 | PBFR1 | 0x0008 | | Port B open drain control register | PBOD | 0x0028 | | Port B pull-up control register | PBPUP | 0x002C | | Port B input control register | PBIE | 0x0038 | #### 8.2.2.3 PBDATA (Port B data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|--------|-------------|-----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PB7 | PB6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PB7 to PB0 | R/W | Port B data register | ### 8.2.2.4 PBCR (Port B output control register) | | | | | | | ~ | | | |-------------|------|-----------------------------|------------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7// | - | - | - | | After reset | 0 | 0 | 0 | 0 < | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | ) <u> </u> | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PB7C | PB6C | PB5C | PB4C | PB3C | PB2C | PB1C | PB0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7-0 | PB7C to PB0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | Page 139 2023/07/21 ### 8.2.2.5 PBFR1 (Port B function register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PB7F1 | PB6F1 | PB5F1 | PB4F1 | PB3F1 | PB2F1 | PB1F1 | PB0F1 | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------| | 31-8 | - | R | Read as "0". | | 7 | PB7F1 | R/W | 0 : PORT | | | | | 1 : D15, AD15 | | 6 | PB6F1 | R/W | 0: PORT | | | | | 1: D14, AD14 | | 5 | PB5F1 | R/W | 0: PORT | | | | | 1: D13, AD13 | | 4 | PB4F1 | R/W | 0: PORT | | | | | 1: D12, AD12 | | 3 | PB3F1 | R/W | 0: PORT | | | | | 1: D11, AD11 | | 2 | PB2F1 | R/W | 0: PORT | | | | | 1; D10, AD10 | | 1 | PB1F1 | R/W | 0: PORT | | | < | | 1: D9, AD9 | | 0 | PB0F1 | R/W | 0; PORT | | | | | 1: D8, AD8 | #### 8.2.2.6 PBOD (Port B open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PB7OD | PB6OD | PB5OD | PB4OD | PB3OD | PB2OD | PB10D | PB0OD | | After reset | 0 | 0 | 0 | 0 | (0/1) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | | |------|-------------------|------|----------------------------|----------|--| | 31-8 | - | R | Read as "0". | | | | 7-0 | PB7OD to<br>PB0OD | R/W | 0 : CMOS<br>1 : Open-drain | | | ## 8.2.2.7 PBPUP (Port B pull-up control register) | | 31 | 30 | 29)) | 28 | 27 | 26 | 25 | 24 | |-------------|---------------|-------|--------|------------|-------|-------|-------|-------| | bit symbol | - | - 6 | )<br>} | - / | | - | - | - | | After reset | 0 | 0 | / | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 // < | 19 | 18 | 17 | 16 | | bit symbol | - < | 1 | 7 - < | | _ | - | - | - | | After reset | 0 | 9 | 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | \ <u>-</u> \/ | - | - | \ <u> </u> | - | - | 1 | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PB7UP | PB6UP | PB5UP | PB4UP | PB3UP | PB2UP | PB1UP | PB0UP | | After reset | | 0> | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|------------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PB7UP to<br>PB0UP | R/W | Pull-up 0: Disable 1: Enable | Page 141 2023/07/21 ## 8.2.2.8 PBIE (Port B input control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|---------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PB7IE | PB6IE | PB5IE | PB4IE | PB3IE | PB2IE | PB1IE | PB0IE | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|----------------|------|----------------------------|----------| | 31-8 | _ | R | Read as "0". | | | 7-0 | PB7IE to PB0IE | R/W | Input 0: Disable 1: Enable | | | | | | | | #### 8.2.3 Port C (PC0 to PC7) The port C is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port C performs the external bus interface, the serial channel, and the serial bus interface. Reset initializes all bits of the port C as general-purpose ports with input, output and pull-up disabled. The Port C has three types of function register. If you use the port C as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port C as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. #### 8.2.3.1 Port C Circuit Type | | 7 | 6 | 5 | 4 | $\bigcirc$ 3 $\land$ | 2 | | 0 | |------|----|----|----|----|----------------------|----|----|----| | Туре | T5 | T4 | Т3 | T2 | (T5) | T4 | T3 | T2 | #### 8.2.3.2 Port C Register Base Address = 0x400C\_0200 | Register name | | Address (Base+) | |------------------------------------|-----------|-----------------| | Port C data register | PCDATA | 0x0000 | | Port C output control register | PCCR | 0x0004 | | Port C function register 1 | PCFR1 | 0x0008 | | Port C function register 2 | PCFR2 | 0x000C | | Port C function register 3 | PCFR3 | 0x0010 | | Port C open drain control register | PCOD | 0x0028 | | Port C pull-up control register | 7/\ PCPUP | 0x002C | | Port C input control register | PCIE | 0x0038 | ### 8.2.3.3 PCDATA (Port C data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-----|--------|------------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>1</b> 7 | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | | After reset | 0 | 0 | 0 | 0 | (0/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PC7 to PC0 | R/W | Port C data register | ## 8.2.3.4 PCCR (Port C output control register) | | | | | | | ~ | | | |-------------|------|-----------------------------|------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7// | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PC7C | PC6C | PC5C | PC4C | PC3C | PC2C | PC1C | PC0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | _ | R | Read as "0". | | 7-0 | PC7C to PC0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | ## 8.2.3.5 PCFR1 (Port C function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PC7F1 | PC6F1 | PC5F1 | PC4F1 | PC3F1 | PC2F1 | PC1F1 | PC0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PC7F1 | R/W | 0 : PORT | | | | | 1 : A8 | | 6 | PC6F1 | R/W | 0: PORT | | | | | 1:A7 | | 5 | PC5F1 | R/W | 0: PORT | | | | | 1: A6 | | 4 | PC4F1 | R/W | 0: PORT | | | | | 1: A5 | | 3 | PC3F1 | R/W | 0: PORT | | | | | 1: A4 | | 2 | PC2F1 | R/W | 0: PORT | | | | | 1; A3 | | 1 | PC1F1 | R/W | 0: PORT | | | | | 1: A2 | | 0 | PC0F1 | R/W | 0; PORT | | | | | 1:A1 | ## 8.2.3.6 PCFR2 (Port C function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|-------|-------|------|----------|-----------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PC6F2 | PC5F2 | PC4F2 | | PC2F2 | PC1F2 | PC0F2 | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-7 | - | R | Read as "0". | | 6 | PC6F2 | R/W | 0: PORT | | | | | 1:SCLK9 | | 5 | PC5F2 | R/W | 0: PORT | | | | | 1: RXD9 | | 4 | PC4F2 | R/W | 0: PORT | | | | | 1: TXD9 | | 3 | - | R | Read as "0". | | 2 | PC2F2 | R/W | 0: PORT | | | | | 1: SCLK8 | | 1 | PC1F2 | R/W | 0: PORT | | | | | 1: RXD8 | | 0 | PC0F2 | R/W | 0; PORT | | | ] | // | 1: TXD8 | #### 8.2.3.7 PCFR3 (Port C function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|----|----|------|---------|-----------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PC6F3 | - | 1 | | PC2F3 | 2-// | - | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|------------|------|--------------|----------| | 31-7 | - | R | Read as "0". | | | 6 | PC6F3 | R/W | 0 : PORT | | | | | | 1 : CTS9 | | | 5-3 | - | R | Read as "0". | | | 2 | PC2F3 | R/W | 0 : PORT | | | | | | 1 : CTS8 | | | 1-0 | - | R | Read as "0". | | ## 8.2.3.8 PCOD (Port C open drain control reigister) | | 31 | 30 | 29 | 287/ | 27 | 26 | 25 | 24 | |-------------|-------------------------|---------|-------|-------|-------|-------|-------|-------| | bit symbol | - ( | 1 | 7 - < | | ) - | - | - | - | | After reset | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | $\langle \cdot \rangle$ | - | - | - | - | - | - | - | | After reset | 0 | 0 | Q | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | - | | - | 1 | - | 1 | - | | After reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | (6 /> \ | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PC7OD | PC6OD | PC5OD | PC4OD | PC3OD | PC2OD | PC10D | PC0OD | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PC7OD to<br>PC0OD | R/W | 0 : CMOS<br>1 : Open-drain | Page 147 2023/07/21 #### 8.2.3.9 PCPUP (Port C pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-----------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PC7UP | PC6UP | PC5UP | PC4UP | PC3UP | PC2UP | PC1UP | PC0UP | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|------------------------------------|----------| | 31-8 | ı | R | Read as "0". | | | 7-0 | PC7UP to<br>PC0UP | R/W | Pull-up<br>0: Disable<br>1: Enable | | ## 8.2.3.10 PCIE (Port C input control register) | | 31 | 30 | 29)) | 28 / | 27 | 26 | 25 | 24 | |-------------|-------|------------|----------|----------|-------|-------|-------|-------| | bit symbol | - | - ( | \\ \( \) | - / | | - | - | - | | After reset | 0 | 0 | / | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 // < | 19 | 18 | 17 | 16 | | bit symbol | - < | 7 | 7 - < | | ) - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | <-\^ | - | - | <u> </u> | - | - | - | - | | After reset | 0 | <b>)</b> 0 | /0, | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PC7IE | PC6IE | PC5IE | PC4IE | PC3IE | PC2IE | PC1IE | PC0IE | | After reset | | 0> | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PC7IE to<br>PC0IE | R/W | Input 0: Disable 1: Enable | #### 8.2.4 Port D (PD0 to PD7) The port D is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port D performs the external bus interface, the serial channel and the external signal interrupt function. Reset initializes all bits of the port D as general-purpose ports with input, output and pull-up disabled. The Port D has three types of of function register. If you use the port D as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port D as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. #### 8.2.4.1 Port D Circuit Type | | | | | | - | | 7 | |------|----|----|----|-------|----|-----|----| | | 7 | 6 | 5 | 4 (3) | 2 | (0) | 0 | | Туре | T6 | T4 | T3 | T2 T5 | T4 | | T2 | #### 8.2.4.2 Port Register Base Address = 0x400C\_0300 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port D data register | PDDATA | 0x0000 | | Port D output control register | RDCR | 0x0004 | | Port D function register 1 | PDFR1 | 0x0008 | | Port D function register 2 | PDFR2 | 0x000C | | Port D function register 3 | PDFR3 | 0x0010 | | Port D open drain control register | PDOD | 0x0028 | | Port D pull-up control register | PDPUP | 0x002C | | Port D input control register | PDIE | 0x0038 | ### 8.2.4.3 PDDATA (Port D data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|----------|------------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PD7 | PD6 | PD5 | PD4 | PD3 | PD2 | PD1 | PD0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PD7 to PD0 | R/W | Port D data register | ## 8.2.4.4 PDCR (Port D output control register) | | | | | | | ~ | | | |-------------|------|-----------------------------|------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7/ | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PD7C | PD6C | PD5C | PD4C | PD3C | PD2C | PD1C | PD0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7-0 | PD7C to PD0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | #### 8.2.4.5 PDFR1 (Port D function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PD7F1 | PD6F1 | PD5F1 | PD4F1 | PD3F1 | PD2F1 | PD1F1 | PD0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PD7F1 | R/W | 0 : PORT | | | | | 1 : A16 | | 6 | PD6F1 | R/W | 0: PORT | | | | | 1:A15 | | 5 | PD5F1 | R/W | 0: PORT | | | | | 1: A14 | | 4 | PD4F1 | R/W | 0: PORT | | | | | 1: A13 | | 3 | PD3F1 | R/W | 0: PORT | | | | | 1: A12 | | 2 | PD2F1 | R/W | 0: PORT | | | | | 1; A11 | | 1 | PD1F1 | R/W | 0: PORT | | | < | | 1: A10 | | 0 | PD0F1 | R/W | 0; PORT | | | | | 1: A9 | ### 8.2.4.6 PDFR2 (Port D function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|------|----------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PD7F2 | PD6F2 | PD5F2 | PD4F2 | | PD2F2 | PD1F2 | PD0F2 | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PD7F2 | R/W | 0 : PORT | | | | | 1: INTB | | 6 | PD6F2 | R/W | 0: PORT | | | | | 1:SCLK11 | | 5 | PD5F2 | R/W | 0: PORT | | | | | 1: RXD11 | | 4 | PD4F2 | R/W | 0: PORT | | | | | 1: TXD11 | | 3 | _ | R | Read as "0". | | 2 | PD2F2 | R/W | 0: PORT | | | | | 1: SCLK10 | | 1 | PD1F2 | R/W | 0; PORT | | | , | | )1; RXD10 | | 0 | PD0F2 | R/W | 0: PORT | | | | | 1; TXD10 | #### 8.2.4.7 PDFR3 (Port D function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|----|----|-----|---------|------------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PD6F3 | - | 1 | | PD2F3 | 2-// | - | | After reset | 0 | 0 | 0 | 0 | (0/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|------------|------|--------------|----------| | 31-7 | - | R | Read as "0". | | | 6 | PD6F3 | R/W | 0 : PORT | | | | | | 1 : CTS11 | | | 5-3 | - | R | Read as "0". | | | 2 | PD2F3 | R/W | 0 : PORT | | | | | | 1 : CTS10 | | | 1-0 | - | R | Read as "0". | | # 8.2.4.8 PDOD (Port D open drain control register) | | 31 | 30 | 29 | (287) | 27 | 26 | 25 | 24 | |-------------|---------------------------------|---------|-------|-------|-------|-------|-------|-------| | bit symbol | - ( | 1 | 7 - < | | ) - | - | - | - | | After reset | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | $\langle \cdot \rangle \rangle$ | - | - | - | 1 | - | - | - | | After reset | 0 | 0 | Q | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | - | | - | 1 | - | - | - | | After reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | (6 /> \ | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PD70D | PD6OD | PD5OD | PD4OD | PD3OD | PD2OD | PD10D | PD00D | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PD7OD to<br>PD0OD | R/W | 0 : CMOS<br>1 : Open-drain | Page 153 2023/07/21 ### 8.2.4.9 PDPUP (Port D pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-----------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PD7UP | PD6UP | PD5UP | PD4UP | PD3UP | PD2UP | PD1UP | PD0UP | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|------------------------------|----------| | 31-8 | ı | R | Read as "0". | | | 7-0 | PD7UP to<br>PD0UP | R/W | Pull-up 0: Disable 1: Enable | | ### 8.2.4.10 PDIE (Port D input control register) | | | | A = A = A | | | | | | |-------------|-----------|------------|-----------|----------|-------|-------|-------|-------| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - ( | | - / | | - | - | - | | After reset | 0 | 0 (/ | <b>/</b> | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | (20 // < | 19 | 18 | 17 | 16 | | bit symbol | - < | | 7 - < | | ) - | - | - | - | | After reset | 0 | Q | 9 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | < <u></u> | - | - | | - | - | - | - | | After reset | 0 | <b>)</b> 0 | /9 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | RD7IE | PD6IE | PD5IE | PD4IE | PD3IE | PD2IE | PD1IE | PD0IE | | After reset | | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PD7IE to<br>PD0IE | R/W | Input 0: Disable 1: Enable | ### 8.2.5 Port E (PE0 to PE7) The port E is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port E performs the external bus interface, the serial channel, external signal interrupt, the 16-bit timer / counter and clock output function. Reset initializes all bits of the port E as general-purpose ports with input, output and pull-up disabled. The Port E has three types of of function register. If you use the port E as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port E as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. Note: In modes other than STOP mode, interrupt input is enabled regardless of the PxFR register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. ### 8.2.5.1 Port E Circuit Type | | 7 | 6 | 5 | 3 | 2 1 | 0 | |------|----|----|----|-------|--------|----| | Туре | T6 | T4 | Т3 | T2 T3 | T3, T3 | Т3 | ### 8.2.5.2 Port E register Base Address = 0x400C\_0400 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port E data register | PEDATA | 0x0000 | | Port E output control register | PECR | 0x0004 | | Port E function register 1 | PEFR1 | 0x0008 | | Port E function register 2 | PEFR2 | 0x000C | | Port E function register 3 | PEFR3 | 0x0010 | | Port E open drain control register | PEOD | 0x0028 | | Port E pull-up control register | PEPUP | 0x002C | | Port E input control register | PEIE | 0x0038 | Page 155 2023/07/21 ### 8.2 Port functions ### 8.2.5.3 PEDATA (Port E data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|---------|-----------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PE7 | PE6 | PE5 | PE4 | PE3 | PE2 | PE1 | PE0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PE7 to PE0 | R/W | Port E data register | # 8.2.5.4 PECR (Port E output control register) | | | | | | | ~ | | | |-------------|------|-----------------------------|------------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7// | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | ) <u> </u> | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PE7C | PE6C | PE5C | PE4C | PE3C | PE2C | PE1C | PE0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7-0 | PE7C to PE0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | ## 8.2.5.5 PEFR1 (Port E function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|-------|-------|-------|----------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>J</u> 77 | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PE6F1 | PE5F1 | PE4F1 | PE3F1 | PE2F1 | PE1F1 | PE0F1 | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------| | 31-8 | - | R | Read as "0". | | 7 | - | R/W | Write "0". | | 6 | PE6F1 | R/W | 0: PORT<br>1:A23 | | 5 | PE5F1 | R/W | 0: PORT<br>1: A22 | | 4 | PE4F1 | R/W | 0: PORT<br>1: A21 | | 3 | PE3F1 | R/W | 0: PORT<br>1: A20 | | 2 | PE2F1 | R/W | 0: PORT<br>1: A19 | | 1 | PE1F1 | R/W | 0; PORT<br>1: A18 | | 0 | PE0F1 | R/W | 0: PORT<br>1: A17 | ## 8.2.5.6 PEFR2 (Port E function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|-----------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PE7F2 | PE6F2 | PE5F2 | PE4F2 | PE3F2 | PE2F2 | PE1F2 | PE0F2 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PE7F2 | R/W | 0 : PORT | | | | | 1: INT5 | | 6 | PE6F2 | R/W | 0: PORT | | | | | 1:SCLK0 | | 5 | PE5F2 | R/W | 0: PORT | | | | | 1: RXD0 | | 4 | PE4F2 | R/W | 0: PORT | | | | | 1: TXD0 | | 3 | PE3F2 | R/W | 0: PORT | | | | | 1 : TB6IN1 | | 2 | PE2F2 | R/W | 0: PORT | | | | | 1; TB6INO | | 1 | PE1F2 | R/W | 0: PORT | | | ~ | | 1: TB5IN1 | | 0 | PE0F2 | R/W | 0; PORT | | | | | 1: TB5IN0 | ### 8.2.5.7 PEFR3 (Port E function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|----|----|-------|--------|-------------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PE7F3 | PE6F3 | - | - | | - | 0-// | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |--------|------------|------|--------------|----------| | 31-8 | - | R | Read as "0". | | | 7 | PE7F3 | R/W | 0 : PORT | | | | | | 1 : SCOUT | | | 6 | PE6F3 | R/W | 0 : PORT | | | | | | 1 : CTS0 | | | 5-4 | - | R/W | Write "0". | | | 3 to 0 | - | R | Read as "0". | | # 8.2.5.8 PEOD (Port E open drain control register) | | 31 | 30 | 29 | 287/ | 27 | 26 | 25 | 24 | |-------------|---------------------------|-------|-------|-------|-------|-------|-------|-------| | bit symbol | - ( | 1 | 7 - < | | _ | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | $\langle \rangle \rangle$ | - | - | - | - | - | - | - | | After reset | 0 | 0 | Q | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | ((-)) | - | | - | - | - | - | - | | After reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Z | (6, ) | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | bit symbol | PE7OD | PE6OD | PE5OD | PE4OD | PE3OD | PE2OD | PE1OD | PE0OD | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PE7OD to<br>PE0OD | R/W | 0 : CMOS<br>1 : Open-drain | Page 159 2023/07/21 ### 8.2.5.9 PEPUP (Port E pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PE7UP | PE6UP | PE5UP | PE4UP | PE3UP | PE2UP | PE1UP | PE0UP | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|------------------------------|----------| | 31-8 | ı | R | Read as "0". | | | 7-0 | PE7UP to<br>PE0UP | R/W | Pull-up 0: Disable 1: Enable | | # 8.2.5.10 PEIE (Port E input control register) | | 31 | 30 | 29)) | 28 / | 27 | 26 | 25 | 24 | |-------------|-------|-------|----------|----------|-------|-------|-------|-------| | bit symbol | - | - ( | \\ \( \) | - / | | - | 1 | - | | After reset | 0 | 0 | / | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 // < | 19 | 18 | 17 | 16 | | bit symbol | - < | | 7 - < | | ) - | - | - | - | | After reset | 0 | 9 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | <-\^ | - | - | <u> </u> | - | - | - | - | | After reset | 0 | 50 | /0, | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | RE7IE | PE6IE | PE5JE | PE4IE | PE3IE | PE2IE | PE1IE | PE0IE | | After reset | | 0> | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|----------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7-0 | PE7IE to PE0IE | R/W | Intput | | | | | 0: Disable | | | | | 1: Enable | # 8.2.6 Port F (PF0 to PF4) The port F is a general-purpose, 5-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port F performs the debug interface function Reset initializes all bits of the port F as general-purpose ports with input, output and pull-up disabled. The Port F has one types of of function register. If you use the port F as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port F as other than a general-purpose port, set "1" to the corresponding bit of the function register. ### 8.2.6.1 Port F Circuit Type | | 7 | 6 | 5 | 4 | (73/^ | 2 | | 0 | |------|---|---|---|----|-------|----|----|----| | Туре | - | - | 1 | T7 | (T7) | T7 | 77 | T7 | ### 8.2.6.2 Port F Register Base Address = 0x400C 0500 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port F data register | PFDATA | 0x0000 | | Port F output control register | PFCR | 0x0004 | | Port F function register 1 | PFFR1 | 0x0008 | | Port F open drain control register | PFOD | 0x0028 | | Port F pull-up control register | PFPUP | 0x002C | | Port F input control register | PFJE | 0x0038 | TMPM362F10FG ## 8.2.6.3 PFDATA (Port F data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|-----|-----|----------|-----------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | PF4 | PF3 | PF2 | PF1 | PF0 | | After reset | 0 | 0 | 0 | 0 | (0/ | 0 | 0 | 0 | | Bit | Bit Symbol | TypF | Function | |------|------------|------|----------------------| | 31-5 | - | R | Read as "0". | | 4-0 | PF4 to PF0 | R/W | Port F data register | # 8.2.6.4 PFCR (Port F output control register) | | | | | | | ~ | | | |-------------|-----|-----------------------------|------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7/ | - | - | - | | After reset | 0 | 0 | 0 | 0 🗸 | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | d | PF4C | PF3C | PF2C | PF1C | PF0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-5 | 1 | R | Read as "0". | | 4-0 | PF4C to PF0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | # 8.2.6.5 PFFR1 (Port F function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|-------|-------|---------|-----------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | PF4F1 | PF3F1 | PF2F1 | PF1F1 | PF0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------| | 31-5 | - | R | Read as "0". | | 4 | PF4F1 | R/W | 0: PORT | | | | | 1: TRACEDATA3 | | 3 | PF3F1 | R/W | 0: PORT | | | | | 1: TRACEDATA2 | | 2 | PF2F1 | R/W | 0: PORT | | | | | 1: TRACEDATA1 | | 1 | PF1F1 | R/W | 0: PORT | | | | | 1: TRACEDATA0 / SWV | | 0 | PF0F1 | R/W | 0: PORT | | | | | 1: TRACECLK | Page 163 2023/07/21 ### 8.2.6.6 PFOD (Port F open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|-------|-------|---------|-----------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | PF4OD | PF3OD | PF2OD | PF10D | PF0OD | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | | |------|-------------------|------|----------------------------|----------|--| | 31-5 | - | R | Read as "0". | | | | 4-0 | PF4OD to<br>PF0OD | R/W | 0 : CMOS<br>1 : Open-drain | | | ## 8.2.6.7 PFPUP (Port F pull-up control register) | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----------------------------|------|----------|-------|-------|-------|-------| | bit symbol | - | - | | - < | 7/ | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | <u> </u> | - | - | - | - | | After reset | Q/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | ) | d | PF4UP | PF3UP | PF2UP | PF1UP | PF0UP | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|------------------------------| | 31-5 | 1- | R | Read as "0". | | 4-0 | PF4UP to<br>PF0UP | R/W | Pull-up 0: Disable 1: Enable | # 8.2.6.8 PFIE (Port F input control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|-------|-------|--------|---------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | PF4IE | PF3IE | PF2IE | PF11E | PF0IE | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|----------------|------|----------------------------|----------| | 31-5 | - | R | Read as "0". | | | 4-0 | PF4IE to PF0IE | R/W | Input 0: Disable 1: Enable | | | | | | | | ### 8.2.7 Port G (PG0 to PG7) The port G is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port G performs the serial bus interface, the external signal interrupt, 16bit timer / event counter , the external bus interface and Watch-dog timer output functions. Reset initializes all bits of the port G as general-purpose ports with input, output and pull-up disabled. The Port G has three types of of function register. If you use the port G as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port G as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the three function registers at the same time. To use the external interrupt input for releasing STOP mode, select this function in the PGFR1 and enable input in the PGIE register. These settings enable the interrupt input even if the CGSTBYCR<DRVE> bit in the clock / mode control block is set to stop driving of pins during STOP mode. Note: In modes other than STOP mode, interrupt input is enabled regardless of the PxFR register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. #### 8.2.7.1 Port G Circuit Type | | 7 | 6 | 5 | 3 | 2 | 1 | 0 | |------|-----|----|------|---|----|----|----| | Туре | T11 | Т9 | T8 T | | Т9 | T8 | T8 | #### 8.2.7.2 Port G register Base Address = 0x400C\_0600 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port G data register | PGDATA | 0x0000 | | Port G output control register | PGCR | 0x0004 | | Port G function register 1 | PGFR1 | 0x0008 | | Port G function register 2 | PGFR2 | 0x000C | | Port G function register 3 | PGFR3 | 0x0010 | | Port G open drain control register | PGOD | 0x0028 | | Port G pull-up control register | PGPUP | 0x002C | | Port G input control register | PGIE | 0x0038 | ### 8.2.7.3 PGDATA (Port G data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|---------|------------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PG7 | PG6 | PG5 | PG4 | PG3 | PG2 | PG1 | PG0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | | |------|------------|------|----------------------|----------|--| | 31-8 | - | R | Read as "0". | | | | 7-0 | PG7 to PG0 | R/W | Port G data register | | | ## 8.2.7.4 PGCR (Port G output control register) | | | | $\overline{}$ | | | ~ | | | |-------------|------|------------|---------------|-----------|------|------|------|------| | | 31 | 30 | 29 🖯 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | | - | - | - | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | / )-[ \ | ) . < | ( ( /// < | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | | | - | - | - | • | | After reset | 6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PG7C | PG6C | PG5C | PG4C | PG3C | PG2C | PG1C | PG0C | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PG7C to PG0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | Page 167 2023/07/21 # 8.2.7.5 PGFR1 (Port G function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-07) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PG7F1 | PG6F1 | PG5F1 | PG4F1 | PG3F1 | PG2F1 | PG1F1 | PG0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------| | 31-8 | - | R | Read as "0". | | 7 | PG7F1 | R/W | 0: PORT | | | | | 1:INT7 | | 6 | PG6F1 | R/W | 0: PORT | | | | | 1: SCK2 | | 5 | PG5F1 | R/W | 0: PORT | | | | | 1: SCL2 / SI2 | | 4 | PG4F1 | R/W | 0: PORT | | | | | 1: SDA2 / SQ2 | | 3 | PG3F1 | R/W | 0: PORT | | | | | 1: INT6 | | 2 | PG2F1 | R/W | 0: PORT | | | | | 1; SCK1 | | 1 | PG1F1 | Ŗ/W | 0: PORT | | | < | | 1: SCL1 / SI1 | | 0 | PG0F1 | R/W | 0; PORT | | | | | 1: SDA1 / SO1 | # 8.2.7.6 PGFR2 (Port G function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|-------|-------|-------|--------|---------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | PG5F2 | PG4F2 | | - | PG1F2 | PG0F2 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------| | 31-8 | - | R | Read as "0". | | 7-6 | - | R/W | Write "0". | | 5 | PG5F2 | R/W | 0: PORT | | | | | 1: TB9IN1 (V/)) | | 4 | PG4F2 | R/W | 0: PORT | | | | | 1: TB9IN0 | | 3-2 | _ | R | Read as "0". | | 1 | PG1F2 | R/W | 0: PORT | | | | | 1: TB7IN1 | | 0 | PG0F2 | R/W | 0: PORT | | | | | 1: TB7IN0 | Page 169 2023/07/21 # 8.2.7.7 PGFR3 (Port G function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|----|----|-------|--------|------------|----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PG7F3 | PG6F3 | - | - | PG3F3 | PG2F3 | 0- | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |--------|------------|------|------------------------| | 31-8 | - | R | Read as "0". | | 7 | PG7F3 | R/W | 0 : PORT<br>1 : WDTOUT | | 6 | PG6F3 | R/W | 0 : PORT<br>1 : CS3 | | 5-4 | - | R | Read as "0". | | 3 | PG3F3 | R/W | 0 : PORT<br>1 : CS1 | | 2 | PG2F3 | R/W | 0 : PORT<br>1 : CSO | | 1 to 0 | - | R | Read as "0": | ### 8.2.7.8 PGOD (Port G open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|---------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PG70D | PG6OD | PG5OD | PG40D | PG3OD | PG2OD | PG10D | PG00D | | After reset | 0 | 0 | 0 | 0 | (0/1) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | | |------|-------------------|------|----------------------------|----------|--| | 31-8 | - | R | Read as "0". | | | | 7-0 | PG7OD to<br>PG0OD | R/W | 0 : CMOS<br>1 : Open-drain | | | ### 8.2.7.9 PGPUP (Port G pull-up control register) | | | | $\overline{}$ | | | | | | |-------------|-------|-------------------|---------------|-------|-------|-------|-------|-------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | | - | - | - | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | 23 | 22 | ))21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ ) \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PG7UP | PG6UP | PG5UP | PG4UP | PG3UP | PG2UP | PG1UP | PG0UP | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|------------------------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PG7UP to<br>PG0UP | R/W | Pull-up 0: Disable 1: Enable | Page 171 2023/07/21 # 8.2.7.10 PGIE (Port G input control register) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>1</b> 77 | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PG7IE | PG6IE | PG5IE | PG4IE | PG3IE | PG2IE | PG11E | PG0IE | | After reset | 0 | 0 | 0 | 0 | (0/1) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|----------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PG7IE to<br>PG0IE | R/W | Input 0: Disable 1: Enable | | | | | | | | ### 8.2.8 Port H (PH0 to PH7) The port H is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port H performs the serial bus interface, the external signal interrupt function and 16bit timer / event counter function. Reset initializes all bits of the port H as general-purpose ports with input, output and pull-up disabled. The Port H has two types of of function register. If you use the port H as a general-purpose port, set "0" to the corresponding bit of the two registers. If you use the port H as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. Note: In modes other than STOP mode, interrupt input is enabled regardless of the PHFR1 register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. ### 8.2.8.1 Port H Circut Type | | 7 | 6 | 5 | 4 3 | 2 1 | 0 | |------|-----|-----|-----|---------|---------|-----| | Туре | T13 | T12 | T12 | T12 T13 | T12 T12 | T12 | #### 8.2.8.2 Port H register Base Address = 0x400C\_0700 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port H data register | PHDATA | 0x0000 | | Port H output control register | PHCR | 0x0004 | | Port H function register 1 | PHFR1 | 0x0008 | | Port H function register 2 | PHFR2 | 0x000C | | Port H open drain control register | PHOD | 0x0028 | | Port H pull-upcontrol register | PHPUP | 0x002C | | Port H input control register | PHIE | 0x0038 | ## 8.2.8.3 PHDATA (Port H data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|----------|------------|-----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PH7 | PH6 | PH5 | PH4 | PH3 | PH2 | PH1 | PH0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PH7 to PH0 | R/W | Port H data register | ## 8.2.8.4 PHCR (Port H output control register) | | | | | | | ~ | | | |-------------|------|-----------------------------|------------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7/ | - | - | - | | After reset | 0 | 0 | 0 | 0 🗸 | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | ) <u> </u> | ((/// | - | - | - | - | | After reset | 0 | 0 | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PH7C | PH6C | PH5C | PH4C | PH3C | PH2C | PH1C | PH0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | _ | R | Read as "0". | | 7-0 | PH7C to PH0C | R/W | Output | | | | | 0: Disable | | , | | | 1: Enable | # 8.2.8.5 PHFR1 (Port H function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-------------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PH7F1 | PH6F1 | PH5F1 | PH4F1 | PH3F1 | PH2F1 | PH1F1 | PH0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------| | 31-8 | - | R | Read as "0". | | 7 | PH7F1 | R/W | 0: PORT | | | | | 1: INTD | | 6 | PH6F1 | R/W | 0: PORT | | | | | 1: SCK4 | | 5 | PH5F1 | R/W | 0: PORT | | | | | 1: SCL4 / SI4 | | 4 | PH4F1 | R/W | 0: PORT | | | | | 1: SDA4 / SO4 | | 3 | PH3F1 | R/W | 0: PORT | | | | | 1: INTC | | 2 | PH2F1 | R/W | 0: PORT | | | | | 1; SCK3 | | 1 | PH1F1 | R/W | 0: PORT | | | | | 1: SCL3 / SI3 | | 0 | PH0F1 | R/W | 0; PORT | | | | | 1: SDA3 / SO3 | ## 8.2.8.6 PHFR2 (Port H function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PH7F2 | PH6F2 | PH5F2 | PH4F2 | PH3F2 | PH2F2 | PH1F2 | PH0F2 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PH7F2 | R/W | 0: PORT | | | | | 1: TBEIN1 | | 6 | PH6F2 | R/W | 0: PORT | | | | | 1: TBEINO | | 5 | PH5F2 | R/W | 0: PORT | | | | | 1: TBDIN1 | | 4 | PH4F2 | R/W | 0: PORT | | | | | 1: TBDINO | | 3 | PH3F2 | R/W | 0: PORT | | | | | 1: TBBIN1 | | 2 | PH2F2 | R/W | 0: PORT | | | | | 1; TBBINO | | 1 | PH1F2 | R/W | 0: PORT | | | < | | 1: TBAIN1 | | 0 | PH0F2 | R/W | 0; PORT | | | | | 1: TBAIN0 | ### 8.2.8.7 PHOD (Port H open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PH7OD | PH6OD | PH5OD | PH4OD | PH3OD | PH2OD | PH10D | PH0OD | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | | |------|-------------------|------|----------------------------|----------|--| | 31-8 | - | R | Read as "0". | | | | 7-0 | PH7OD to<br>PH0OD | R/W | 0 : CMOS<br>1 : Open-drain | | | ### 8.2.8.8 PHPUP (Port H pull-up control register) | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | |-------------|-----------------|-----------------------------|--------|----------|-------|-------|-------|-------| | bit symbol | - | - | - (()) | | 7// | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | <u> </u> | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | <del>/</del> /\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PH7UP | PH6UP | PH5UP | PH4UP | PH3UP | PH2UP | PH1UP | PH0UP | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|------------------------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PH7UP to<br>PH0UP | R/W | Pull-up 0: Disable 1: Enable | Page 177 2023/07/21 # 8.2.8.9 PHIE (Port H input control register) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-----------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PH7IE | PH6IE | PH5IE | PH4IE | PH3IE | PH2IE | PH11E | PH0IE | | After reset | 0 | 0 | 0 | 0 | (0/1) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|----------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PH7IE to<br>PH0IE | R/W | Input 0: Disable 1: Enable | | | | • | | | | ### 8.2.9 Port I (PI0 to PI3) The port I is a general-purpose, 4-bit input/output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose port function, the port I performs the external signal interrupt input, CEC input and the operation mode setting. Reset initializes PIO as general-purpose ports with input, output and pull-up disabled. Reset initializes PI1, PI2 and PI3 as general-purpose ports with input, output disabled. Pull-up is enabled for PI2, PI3. PI1 is N-ch open-drain ports. The Port I has one types of of function register. If you use the port I as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port I as other than a general-purpose port, set "1" to the corresponding bit of the function register. While RESET pin is "Low", input and pull-up of PI0(BOOT) are enabled. At the rising edge of RESET pin, if PI0(BOOT) is "High", TMPM362F10FG enters the single chip mode and boots from the on chip Flash ROM. If PI0(BOOT) is "Low", TMPM362F10FG enters the single boot mode and boots from the on chip BOOTROM. For details of the single boot mode, refer to "Flash memory operation". Note: In modes other than STOP mode, interrupt input is enabled regardless of the PxFR register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. ### 8.2.9.1 Port I Circuit Type | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|---|---|---|-----|-----|-----|-----| | Туре | - | - | | - | T16 | T16 | T15 | T14 | ### 8.2.9.2 Port I register Base Address = 0x400C\_0800 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port I data register | PIDATA | 0x0000 | | Port I output control register | PICR | 0x0004 | | Port I function register 1 | PIFR1 | 0x0008 | | Port I open drain control register | PIOD | 0x0028 | | Port I pull-up control register | PIPUP | 0x002C | | Port I input control register | PIIE | 0x0038 | Page 179 2023/07/21 # 8.2.9.3 PIDATA (Port I data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-------|--------|------------|-----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | S | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | PI3 | PI2 | PI1 | PI0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | | |------|------------|------|----------------------|----------|--| | 31-4 | - | R | Read as "0". | | | | 3-0 | PI3 to PI0 | R/W | Port I data register | | | # 8.2.9.4 PICR (Port I output control register) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|----|----|----|----|-------|--------|-------------|------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | PI3C | PI2C | PI1C | PI0C | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|------------|------|-----------------------------|----------| | 31-4 | - | R | Read as "0". | | | 3-0 | PI3C-PI0C | R/W | Output 0: Disable 1: Enable | | | | | - | | | # 8.2.9.5 PIFR1 (Port I function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-------|--------|------------|----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | PI3F1 | PI2F1 | PI1F1 | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|------------|------|--------------|----------| | 31-4 | - | R | Read as "0". | | | 3 | PI3F1 | R/W | 0: PORT | | | | | | 1: INTF | | | 2 | PI2F1 | R/W | 0: PORT | | | | | | 1: INTE | | | 1 | PI1F1 | R/W | 0: PORT | | | | | | 1: CEC | | | 0 | - | R/W | Write "0". | | ### 8.2.9.6 PIOD (Port I open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | 1 | PI3OD | PI2OD | 2-// | PI0OD | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------|------|----------------|----------| | 31-4 | - | R | Read as "0". | | | 3-2 | PI3OD-PI2OD | R/W | 0 : CMOS | | | | | | 1 : Open-drain | | | 1 | _ | R | Read as "0". | | | 0 | PI0OD | R/W | 0 : CMOS | | | | | | 1 : Open-drain | | # 8.2.9.7 PIPUP (Port I pull-up control register) | | 31 | 30 (/ | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|--------|------------|-------|-----------------------------------------|----|-----|----|----| | bit symbol | - / | | | $(\Omega/2)$ | - | - | - | 1 | | After reset | 0 | 0 | 7 0 | \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \ | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | -// | | - | - | = | - | | After reset | ⟨0, /⟩ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | <u></u> 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | (=) | ) | . ( ( | _ | | | | | | | | | 7 / / | - | - | - | - | • | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | After reset | 0 | 0 | 0 5 | | | 0 2 | 0 | 0 | | After reset | | | 5 | 0 | 0 | | | | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-1 | - | R | Read as "0". | | 0 | PI0UP | R/W | Pull-up | | | | | 0: Disable | | | | | 1: Enable | Page 183 2023/07/21 # 8.2.9.8 PIIE (Port I input control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-------|-------|-------|-------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 \ | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | 1 | 1 | - < | | ) - | ı | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | - | PI3IE | PI2IE | PI1IE | PIOIE | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | 0 | 0 | | | _ | | | | |------|-------------|------|--------------|----------| | Bit | Bit Symbol | Туре | | Function | | 31-4 | - | R | Read as "0". | | | 3-0 | PI3IE-PI0IE | R/W | Input | | | | | | 0: Disable | | | | | | 1: Enable | | ### 8.2.10 Port J (PJ0 to PJ7) The port J is an 8-bit input port. Besides the general-purpose input function, the port J performs the AD converter and the key-on wake-up function. Reset initializes all bits of the port J as general-purpose ports with input and pull-up disabled. The Port J has one types of of function register. If you use the port J as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port J as other than a general-purpose port, set "1" to the corresponding bit of the function register. Note: Unless you use all the bits of port J as analog input pins, conversion accurary may be reduced.Be sure to verify that this causes no problem on your system. ### 8.2.10.1 Port J Circuit Type | | 7 | 6 | 5 | 4 3 | 2 | 0 | |------|-----|-----|-----|---------|---------|-----| | Туре | T19 | T19 | T19 | T19 T18 | T17 T17 | T17 | ### 8.2.10.2 Port J register Base Address = 0x400C\_0900 | Register name | | Address (Base+) | |---------------------------------|--------|-----------------| | Port J data register | PJDATA | 0x0000 | | Port J function register 2 | PJFR2 | 0x000C | | Port J pull-up control register | PJPUP | 0x002C | | Port J input control register | PJIE | 0x0038 | ## 8.2.10.3 PJDATA (Port J data register) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|-----|-----|-----|-----|----------|--------|-------------|-----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PJ7 | PJ6 | PJ5 | PJ4 | PJ3 | PJ2 | PJ1 | PJ0 | | After reset | 1 | 1 | 1 | 1 | ((/1/5)) | 1 | | 1 | | | Bit | Bit Symbol | Туре | | Function | | |-----|-----|--------------|------|----------------------|----------|--| | 31- | -8 | - | R | Read as "0". | | | | 7-0 | ) | P 17 to P 10 | R | Port I data register | | | ## 8.2.10.4 PJFR2 (Port J function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-------------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PJ7F2 | PJ6F2 | PJ5F2 | PJ4F2 | PJ3F2 | - | 2-// | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PJ7F2 | R/W | 0: PORT | | | | | 1: KWUP3 | | 6 | PJ6F2 | R/W | 0: PORT | | | | | 1: KWUP2 | | 5 | PJ5F2 | R/W | 0: PORT | | | | | 1: KWUP1 | | 4 | PJ4F2 | R/W | 0: PORT | | | | | 1: KWUPO | | 3 | PJ3F2 | R/W | 0: PORT | | | | | 1: ADTRG | | 2-0 | _ | R | Read as "0". | ### 8.2.10.5 PJPUP (Port J pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|-----------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PJ7UP | PJ6UP | PJ5UP | PJ4UP | PJ3UP | PJ2UP | PUTUP | PJ0UP | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|------------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PJ7UP to<br>PJ0UP | R/W | Pull-up 0: Disable 1: Enable | | ## 8.2.10.6 PJIE (Port J input control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----------|-------|------------|----------|-------|-------|-------|-------| | bit symbol | - | - ((/ | / | / ( | 1 | - | - | - | | After reset | 0 | 0 | $\bigcirc$ | 07/ | 0 | 0 | 0 | 0 | | | 23 | 22 | 7 21 | 20 | ) 19 | 18 | 17 | 16 | | bit symbol | - | \\\\- | | | - | - | - | - | | After reset | 0 | 0 | 0/ | | 0 | 0 | 0 | 0 | | | <u> </u> | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 3// | h - | _ | <u> </u> | - | - | - | - | | After reset | 0 | 0 | 6 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PJ7IE | PJ6IE | RJ5IE | PJ4IE | PJ3IE | PJ2IE | PJ1IE | PJ0IE | | After reset | | (6 >/ | (b) | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|----------------|------|--------------| | 31-8 | _ | R | Read as "0". | | 7-0 | PJ7IE to PJ0IE | R/W | Input | | | | | 0: Disable | | | | | 1: Enable | ## 8.2.11 Port K (PK0 to PK7) The port K is an 8-bit input port. Besides the general-purpose input function, the port J performs the AD converter. Reset initializes all bits of the port K as general-purpose ports with input and pull-up disabled. Note: Unless you use all the bits of port K as analog input pins, conversion accurary may be reduced. Be sure to verify that this causes no problem on your system. ### 8.2.11.1 Port K Circuit Type | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | |------|-----|-----|-----|-----|-----|-----|-----|-----| | Туре | T17 ### 8.2.11.2 Port K register Base Address = 0x400C\_0A00 | | Register name | $\Diamond$ | Address (Base+) | |---------------------------------|---------------|------------|-----------------| | Port K data register | 4( / | PKDATA | 0x0000 | | Port K pull-up control register | | PKPUP | 0x002C | | Port K input control register | | PKIE | 0x0038 | ## 8.2.11.3 PKDATA (Port K data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-----|---------|------------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PK7 | PK6 | PK5 | PK4 | PK3 | PK2 | PK1 | PK0 | | After reset | 1 | 1 | 1 | 1 | | 1 | | 1 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PK7 to PK0 | R | Port K data register | # 8.2.11.4 PKPUP (POrt K pull-up control register) | | | | | | | ~ | | | |-------------|-------|-----------------------------|-------|-------|-------|-------|-------|-------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7// | - | - | - | | After reset | 0 | 0 | 0 | 0 🗸 | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PK7UP | PK6UP | PK5UP | PK4UP | PK3UP | PK2UP | PK1UP | PK0UP | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit Bit | Symbol Type | Function | |------------------|-------------|------------------------------| | 31-8 | R | Read as "0". | | 7-0 PK7U<br>PK0U | | Pull-up 0: Disable 1: Enable | ## 8.2.11.5 PKIE (Pork K input control register) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PK7IE | PK6IE | PK5IE | PK4IE | PK3IE | PK2IE | PK1IE | PK0IE | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|----------------|------|----------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PK7IE to PK0IE | R/W | Input 0: Disable 1: Enable | | | | | | | | Page 191 2023/07/21 #### 8.2.12 Port L (PL0 to PL7) The port L is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port L performs the serial channel, the serial bus interface, the external signal interrupt input and 16bit timer / event counter function. Reset initializes all bits of the port L as general-purpose ports with input, output and pull-up disabled. The Port L has three types of of function register. If you use the port L as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port L as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. Note:: In modes other than STOP mode, interrupt input is enabled regardless of the PxFR register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. #### 8.2.12.1 Port L Circut Type | | 7 | 6 | 5 | 4 | 3 | 2 1 | 0 | |------|-----|-----|-----|-----|-----|---------|-----| | Туре | T21 | T24 | T23 | T22 | T21 | T20 T20 | T20 | #### 8.2.12.2 Port L register Base Address = 0x400C\_0B00 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port L data register | PLDATA | 0x0000 | | Port L output control register | PLCR | 0x0004 | | Port L function register 1 | PLFR1 | 0x0008 | | Port L function register 2 | PLFR2 | 0x000C | | Port L function register 3 | PLFR3 | 0x0010 | | Port L open drain control register | PLOD | 0x0028 | | Port L pull-up control register | PLPUP | 0x002C | | Port L input control register | PLIE | 0x0038 | ### 8.2.12.3 PLDATA (Port L data register) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|-----|-----|-----|-----|-------|--------|-------------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PL7 | PL6 | PL5 | PL4 | PL3 | PL2 | PL1 | PL0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PL7 to PL0 | R/W | Port L data register | ## 8.2.12.4 PLCR (Port L output control register) | | | | | | | ~ | | | |-------------|------|------------|-------|-----------|------|------|------|------| | | 31 | 30 | 29 🖯 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | | - | - | - | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | / )-[ \ | ) . < | ( ( /// < | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | | | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PL7C | PL6C | PL5C | PL4C | PL3C | PL2C | PL1C | PL0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7-0 | PL7C to PL0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | Page 193 2023/07/21 ## 8.2.12.5 PLFR1 (Port K function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PL7F1 | PL6F1 | PL5F1 | PL4F1 | PL3F1 | PL2F1 | PL1F1 | PL0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------| | 31-8 | - | R | Read as "0". | | 7 | PL7F1 | R/W | 0: PORT | | | | | 1:INT1 | | 6 | PL6F1 | R/W | 0: PORT | | | | | 1: SCLK1 | | 5 | PL5F1 | R/W | 0: PORT | | | | | 1: RXD1 | | 4 | PL4F1 | R/W | 0: PORT | | | | | 1: TXD1 | | 3 | PL3F1 | R/W | 0: PORT | | | | | 1: INTO | | 2 | PL2F1 | R/W | 0: PORT | | | | | 1; SCK0 | | 1 | PL1F1 | Ŗ/W | 0: PORT | | | < | | 1: SCL0 / SI0 | | 0 | PL0F1 | R/W | 0; PORT | | | | | 1: SDA0 / SO0 | ### 8.2.12.6 PLFR2 (Port L function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>J</u> 77 | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PL7F2 | PL6F2 | PL5F2 | PL4F2 | PL3F2 | PL2F2 | PL1F2 | PL0F2 | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PL7F2 | R/W | 0: PORT | | | | | 1: TB7OUT | | 6 | PL6F2 | R/W | 0: PORT | | | | | 1: TB6OUT | | 5 | PL5F2 | R/W | 0: PORT | | | | | 1: TB5OUT | | 4 | PL4F2 | R/W | 0: PORT | | | | | 1: TB4OUT | | 3 | PL3F2 | R/W | 0: PORT | | | | | 1: TB3OUT | | 2 | PL2F2 | R/W | 0: PORT | | | | | 1; TB2OUT | | 1 | PL1F2 | Ŗ/W | 0: PORT | | | < | | 1: TB1OUT | | 0 | PL0F2 | R/W | 0; PORT | | | | | 1s TB0OUT | # 8.2.12.7 PLFR3 (Port L function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|----|----|------|----------|-------------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PL6F3 | - | 1 | | - | 2-// | - | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-7 | - | R | Read as "0". | | 6 | PL6F3 | R/W | 0 : PORT | | | | | 1: CTS1 | | 5-4 | _ | R/W | Write "0". | | 3-0 | - | R | Read as "0". | ## 8.2.12.8 PLOD (Port L open drain control register) | | | | | | - 11 | | | | |-------------|----------|----------|----------|-------|-------|-------|-------|-------| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | <u> </u> | / ))- | | 7 | - | - | - | | After reset | 0 / | 0 | | (0)/< | 0 | 0 | 0 | 0 | | | 23 | 22 | 7 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | | | | 1 | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | (15/) | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | <u> </u> | <u></u> | $\wedge$ | - | - | - | - | - | | After reset | 0 | 0 | No | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PL70D | PL6OD | PL5OD | PL4OD | PL3OD | PL2OD | PL10D | PL0OD | | After reset | 0 | (0/) | 9 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | _ | R | Read as "0". | | 7-0 | PL7OD to<br>PL0OD | R/W | 0 : CMOS<br>1 : Open-drain | ### 8.2.12.9 PLPUP (Port L pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PL7UP | PL6UP | PL5UP | PL4UP | PL3UP | PL2UP | PL1UP | PL0UP | | After reset | 0 | 0 | 0 | 0 | (0/1) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|------------------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PL7UP to<br>PL0UP | R/W | Pull-up<br>0: Disable<br>1: Enable | | ## 8.2.12.10 PLIE (Port L input control register) | | 31 | 30 | 29)) | 28 | 27 | 26 | 25 | 24 | |-------------|-------|----------------|---------|---------|-------|-------|-------|-------| | bit symbol | - | - ( | | - ( | | - | 1 | - | | After reset | 0 | 0 | / ) ) 0 | | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 // < | 19 | 18 | 17 | 16 | | bit symbol | - < | | 7 - < | | _ | - | 1 | - | | After reset | 0 | 9 | 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | <-√> | - | - | | - | - | - | - | | After reset | 0/ | <b>\( \)</b> 0 | /9 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | RL7IE | PL6IE | PL5IE | PL4IE | PL3IE | PL2IE | PL1IE | PL0IE | | After reset | | 0> | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|----------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7-0 | PL7IE to PL0IE | R/W | Input | | | | | 0: Disable | | | | | 1: Enable | Page 197 2023/07/21 #### 8.2.13 Port M (PM0 to PM7) The port M is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port M performs the serial channel, the external signal interrupt input,16bit timer / event counter and the alarm output function. Reset initializes all bits of the port M as general-purpose ports with input, output and pull-up disabled. The Port M has three types of of function register. If you use the port M as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port M as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. Note: In modes other than STOP mode, interrupt input is enabled regardless of the PxFR register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. #### 8.2.13.1 Port Circuit Type | | 7 | 6 | 5 | 4 3 | 2 1 | 0 | |------|-----|-----|-----|---------|---------|-----| | Туре | T30 | T29 | T28 | T27 T21 | T23 T26 | T25 | #### 8.2.13.2 Port M register Base Address = 0x400C\_0C00 | Register name | | Address (Base+) | |-------------------------------------|--------|-----------------| | Port M data register | PMDATA | 0x0000 | | Port M output control register | PMCR | 0x0004 | | Port M function register 1 | PMFR1 | 0x0008 | | Port M function register 2 | PMFR2 | 0x000C | | Port M function register 3 | PMFR3 | 0x0010 | | Port M open drain control registert | PMOD | 0x0028 | | Port M pull-up control register | PMPUP | 0x002C | | Port M input control register | PMIE | 0x0038 | #### 8.2.13.3 PMDATA (Port M data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|--------|-------------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PM7 | PM6 | PM5 | PM4 | PM3 | PM2 | PM1 | PM0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PM7 to PM0 | R/W | Port M data register | ## 8.2.13.4 PMCR (Port M output control register) | | | | | | | ~ | | | |-------------|------|-------------------|------|-------|------|------|------|------| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | | - | - | - | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | 23 | 22 | ))21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ ) \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | - | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PM7C | PM6C | PM5C | PM4C | РМ3С | PM2C | PM1C | PM0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PM7C to PM0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | Page 199 2023/07/21 ## 8.2.13.5 PMFR1 (Port M function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|------------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PM7F1 | PM6F1 | PM5F1 | PM4F1 | PM3F1 | PM2F1 | PM1F1 | PM0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PM7F1 | R/W | 0: PORT | | | | | 1: INT3 | | 6 | PM6F1 | R/W | 0: PORT | | | | | 1: RXD3 | | 5 | PM5F1 | R/W | 0: PORT | | | | | 1: TXD3 | | 4 | PM4F1 | R/W | 0: PORT | | | | | 1: SCLK3 | | 3 | PM3F1 | R/W | 0: PORT | | | | | 1: INT2 | | 2 | PM2F1 | R/W | 0: PORT | | | | | 1; RXD2 | | 1 | PM1F1 | R/W | 0: PORT | | | | | 1: TXD2 | | 0 | PM0F1 | R/W | 0; PORT | | | | | 1: SCLK2 | ## 8.2.13.6 PMFR2 (Port M function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-------|---------------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \rangle | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | - | PM3F2 | PM2F2 | PM1F2 | PM0F2 | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-4 | - | R | Read as "0". | | 3 | PM3F2 | R/W | 0: PORT | | | | | 1: TB3OUT | | 2 | PM2F2 | R/W | 0: PORT | | | | | 1: ALARM | | 1 | PM1F2 | R/W | 0: PORT | | | | | 1: TB1IN1 | | 0 | PM0F2 | R/W | 0: PORT | | | | | 1: TB1IN0 | Page 201 2023/07/21 ### 8.2.13.7 PMFR3 (Port M function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|-------|-------|---------|--------------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>1</b> 77 | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | - | PM4F3 | | - | <b>⊘-</b> // | PM0F3 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|------------|------|--------------|----------------------------| | 31-5 | ı | R | Read as "0". | | | 4 | PM4F3 | R/W | 0 : PORT | | | | | | 1 : CTS3 | | | 3-1 | - | R | Read as "0". | $\mathcal{A}(\mathcal{A})$ | | 0 | PM0F3 | R/W | 0 : PORT | | | | | | 1 : CTS2 | | ## 8.2.13.8 PMOD (Port M open drain control register) | | 31 | 30 (/ | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----------|------------|-------|-------|-------|-------|-------|-------| | bit symbol | - / | | )- , | (0) | - | - | - | - | | After reset | 0 < | 0 | 7 0 | | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | > | -// | | - | - | - | - | | After reset | ⟨0, /⟩ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | <u></u> 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | <u>.</u> | 4 | - | - | - | - | - | | After reset | ( ( 0 ) ) | 0 | 9 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6, | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PM7OD | PM6OD | PM50D | PM4OD | PM3OD | PM2OD | PM1OD | PM0OD | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PM7OD to<br>PM0OD | R/W | 0 : CMOS<br>1 : Open-drain | ### 8.2.13.9 PMPUP (Port M pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PM7UP | PM6UP | PM5UP | PM4UP | PM3UP | PM2UP | PM1UP | PM0UP | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|------------------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PM7UP to<br>PM0UP | R/W | Pull-up<br>0: Disable<br>1: Enable | | ## 8.2.13.10 PMIE (Port M input control register) | | 31 | 30 | 29)) | 28 | 27 | 26 | 25 | 24 | |-------------|-----------|----------------|---------|---------|------------|-------|-------|-------| | bit symbol | - | - 6 | | - < | | - | - | - | | After reset | 0 | 0 | / ) ) 0 | | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 // < | 19 | 18 | 17 | 16 | | bit symbol | - < | 1 | 7 - < | | <i>)</i> - | - | - | - | | After reset | 0 | 9 | 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | < <u></u> | - | - | | - | - | - | - | | After reset | 0 | <b>\( \)</b> 0 | /9 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PM7IE | PM6IE | PM5IE | PM4IE | PM3IE | PM2IE | PM1IE | PM0IE | | After reset | | 0> | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PM7IE to<br>PM0IE | R/W | Input 0: Disable 1: Enable | Page 203 2023/07/21 #### 8.2.14 Port N (PN0 to PN7) The port N is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port N performs the serial channel, the external signal interrupt input, 16bit timer / counter and the remote control signal preprocessor input function. Reset initializes all bits of the port N as general-purpose ports with input, output and pull-up disabled. The Port N has three types of of function register. If you use the port N as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port N as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. Note: In modes other than STOP mode, interrupt input is enabled regardless of the PxFR register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. #### 8.2.14.1 Port N Circuit Type | | _ | | | | | | | |------|-----|-----|-----|-------|--------|-----|-----| | | 7 | 6 | 5 | 4 | 3 2 | ) 1 | 0 | | Туре | T30 | T25 | T29 | T28 T | 30 T25 | T29 | T28 | #### 8.2.14.2 Port N register Base Address = 0x400C\_0D00 | Register name | | Address (Base+) | |-------------------------------------|--------|-----------------| | Port N data register | PNDATA | 0x0000 | | Port N output control register | PNCR | 0x0004 | | Port N function register 1 | PNFR1 | 0x0008 | | Port N function register 2 | PNFR2 | 0x000C | | Port N function register 3 | PNFR3 | 0x0010 | | Port N open drain control registert | PNOD | 0x0028 | | Port N pull-up control register | PNPUP | 0x002C | | Port N input control register | PNIE | 0x0038 | ### 8.2.14.3 PNDATA (Port N data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|---------|-----------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PN7 | PN6 | PN5 | PN4 | PN3 | PN2 | PN1 | PN0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PN7 to PN0 | R/W | Port N data register | # 8.2.14.4 PNCR (Port N output control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|------| | bit symbol | - | - | | 1 | \\ - | - | - | - | | After reset | 0 | 0 | | 0 | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 < | 19 | 18 | 17 | 16 | | bit symbol | - | | ( ) ) - | | 7 | - | - | - | | After reset | 0 | / )0 | <ul><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li><!--</td--><td>(0//</td><td>0</td><td>0</td><td>0</td><td>0</td></li></ul> | (0// | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | 1. | | | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7, | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PN7C | PN6C | PN5C | PN4C | PN3C | PN2C | PN1C | PN0C | | After reset | 0 | 0 | (0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Type / | Function | |------|--------------|--------|-----------------------------| | 31-8 | | R | Read as "0". | | 7-0 | PN7C to PN0C | R/W | Output 0: Disable 1: Enable | Page 205 2023/07/21 ## 8.2.14.5 PNFR1 (Port N function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PN7F1 | PN6F1 | PN5F1 | PN4F1 | PN3F1 | PN2F1 | PN1F1 | PN0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PN7F1 | R/W | 0: PORT | | | | | 1:INT8 | | 6 | PN6F1 | R/W | 0: PORT | | | | | 1: SCLK5 | | 5 | PN5F1 | R/W | 0: PORT | | | | | 1: RXD5 | | 4 | PN4F1 | R/W | 0: PORT | | | | | 1: TXD5 | | 3 | PN3F1 | R/W | 0: PORT | | | | | 1: INT4 | | 2 | PN2F1 | R/W | 0: PORT | | | | | 1; SCLK4 | | 1 | PN1F1 | R/W | 0: PORT | | | < | | 1: RXD4 | | 0 | PN0F1 | R/W | 0; PORT | | | | | 1s.TXD4 | ## 8.2.14.6 PNFR2 (Port N function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|----|----|-------|----------|--------------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PN7F2 | PN6F2 | - | - | PN3F2 | PN2F2 | <b>⊘-</b> // | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PN7F2 | R/W | 0: PORT | | | | | 1: TBFIN1 | | 6 | PN6F2 | R/W | 0: PORT | | | | | 1: TBFINO | | 5-4 | - | R | Read as "0". | | 3 | PN3F2 | R/W | 0: PORT | | | | | 1: TB2IN1 | | 2 | PN2F2 | R/W | 0: PORT | | | | | 1: TB2IN0 | | 1-0 | - | R | Read as "0": | Page 207 2023/07/21 ## 8.2.14.7 PNFR3 (Port N function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|----|----|-------|----------|-------------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PN7F3 | PN6F3 | - | 1 | PN3F3 | PN2F3 | 2-// | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | | _ | | | |--------|------------|------|--------------| | Bit | Bit Symbol | Туре | Function | | 31-8 | - | R | Read as "0". | | 7 | PN7F3 | R/W | 0 : PORT | | | | | 1 : RMC1 | | 6 | PN6F3 | R/W | 0 : PORT | | | | | 1 : CTS5 | | 5-4 | - | R | Read as "0". | | 3 | PN3F3 | R/W | 0 : PORT | | | | | 1 : RMC0 | | 2 | PN2F3 | R/W | 0 : PORT | | | | | 1 : CTS4 | | 1 to 0 | - | R | Read as "0": | #### 8.2.14.8 PNOD (Port N open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PN7OD | PN6OD | PN5OD | PN4OD | PN3OD | PN2OD | PN10D | PN0OD | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|----------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PN7OD to<br>PN0OD | R/W | D : CMOS<br>1 : Open-drain | | ### 8.2.14.9 PNPUP (Port N pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-----------------------------|-------|----------|-------|-------|-------|-------| | bit symbol | - | - | | - < | | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | 6 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | | <u>-</u> | - | - | - | - | | After reset | Q/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PN7UP | PN6UP | PN5UP | PN4UP | PN3UP | PN2UP | PN1UP | PN0UP | | After reset | (0)) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|------------------------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PN7UP to<br>PN0UP | R/W | Pull-up 0: Disable 1: Enable | Page 209 2023/07/21 ## 8.2.14.10 PNIE (Port N input control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|--------|------------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PN7IE | PN6IE | PN5IE | PN4IE | PN3IE | PN2IE | PN1IE | PN0IE | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | #### 8.2.15 Port O (PO0 to PO7) The port O is a general-purpose, 8-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port O performs the serial channel function (UART/SIO), external signal interrupt input and 16bit timer / event counter output function. Reset initializes all bits of the port O as general-purpose ports with input, output and pull-up disabled. The Port O has three types of of function register. If you use the port O as a general-purpose port, set "0" to the corresponding bit of the three registers. If you use the port O as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the some function registers at the same time. Note: In modes other than STOP mode, interrupt input is enabled regardless of the POFR1 register setting if input is enabled in PxIE. Make sure to disable unused interrupts when programming the device. #### 8.2.15.1 Port O Circuit Type | | 7 | 6 | 5 | 4 3 | 2 1 | 0 | |------|-----|-----|-----|---------|---------|-----| | Туре | T21 | T24 | T23 | T22 T21 | T24 T23 | T22 | #### 8.2.15.2 Port O register Base Address = 0x400C\_0E00 | Register name | | Address (Base+) | |-------------------------------------|--------|-----------------| | Port O data register | PODATA | 0x0000 | | Port O output control register | POCR | 0x0004 | | Port O function register 1 | POFR1 | 0x0008 | | Port O function register 2 | POFR2 | 0x000C | | Port O function register 3 | POFR3 | 0x0010 | | Port O open drain control registert | POOD | 0x0028 | | Port O pull-up control register | POPUP | 0x002C | | Port O input control register | POIE | 0x0038 | ### 8.2.15.3 PODATA (Port O data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|-----|-----|-------|---------|-----------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | P07 | P06 | PO5 | PO4 | PO3 | PO2 | P01 | P00 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PO7 to PO0 | R/W | Port O data register | ## 8.2.15.4 POCR (Port O output control register) | | | | | | | ~ | | | |-------------|------|-----------------------------|------------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7// | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | ) <u> </u> | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PO7C | PO6C | PO5C | PO4C | PO3C | PO2C | PO1C | PO0C | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-8 | 1 | R | Read as "0". | | 7-0 | PO7C to PO0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | ### 8.2.15.5 POFR1 (Port O function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>1</b> 77 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PO7F1 | PO6F1 | PO5F1 | PO4F1 | PO3F1 | PO2F1 | P01F1 | PO0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PO7F1 | R/W | 0: PORT | | | | | 1:INTA | | 6 | PO6F1 | R/W | 0: PORT | | | | | 1: SCLK7 | | 5 | PO5F1 | R/W | 0: PORT | | | | | 1: RXD7 | | 4 | PO4F1 | R/W | 0: PORT | | | | | 1: TXD7 | | 3 | PO3F1 | R/W | 0: PORT | | | | | 1: INT9 | | 2 | PO2F1 | R/W | 0: PORT | | | | | 1; SQLK6 | | 1 | PO1F1 | R/W | 0: PORT | | | | | 1: RXD6 | | 0 | PO0F1 | R/W | 0; PORT | | | | | 1: TXD6 | ## 8.2.15.6 POFR2 (Port O function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|----------|-------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) \) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PO7F2 | PO6F2 | PO5F2 | PO4F2 | PO3F2 | PO2F2 | PO1F2 | PO0F2 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-8 | - | R | Read as "0". | | 7 | PO7F2 | R/W | 0: PORT | | | | | 1:TBFOUT | | 6 | PO6F2 | R/W | 0: PORT | | | | | 1: TBEOUT | | 5 | PO5F2 | R/W | 0: PORT | | | | | 1: TBDOUT | | 4 | PO4F2 | R/W | 0: PORT | | | | | 1: TBCOUT | | 3 | PO3F2 | R/W | 0: PORT | | | | | 1: TBBOUT | | 2 | PO2F2 | R/W | 0: PORT | | | | | 1; TBAOUT | | 1 | PO1F2 | R/W | 0: PORT | | | < | | 1: TB9OUT | | 0 | PO0F2 | R/W | 0; PORT | | | | | 1s.TB8OUT | ### 8.2.15.7 POFR3 (Port O function register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|----|----|-------|--------|-------------|----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PO6F3 | - | - | | PO2F3 | 0-// | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|------------|------|--------------|----------| | 31-7 | - | R | Read as "0". | | | 6 | PO6F3 | R/W | 0 : PORT | | | | | | 1 : CTS7 | | | 5-3 | _ | R | Read as "0". | | | 2 | PO2F3 | R/W | 0 : PORT | | | | | | 1 : CTS6 | | | 1-0 | _ | R | Read as "0". | | ## 8.2.15.8 POOD (Port O open drain control register) | | 31 | 30 | 29 | 287/ | 27 | 26 | 25 | 24 | |-------------|---------------------------|----------------|-------|-------|-------|-------|-------|-------| | bit symbol | - ( | / | 7 - < | | ) - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | $\langle \rangle \rangle$ | - | - | - | - | - | - | - | | After reset | 0 | <b>\( \)</b> 0 | Q | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | ((-)) | - | | - | 1 | - | - | - | | After reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | (6 /> \ | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PO7OD | PO6OD | PO5OD | PO4OD | PO3OD | PO2OD | PO10D | PO0OD | | , , | | | | | | | | | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PO7OD to<br>PO0OD | R/W | 0 : CMOS<br>1 : Open-drain | Page 215 2023/07/21 ### 8.2.15.9 POPUP (Port O pull-up control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|---------|-----------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | Q | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | PO7UP | PO6UP | PO5UP | PO4UP | PO3UP | PO2UP | PO1UP | PO0UP | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|-------------------|------|------------------------------|----------| | 31-8 | - | R | Read as "0". | | | 7-0 | PO7UP to<br>PO0UP | R/W | Pull-up 0: Disable 1: Enable | | ## 8.2.15.10 POIE (Port O input control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|------------|----------|----------|-------|-------|-------|-------| | bit symbol | - | - ( | | - < | | - | - | - | | After reset | 0 | 0 | 0 ( | | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 // < | 19 | 18 | 17 | 16 | | bit symbol | - < | 1 | 7 - < | | / - | - | - | - | | After reset | 0 | Q | 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | \-\/\ | - | - | <u> </u> | - | - | - | - | | After reset | 0/ | <b>)</b> 0 | <u> </u> | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | PO7IE | PO6IE | PO5IE | PO4IE | PO3IE | PO2IE | PO1IE | PO0IE | | After reset | | 0> | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|----------------------------| | 31-8 | - | R | Read as "0". | | 7-0 | PO7IE to<br>PO0IE | R/W | Input 0: Disable 1: Enable | #### 8.2.16 Port P (PP0 to PP6) The port P is a general-purpose, 7-bit input / output port. For this port, inputs and outputs can be specified in units of bits. Besides the general-purpose input / output function, the port P performs the external bus interface, and SSP function. Reset initializes all bits of the port P as general-purpose ports with input, output and pull-up disabled. The Port P has two types of of function register. If you use the port P as a general-purpose port, set "0" to the corresponding bit of the two registers. If you use the port P as other than a general-purpose port, set "1" to the corresponding bit of the function register. Do not set "1" to the both function registers at the same time. #### 8.2.16.1 Port P Circuit Type | | 7 | 6 | 5 | 4 | (73 | 2 | (1) | 0 | |------|---|----|-----|-----|------|-----|-----|----| | Туре | - | T5 | T35 | T34 | T33) | T32 | T31 | T5 | #### 8.2.16.2 Port P register Base Address = 0x400C\_0F00 | Register name | | Address (Base+) | |------------------------------------|--------|-----------------| | Port P data register | PPDATA | 0x0000 | | Port P output control register | /RPCR | 0x0004 | | Port P function register 1 | PRFR1 | 0x0008 | | Port P function register 2 | PPFR2 | 0x000C | | Port P open drain control register | PPOD | 0x0028 | | Port P pull-up control register | PPPUP | 0x002C | | Port P input control register | PPIE | 0x0038 | ## 8.2.16.3 PPDATA (Port P data register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-----|-----|-----|-------|---------|------------|-----| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PP6 | PP5 | PP4 | PP3 | PP2 | PP1 | PP0 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------| | 31-7 | - | R | Read as "0". | | 6-0 | PP6 to PP0 | R/W | Port P data register | ## 8.2.16.4 PPCR (Port P output control register) | | | | | | | ~ | | | |-------------|-----|-----------------------------|------------|-------|------|------|------|------| | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | | - < | 7// | - | - | - | | After reset | 0 | 0 | 0 | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | ) <u> </u> | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | -// | 1 | - | - | - | - | | After reset | 0/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | PP6C | PP5C | PP4C | PP3C | PP2C | PP1C | PP0C | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|--------------| | 31-7 | - | R | Read as "0". | | 6-0 | PP6C to PP0C | R/W | Output | | | | | 0: Disable | | | | | 1: Enable | ## 8.2.16.5 PPFR1 (Port P function register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|-------|-------|-------|---------|------------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 8 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u></u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) p | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PP6F1 | PP5F1 | PP4F1 | PP3F1 | PP2F1 | PP1F1 | PP0F1 | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------| | 31-7 | - | R | Read as "0". | | 6 | PP6F1 | R/W | 0: PORT | | | | | 1: ALE | | 5 | PP5F1 | R/W | 0: PORT | | | | | 1: OE | | 4 | PP4F1 | R/W | 0: PORT | | | | | 1: WE | | 3 | PP3F1 | R/W | 0: PORT | | | | | 1: BLS1 | | 2 | PP2F1 | R/W | 0: PORT | | | | | 1: BLS0 | | 1 | PP1F1 | R/W | Write "0". | | 0 | PP0F1 | R/W | 0; PORT | | | <b> </b> | | )1: <del>CS2</del> | ## 8.2.16.6 PPFR2 (Port P function register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|-------|-------|-------|--------|-------------|----| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <u>)</u> 17 | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | - | PP5F2 | PP4F2 | PP3F2 | PP2F2 | 0-// | - | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------| | 31-6 | - | R | Read as "0". | | 5 | PP5F2 | R/W | 0: PORT | | | | | 1: SPFSS | | 4 | PP4F2 | R/W | 0: PORT | | | | | 1: SPCLK | | 3 | PP3F2 | R/W | 0: PORT | | | | | 1: SPDI | | 2 | PP2F2 | R/W | 0: PORT | | | | | 1: SPDO | | 1-0 | - | R | Read as "0". | ### 8.2.16.7 PPOD (Port P open drain control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|-------|-------|-------|-------|---------|-----------|-------| | bit symbol | - | - | - | - | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -) ) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PP6OD | PP5OD | PP4OD | PP3OD | PP2OD | PP10D | PP00D | | After reset | 0 | 0 | 0 | 0 | (0/0) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | | |------|-------------------|------|----------------------------|--| | 31-7 | - | R | Read as "0". | | | 6-0 | PP6OD to<br>PP0OD | R/W | 0 : CMOS<br>1 : Open-drain | | ### 8.2.16.8 PPPUP (Port P pull-up control register) | | 31 | 30 | 29 🔨 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----------------------------|-------|----------|-------|-------|-------|-------| | bit symbol | - | - | | - < | 7// | - | - | - | | After reset | 0 | 0 0 | | 0 ( | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | $/ \rightarrow \downarrow $ | | ((/// | - | - | - | - | | After reset | 0 | | 7 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | | <u> </u> | - | - | - | - | | After reset | Q/ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7/\ | <b>)</b> 6 | /5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | (- | PP6UP | PR5UP | PP4UP | PP3UP | PP2UP | PP1UP | PP0UP | | After reset | (0) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|------------------------------| | 31-7 | 1 | R | Read as "0". | | 6-0 | PP6UP to<br>PP0UP | R/W | Pull-up 0: Disable 1: Enable | Page 221 2023/07/21 ## 8.2.16.9 PPIE (Port P input control register) | | 31 | 30 | 29 | 28 | 27 | 26 _ | 25 | 24 | |-------------|----|-------|-------|-------|-------|--------|-----------|-------| | bit symbol | - | - | - | 1 | - | - \ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | <b>17</b> | 16 | | bit symbol | - | - | - | - | - | (-0) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | )) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | PP6IE | PP5IE | PP4IE | PP3IE | PP2IE | PP11E | PP0IE | | After reset | 0 | 0 | 0 | 0 | (0/1) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | | Function | |------|----------------|------|----------------------------|----------| | 31-7 | - | R | Read as "0". | | | 6-0 | PP6IE to PP0IE | R/W | Input 0: Disable 1: Enable | | | | | | • | | TOSHIBA TMPM362F10FG ## 8.3 Block Diagrams of Ports ### 8.3.1 Port Types The ports are classified as shown below. Please refer to the following pages for the block diagrams of each port type. Dot lines in the figure indicate the part of the equivalent circuit described in the "Block diagrams of ports". Table 8-3 Function lists | _ | Input/ | | | | | - :: | Program- | | |------|---------|-------------|------------|--------------|---------------|---------|---------------------|---------------------------------| | Туре | Output | Function1 | Function2 | Function3 | Analog | Pull-up | mable<br>open-drain | Note | | T1 | I/O | I/O | - | - | - | R | | | | T2 | I/O | Output | Output | - | - | R | 0 | | | T3 | I/O | Output | Input | - | - | R | 0 | | | T4 | I/O | Output | I/O | Input | - ( | //R | 0 < | | | T5 | I/O | Output | ı | - | | R | 0 | $(\mathcal{A})$ | | T6 | I/O | Input (int) | Output | - | 4 | R | 0 | | | T7 | I/O | Output | ı | - | \(\frac{-\}{} | R | • | | | Т8 | I/O | I/O | Input | - ( | | R | | | | T9 | I/O | I/O | 1 | Input | - | R | (%) | | | T10 | I/O | Input (int) | I | Input | >- | R | | | | T11 | I/O | Input (int) | 1 | Output | > - / | R | 0 | | | T12 | I/O | I/O | Input | | _ | R | ) ) o | | | T13 | I/O | Input (int) | Input | (-) | - | R | 0 | | | T14 | I/O | - | | )- | - < | R | 0 | BOOT input enabled during reset | | T15 | I/O | Input | | ) - | -(6 | 1 | ı | Nch open drain port | | T16 | I/O | Input (int) | 7/ | 1 | 4 | NoR | 0 | | | T17 | Input | <u>-</u> | | - / | 79 | R | - | | | T18 | Input / | Input | ) | ( - \ | ((o)) | R | ı | | | T19 | Input | Input | <br> -<br> | - | 0 | R | ı | | | T20 | I/O | 1/0 | Output | | _ | R | 0 | | | T21 | \VO\> | Input | Output | <del>-</del> | - | R | 0 | | | T22 | 1/0 | Output | Output | _ | - | R | 0 | | | T23 | 1/0 | Input | Output | - | _ | R | 0 | | | T24 | 1/0 | I/O | Output | Input | - | R | 0 | | | T25 | )9 | 1/0 | Input | Input | - | R | 0 | | | T26 | Ю | Output | Input | - | - | R | 0 | | | T27 | I/O | 1/0 | ۱ ( | Output | - | R | 0 | | | T28 | ) I/O | Output | <u>\_</u> | - | - | R | 0 | | | T29 | I/O | Input | - | - | - | R | 0 | | | T30 | I/O | Input (int) | 1 | - | - | R | 0 | | | T31 | I/O | - | 1 | - | - | R | 0 | | | T32 | I/O | Output | Output | - | - | R | 0 | | | T33 | I/O | Output | Input | - | - | R | 0 | | | T34 | I/O | Output | I/O | - | - | R | 0 | | | T35 | I/O | Output | 1 | - | - | R | 0 | | int : Interrupt input - : Not exist o: exist R : Forced disable during reset NoR : Unaffected by reset #### 8.3 Block Diagrams of Ports Table 8-3 Function lists | Туре | Input/<br>Output | Function1 | Function2 | Function3 | Analog | Pull-up | Program-<br>mable<br>open-drain | Note | |------|------------------|-----------|-----------|-----------|--------|---------|---------------------------------|---------------------------| | T36 | I/O | Output | Output | Output | - | R | 0 | | | T37 | I/O | Output | Input | Input | - | R | 0 | | | T38 | I/O | I/O | Output | Output | - | R | 0 | $\langle \rangle \rangle$ | | T39 | I/O | Input | Input | Output | ı | R | 0 | | int : Interrupt input - : Not exist o : exist R : Forced disable during reset NoR : Unaffected by reset # 8.3.2 Type T1 Page 225 2023/07/21 # 8.3.3 Type T2 ### 8.3.4 Type T3 Page 227 2023/07/21 ## 8.3.5 Type T4 Figure 8-4 Port Type T4 ## 8.3.6 Type T5 Page 229 2023/07/21 ## 8.3.7 Type T6 ### 8.3.8 Type T7 Page 231 2023/07/21 Figure 8-8 Port Type T8 ## 8.3.10 Type T9 Page 233 2023/07/21 ### 8.3.12 Type T11 Page 235 2023/07/21 # 8.3.13 Type T12 ### 8.3.14 TypeT13 Page 237 2023/07/21 # 8.3.15 Type T14 ## 8.3.16 Type T15 Page 239 2023/07/21 ## 8.3.17 TypeT16 ## 8.3.18 Type T17 Page 241 2023/07/21 ## 8.3.20 Type T19 Page 243 2023/07/21 ### 8.3.21 Type T20 ### 8.3.22 Type T21 Page 245 2023/07/21 ## 8.3.23 Type T22 ### 8.3.24 Type T23 Page 247 2023/07/21 ### 8.3.25 Type T24 ### 8.3.26 Type T25 Figure 8-25 Port Type T25 Page 249 2023/07/21 ### 8.3.27 TypeT26 ### 8.3.28 Type T27 Page 251 2023/07/21 # 8.3.29 Type T28 ### 8.3.30 Type T29 Page 253 2023/07/21 ## 8.3.32 Type T31 Page 255 2023/07/21 ### 8.3.34 Type T33 Page 257 2023/07/21 ## 8.3.35 Type T34 ### 8.3.36 Type T35 Page 259 2023/07/21 ### 8.3.38 Type T37 Page 261 2023/07/21 ### 8.3.39 Type T38 ### 8.3.40 Type T39 Figure 8-39 Port Type T39 Page 263 2023/07/21 #### 8.4 Appendix (Port setting List) ### 8.4 Appendix (Port setting List) The following table shows the register setting for each function. Initialization of the ports where the o does not exist in the "After reset" field is set to "0" for all register settings. Setting for the bit "×" can be arbitrarily-specified. ### 8.4.1 Port A setting Table 8-4 Port Setting List (Port A) | Pin | Port<br>Type | Function | After reset | PACR | PAFR1 | PAOD | PAPUP | PAIE | |------|------------------|--------------------------------------|--------------|-----------------------|----------------|------|------------|------| | | | Input Port | | 0 | 0 | × | × | 1 | | PA0 | T1 | Output Port | | 10 | 7,0 | × | × | 0 | | 17.0 | | Data (I/O) / Address data (I/O) | | 1 | ) <del>1</del> | × | × | 1) | | | | Input Port | | 0 | 0 | × | × | 1 | | PA1 | T1 | Output Port | 40 | <del>\frac{f}{}</del> | 0 | *( | × | 0 | | | | Data (I/O) / Address data (I/O) | | <u></u> | 1 ( | | \(\sigma\) | 1 | | | | Input Port | | 0 | 0 | (×) | × | 1 | | PA2 | T1 | Output Port | $\nearrow$ | 1// | 0 | × | × | 0 | | | | Data (I/O) / Address da-<br>ta (I/O) | $\Diamond$ | 1 | 1 | ) × | × | 1 | | | | Input Port | | 0 | 0 | × | × | 1 | | PA3 | T1 | Output Port | | Y | 0 | × | × | 0 | | | | Data (I/O) / Address data (I/O) | _ | 1 | ) 1 | × | × | 1 | | | | Input Port | | 19 | 0 | × | × | 1 | | PA4 | // <sub>T1</sub> | Output Port | $\square(7/$ | <b>∆</b> 1 | 0 | × | × | 0 | | , | | Data (I/O) / Address data (I/O) | | / 1 | 1 | × | × | 1 | | | | Input Port | | 0 | 0 | × | × | 1 | | PA5 | T1 | Output Port | | 1 | 0 | × | × | 0 | | | $\searrow$ | Data (I/O) / Address data (I/O) | <b>&gt;</b> | 1 | 1 | × | × | 1 | | | | Input Port | | 0 | 0 | × | × | 1 | | PA6 | T1 ^ | Output Port | | 1 | 0 | × | × | 0 | | | | Data (I/O) / Address data (I/O) | | 1 | 1 | × | × | 1 | | | 7 | Input Port | | 0 | 0 | × | × | 1 | | PA7 | T1 | Output Port | | 1 | 0 | × | × | 0 | | | | Data (I/O) / Address data (I/O) | | 1 | 1 | × | × | 1 | ### 8.4.2 Port B Setting Table 8-5 Port Setting List (Port B) | Pin | Port<br>Type | Function | After reset | PBCR | PBFR1 | PBOD | PBPUP | PBIE | |----------------------------------------|--------------|--------------------------------------|-------------|-------------|-------|-------------------|-------------|------| | | | Input port | | 0 | 0 | × | × | 1 | | PB0 | T1 | Output port | | 1 | 0 | ( <del>*</del> 7/ | × | 0 | | | | Data (I/O) / Address data (I/O) | | 1 | 1 | × | <i>//</i> × | 1 | | | | Input port | | 0 | 0 (( | × | × | 1 | | PB1 | T1 | Output port | | 1 | 0 | )* | × | 0 | | | | Data (I/O) / Address da-<br>ta (I/O) | | 1 < | 1 | × | * < | 1 | | | | Input port | | 0 | \_0\ | × | × 1 | 1> | | PB2 | T1 | Output port | | 1// | | × | × V | 0 | | | | Data (I/O) / Address data (I/O) | | 1 | 1 | × | × | 9 | | | | Input port | 20 | 0 | 0 | *( | × | 1 | | PB3 | T1 | Output port | | 1 | 0 | × . | Z.k | 0 | | | | Data (I/O) / Address da-<br>ta (I/O) | | 1 | 1 | (/x) | × | 1 | | | | Input port | | 0// | 0 | × | × | 1 | | PB4 | T1 | Output port | /> | 1 | 0 | ) × | × | 0 | | | | Data (I/O) / Address data (I/O) | | 1 | \ | × | × | 1 | | | | Input port | | 0 | 0 | × | × | 1 | | PB5 | T1 | Output port | | 7 | 0 | × | × | 0 | | | | Data (I/O) / Address data (I/O) | 4 | 7 | 1 | × | × | 1 | | | | Input port | (0) | | 0 | × | × | 1 | | PB6 | T1/ | Output port | | <i>//</i> 1 | 0 | × | × | 0 | | | | Data (I/O) / Address da-<br>ta (I/O) | | 1 | 1 | × | × | 1 | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | , | Input port | | 0 | 0 | × | × | 1 | | PB7 | <b>J</b> 1) | Output port | $\supset$ | 1 | 0 | × | × | 0 | | | | Data (I/O) / Address data (I/O) | | 1 | 1 | × | × | 1 | ### 8.4 Appendix (Port setting List) ## 8.4.3 Port C Setting Table 8-6 Port Setting List (Port C) | | | 7 | | - | | | | | | | |-----|-----------------|------------------|---------------|------|-------|-------|--------|--------|-------|------| | Pin | Port<br>Type | Function | After reset | PCCR | PCFR1 | PCFR2 | PCFR3 | PGOD | PCPUP | PCIE | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | DOO | то. | Output port | | 1 | 0 | 0 | (07/ | × | × | 0 | | PC0 | T2 | Address (Output) | | 1 | 1 | 0 | 0 | ))× | × | 0 | | | | TXD8 (Output) | | 1 | 0 | 1 ( | 9 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | | × | × | 1 | | DC4 | Т3 | Output port | | 1 | 0 | 0 | )° | × | (× | 0 | | PC1 | 13 | Address (Output) | | 1 | 1 | 0 | → o | × < | ( × ) | > o | | | | RXD8 (Input) | | 0 | 0 | \ | 0 | × | × | 1 | | | | Input port | | 0 | 6 | ) 0 | 0 <> | (×) | × | 1 | | | | Output port | | 1 ( | 0 | 0 | 0 | XX | | 0 | | PC2 | T4 | Address (Output) | | 1 | 1 | 0 | 0/ | × | )× | 0 | | PG2 | 14 | SCLK8 (Input) | | 0 | 0 | 1 | ) | $\sim$ | × | 1 | | | | SCLK8 (Output) | / | | 0 | 1 | 0 | × | × | 0 | | | | CTS8 (Input) | | 0 | 0 | 0 | V/1 )) | × | × | 1 | | | | Input port | 4( | 0 | 0 | 6 | ) | × | × | 1 | | PC3 | T5 | Output port | | 1 | 6 | 0 | 0 | × | × | 0 | | | | Address (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | DC4 | TO | Output port | $\Diamond$ | 1 | 0 | 0 | 0 | × | × | 0 | | PC4 | T2 | Address (Output) | <i>)</i> | 1 | | 0 | 0 | × | × | 0 | | | | TXD9 (Output) | | 1 < | | 1 | 0 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | PC5 | тз < | Output port | | 4/ | ) ) o | 0 | 0 | × | × | 0 | | PC5 | 13 | Address (Output) | | ) | 1 | 0 | 0 | × | × | 0 | | | | RXD9 (Input) | $\overline{}$ | 0 | 0 | 1 | 0 | × | × | 1 | | | $\wedge \wedge$ | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | 7/ | Output port | | √ 1 | 0 | 0 | 0 | × | × | 0 | | DOC | (T) | Address (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | PC6 | (T4) | SCLK9 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | SCLK9 (Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | 4 | CTS9 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | PC7 | T5 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | | | Address (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | # 8.4.4 Port D Setting Table 8-7 Port Setting List (Port D) | Pin | Port<br>Type | Function | After reset | PDCR | PDFR1 | PDFR2 | PDFR3 | PDOD | PDPUP | PDIE | |------|-----------------|------------------|-----------------|------|-------|-------|-------|------|-------|------| | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | (07) | × | × | 0 | | PD0 | T2 | Address (Output) | | 1 | 1 | 0 | 0 | ))× | × | 0 | | | | TXD10 (Output) | | 1 | 0 | 1 ( | 9 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | 9 | × | × | 1 | | 55.4 | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PD1 | T3 | Address (Output) | | 1 | 1 | 0 | 0 | × < | ( × | > o | | | | RXD10 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | Input port | | 0 | 6// | ) ) | 0 🔷 | (×O | X | 1 | | | | Output port | | 1 ( | 0 | 0 | 0 | XX | 1 ×/ | 0 | | DD2 | T4 | Address(Output) | | 1 | 1 | 0 | 0/ | × | )× | 0 | | PD2 | 14 | SCLK10 (Input) | | 0 | 0 | 1 | | (x) | × | 1 | | | | SCLK10 (Output) | | Ţ | 0 | 1 / | 6 | × | × | 0 | | | | CTS10 (Input) | | 0 | > 0 | 0 | V/1 ) | × | × | 1 | | | | Input port | 4 | 0 | 0 | 0 | ) | × | × | 1 | | PD3 | T5 | Output port | | 1 | 6 | 0 | 0 | × | × | 0 | | | | Address (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | Input port | $\bigg) \bigg)$ | 0 | 0 | 0 | 0 | × | × | 1 | | DD4 | то | Output port | $\Diamond$ | 1 | 0 | 0 | 0 | × | × | 0 | | PD4 | T2 | Address (Output) | | 1 | | 0 | 0 | × | × | 0 | | | | TXD11 (Output) | | 1 < | 9 | 1 | 0 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | DDE | тз < | Output port | | 4/ | )) o | 0 | 0 | × | × | 0 | | PD5 | 13 | Address (Output) | | ) | 1 | 0 | 0 | × | × | 0 | | | | RXD11 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | $\wedge \wedge$ | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | 2/ | Output port | | √ 1 | 0 | 0 | 0 | × | × | 0 | | PD6 | (TA) | Address (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | FD0 | (T4) | SCLK11 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | SCLK11 (Output) | $\rightarrow$ | 1 | 0 | 1 | 0 | × | × | 0 | | | // | CTS11 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | PD7 | Т6 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | FUI | 10 | Address (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | INTB (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | Page 267 2023/07/21 ### 8.4 Appendix (Port setting List) ### 8.4.5 Port E Setting Table 8-8 Port Setting List (Port E) | | | | | - | | | | $\sim$ | | | |-----|-----------------|------------------|-------------|------|----------|-------|-------|--------|-------|------| | Pin | Port<br>Type | Function | After reset | PECR | PEFR1 | PEFR2 | PEFR3 | PEOD | PEPUP | PEIE | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | DEO | т2 | Output port | | 1 | 0 | 0 | (07/ | × | × | 0 | | PE0 | T3 | Address (Output) | | 1 | 1 | 0 | 0 | ))× | × | 0 | | | | TB5IN0 (Input) | | 0 | 0 | 1 ( | 9 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | | × | × | 1 | | DE4 | Т3 | Output port | | 1 | 0 | 0 | )° | × | (× | 0 | | PE1 | 13 | Address (Output) | | 1 | 1 | 0 | → o | × < | (× / | ○ 0 | | | | TB5IN1 (Input) | | 0 | 0 | 7 | 0 | × | × | 1 | | | | Input port | | 0 | 6// | ) 0 | 0 🔷 | (×) | × | 1 | | DEO | то | Output port | | 1 ( | 0 | 0 | 0 | X | 1(x) | 0 | | PE2 | Т3 | Address (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | TB6IN0 (Input) | | 0 | 0 | 1 | | (x) | × | 1 | | | | Input port | / | 0 | <b>0</b> | 0 | 0 | × | × | 1 | | DEO | то. | Output port | | 1 | 0 | 0 | V/6 ) | × | × | 0 | | PE3 | Т3 | Address (Output) | 4 | 1 | 1 // | 0 | 0 | × | × | 0 | | | | TB6IN1 (Input) | | 0 | 6 | 1 | 0 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PE4 | T2 | Address (Output) | $\Diamond$ | 1 | 4 | 0 | 0 | × | × | 0 | | | | TXD0 (Output) | <i>)</i> | 1 | 6 | 1 | 0 | × | × | 0 | | | | Input port | | 0 < | 6 | 0 | 0 | × | × | 1 | | | | Output port | | (1) | 0 | 0 | 0 | × | × | 0 | | PE5 | T3 / | Address (Output) | | (4/ | ))1 | 0 | 0 | × | × | 0 | | | | RXD0 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | $\wedge \wedge$ | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | 250 | 2/ | Address (Output) | | √ 1 | 1 | 0 | 0 | × | × | 0 | | PE6 | T4 | SCLK0 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | $((\ ))$ | SCLK0 (Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | | CTS0 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | DEZ | TO | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PÈ7 | T6 | INT5 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | SCOUT (Output) | | 1 | 0 | 0 | 1 | × | × | 0 | # 8.4.6 Port F Setting Table 8-9 Port Setting List (Port F) | Pin | Port<br>Type | Function | After reset | PFCR | PFFR1 | PFOD | PFPUP | PFIE | |-----|--------------|-------------------------|-------------|------------|-------|---------------------|----------------|------| | | | Input port | | 0 | 0 | × | × | 1 | | PF0 | T7 | Output port | | 1 | ^ o | $(\nearrow/\langle$ | × | 0 | | | | TRACECLK (Output) | | 1 | 4 | (x) | / × | 0 | | | | Input port | | 0 | 0 | ) × | × | 1 | | PF1 | T7 | Output port | | 1 | 0 | )× | × | 0 | | | | TRACEDATA0/SWV (Output) | | 1 ( | 1 | × | × | 0 | | | | Input port | | 0 | 0 | × | × | 1 | | PF2 | T7 | Output port | | (1) | 0 | × | × | 9 | | | | TRACEDATA1 (Output) | | (1/ | ) 1 | <>> | $(\mathbf{x})$ | O O | | | | Input port | | | 0 | × | X | ]/1 | | PF3 | T7 | Output port | | 1 | 0 | × | × | 0 | | | | TRACEDATA2 (Output) | 4 | <u>\</u> 1 | 1 | × | ) ) × | 0 | | | | Input port | | 0 | 0 | >>× C | × | 1 | | PF4 | T7 | Output port | | 1 | 0( | / *) | × | 0 | | | | TRACEDATA3 (Output) | | 1 | | × | × | 0 | ### 8.4 Appendix (Port setting List) ## 8.4.7 Port G Setting Table 8-10 Port Setting List (Port G) | Pin | Port<br>Type | Function | After reset | PGCR | PGFR1 | PGFR2 | PGFR3 | PGOD | PGPUP | PGIE | |----------|-----------------|-----------------|---------------|------|-------|-------|---------------|------|-------|------| | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | (07) | × | × | 0 | | PG0 | T8 | SO1 (Output) | | 1 | 1 | 0 | 0 | ))× | × | 0 | | | | SDA1 (I/O) | | 1 | 1 | 0 ( | 9 | 1 | × | 1 | | | | TB7IN0 (Input) | | 0 | 0 | 1 | <b>1</b> | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × < | ( x | > o | | PG1 | Т8 | SI1 (Input) | | 0 | 1 | 0 | 0 | × | X | 1 | | | | SCL1 (I/O) | | 1 | 4 | 0 | 0 > | (1) | X | 1 | | | | TB7IN1 (Input) | | 0 / | 0 | 1 | 0 | X | ( *) | 1 | | | | Input port | | 0 | 0 | 0 | 0/ | × | × | 1 | | | | Output port | | 4 | 0 | 0 | | × | × | 0 | | PG2 | Т9 | SCK1 (Input) | , | 0 | ) 1 | 0 | 0 | ✓× | × | 1 | | | | SCK1 (Output) | | 1 | 1 | 0 | <b>(</b> /6 ) | × | × | 0 | | | | CTS0 (Input) | 40 | 0 | 0 / | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 6 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | / o | × | × | 0 | | PG3 | T10 | INT6 (Input) | | 0 | _1 | 0 | 0 | × | × | 1 | | | | CTS1 (Input) | $\Diamond$ | 0 | 0 | 0 | 1 | × | × | 1 | | | | Input port | 7) | 0 | (0) | 0 | 0 | × | × | 1 | | | | Output port | | 1 < | 0 | 0 | 0 | × | × | 0 | | PG4 | Т8 | SO2 (Output) | | (1) | 1 | 0 | 0 | × | × | 0 | | | / | SDA2 (I/O) | | (4/ | ))1 | 0 | 0 | 1 | × | 1 | | | | TB9IN0 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | $\wedge \wedge$ | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PG5 | 78 | SI2 (Input) | | → o | 1 | 0 | 0 | × | × | 1 | | | | SCL2 (I/O) | | 1 | 1 | 0 | 0 | 1 | × | 1 | | $\wedge$ | | TB9IN1 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | Input port | $\rightarrow$ | 0 | 0 | 0 | 0 | × | × | 1 | | | _/_ | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PG6 | Т9 | SCK2 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | SCK2 (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | CTS3 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PG7 | T11 | INT7 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | WDTOUT (Output) | | 1 | 0 | 0 | 1 | × | × | 0 | # 8.4.8 Port H Setting Table 8-11 Port Setting List (Port H) | Pin | Port<br>Type | Function | After reset | PHCR | PHFR1 | PHFR2 | PHOD | PHPUP | PHIE | |-----|--------------|----------------|-------------|------------|-------------------------------|------------|-------------------|---------------|---------| | | | Input port | | 0 | 0 | 0 | × | | 1 | | | | Output port | | 1 | 0 | 0 ( | $7 \times \wedge$ | × | 0 | | PH0 | T12 | SO3 (Output) | | 1 | 1 | 0 | (x) | × | 0 | | | | SDA3 (I/O) | | 1 | 1 | 0 | 1 | × | 1 | | | | TBAIN0 (Input) | | 0 | 0 | | ))′× | × | 1 | | | | Input port | | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 8 | 0 | × | × | 0 | | PH1 | T12 | SI3 (Input) | | 0 | $\bigcirc 1 \rangle_{\wedge}$ | <b>○</b> 0 | × | X. | <u></u> | | | | SCL3 (I/O) | | 1 | $\sqrt{1}$ | 0 | <>1 ( | $\bigcirc x)$ | 1 | | | | TBAIN1 (Input) | | 0 | 0 | 1 | × | × | // 1 | | | | Input port | | 0 | 0 | 0 | (×) | × _ | 1 | | | | Output port | < | (1) | <b>)</b> 0 | 0 | (*) | ) × | 0 | | PH2 | T12 | SCK3 (Input) | | 0 | 1 | 9 | >,* | × | 1 | | | | SCK3 (Output) | 20 | <b>\</b> | 1 | 0 | * | × | 0 | | | | TBBIN0 (Input) | 1 | <b>0</b> | 0 | 1 | × | × | 1 | | | | Input port | | 0 | ( o | 9 | × | × | 1 | | | | Output port | 1) | 1 | 0 | 0/ | × | × | 0 | | PH3 | T13 | INT6 (Input) | | 0 | 1 | <b>1</b> 0 | × | × | 1 | | | | TBBIN1 (Input) | | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 70 | 0 | × | × | 1 | | | | Output port | | | 0 | 0 | × | × | 0 | | PH4 | T12 | SO4 (Output) | | | → 1 | 0 | × | × | 0 | | | | SDA4 (I/O) | ( | // 1)) | 1 | 0 | 1 | × | 1 | | | | TBDIN0 (Input) | | 0 | 0 | 1 | × | × | 1 | | | | Input port | | <b>)</b> 0 | 0 | 0 | × | × | 1 | | _ | \ \ \ | Output port | | 1 | 0 | 0 | × | × | 0 | | PH5 | T12 | SI4 (Input) | | 0 | 1 | 0 | × | × | 1 | | | | SCL4 (I/O) | | 1 | 1 | 0 | 1 | × | 1 | | | | TBDIN1 (Input) | | 0 | 0 | 1 | × | × | 1 | | /// | | Input port | | 0 | 0 | 0 | × | × | 1 | | | > | Output port | | 1 | 0 | 0 | × | × | 0 | | PH6 | T12 | SCK2 (Input) | | 0 | 1 | 0 | × | × | 1 | | | | SCK2 (Output) | | 1 | 1 | 0 | × | × | 0 | | * | | TBEIN0 (Input) | | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | × | × | 0 | | PH7 | T13 | INT7 (Input) | | 0 | 1 | 0 | × | × | 1 | | | | TBEIN1 (Input) | | 0 | 0 | 1 | × | × | 1 | ### 8.4.9 Port I Setting Table 8-12 Port Setting List (Port I) | Port | | | | | | | | |------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------------------|-------------|------| | Туре | Function | After reset | PICR | PIFR1 | PIOD | PIPUP | PIIE | | T4.4 | Input port | | 0 | 0 | × | X | 1 | | 114 | Output port | | 1 | 0 | ( <del>*</del> 7) | × | 0 | | | Input port | | 0 | /0 | × | <i>))</i> × | 1 | | T15 | Output port | | 1 | 0 | × | × | 0 | | | CEC (Input) | | 0 | 1 | ×) | × | 1 | | | Input port | | 0 | 9 | ) × | × | ) | | T16 | Output port | | 1 | 0 | × | × < | 0 | | | INTE (Input) | | 0 | 7 | × | × | 4 | | | Input port | | 6// | ) 0 | × | (×) | | | T16 | Output port | | 7 | 0 | × | × | 10// | | | INTF (Input) | | 0 | 1 | × | × | 1 | | | T14 T15 T16 | T14 Input port Output port Input port T15 Output port CEC (Input) Input port T16 Output port INTE (Input) Input port T16 Output port Output port T16 Output port | T14 Input port Output port Input port T15 Output port CEC (Input) Input port T16 Output port INTE (Input) Input port T16 Output port Output port T17 Output port T18 Output port | Input port 0 | T14 | T14 | T14 | Note: The PI0 input and pull-up are enabled and act as BOOT input pin while a RESET is in "Low" state. # 8.4.10 Port J Setting Table 8-13 Port Setting List (Port J) | Pin | Port<br>Type | Function | After reset | PJFR2 | PJPUP | РЫЕ | |-----|--------------|---------------|-------------|-------|-------|---------------| | PJ0 | T17 | Input port | | 0 | × | $\mathcal{F}$ | | F30 | 117 | Analog input | | 0 | (07) | <b>0</b> | | PJ1 | T17 | Input port | | 0 | XX | <u> </u> | | FJI | 117 | Analog input | | 0 ( | 0 | 0 | | PJ2 | T17 | Input port | | 0 | ×)/ | 1 | | PJ2 | 117 | Analog input | | 0 | 0 | 0 | | | | Input port | < | 0 | × | 1 < | | PJ3 | T18 | Analog input | 0 | 0 | 0 | 0/4 | | | | ADTRG (Input) | | | × | (1) | | | | Input port | | 0 | × | 173 | | PJ4 | T19 | Analog input | | 0 | 0/ | 0 | | | | KWUP0 (Input) | | 1 | *(_ | <u></u> | | | | Input port | | 0 | × | $\sim_1$ | | PJ5 | T19 | Analog input | > | 0 | (/o) | 0 | | | | KWUP1 (Input) | | 1 | × | 1 | | | | Input port | | 0 | × | 1 | | PJ6 | T19 | Analog input | | 0 | 0 | 0 | | | | KWUP2 (Input) | | 1 | × | 1 | | | | Input port | | 0 | × | 1 | | PJ7 | T19 | Analog input | (4) | 0 | 0 | 0 | | | (7) | KWUP3 (Input) | 7// | 1 | × | 1 | # 8.4 Appendix (Port setting List) #### Port K Setting 8.4.11 | Pin | Port<br>Type | Function | After reset | PKPUP | PKIE | | |------|--------------|--------------|---------------|---------------|----------------------|---------| | DICO | T17 | Input port | | × | 1 | <i></i> | | PK0 | 117 | Analog input | | 0 ( | $\bigcirc 0 \land$ | | | PK1 | T17 | Input port | | × | (1) | | | FKI | 117 | Analog input | | 0 | 0 | | | PK2 | T17 | Input port | | × | )) 1 | | | FNZ | 117 | Analog input | | 0 | 0 | | | PK3 | T17 | Input port | (1) | × | 1 | 1/2 | | FN3 | 117 | Analog input | | <b>&gt;</b> 0 | 0 | 77// | | PK4 | T17 | Input port | | × | <>1 ( | 9)6 | | FN4 | 117 | Analog input | | 0 | 0 | 790) | | PK5 | T17 | Input port | | × | 7 | | | FNJ | 117 | Analog input | $\rightarrow$ | 0 | | ) | | PK6 | T17 | Input port | | × | $\rightarrow \wedge$ | | | FNU | 117 | Analog input | | 6 | ) ) | | | PK7 | T17 | Input port | | × | 1 | | | FK/ | 117 | Analog input | | 9 | 0 | | | | | | | | | | # 8.4.12 Port L Setting Table 8-15 Port Setting List (Port L) | Pin | Port<br>Type | Function | After reset | PLCR | PLFR1 | PLFR2 | PLFR3 | PLOD | PLPUP | PLIE | |-----|--------------|----------------|---------------|------|-------|-------|-------|------|-------|------| | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | (07) | × | × | 0 | | PL0 | T20 | SO0 (Output) | | 1 | 1 | 0 | 0 | ))× | × | 0 | | | | SDA0 (I/O) | | 1 | 1 | 0 ( | 0 | 1 | × | 1 | | | | TB0OUT(Output) | | 1 | 0 | 1 | | × | × | 0 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × < | ( × | > o | | PL1 | T20 | SI0 (Input) | | 0 | 10 | > 0 | 0 | × | × | 1 | | | | SCL0 (I/O) | | 1 | 4// | ) 0 | 0 > | (1) | X | 1 | | | | TB1OUT(Output) | | 1 / | 0 | 1 | 0 | X | 1(*) | 0 | | | | Input port | | 0 | 0 | 0 | 0/ | × | × | 1 | | | | Output port | | 4 | 0 | 0 | | × | × | 0 | | PL2 | T20 | SCK0 (Input) | / | 0 | ) 1 | 0 | 0 | ✓× | × | 1 | | | | SCK0 (Output) | | 1 | 1 | 0 | V/6 ) | × | × | 0 | | | | TB2OUT(Output) | 4 | 1 | 0 / | 1 | • | × | × | 0 | | | | Input port | | 0 | 6< | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PL3 | T21 | INT0 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | TB3OUT(Output) | $\wedge$ | 1 | 0 | 1 | 0 | × | × | 0 | | | | Input port | )) | 0 | (0) | 0 | 0 | × | × | 1 | | | | Output port | | 1 < | 0 | 0 | 0 | × | × | 0 | | PL4 | T22 | TXD1 (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | TB4OUT(Output) | ^ | (4// | )) o | 1 | 0 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PL5 | T23 | RXD1 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | >/< | TB5OUT(Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | ^ | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | | | SCLK1 (Input) | $\rightarrow$ | 0 | 1 | 0 | 0 | × | × | 1 | | PL6 | T24 | SCLK1 (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | TB6OUT(Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | | CTS1 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PL7 | T21 | INT1 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | TB7OUT(Output) | | 1 | 0 | 1 | 0 | × | × | 0 | Page 275 2023/07/21 ### 8.4 Appendix (Port setting List) ### 8.4.13 Port M Setting Table 8-16 Port Setting List (Port M) | | 1 | 1 | | | | | | | | | |-------|--------------|----------------|-------------|------|---------|-------|-------------|-------------|----------------|------------| | Pin | Port<br>Type | Function | After reset | PMCR | PMFR1 | PMFR2 | PMFR3 | PMOD | PMPUP | PMIE | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | (0) | × | × | 0 | | PM0 | T25 | SCLK2 (Input) | | 0 | 1 | 0 | 0 | <i>))</i> × | × | 1 | | PIVIU | 125 | SCLK2 (Output) | | 1 | 1 | 0 ( | 9 | × | × | 0 | | | | TB1IN0 (Input) | | 0 | 0 | 1 | | × | × | 1 | | | | CTS2 (Input) | | 0 | 0 | 0 | )1 | × | (× | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × < | × / | <b>)</b> 1 | | DM4 | T00 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PM1 | T26 | TXD2 (Output) | | 1 | 4// | 9 | 0 | (×O | X | 0 | | | | TB1IN1 (Input) | | 0 ( | 0 | 1 | 0 | X | 1( <b>y</b> // | 1 | | | | Input port | | 0 | 0 | 0 | 0/ | × | × | 1 | | D140 | T00 | Output port | | 4 | 0 | 0 | | (x) | × | 0 | | PM2 | T23 | RXD2 (Input) | / | 0 | <u></u> | 0 | 0 | ✓× | × | 1 | | | | ALARM (Output) | | 1 | > 0 | 1 \ | <b>V</b> /6 | × | × | 0 | | | | Input port | 4 | 0 | 0 / | 0 | 0 | × | × | 1 | | 21.40 | | Output port | | 1 | 6 | 0 | 0 | × | × | 0 | | PM3 | T21 | INT2 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | TB3OUT(Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | | Input port | $\Diamond$ | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | 7) | 1 | (6) | 0 | 0 | × | × | 0 | | PM4 | T27 | SCLK3 (Input) | | 0 < | 1 | 0 | 0 | × | × | 1 | | | | SCLK3 (Output) | | (1) | 1 | 0 | 0 | × | × | 0 | | | /. | CTS3 (Input) | <u> </u> | 0/ | )) o | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | PM5 | T28 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | | ^ ^ | TXD3 (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | 7/ | Input port | | > o | 0 | 0 | 0 | × | × | 1 | | PM6 | T29 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | ^ | | RXD3 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | Input port | $\Diamond$ | 0 | 0 | 0 | 0 | × | × | 1 | | PM7 | T30 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | | | INT3 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | 7 / | | | | | | | | | # 8.4.14 Port N setting Table 8-17 Port Setting List (Port N) | Pin | Port<br>Type | Function | After reset | PNCR | PNFR1 | PNFR2 | PNFR3 | PNOD | PNPUP | PNIE | |----------|--------------|----------------|-----------------|------|----------|-------|----------------|------|----------------|------| | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | PN0 | T28 | Output port | | 1 | 0 | 0 | (07/ | × | × | 0 | | | | TXD4 (Output) | | 1 | 1 | 0 | 0 | ))× | × | 0 | | | | Input port | | 0 | 0 | 0 ( | 9 | × | × | 1 | | PN1 | T29 | Output port | | 1 | 0 | 0 | | × | × | 0 | | | | RXD2 (Input) | | 0 | 1 | 0 | )° | × | (× | 1 | | | | Input port | | 0 | 0 | 0 | У <sub>0</sub> | × < | /( × / | → 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | DNIO | T05 | SCLK4 (Input) | | 0 | 4// | ) ) | 0 🔷 | (×O | X | 1 | | PN2 | T25 | SCLK4 (Output) | | 1 ( | 1 | 0 | 0 | X | 1( <b>y</b> // | 0 | | | | TB2IN0 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | CTS4 (Input) | | 9 | 0) | 0 | | (x) | × | 1 | | | | Input port | / | 0 | <b>0</b> | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | V/6 ) | × | × | 0 | | PN3 | T30 | INT4 (Input) | 4( | 0 | 1 // | 0 | 0 | × | × | 1 | | | | TB2IN1 (Input) | | 0 | 6 | 1 | 0 | × | × | 1 | | | | RMC0 (Input) | | 0 | 0 | 0 | / 1 | × | × | 1 | | | | Input port | $\bigg) \bigg)$ | 0 | 0 | 0 | 0 | × | × | 1 | | PN4 | T28 | Output port | $\Diamond$ | 1 | 0 | 0 | 0 | × | × | 0 | | | | TXD5 (Output) | <i>)</i> | 1 | | 0 | 0 | × | × | 0 | | | | Input port | | 0 < | 0 | 0 | 0 | × | × | 1 | | PN5 | T29 | Output port | | (1) | 0 | 0 | 0 | × | × | 0 | | | | RXD5 (Input) | | 0/ | ))1 | 0 | 0 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | DNC | \_Tor\\ | SCLK5 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | PN6 | T25 | SCLK5 (Output) | | √ 1 | 1 | 0 | 0 | × | × | 0 | | | | TBFIN0 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | $\wedge$ | $((\ ))$ | CTS5 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PN7 | T30 | INT8 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | > | TBFIN1 (Input) | | 0 | 0 | 1 | 0 | × | × | 1 | | | | RMC1 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | Page 277 2023/07/21 ### 8.4 Appendix (Port setting List) ## 8.4.15 Port O Setting Table 8-18 Port Setting List (Port O) | Pin | Port | Function | After | POCR | POFR1 | POFR2 | POFR3 | POOD | POPUP | POIE | |------|-----------------|-----------------|------------|--------|----------|---------|------------|------------------|----------------|----------------------| | | Туре | 1 direction | reset | 1 0011 | 1 01 111 | 1 01112 | 1 01110 | ( 300) | > | . 0.2 | | | | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | PO0 | T22 | Output port | | 1 | 0 | 0 | (07/ | \(\neg \times \) | × | 0 | | 1 00 | 122 | TXD6 (Output) | | 1 | 1 | 0 | 0 | //× | × | 0 | | | | TB8OUT (Output) | | 1 | 0 | 1 ( | 9 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | | × | × | 1 | | PO1 | T23 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | POI | 123 | RXD6 (Input) | | 0 | 1 | 9 | 0 | × < | ( x | <b>\rightarrow</b> 1 | | | | TB9OUT (Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | | Input port | | 0 | 6// | ) ) | 0 | (×O | X | 1 | | | | Output port | | 1 ( | 0 | 0 | 0 | X | 1( <b>y</b> // | 0 | | DOG | T04 | SCLK6 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | PO2 | T24 | SCLK6 (Output) | | 4 | 1) | 0 | | (x) | × | 0 | | | | TBAOUT (Output) | | ) | 0 | 1 | 0 | × | × | 0 | | | | CTS6 (Input) | | 0 | > 0 | 0 | $\sqrt{1}$ | × | × | 1 | | | | Input port | 4 | 0 | 0 / | 0 | 0 | × | × | 1 | | D00 | <b>T</b> 0.4 | Output port | | 1 | 6 | 0 | 0 | × | × | 0 | | PO3 | T21 | INT9 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | TBBOUT (Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | T00 | Input port | $\Diamond$ | 0 | 0 | 0 | 0 | × | × | 1 | | DO 4 | | Output port | <i>)</i> | 1 | (6) | 0 | 0 | × | × | 0 | | PO4 | T22 | TXD7 (Output) | | 1 < | 71/ | 0 | 0 | × | × | 0 | | | | TBCOUT (Output) | | (1) | 0 | 1 | 0 | × | × | 0 | | | | Input port | | 0/ | )) o | 0 | 0 | × | × | 1 | | BO5 | Too | Output port | | | 0 | 0 | 0 | × | × | 0 | | PO5 | T23 | RXD7 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | $\wedge \wedge$ | TBDOUT (Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | 7/ | Input port | | > o | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PQ6 | | SCLK7 (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | PO6 | T24 | SCLK7 (Output) | | 1 | 1 | 0 | 0 | × | × | 0 | | | | TBEOUT (Output) | | 1 | 0 | 1 | 0 | × | × | 0 | | | | CTS7 (Input) | | 0 | 0 | 0 | 1 | × | × | 1 | | | > | Input port | | 0 | 0 | 0 | 0 | × | × | 1 | | D07 | T04 | Output port | | 1 | 0 | 0 | 0 | × | × | 0 | | PO7 | T21 | INTA (Input) | | 0 | 1 | 0 | 0 | × | × | 1 | | | | TBFOUT (Output) | | 1 | 0 | 1 | 0 | × | × | 0 | # 8.4.16 Port P Setting Table 8-19 Port Setting List (Port P) | Pin | Port<br>Type | Function | After reset | PPCR | PPFR1 | PPFR2 | PPOD | PRPUP | PPIE | |-----|-------------------|----------------|-------------|------------|---------------------|---------------|------------------|---------------|------| | | | Input port | | 0 | 0 | 0 | )× | × | 1 | | PP0 | T5 | Output port | | 1 | 0 | 0 ( | $\nearrow \land$ | × | 0 | | | | CS2 (Output) | | 1 | 1 | 6 | \\<br>\\ | × | 0 | | PP1 | T31 | Input port | | 0 | 0 | 0 | ) × | × | 1 | | PPT | 131 | Output port | | 1 | 0 | 0 | )) × | × | 0 | | | | Input port | | 0 | 0 | 0 | × | × | 1 | | PP2 | T32 | Output port | | 1 | 0 | o | × | × | 0 | | PP2 | 132 | BLS0 (Output) | | 1 / | | <b>&gt;</b> 0 | × | Y<br>Y | 0 | | | | SPDO (Output) | | 1 | <u>(0)</u> | 1 | | ) <b>x</b> )/ | 0 | | | | Input port | | 0 | 0 | 0 | \ <u>\</u> | )<br>)<br>) | // 1 | | PP3 | T33 | Output port | | | 0 | 0 | (× | )<br>/* | 0 | | FF3 | | BLS1 (Output) | < | 1 | <b>)</b> 1 | 0 | × | ) × | 0 | | | | SPDI (Input) | | 0 | 0 | 10 | >_ <b>x</b> | × | 1 | | | | Input port | 4 | 0 | 0 | 6 | <b>)</b> } | × | 1 | | | | Output port | 1( // | <b>)</b> 1 | 0 | Q | × | × | 0 | | PP4 | T34 | WE (Output) | | 1 1 | $\langle 1 \rangle$ | 9 | × | × | 0 | | | | SPCLK (Input) | | 0 | 0 | 1/ | × | × | 1 | | | | SPCLK (Output) | | 1 | 0 | 1 | × | × | 0 | | | | Input port | | 0 | 0 | 0 | × | × | 1 | | | | Output port | | 1 | 70 | 0 | × | × | 0 | | PP5 | T35 | OE (Output) | | 1 | 1 | 0 | × | × | 0 | | | | SPFSS (Input) | | | $\nearrow$ 0 | 1 | × | × | 1 | | | | SPFSS (Output) | 1 | // 1)) | 0 | 1 | × | × | 0 | | | | Input port | | ) 🔊 | 0 | 0 | × | × | 1 | | PP6 | T5 | Output port | | <u></u> | 0 | 0 | × | × | 0 | | | $\langle \rangle$ | ALE (Output) | | 1 | 1 | 0 | × | × | 0 | # 9. DMA Controller(DMAC) # 9.1 Overview The table below lists its major functions. Table 9-1 DMA controller functions (1 Unit) | Item | Function | Description | | | |-----------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Number of channels | 2ch | ( ( ) ) - | | | | Number of DMA request | 16 | - | | | | DMA Start up | Hardware start | Started with DMA request for peripheral circuit. | | | | trigger | Software start | Started with a write to the DMACxSoftBReq register. | | | | Bus master | 32bit × 1 (AHB) | | | | | Priority | High: CH0<br>Low: CH1 | Fixed | | | | FIFO | 4word × 2ch (1word = 32bit) | | | | | Bus width | 8/16/32bit | Settable individually for transfer source and destination. | | | | Burst size | 1/4/8/16/32/64/128/256 | · · · · · · · · · · · · · · · · · · · | | | | Number of transfers | up to 4095 | <u>-</u> | | | | Address | Transfer source address increment not increment | It is possible to specify whether Source and Destination addresses should increment or | | | | | Transfer destination address increment not increment | should not increment. (Address wrapping is not supported.) | | | | Endian | Littleendian is supported. | - | | | | Transfer type | Peripheral to Memory Memory to Peripheral | When "Memory to Memory" is selected, hardware start for DMA startup is not supported. Refer to the DMACxCnConfiguration for | | | | | Memory to Memory Peripheral to Peripheral | more information. Particular peripheral can be assigned as Source or Distination when "Peripheral to Peripheral" is selected. Regarding to peripheral assigned, refer to "9.4.1 Peripheral function supported with Peripheral to Peripheral Transfer". TMPM362F10FG does not support Peripher- | | | | \\ | | al to Peripheral. | | | | Interrupt function | Transfer end interrupt (INTDMACxTC) Error interrupt (INTDMACxERR) | - | | | | Special Function | Scatter/gather function | - | | | Page 281 2023/07/21 ### 9.2 DMA transfer type Table 9-2 DMA transfer type | No. | DMA transfer<br>type | Circuit<br>generated DMA<br>request | DMA request type | Description | | | | | |-----|---------------------------|-------------------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 1 | Memory to Pe-<br>ripheral | Peripheral (Destination) | Burst request | In case of 1word transmission, set to the "1" for burst size of DMA controller. | | | | | | 2 | Peripheral to<br>Memory | Peripheral<br>(Source) | Burst request /<br>single request | If the amount of transfer data is not an integral multiple of the burst size, both burst and single request can be used. If amount of transfer data is more or equal than burst size, the single request is ignored and the burst transfer is used. If it becomes less than burst size, the single transfer is used. | | | | | | 3 | Memory то<br>Memory | DMAC | None | Enabling the DMAC starts data transfer without DMAC request. (Select Memory to Memory mode, set DMACxCnConfiguration <e> to "1") When All transfer data is transferred completely or when the DMAC channel is disabled, DMAC is stopped.</e> | | | | | | 4 | Peripheral to | Peripheral<br>(Source) | Burst request / single request | Transfer size Source Destination (1)An integral multiple of the burst size Burst request Burst request | | | | | | | Peripheral | | | (2)Not an integral multiple of the burst size Burst request / single request - | | | | | Note: When much data is transferred in memory to memory, we recommend that a lower priority channel is used. If a lower priority channel is used, a higher priority channel can be started to transfer during a lower priority channel is transferring. If a higher priority channel is used, a lower priority channel can not be started to transfer during a higher priority channel is transferring. TMPM362F10FG ### 9.3 Block diagram Figure 9-1 DMAC Block diagram Page 283 2023/07/21 ### 9.4 Product information of TMPM362F10FG ### 9.4.1 Peripheral function supported with Peripheral to Peripheral Transfer Peripheral functions (Register) supported with Peripheral to Peripheral Transfer are shown below. TMPM362F10FG does not support Peripheral to Peripheral Transfer. ### 9.4.2 DMA request DMA request against each DMA request no. are shown as bellows. Table 9-3 DMA request factor | | Corresponding peripheral | | | | | | | |-----------------|-------------------------------------|----------------|--|--|--|--|--| | DMA request No. | ch0,ch1 | | | | | | | | request ivo. | Burst request | Single request | | | | | | | 0 | SIO0/UART0 Transmission / Reception | | | | | | | | 1 | SIO1/UART1 Transmission / Reception | | | | | | | | 2 | SIO2/UART2 Transmission / Reception | <u> </u> | | | | | | | 3 | SIO3/UART3 Transmission / Reception | <u>//</u> | | | | | | | 4 | SIO4/UART4 Transmission / Reception | - | | | | | | | 5 | | <u>→</u> | | | | | | | 6 ( ( // | - 3 | _ | | | | | | | 7 | - (7) | - | | | | | | | /8 | (\-\V) | - | | | | | | | 9 | | - | | | | | | | 10 | | - | | | | | | | 11 | | - | | | | | | | 12 | SSP Transmission | - | | | | | | | 13 | SSP Reception | SSP Reception | | | | | | | 14 | | - | | | | | | | 15 (( | Normal AD Conversion End | - | | | | | | ### 9.4.3 Interrupt request | Transfer complete interrupt | Error interrupt | |-----------------------------|-----------------| | INTDMACTC | INTDMACERR | # 9.4.4 Base address of registers Page 285 2023/07/21 ### 9.5 Description of Registers ### 9.5.1 DMAC register list The function and address for each register are shown bellow. | Register Name | | Address (Base+) | |---------------------------------------------------|------------------------|-----------------| | DMAC Interrupt Status Register | DMACxIntStaus | 0x0000 | | DMAC Interrupt Terminal Count Status Register | DMACxIntTCStatus | 0x0004 | | DMAC Interrupt Terminal Count Clear Register | DMACxIntTCClear | 0x0008 | | DMAC Interrupt Error Status Register | DMACxIntErrorStatus | 0x000C | | DMAC Interrupt Error Clear Register | DMACxIntErrClr | 0x0010 | | DMAC Raw Interrupt Terminal Count Status Register | DMACxRawIntTCStatus | 0x0014 | | DMAC Raw Error Interrupt Status Register | DMACxRawIntErrorStatus | 0x0018 | | DMAC Enabled Channel Register | DMACxEnbldChns | 0x001C | | DMAC Software Burst Request Register | DMACxSoftBReq | 0x0020 | | DMAC Software Single Request Register | DMACxSoftSReq | 0x0024 | | Reserved | | 0x0028 | | Reserved | | 0x002C | | DMAC Configuration Register | DMACxConfiguration | 0x0030 | | Reserved | - | 0x0034 | | DMAC Channel0 Source Address Register | DMACxC0SrcAddr | 0x0100 | | DMAC Channel0 Destination Address Register | DMACxC0DestAddr | 0x0104 | | DMAC Channel0 Linked List Item Register | DMACxC0LLI | 0x0108 | | DMAC Channel0 Control Register | DMACxC0Control | 0x010C | | DMAC Channel0 Configuration Register | DMACxC0Configuration | 0x0110 | | DMAC Channel1 Source Address Register | DMACxC1SrcAddr | 0x0120 | | DMAC Channel1 Destination Address Register | DMACxC1DestAddr | 0x0124 | | DMAC Channel1 Linked List Item Register | DMACxC1LLI | 0x0128 | | DMAC Channel1 Control Register | DMACxC1Control | 0x012C | | DMAC Channel 1 Configuration Register | DMACxC1Configuration | 0x0130 | | 77 11 | 1777 7 1 | | - Note 1: Access the registers by using word (32bit) reads and word writes. - Note 2: Access to the "Reserved" area is prohibited. - Note 3: For the registers prepared for every channel, if the channel structure is the same, unit number is expressed as "x" and channel number is expresses as "n". - Note 4: When the register which is not assigned with an each channel is read after the register which is assigned with an each channel is written, one machine cycle is inserted between the instructions or read the register which is not assigned with an each channel twice. ### 9.5.2 DMACxIntStatus (DMAC Interrupt Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|------------|------------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (-0) | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> Y | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 7 | 0 | | bit symbol | - | - | - | - | | > - | IntStatus1 | IntStatus0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | - | Write as zero. | | 1 | IntStatus1 | R | Status of DMAC channel 1 transfer end interrupt. 0 : Interrupt not requested 1 : Interrupt requested Status of the DMAC interrupt generation after passing through the transfer end interrupt enable register and error interrupt enable register. An interrupt is requested when there is a transfer error or when the coun- | | 0 | IntStatus0 | R | status of DMAC channel 0 interrupt generation. 0 : Interrupt requested 1 : Interrupt requested Status of the DMAC interrupt generation after passing through the transfer end interrupt enable register and error interrupt enable register. An interrupt is requested when there is a transfer error or when the counter completes counting. | Figure 9-2 Interrupt-related block diagram ### 9.5 Description of Registers # 9.5.3 DMACxIntTCStatus (DMAC Interrupt Terminal Count Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|----------------------------------------------|--------------|--------------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <u> - </u> | IntTCStatus1 | IntTCStatus0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | - | Write as zero. | | 1 | IntTCStatus1 | R | Status of DMAC channel 1 transfer end interrupt. 0 : Interrupt not requested 1 : Interrupt requested The status of post-enable transfer end interrupt generation. | | 0 | IntTCStatus0 | R | Status of DMAC channel 0 transfer end interrupt. 0 : Interrupt not requested 1 : Interrupt requested The status of post-enable transfer end interrupt generation. | # 9.5.4 DMACxIntTCClear (DMAC Interrupt Terminal Count Clear Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|----------------------------------------------|-------------|-------------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <u> - </u> | IntTCClear1 | IntTCClear0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | - | Write as zero. | | 1 | IntTCClear1 | W | Clear DMAC channel 1 transfer end interrupt. 0 : Do nothing 1 : Clear The DMACxIntTCStatus The DMACxIntTCStatus The DMACxIntTCStatus | | 0 | IntTCClear0 | w | Clear DMAC channel 0 transfer end interrupt. 0 : Do nothing 1 : Clear The DMACxIntTCStatus <inttcstatus0> will be cleared when "1" is written.</inttcstatus0> | Page 289 2023/07/21 ### 9.5 Description of Registers # 9.5.5 DMACxIntErrorStatus (DMAC Interrupt Error Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|----------------------------------------------|---------------|----------------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <u> - </u> | IntErrStatus1 | IIntErrStatus0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | (0) | 0 | | | | | (a) v | |------|---------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-2 | - | - | Write as zero. | | 1 | IntErrStatus1 | R | Status of DMAC channel 1 error interrupt generation. 0 : Interrupt not requested 1 : Interrupt requested Shows error interrupt status after enabled. | | 0 | IntErrStatus0 | R | Status of DMAC channel 0 error interrupt generation: 0 : Interrupt requested 1 : Interrupt requested Shows error interrupt status after enabled. | # 9.5.6 DMACxIntErrClr (DMAC Interrupt Error Clear Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|------------|------------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <del>-</del> | IntErrClr1 | IntErrClr0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | (0) | 0 | | | | _ | | |------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-2 | - | - | Write as zero. | | 1 | IntErrClr1 | W | Clear DMAC channel 1 transfer end interrupt. 0 : Do nothing | | | | | 1 : Clear The DMACxIntErrorStatus <interrstatus1> will be cleared when "1" is written.</interrstatus1> | | 0 | IntErrClr0 | W | Clear DMAC channel 0 transfer end interrupt. 0 : Do nothing 1 : Clear The DMACxIntErrorStatus <interrstatus0> will be cleared when "1" is written.</interrstatus0> | ### 9.5 Description of Registers # 9.5.7 DMACxRawIntTCStatus (DMAC Raw Interrupt Terminal Count Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|------------|------------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | · - | RawIntTCS1 | RawIntTCS0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | - | Write as zero. | | 1 | RawIntTCS1 | R | Status of DMAC channel 1 pre-enable transfer end interrupt generation 0 : Interrupt not requested 1 : Interrupt requested | | 0 | RawIntTCS0 | R | Status of DMAC channel 0 pre-enable transfer end interrupt generation 0 : Interrupt not requested 1 : Interrupt requested | # 9.5.8 DMACxRawIntErrorStatus (DMAC Raw Error Interrupt Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|----------------------------------------------|-------------|-------------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <u> - </u> | RawIntErrS1 | RawIntErrS0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------|------|------------------------------------------------------------------------------------------------------------| | 31-2 | - | - | Write as zero. | | 1 | RawIntErrS1 | R | Status of DMAC channel 1 pre-enable error interrupt. 0 : Interrupt requested 1 : Interrupt requested | | 0 | RawIntErrS0 | R | Status of DMAC channel 0 pre-enable error interrupt. 0 : Interrupt not requested 1 : Interrupt requested | Page 293 2023/07/21 ### 9.5 Description of Registers # 9.5.9 DMACxEnbldChns (DMAC Enabled Channel Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|----------------------------------------------|------------|------------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <u> - </u> | EnabledCH1 | EnabledCH0 | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | - | Write as zero. | | 1 | EnabledCH1 | R | DMA channel 1 enable status. 0 : Disable 1 : Enable After finishing all the total transfer number of times in DMACxCnControl register (the value becomes the zero), the this flag is clearded. | | 0 | EnabledCH0 | R | DMA channel 0 enable status. 0 : Disable 1 : Enable After finishing all the total transfer number of times in DMACxCnControl register (the value becomes the zero), the this flag is clearded. | # 9.5.10 DMACxSoftBReq (DMAC Software Burst Request Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|------------|------------|------------|------------|------------|------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | SoftBReq15 | SoftBReq14 | SoftBReq13 | SoftBReq12 | SoftBReq11 | SoftBReq10 | SoftBReq9 | SoftBReq8 | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | SoftBReq7 | SoftBReq6 | SoftBReq5 | SoftBReq4 | SoftBReq3 | SoftBReq2 | SoftBReq1 | SoftBReq0 | | After reset | 0 | 0 | 0 | 0 | | 0 . | | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | - | - | Write as zero. | | 15 | SoftBReq15 | R/W | DMA burst request by software (Request No. [15]) Read: 0: Stopping DMA burst transfer 1: running DMA burst transfer Write: 0: invaild 1: DMA burst requested | | 14 | SoftBReq14 | R/W | DMA burst request by software (Request No. [14]) Read: 0 :Stopping DMA burst transfer 1 : running DMA burst transfer Write: 0 : invaild 1 : DMA burst requested | | 13 | SoftBReq13 | R/W | DMA burst request by software (Request No. [13]) Read v 0 :Stopping DMA burst transfer 1 : running DMA burst transfer Write: 0 : invaild 1 : DMA burst requested | | 12 | SoftBReq12 | R/W | DMA burst request by software (Request No. [12]) Read: 0:Stopping DMA burst transfer 1: running DMA burst transfer Write: 0: invaild 1: DMA burst requested | | 11 | SoftBReq11 | R/W | DMA burst request by software (Request No. [11]) Read: 0 :Stopping DMA burst transfer 1 : running DMA burst transfer Write: 0 : invaild 1 : DMA burst requested | | 10 | SoftBReq10 | R/W | DMA burst request by software (Request No. [10]) Read: 0 :Stopping DMA burst transfer 1 : running DMA burst transfer Write: 0 : invaild 1 : DMA burst requested | | 9 | SoftBReq9 | R/W | DMA burst request by software (Request No. [9]) Read: 0:Stopping DMA burst transfer 1: running DMA burst transfer Write: 0: invaild 1: DMA burst requested | Page 295 2023/07/21 | Bit | Bit Symbol | Туре | Function | |-----|----------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------| | 8 | SoftBReq8 | R/W | DMA burst request by software (Request No. [8]) | | | | | Read: 0:Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer | | | | | Write: 0 : invaild | | | | | 1 : DMA burst requested | | 7 | SoftBReq7 | R/W | DMA burst request by software (Request No. [7]) | | | | | Read : 0 :Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer | | | | | Write: 0 : invaild | | | | | 1 : DMA burst requested | | 6 | SoftBReq6 | R/W | DMA burst request by software (Request No. [6]) | | | | | Read: 0:Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer | | | | | Write: 0 : invaild | | | | | 1 : DMA burst requested | | 5 | SoftBReq5 | R/W | DMA burst request by software (Request No. [5]) | | | | | Read: 0:Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer | | | | | Write: 0 : invaild | | | | | 1 : DMA burst requested | | 4 | SoftBReq4 | R/W | DMA burst request by software (Request No. [4]) | | | | | Read : 0 :Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer Write: 0 : invaild | | | | | 1 : DMA burst requested | | 3 | Co#DDow2 | R/W | | | 3 | SoftBReq3 | I K/VV | DMA burst request by software (Request No. [3]) Read: 0 :Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer | | | | | Write: 0 : invaild | | | | | 1 : DMA burst requested | | 2 | SoftBReq2 | R/W | DMA burst request by software (Request No. [2]) | | _ | CONDINOQE | | Read: 0 :Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer | | | | | Write: 0 : invaild | | | < | $\langle \langle \rangle \rangle$ | 1 : DMA burst requested | | 1 | SoftBReq1 | R/W | DMA burst request by software (Request No. [1]) | | | | | Read : 0 :Stopping DMA burst transfer | | | | | 1 : running DMA burst transfer | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | Write: 0 : invaild | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 5 | 1 : DMA burst requested | | 0 | SoftBReq0 | R/W | DMA burst request by software (Request No. [0]) | | ^ | (() | | Read : 0 :Stopping DMA burst transfer | | | | ł . | 1 : running DMA burst transfer | | | | ( | Write: 0 : invaild | | / _ | | \ | 1 : DMA burst requested | Note 1: Do not execute DMA requests by software and hardware at the same time. Note 2: Refer to "9.4.2 DMA request" for DMA request number. Clear "0" to bit corresponded with the DMA request number which has no burst request. # 9.5.11 DMACxSoftSReq (DMAC Software Single Request Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |------------------------|------------------|------------------|------------------|------------------|------------------|------------------|----------------|----------------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 13 | - | | After reset | Undefined | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | (107/ | 9 | 8 | | bit symbol | 15<br>SoftSReq15 | 14<br>SoftSReq14 | 13<br>SoftSReq13 | 12<br>SoftSReq12 | 11<br>SoftSReq11 | 10<br>SoftSReq10 | 9<br>SoftSReq9 | 8<br>SoftSReq8 | | bit symbol After reset | | | | | | | | | | | SoftSReq15 | SoftSReq14 | SoftSReq13 | SoftSReq12 | SoftSReq11 | | SoftSReq9 | SoftSReq8 | | | SoftSReq15 | SoftSReq14 | SoftSReq13 | SoftSReq12 | SoftSReq11 | SoftSReq10 | SoftSReq9 | SoftSReq8 | | | | _ | | |-------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-16 | - | - | Write as zero. | | 15 | SoftSReq15 | R/W | DMA single request by software (Request No. [15]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 14 | SoftSReq14 | R/W | DMA single request by software (Request No. [14]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 13 | SoftSReq13 | R/W | DMA single request by software (Request No. [13]) Read: 0:Stopping DMA single transfer 1: running DMA single transfer Write: 0:Invaild 1: DMA single requested | | 12 | SoftSReq12 | R/W | DMA single request by software (Request No. [12]) Read: 0 :Stopping DMA single transfer 1 : running DMA single transfer Write: 0 : invaild 1 : DMA single requested | | 11 | SoftSReq11 | R/W | DMA single request by software (Request No. [11]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 10 | SoftSReq10 | R/W | DMA single request by software (Request No. [10]) Read: 0 : Stopping DMA single transfer 1 : running DMA single transfer Write: 0 : invaild 1 : DMA single requested | | 9 | SoftSReq9 | R/W | DMA single request by software (Request No. [9]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 8 | SoftSReq8 | R/W | DMA single request by software (Request No. [8]) Read: 0:Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | Page 297 2023/07/21 | Bit | Bit Symbol | Туре | Function | |-----|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SoftSReq7 | R/W | DMA single request by software (Request No. [7]) Read: 0:Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 6 | SoftSReq6 | R/W | DMA single request by software (Request No. [6]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 5 | SoftSReq5 | R/W | DMA single request by software (Request No. [5]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 4 | SoftSReq4 | R/W | DMA single request by software (Request No. [4]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 3 | SoftSReq3 | R/W | DMA single request by software (Request No. [3]) Read: 0:Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 2 | SoftSReq2 | R/W | DMA single request by software (Request No. [2]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | | 1 | SoftSReq1 | R/W | DMA single request by software (Request No. [1]) Read : 0 : Stopping DMA single transfer 1 : running DMA single transfer Write: 0 : invaild 1 : DMA single requested | | 0 | SoftSReq0 | R/W | DMA single request by software (Request No. [0]) Read: 0: Stopping DMA single transfer 1: running DMA single transfer Write: 0: invaild 1: DMA single requested | Note 1: Do not execute DMA requests by software and hardware at the same time. Note 2: Refer to "9.4.2 DMA request" for DMA request number. Clear "0" to bit corresponded with the DMA request number which has no single request. # 9.5.12 DMACxConfiguration (DMAC Configuration Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | - | | ) - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | - | - ( | | M | Е | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | \d(\) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | - | Write as zero. | | 1 | М | R/W | Write as zero. | | 0 | E | R/W | DMA circuit control | | | | | 0 : Stop | | | | | 1 : Operate | | | | | When circuit stops, the registers for the DMA circuit cannot be written or read. When operating the DMA, always set <e>="1".</e> | #### 9.5.13 DMACxCnSrcAddr (DMAC Channelx Source Address Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|-----|----------|-------|-----|----| | bit symbol | | - | | Src | Addr | | 7 | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | | | Src | Addr | (0/4) | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | Src | Addr | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | Src | Addr | > | 2 | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Type | Function | |------|---------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | SrcAddr[31:0] | R/W | Sets a DMA transfer source address. Make sure to confirm the source address and the bit width before setting. The below are the restrictions in setting of source address bit width. Source address bit width DMACxCnControl <swidth[2:0]> Setting of least significant address</swidth[2:0]> | | | | | 000 : Byte (8 bits) no restriction 001 : Half word (16 bits) Setting as multiples of 2, (0x0,0x02,0x4,0x06,0x8,0xA,0xC) 010 : Word (32 bits) Setting as multiples of 4, (0x0,0x4,0x8,0xC) | Because enabling channel "n" (DMACxCnConfiguration <E>="1") updates the data written in the registers, set DMACxCnSrcAddr before enabling the channels: When the DMA is operating, the value in the DMACxCnSrcAddr register sequentially changes, so the read values are not fixed. And do not update DMACxCnSrcAddr during transfer. To change DMACxCnSrcAddr, be sure to disable the channel "n" (DMACxCnConfiguration <E>="0") before change. ### 9.5.14 DMACxCnDestAddr (DMAC Channelx Destination Address Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----------|----|------|------|-------|----|----| | bit symbol | | | | Dest | Addr | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 🔨 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | | | Dest | Addr | (( | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | | | | Dest | Addr | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | DestAddr | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | DestAddr[31:0] | R/W | Sets a DMA transfer destination address. Make sure to confirm the destination address and the bit width before setting. The below are the restrictions in setting of destination address bit width. | | | | | Destination address bit width DMACxCControl <dwidth[2:0]> Setting of least significant address</dwidth[2:0]> | | | | | 000 : Byte (8 bits) no restriction | | | | | 001 : Half word (16 bits) Setting as multiples of 2 (0x0,0x02,0x4,0x06,0x8,0xA,0xC) | | | | | 010 : Word (32 bits) Setting as multiples of 4, (0x0,0x4,0x8,0xC) | Do not update DMACxCnDestAddr during transfer. To change DMACxCnDestAddr, be sure to disable the channel "n" (DMACxCnConfiguration<E>="0") before change. Page 301 2023/07/21 # 9.5.15 DMACxCnLLI (DMAC Channelx Linked List Item Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|-----------|-----------| | bit symbol | | | | L | LI | | 2 | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | | | L | LI | (0/4) | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | L | LI | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | L | LI | | > | 2-// | - | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | Undefined | Undefined | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | LLI[29:0] | R/W | Sets the first address of the next transfer information. Set a value smaller than 0xFFFF_FFF0. When <lli> = 0, LLI is the last chain. After DMA transfer finishes, the DMA channel is disabled.</lli> | | 1-0 | - | R/W | Write as zero. | Note: For <LLI> detailed operation, see "9.6 Special Functions". # 9.5.16 DMACxCnControl (DMAC Channeln Control Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|--------|-----------|-----------|-----------|----------|--------|-----------|-----------| | bit symbol | I | - | - | - | DI | SI | - | - | | After reset | 0 | Undefined | Undefined | Undefined | 0 | 0 (( | Undefined | Undefined | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | Dwidth | | | Swidth | (0) | DBS | Size | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | DBSize | | SBSize | | 1 | Transf | ferSize | | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | Transf | erSize | > | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | I | R/W | Register for enabling a transfer interrupt. 0 : Disable 1 : Enable The transfer end interrupt is generated by setting <i>="1" and DMACxCnConfiguration<itc>="1". When the scatter/gather function is used in the last transfer DMAC setting flow and by setting this bit to enable, to generate the transfer end interrupt is enable only at the last transfer. To generate interrupt during normal transfer, set this bit to "1" and change to enable mode.</itc></i> | | 30-28 | - | W | Write as zero. | | 27 | DI | R/W | Increment the transfer destination address 0 : Do not increment 1 : Increment | | 26 | SI | R/W | Increment the transfer source address 0 : Do not increment 1 : Increment | | 25-24 | - < | W | Write-as zero. | | 23-21 | Dwidth[2:0] | R/W | Transfer destination bit width. 000: Byte (8 bits) 001: Half-word (16 bits) 010: Word (32 bits) other: Reserved Refer to Table 9-4 for the setting value. | | 20-18 | Swidth[2:0] | R/W | Transfer source bit width 000: Byte (8 bits) 001: Half-word (16 bits) 010: Word (32 bits) other: Reserved Refer to Table 9-4 for the setting value. | | 17-15 | DBSize[2:0] | R/W | Transfer destination burst size: (Note 1) 000: 1 beat | Page 303 2023/07/21 | Bit | Bit Symbol | Туре | | | Function | |-------|------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------| | 14-12 | SBSize[2:0] | R/W | Transfer source burst size: (Note 1) | | | | | | | 000: 1 beat | 100: | 32 beats | | | | | 001: 4 beats | 101: | 64 beats | | | | | 010: 8 beats | 110: | 128 beats | | | | | 011: 16 beats | 111: | 256 beats | | | | | Refer to Table 9-4 for the setting value | | | | 11-0 | TransferSize<br>[11:0] | R/W | set into <transdersize[11:0]>. Because quest internally, amount of transfer data source bit width and total number of tra. The value of <transfersize[11:0]> is de If this is read, the value which is the number of transfers is used a For examples: When <swidth>="000" (8bit), the number <swidth>="001" (16bit), the</swidth></swidth></transfersize[11:0]></transdersize[11:0]> | e the burs<br>a is never<br>ansfers a<br>ecrement<br>umber of<br>s the uni- | ed to 0 by the DMA transferring.<br>data not to transfer. | Note: The burst size to be set with DBsize and SBsize has no connections with the HBURST for the AHB Table 9-4 How to decide the value of <Dwidth[2:0]>, <Swidth[2:0]>, <DBSize[2:0]>, <SBSize[2:0]> | <dwidth[2:0]> /<br/><swidth[2:0]></swidth[2:0]></dwidth[2:0]> | Set the number so that the following expression is satisfied: Transfer source bit width × Total number of transfers = Transfer destination bit width × N (N : Integer number) | |----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | (ex.1) Bit width of transfer source:8 bit, bit width of transfer destination:32 bit, total number of transfers:25 times 8 bit × 25 times = 200 bit (25 byte) N = 200 ÷ 32 = 6.25 word Since 6.25 is not an integer number, the above setting is invalid. | | | If the transfer source bit width is smaller than the transfer destination bit width, care must be taken when setting the total number of transfers. | | • | (ex.2) Bit width of transfer source :32 bit, bit width of transfer destination:16 bit, total number of transfers: 13 times 32 bit × 13 times = 416 bit (13 word) | | ^ ^ | N = 416 ÷ 16 = 26 half_word | | >,< | Since 26 is an integer number, the above setting is valid. | | <pre><dbsize[2:0]> / <sbsize[2:0]></sbsize[2:0]></dbsize[2:0]></pre> | When "Peripheral to Memory" or "Memory to Peripheral" is performed, peripheral circuits generates DMA request signal to indicate the preparation is ready. This signal triggers to execute data transfers. (In the case of "Memory to Memory", only software start is used.) | | | Set the burst size to define the amount of data transferred from peripherals per DMA request signal. This register is used with FIFO buffer that can be contained multiple data. | # 9.5.17 DMACxCnConfiguration (DMAC Channel n Configuration Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | Halt // | Active | Lock | | After reset | Undefined | Undefined | Undefined | Undefined | Undefined | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | ITC | IE | | FlowCntrl | | (\)Y | DestPe | ripheral | | After reset | 0 | 0 | 0 | 0 | 0 | Undefined | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | DestPe | ripheral | - | | SrcPer | ripheral | 2// | Е | | After reset | 0 | 0 | Undefined | 0 | ((/o/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | | | | | |-------|----------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 31-19 | - | W | Write as zero. | | | | | | 18 | Halt | R/W | Controls accepting a DMA request 0 : Accept a DMA request 1 : Ignore a DMA request | | | | | | 17 | Active | R | Indicates whether data is present in the channel FIFO. 0 : No data exists in the FIFO 1 : Data exists in the FIFO | | | | | | 16 | Lock | R/W | Sets a locked transfer (Non-divided transfer). D: Disable locked transfer Enable locked transfer When locked transfer is enabled, as many burst transfers as specified are consecutively executed without re- easing the bus. For detailed operation, see "9.6 Special Functions". | | | | | | 15 | ITC < | R/W | Transfer end interrupt enable register. 0 : Disable interrupt 1 : Enable interrupt | | | | | | 14 | IE 💢 | R/W | Error interrupt enable register 0 :Disable interrupt 1: Enable interrupt | | | | | | 13-11 | FlowCntrl[2:0] | R/W | Sets transfer method | | | | | | < | | ) | <flowcntrl[2:0]> setting value Transfer method</flowcntrl[2:0]> | | | | | | | | ( | 000: Memory to Memory (Note) | | | | | | | | | 001: Memory to Peripheral | | | | | | | | | 010: Peripheral to Memory | | | | | | | ~ | | 011 to 111: Reserved | | | | | | 10 | - | W | Write as zero. | | | | | | 9-6 | DestPeripheral [3:0] | R/W | Sets transfer destination peripheral (Note 2) Refer to "9.4.2 DMA request". When a memory is the transfer destination, this setting is ignored. | | | | | | 5 | - | W | Write as zero. | | | | | | 4-1 | SrcPeripheral [3:0] | R/W | Sets transfer source peripheral (Note 2) Refer to "9.4.2 DMA request". When a memory is the transfer source, this setting is ignored. | | | | | Page 305 2023/07/21 | Bit | Bit Symbol | Туре | Function | |-----|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Е | R/W | Channel enable | | | | | 0 : Disable | | | | | 1 : Enable | | | | | This bit can be used to enable/disable the channels. (This bit works as start bit when "Memory" is selected.) | | | | | Amount of transfer data specified by DMACxCnControl <transfersize> is completed, the corresponding <e> is cleared to "0" automatically.</e></transfersize> | | | | | Disabling channels during transfer loses the data in the FIFO. Initialize all the channels before restart. | | | | | To pause the transfer, stop the DMA request by using the <halt>, and poll the data until the <active> becomes "0" and then disable the channel with the <e> bit.</e></active></halt> | Note 1: When "Memory to Memory" is selected, hardware start for DMA startup is not supported. Write "1" <E> for starting transfer. Note 2: When DMACxENableChns<EnabledCHx> is enabled and the corresponding DMACxCnConfiguration<Halt> is set to "1", write them after channel enable bit (E:bit0) is clear to "0". Without this, in the case of the slave error is occurred when writing them, the error is recovered by reset. Regarding slave error, when the width and address of transfer have mismatch, this error is occurred. TMPM362F10FG #### 9.6 Special Functions #### 9.6.1 Scatter/gather function When removing a part of image data and transferring it, image data cannot be handled as consecutive data, and the address changes dramatically depending on the special rule. Since DMA can transfer data only by using consecutive addresses, it is necessary to make required settings at locations where addresses changes. The scatter/gather function can consecutively operate DMA settings (transfer source address, destination address, number of transfers, and transfer bus width) by re-loading them each time a specified number of DMA executions have completed via a pre-set "Linked List" where the CPU does not need to control the operation. Setting "1" in the DMACxCnLLI register enables/disables the operation. The items that can be set with Linked List are configured with the following 4 words: - 1. DMACxCnSrcAddr - 2. DMACxCnDestAddr - 3. DMACxCnLLI - 4. DMACxCnControl They can be used with the interrupt operation. An interrupt depends on the count end interrupt enable bit of the DMACxCnControl register, and can be generated at the end of each LLI. When this bit is used, a condition can be added even during transfer using LLI to perform branch operation, etc. To clear the interrupt, control the appropriate bit of the DMACxIntTCClear register. Page 307 2023/07/21 9.6 Special Functions TMPM362F10FG #### 9.6.2 Linked list operation To operate the scatter/gather function, a transfer source and source data areas need to be defined by creating a set of Linked Lists first. Each setting is called LLI (LinkedList). Each LLI controls the transfer of one block of data. Each LLI indicates normal DMA setting and controls transfer of successive data. Each time each DMA transfer is complete, the next LLI setting will be loaded to continue the DMA operation (Daisy Chain). An example of the setting is shown below. - 1. The first DMA transfer setting should be made directly in the DMA register. - 2. The second and subsequent DMA transfer settings should be written in the addresses of the memory set in "next LLI AddressX." - 3. To stop up to N'th DMA transfer, set "next LLI AddressX" to 0x0000\_0000. When transferring data in the area enclosed by the square | | 0x00 | 2000 | 0x00E000 | | | |---------|------|------|----------|--|--| | 0x0A000 | | | | | | | 0x0B000 | | | | | | | 0x0C000 | | | | | | Page 309 2023/07/21 9.6 Special Functions TMPM362F10FG TMPM362F10FG # 10. Static Memory Controller TMPM362F10FG contains static memory (NOR type Flash memory and SRAM) controller with asynchronous access. Note 1: Execute the WFI instruction after confirming the external memory access is completed. Note 2: The external memory can not be used as a FIFO becase the dummy read cycle in the reading cycle from an external bus may be occurred. #### 10.1 Function Overview Outline function is shown in Table 10-1. Table 10-1 Out line function of Static memory Controller | Item | | |------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Supported Memory type and bus connection | Asynchronous access memory (NOR Flash memory, SRAM, etc.) Multiplex bus and separate bus supported | | Data bus width | 16bit data bus width | | Memory map | 64MB access area is supported and divide into four CS signal and area. CS0: 0x6000_0000 to 0x60FF_FFFF (16MB) CS1: 0x6100_0000 to 0x61FF_FFFF (16MB) CS2: 0x6200_0000 to 0x62FF_FFFF (16MB) CS3: 0x6300_0000 to 0x63FF_FFFF (16MB) | | Timing adjustment | Can be controlled AC timing by registers. | | Clock (SMCCLK) | fsys / 2 | | External control signals | Separate bus: D0 to D15, A1 to A23, $\overline{OE}$ , $\overline{WE}$ , $\overline{CSO}$ to $\overline{CS3}$ , $\overline{BLSO}$ , $\overline{BLS1}$ Multiplex bus: AD0 to AD15, A17 to A23, $\overline{OE}$ , $\overline{WE}$ , $\overline{ALE}$ , $\overline{CSO}$ to $\overline{CS3}$ , $\overline{BLSO}$ , $\overline{BLS1}$ | 10.2 Block diagram TMPM362F10FG # 10.2 Block diagram The block diagram of SMC is shown as below. Figure 10-1 SMC Block Diagram #### 10.3.1 SFR List The following lists the SFRs. Base Address = 0x4000\_1000 | Register name | Address (Base+) | | |---------------------------------------------|--------------------|----------------------------------------------------| | Reserved | - | (7)\0x0000 | | SMC Memory Interface Configuration Register | smc_memif_cfg | 0x0004 | | Reserved | - | 0x0008 | | Reserved | - (( | 0x000C | | SMC Direct Command Register | smc_direct_cmd | 0x0010 | | SMC Set Cycles Register | smc_set_cycles | 0x0014 | | SMC Set Opmode Register | smc_set_opmode | 0x0018 | | Reserved | (7/6) | 0x0020 | | SMC SRAM Cycles Registers <0> | smc_sram_cycles0_0 | 0x0100 | | SMC Opmode Registers <0> | smc_opmode0_0 | 0x0104 | | SMC SRAM Cycles Registers <1> | smc_sram_cycles0_1 | 0x0120 | | SMC Opmode Registers <1> | smc_opmode0_1 | 0x0124 | | SMC SRAM Cycles Registers <2> | smc_sram_cycles0_2 | 0x0140 | | SMC Opmode Registers <2> | smc_opmode0_2 | 0x0144 | | SMC SRAM Cycles Registers <3> | smc_sram_cycles0_3 | 0x0160 | | SMC Opmode Registers <3> | smc_opmode0_3 | 0x0164 | | Reserved | - | 0x0200 to 0x0204,0x0E00 to 0x0E08,0x0FE0 to 0x0FFC | Base Address = 0x41FF\_F100 | | Register name | | Address (Base+) | |-------------------|-------------------------------------------------|-----------|-----------------| | SMC Mode Register | $( \langle // $ | SMCMDMODE | 0x0000 | Note 1: Access the registers by using word reads and word writes. Note 2: Do not access at reserved address. # 10.3.2 SMCMDMODE (Mode Register) | | 31 | 30 | 29 | 28 | 27 | 26 < | 25 | 24 | |-------------|----|----|----|----|-----|-------|----|----------------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (-0) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > _ | 3 | IFSMC<br>MUXMD | | After reset | 0 | 0 | 0 | 0 | | 0 | | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------| | 31-8 | _ | R | Read as "0". | | 7-1 | _ | R/W | Write as "0". | | 0 | IFSMCMUXMD | R/W | SMC memory bus mode setting 0:Separate bus mode 1:Multiplex bus mode | Note 1: Do not change <IFSMCMUXMD> during SMC operation. # 10.3.3 smc\_memif\_cfg (SMC Memory Interface Configuration Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|--------------|-----------|--------------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | _ | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | memory_width | | memory_chips | | memoi | y_type | | After reset | Undefined | Undefined | 0 | 1 | ((/1/ \) | 1, 0 | | 1 | | Bit | Bit Symbol | Туре | Function | |------|-----------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-6 | - | R | Read as undefined. | | 5-4 | memory_width [1:0] | R | Maximum external SMC memory bus width 01 : 16 bits Others : Don't care | | 3-2 | memory_chips<br>[1:0] | R | The number of supported memory CS 00 : 1 chip 01 : 2 chip 10 : 3 chip 11 : 4 chip | | 1-0 | memory_type<br>[1:0] | R | Supported memory types: SRAM When <ifsmcmuxmd> is "0", read as "01". When <ifsmcmuxmd> is "1", read as "11". Others: Don't care</ifsmcmuxmd></ifsmcmuxmd> | ### 10.3.4 smc\_direct\_cmd (SMC Direct Command Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-------------|-----------|-----------|-----------|-----------|----------------------------------------------|-----------|-----------| | bit symbol | - | - | - | - | - | - chip_sele | | select | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | chip_select | cmd | _type | - | - ^ | (0) | - | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <u> - </u> | 2-// | - | | After reset | Undefined | Bit | Bit Symbol | Туре | Function | |-------|------------------|------|----------------------------------------------------------| | 31-26 | - | W | Write as "0". | | 25-23 | chip_select[2:0] | W | CS selection | | | | | 000 : CS0 | | | | | 001 : CS1 | | | | | 010 : CS2 | | | | | 011 : CS3 | | | | | 100 to 111 : Setting prohibition | | | | | | | | | | Select objective Chip Select terminal | | 22-21 | cmd_type[1:0] | W | Update set_opmode register and set_cycles register value | | | | | 10 : Update registers | | | | | Others: Setting prohibition | | 20-0 | _ | /w/ | Write as "0". | ### 10.3.5 smc\_set\_cycles (SMC Set Cycles Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|--------------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | _ | Set_t5 | | Set_t4 | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | Se | t_t4 | Set_t3 | | | | Set_t2 | | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | Se | <u>t_</u> t1 | - | | Set | t_t0 | | | After reset | Undefined | Bit | Bit Symbol | Туре | Function | |-------|-----------------------|---------------|----------------------------------------------------------------------------------------------------------------------| | 31-20 | _ | W | Write as "0". | | 19-17 | Set_t5[2:0] | W | Set value of t <sub>TR</sub> | | | | | 000 : Setting prohibition | | | | | 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 16-14 | Set_t4[2:0] | W | Set value of t <sub>PC</sub> | | | | | 000 : Setting prohibition | | | | | 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | | | | Page access is not supported in multiplex bus mode. t <sub>PC</sub> is effective only separate bus mode. | | 13-11 | Set_t3[2:0] | W | Set value of t <sub>WP</sub> (note) | | | | | 000 . Setting prohibition | | | | | 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | | | | In multiplex mode, write pulse width (twp) increase for one more clock pulse against for value of <set_t3>.</set_t3> | | 10-8 | Set_t2[2:0] < | (w | Set value of t <sub>CEOE</sub> (note) | | | | // | 000 : Setting prohibition | | | | | 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 7-4 | Set_t1[3:0] | W | Set value of t <sub>WC</sub> (note) | | | | | 0000 : Setting prohibition | | | | $\mathcal{S}$ | 0011 to 1111 : SMCCLK × 3 clock to SMCCLK × 15 clock | | 3-0 | Set_t0[3:0] | W | Set value of t <sub>RC</sub> (note) | | | $\langle ( ) \rangle$ | ) | 0000 : Setting prohibition | | | | | 0010 to 1111 : SMCCLK × 2 clock to SMCCLK × 15 clock | This register is provided to adjust the access cycle of static memory and should be set to satisfy the A.C. specifications of the memory to be used. Adjust base clock is SMCCLK: fsys/2. To validate SMC set cycles register setting, it is necessary to execute update register command on smc\_direct\_cmd register. Note: It needs to keep below relation. | <set_t3>,<set_t1></set_t1></set_t3> | · | $:(t_{WP} + SMCCLK \times 2 clock) ≤ t_{WC}$<br>$:(t_{WP} + SMCCLK \times 3 clock) ≤ t_{WC}$ | |-------------------------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------| | <set_t2>,<set_t0></set_t0></set_t2> | • | $ \begin{split} :&(t_{CEOE} + SMCCLK \times 1 \text{ clock}) \leq t_{RC} \\ :&(t_{CEOE} + SMCCLK \times 1 \text{ clock}) \leq t_{RC} \end{split} $ | Page 317 2023/07/21 ### 10.3.6 smc\_set\_opmode (SMC Set Opmode Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 1-3 | - | | After reset | Undefined | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | set_adv | | ) - | - | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | | set_rd_bl | | | set | _mw | | After reset | Undefined | Bit | Bit Symbol | Туре | Function | |-------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-12 | - | W | Write as "0". | | 11 | set_adv | W | ALE signal 0 : Address latch enable (ALE) not used (select when separate bus mode is used.) 1 : Address latch enable (ALE) used (select when multiplex bus mode is used.) | | 10-6 | - | W | Write as "0". | | 5-3 | set_rd_bl[2:0] | W | Setting bits for Burst length of data read 000 : 1 beat 001 : 4 beats Others : Reserved | | 2 | - | W | Write as "0". | | 1-0 | set_mw[1:0] | w | Holding register of the memory data bus width set value 01 : 16-bits Others : Reserved Setting bits for data bus width. | To validate SMC set opmode register settings, it is necessary to execute update register command on smc\_direct\_cmd register. # 10.3.7 smc\_sram\_cycles0\_0 (SMC SRAM Cycles Registers 0 <0>) | | 31 | 30 | 29 | 28 | 27 | 26 < | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|---------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | _ | <u>(</u> tr// | | t_pc | | After reset | Undefined | Undefined | Undefined | Undefined | 0 | | ) 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | t_ | рс | t_wp | | | | t_ceoe | | | After reset | 1 | 0 | 1 | 1 | 0 | | 1 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | | t_ | wc | | | t_ | rc 🚶 | | | After reset | 1 | 1 | 0 | 0 | ((/1/ \) | 1_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|----------------------------------------------------------------------------------| | 31-20 | - | W | Write as "0". | | 19-17 | t_tr[2:0] | R | Turn around cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 16-14 | t_pc[2:0] | R | Page cycle time (note) 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 13-11 | t_wp[2:0] | R | WE pulse cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 10-8 | t_ceoe[2:0] | R | Delay cycle time to OE assert 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 7-4 | t_wc[3:0] | R | Write cycle time 0011 to 1111): SMCCLK × 3 clock to SMCCLK × 15 clock | | 3-0 | t_rc[3:0] | R | Read cycle time 0010 to 1111 : SMCCLK × 2 clock to SMCCLK × 15 clock | Note: Page access is not supported in multiplex bus mode. $t_{PC}$ is effective only separate bus mode. # 10.3.8 smc\_sram\_cycles0\_1 (SMC SRAM Cycles Registers 0 <1>) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-------------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | _ | <u>t_</u> tr // < | | t_pc | | After reset | Undefined | Undefined | Undefined | Undefined | 0 | | ) 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | t_ | рс | t_wp | | | | t_ceoe | | | After reset | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | t_ | wc | | | t_ | rc 🚶 | | | After reset | 1 | 1 | 0 | 0 | ((/1/ \) | 1_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|----------------------------------------------------------------------------------| | 31-20 | - | W | Write as "0". | | 19-17 | t_tr[2:0] | R | Turn around cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 16-14 | t_pc[2:0] | R | Page cycle time (note) 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 13-11 | t_wp[2:0] | R | WE pulse cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 10-8 | t_ceoe[2:0] | R | Delay cycle time to OE assert 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 7-4 | t_wc[3:0] | R | Write cycle time 0011 to 1111 : SMCCLK × 3 clock to SMCCLK × 15 clock | | 3-0 | t_rc[3:0] | R | Read cycle time 0010 to 11111 : SMCCLK × 2 clock to SMCCLK × 15 clock | Note: Page access is not supported in multiplex bus mode. $t_{\text{PC}}$ is effective only separate bus mode. # 10.3.9 smc\_sram\_cycles0\_2 (SMC SRAM Cycles Registers 0 <2>) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------------|-----------|-----------| | bit symbol | - | | | - | | | | - | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | _ | ( <u>_</u> tr// | | t_pc | | After reset | Undefined | Undefined | Undefined | Undefined | 0 | | ) 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | t_ | рс | | t_wp | | | t_ceoe | | | After reset | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | t_ | wc | | | > t_ | rc 🚶 | | | After reset | 1 | 1 | 0 | 0 | ((/1/5) | 1_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|----------------------------------------------------------------------------------| | 31-20 | - | W | Write as "0". | | 19-17 | t_tr[2:0] | R | Turn around cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 16-14 | t_pc[2:0] | R | Page cycle time (note) 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 13-11 | t_wp[2:0] | R | WE pulse cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 10-8 | t_ceoe[2:0] | R | Delay cycle time to OE assert 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 7-4 | t_wc[3:0] | R | Write cycle time 0011 to 1111: SMCCLK × 3 clock to SMCCLK × 15 clock | | 3-0 | t_rc[3:0] | R | Read cycle time 0010 to 1111 : SMCCLK × 2 clock to SMCCLK × 15 clock | Note: Page access is not supported in multiplex bus mode. $t_{PC}$ is effective only separate bus mode. # 10.3.10 smc\_sram\_cycles0\_3 (SMC SRAM Cycles Registers 0 <3>) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - // - | | | After reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | | - | - | _ | (4F)/A | | | | After reset | Undefined | Undefined | Undefined | Undefined | 0 | | ) 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | t_ | рс | t_wp | | | | t_ceoe | | | After reset | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | t_ | wc | | | > t_ | rc 🚶 | | | After reset | 1 | 1 | 0 | 0 | ((/1/ \) | 1_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|---------------------------------------------------------------------------------| | 31-20 | - | W | Write as "0". | | 19-17 | t_tr[2:0] | R | Turn around cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 16-14 | t_pc[2:0] | R | Page cycle time (note) 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 13-11 | t_wp[2:0] | R | WE pulse cycle time 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 10-8 | t_ceoe[2:0] | R | Delay cycle time to OE assert 001 to 111 : SMCCLK × 1 clock to SMCCLK × 7 clock | | 7-4 | t_wc[3:0] | R | Write cycle time 0011 to 1111 : SMCCLK × 3 clock to SMCCLK × 15 clock | | 3-0 | t_rc[3:0] | R | Read cycle time 0010 to 1111 : SMCCLK × 2 clock to SMCCLK × 15 clock | Note: Page access is not supported in multiplex bus mode. $t_{\text{PC}}$ is effective only separate bus mode. # 10.3.11 smc\_opmode0\_0 (SMC Opmode Registers 0<0>) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | | | | | |-------------|-----------|---------------|-----------|-----------|----------|--------------|----------------|-----------|--|--|--|--| | bit symbol | | address_match | | | | | | | | | | | | After reset | 0 | 1 | 1 | 0 | 0 | 0 (( | 0 | 0 | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | | ) 1 | 1 | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | bit symbol | - | - | - | - | adv | ( <u>)</u> Y | - | - | | | | | | After reset | Undefined | Undefined | Undefined | Undefined | 1 ( | Undefined | Undefined | Undefined | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | | | | | bit symbol | - | - | | rd_bl | | > - | , u | ıw | | | | | | After reset | Undefined | Undefined | 0 | 0 | ((/o/ \) | Undefined | $(\bigcirc 1)$ | 0 | | | | | | Bit | Bit Symbol | Туре | Function | |-------|---------------------|------|-------------------------------------------------------------------------------------------------------------------------| | 31-24 | address_match [7:0] | R | Start address of CS0 area Read as "0x60". | | 23-16 | _ | R | Read as "0xFF". | | 15-12 | _ | R | Read as undefined. | | 11 | adv | R | Address latch enable signal 0 : Address latch enable signal (ALE) not used 1 : Address latch enable signal (ALE) used | | 10-6 | - | R | Read as undefined. | | 5-3 | rd_bl[2:0] | R | Burst length of data read 000 : 1 beat 001 : 4 beats 010 to 111 : Don't care | | 2 | - < | R | Read as undefined. | | 1-0 | mw[1:0] | R | Data bus width of CS0 01 : 16 bits Others : Don't care | Note:Do not access the external memory area except set CS area. # 10.3.12 smc\_opmode0\_1 (SMC Opmode Registers 0<1>) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | | | | | |-------------|-----------|---------------|-----------|-----------|----------|--------------|-----------|-----------|--|--|--|--| | bit symbol | | address_match | | | | | | | | | | | | After reset | 0 | 1 | 1 | 0 | 0 | 0 (( | 0 | 1 | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | | ) 1 | 1 | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | bit symbol | - | - | - | - | adv | ( <u>)</u> } | - | - | | | | | | After reset | Undefined | Undefined | Undefined | Undefined | 1 | Undefined | Undefined | Undefined | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | | | | | bit symbol | - | - | | rd_bl | | > - | , u | ıw | | | | | | After reset | Undefined | Undefined | 0 | 0 | ((/o/ \) | Undefined | () | 0 | | | | | | | _ | | | |-------|---------------------|------|-------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-24 | address_match [7:0] | R | Start address of CS1 area Read as "0x61". | | 23-16 | _ | R | Read as "0xFF". | | 15-12 | _ | R | Read as undefined. | | 11 | adv | R | Address latch enable signal 0 : Address latch enable signal (ALE) not used 1 : Address latch enable signal (ALE) used | | 10-6 | _ | R | Read as undefined. | | 5-3 | rd_bl[2:0] | R | Burst length of data read 000 : 1 beat 001 : 4 beats 010 to 111 : Don't care | | 2 | - < | R | Read as undefined. | | 1-0 | mw[1:0] | R | Data bus width of CS1 01 : 16 bits Others : Don't care | Note: Do not access the external memory area except set CS area. # 10.3.13 smc\_opmode0\_2 (SMC Opmode Registers 0<2>) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | |-------------|-----------|---------------|-----------|-----------|-----|-----------|-----------|-----------|--|--|--|--|--| | bit symbol | | address_match | | | | | | | | | | | | | After reset | 0 | 1 | 1 | 0 | 0 | 0 < | 1 | 0 | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | bit symbol | - | - | - | 1 | - | - (( | - | - | | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | 1 | 5 | 1 | | | | | | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | | | | | | bit symbol | - | - | - | - | adv | | ) - | - | | | | | | | After reset | Undefined | Undefined | Undefined | Undefined | 1 | Undefined | Undefined | Undefined | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | bit symbol | - | - | | rd_bl | | | | mw | | | | | | | After reset | Undefined | Undefined | 0 | 0 | 0/ | Undefined | 4( ) | 0 | | | | | | | Bit | Bit Symbol | Туре | Function | |-------|------------------------|------|-------------------------------------------------------------------------------------------------------------------------| | 31-24 | address_match<br>[7:0] | R | Start address of CS2 area Read as "0x62". | | 23-16 | _ | R | Read as "0xFF". | | 15-12 | _ | R | Read as undefined. | | 11 | adv | R | Address latch enable signal 0 : Address latch enable signal (ALE) not used 1 : Address latch enable signal (ALE) used | | 10-6 | _ | R | Read as undefined | | 5-3 | rd_bl[2:0] | R | Burst length of data read 000 : 1 beat 001 : 4 beats 010 to 111 : Don't care | | 2 | _ | R | Read as undefined. | | 1-0 | mw[1:0] | R | Data bus width of CS2 01 : 16 bits Others : Don't care | Note: Do not access the external memory area except set CS area. # 10.3.14 smc\_opmode0\_3 (SMC Opmode Registers 0<3>) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | | | | | |-------------|-----------|---------------|-----------|-----------|----------|--------------|-----------|-----------|--|--|--|--| | bit symbol | | address_match | | | | | | | | | | | | After reset | 0 | 1 | 1 | 0 | 0 | 0 (( | 1 | 1 | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | | | | | After reset | 1 | 1 | 1 | 1 | 1 | | ) 1 | 1 | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | bit symbol | - | - | - | - | adv | ( <u>)</u> } | - | - | | | | | | After reset | Undefined | Undefined | Undefined | Undefined | 1 | Undefined | Undefined | Undefined | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | | | | | bit symbol | - | - | | rd_bl | | > - | , u | ıw | | | | | | After reset | Undefined | Undefined | 0 | 0 | ((/o/ \) | Undefined | | 0 | | | | | | | _ | | | |-------|---------------------|------|-------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-24 | address_match [7:0] | R | Start address of CS3 area Read as "0x63". | | 23-16 | _ | R | Read as "0xFF". | | 15-12 | _ | R | Read as undefined. | | 11 | adv | R | Address latch enable signal 0 : Address latch enable signal (ALE) not used 1 : Address latch enable signal (ALE) used | | 10-6 | _ | R | Read as undefined. | | 5-3 | rd_bl[2:0] | R | Burst length of data read 000 : 1 beat 001 : 4 beats 010 to 111 : Don't care | | 2 | - < | R | Read as undefined. | | 1-0 | mw[1:0] | R | Data bus width of CS3 01 : 16 bits Others : Don't care | Note: Do not access the external memory area except set CS area. ### 10.4 External Bus Cycle ### 10.4.1 Separate bus mode Page 327 2023/07/21 ### 10.4.1.2 $t_{WC}$ / $t_{WP}$ setting example $t_{WC}$ =4, $t_{WP}$ =2(smc\_set\_cycles = 0x0002934C) | | | t <sub>TR</sub> | t <sub>PC</sub> | t <sub>WP</sub> | tceoe | t <sub>WC</sub> | t <sub>RC</sub> | |----------------|-------|-----------------|-----------------|-----------------|-------------|-----------------|-----------------| | ama aat ayalaa | 31-20 | 19-17 | 16-14 | 13-11 | 10-8 | 7-4 | 3-0 | | smc_set_cycles | - | Set_t5[2:0] | Set_t4[2:0] | Set_t3[2:0] | Set_t2[2:0] | Set_t1[3:0] | Set_t0[3:0] | | Setting | 0 | 001(1) | 010(2) | 010(2) | 011(3) | 0100(4) | 1100(C) | Figure 10-3 Asynchronous Write ### 10.4.1.3 $t_{RC}$ / $t_{CEOE}$ / $t_{PC}$ setting example t<sub>RC</sub> =3, t<sub>CEOE</sub> =2, t<sub>PC</sub> =1(smc\_set\_cycles = 0x000272C3) | | | t <sub>TR</sub> | t <sub>PC</sub> | t <sub>WP</sub> | tCEOE | t <sub>WC</sub> | t <sub>RC</sub> | |----------------|-------|-----------------|-----------------|-----------------|-------------|-----------------|-----------------| | ama aat ayalaa | 31-20 | 19-17 | 16-14 | 13-11 | 10-8 | 7-4 | 3-0 | | smc_set_cycles | - | Set_t5[2:0] | Set_t4[2:0] | Set_t3[2:0] | Set_t2[2:0] | Set_t1[3:0] | Set_t0[3:0] | | Setting value | 0 | 001(1) | 001(1) | 110(6) | 010(2) | 1100(C) | 0011(3) | Figure 10-4 Asynchronous Page Read ### 10.4.1.4 t<sub>TR</sub> setting example $t_{TR} = 1 (smc\_set\_cycles = 0x00029143)$ | | | $t_{TR}$ | $t_{PC}$ | t <sub>WP</sub> | tceoe | $t_{WC}$ | $t_{RC}$ | | |----------------|-------|-------------|-------------|-----------------|-------------|-------------|-------------|--| | smc_set_cycles | 31-20 | 19-17 | 16-14 | 13-11 | 10-8 | 7-4 | 3-0 | | | | - | Set_t5[2:0] | Set_t4[2:0] | Set_t3[2:0] | Set_t2[2:0] | Set_t1[3:0] | Set_t0[3:0] | | | Setting value | 0 | 001(1) | 010(2) | 010(2) | 001(1) | 0100(4) | 0011(3) | | Figure 10-5 Asynchronous Read and Asynchronous Write ### 10.4.2 Multiplex mode ### 10.4.2.1 $t_{RC}$ / $t_{CEOE}$ setting example $t_{RC}$ =4, $t_{CEOE}$ =1 (smc\_set\_cycles = 0x0002B1C4) | | | $t_{TR}$ | t <sub>PC</sub> | t <sub>WP</sub> | t <sub>CEOE</sub> | $t_{WC}$ | $t_{RC}$ | |----------------|-------|-------------|-----------------|-----------------|-------------------|-------------|-------------| | smc_set_cycles | 31-20 | 19-17 | 16-14 | 13-11 | 10-8 | 7-4 | 3-0 | | | - | Set_t5[2:0] | Set_t4[2:0] | Set_t3[2:0] | Set_t2[2:0] | Set_t1[3:0] | Set_t0[3:0] | | Setting value | 0 | 001(1) | 010(2) | 110(6) | 001(1) | 1100(C) | 0100(4) | Figure 10-6 Asynchronous Read Page 331 2023/07/21 ### 10.4.2.2 $\;\;$ $t_{WC}$ / $t_{WP}$ setting example $t_{WC}$ =5, $t_{WP}$ =1 (smc\_set\_cycles = 0x00028B5C) | | | t <sub>TR</sub> | t <sub>PC</sub> | t <sub>WP</sub> | tceoe | t <sub>WC</sub> | t <sub>RC</sub> | | |----------------|-------|-----------------|-----------------|-----------------|-------------|-----------------|-----------------|--| | smc_set_cycles | 31-20 | 19-17 | 16-14 | 13-11 | 10-8 | 7-4 | 3-0 | | | | - | Set_t5[2:0] | Set_t4[2:0] | Set_t3[2:0] | Set_t2[2:0] | Set_t1[3:0] | Set_t0[3:0] | | | Setting value | 0 | 001(1) | 010(2) | 001(1) | 011(3) | 0101(5) | 1100(C) | | Figure 10-7 Asynchronous Write #### 10.4.2.3 t<sub>TR</sub> setting example $t_{TR} = 1 \text{ (smc\_set\_cycles} = 0x00029144)$ | | | t <sub>TR</sub> | t <sub>PC</sub> | t <sub>WP</sub> | tceoe | $t_{WC}$ | t <sub>RC</sub> | |----------------|-------|-----------------|-----------------|-----------------|-------------|-------------|-----------------| | smc_set_cycles | 31-20 | 19-17 | 16-14 | 13-11 | 10-8 | 7-4 | 3-0 | | | - | Set_t5[2:0] | Set_t4[2:0] | Set_t3[2:0] | Set_t2[2:0] | Set_t1[3:0] | Set_t0[3:0] | | Setting value | 0 | 001(1) | 010(2) | 010(2) | 001(1) | 0100(4) | 0100(4) | Figure 10-8 Asynchronous Read and Asynchronous Write ### 10.5 Connection example for external memory Below figures show connection example for external 16bit NOR-Flash and 16bit SRAM. Figure 10-9 Connection Example for external 16bit SRAM and NOR-Flash (Separate mode) Figure 10-10 Connection example for external 16bit SRAM and NOR-Flash (Multiplex mode) Page 335 2023/07/21 TOSHIBA TMPM362F10FG # 11. 16-bit Timer / Event Counters (TMRB) ### 11.1 Outline TMRB operate in the following four operation modes: - 16-bit interval timer mode - 16-bit event counter mode - 16-bit programmable pulse generation mode (PPG) - · Timer synchronous mode The use of the capture function allows TMRB to perform the following three measurements. - · One shot pulse output by an external trigger - · Frequency measurement - · Pulse width measurement - · Time difference measurement In the following explanation of this section, "x" indicates a channel number. ## 11.2 Differences in the Specifications TMPM362F10FG contains 16-channel of TMRB. Each channel functions independently and the channels operate in the same way except for the differences in their specification as shown in Table 11-1. Some of the channels can put the capture trigger and the synchronous start trigger on other channels. - 1. The flip-flop output of TMRB 0, 4, 8 and C can be used as the capture trigger of other channels. - TB0OUT → available for TMRB5 through TMRB7 - TB4OUT → available for TMRB1 through TMRB3 - TB8OUT → available for TMRBD through TMRBF - TBCOUT → available for TMRB9 through TMRBB - 2. The start trigger of the timer synchronous mode (with TBxRUN) - TMRB0 → can start TMRB0 through TMRB3 synchronously - TMRB4 → can start TMRB4 through TMRB7 synchronously - TMRB8 → can start TMRB8 through TMRBB synchronously - TMRBC → can start TMRBC through TMRBF synchronously Table 11-1 Differences in the Specifications of TMRB Modules | Specification | Extern | al pins | Trigger function | n between timers | Inte | errupt | |---------------|---------------------------------------------|-----------------------------------|--------------------|---------------------------|------------------------|-------------------| | Channel | External clock / capture trigger input pins | Timer flip-flop output pin | Capture<br>trigger | Synchronous start trigger | Capture in-<br>terrupt | TMRB<br>interrupt | | | Signal | Signal | uiggei | channel | | тепарі | | TMRB0 | - | TB0OUT | - | TMRB0 ( | 7-> | INTTB0 | | TMRB1 | TB1IN0<br>TB1IN1 | TB1OUT | TB4OUT | TMRB0 | INTCAP10<br>INTCAP11 | INTTB1 | | TMRB2 | TB2IN0<br>TB2IN1 | TB2OUT | TB4OUT | TMRB0 | INTCAP20<br>INTCAP21 | INTTB2 | | TMRB3 | -<br>(Connect to SCLK3) | TB3OUT | TB4OUT | TMRB0 | - ( | INTTB3 | | TMRB4 | - | TB4OUT | - 🗸 ( | TMRB4 | -(( | INTTB4 | | TMRB5 | TB5IN0<br>TB5IN1 | TB5OUT (Connect to SIO0 to SIO3) | TB0OUT | TMRB4 | INTCAP50<br>INTCAP51 | INTTB5 | | TMRB6 | TB6IN0<br>TB6IN1 | TB6OUT (Connect to SIO4 to SIO7) | TB0OUT | TMRB4 | INTCAP60<br>INTCAP61 | INTTB6 | | TMRB7 | TB7IN0<br>TB7IN1 | ТВ7ОИТ | TB0OUT | TMRB4 | INTCAP70<br>INTCAP71 | INTTB7 | | TMRB8 | - | TB8OUT | - | TMRB8 | <i>y</i> - | INTTB8 | | TMRB9 | TB9IN0<br>TB9IN1 | TB9OUT (Connect to SIO8 to SIO11) | TBCOUT | TMRB8 | INTCAP90<br>INTCAP91 | INTTB9 | | TMRBA | TBAIN0<br>TBAIN1 | TBAOUT<br>(Connect to CEC) | твсоит | TMRB8 | INTCAPA0<br>INTCAPA1 | INTTBA | | TMRBB | TBBIN0<br>TBBIN1 | TBBOUT (Connect to RMC) | твсоит | TMRB8 | INTCAPB0<br>INTCAPB1 | INTTBB | | TMRBC | - | ТВСОИТ | <u> </u> | TMRBC | - | INTTBC | | TMRBD | TBDIN0<br>TBDIN1 | TBDOUT | TB8OUT | TMRBC | INTCAPD0<br>INTCAPD1 | INTTBD | | TMRBE | TBEIN0<br>TBEIN1 | TBEOUT | TB8OUT | TMRBC | INTCAPE0<br>INTCAPE1 | INTTBE | | TMRBF | TBFIN0<br>TBFIN1 | TBFOUT | TB8OUT | TMRBC | INTCAPF0<br>INTCAPF1 | INTTBF | 11.3 Configuration TMPM362F10FG ## 11.3 Configuration Each channel consists of a 16-bit up-counter, two 16-bit timer registers (double-buffered), two 16-bit capture registers, two comparators, a capture input control, a timer flip-flop and its associated control circuit. Timer operation modes and the timer flip-flop are controlled by a register. Figure 11-1 TMRBx Block Diagram (x= 0 to 2, 4 to F) Figure 11-2 TMRBx Block Diagram (x= 3) Page 341 2023/07/21 1.4 Registers TMPM362F10FG ## 11.4 Registers ### 11.4.1 Register list according to channel The following table shows the register names and addresses of each channel. | 21 1 | T | |-----------|--------------| | Channel x | Base Address | | Channel 0 | 0x400D_0000 | | Channel 1 | 0x400D_0100 | | Channel 2 | 0x400D_0200 | | Channel 3 | 0x400D_0300 | | Channel 4 | 0x400D_0400 | | Channel 5 | 0x400D_0500 | | Channel 6 | 0x400D_0600 | | Channel 7 | 0x400D_0700 | | Channel 8 | 0x400D_0800 | | Channel 9 | 0x400D_0900 | | Channel A | 0x400D_0A00 | | Channel B | 0x400D_0B00 | | Channel C | 0x400D_0C00 | | Channel D | 0x400D_0D00 | | Channel E | 0x400D_0E00 | | Channel F | 0x400D_0F00 | # 11.4.2 TBxEN (Enable register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|------|----|----|----|----------|--------------|------|----| | bit symbol | - | - | - | - | - | - | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ٦ | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | TBEN | - | - | - | | > - | 2-// | - | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | TBEN | R/W | TMRBx operation | | | | | 0: Disable | | | | | 1: Enable | | | | | Specifies the TMRB operation. When the operation is disabled, no clock is supplied to the other registers in the TMRB module. This can reduce power consumption. (This disables reading from and writing to the other registers except TBxEN register.) | | | | | To use the TMRB, enable the TMRB operation (set to "1") before programming each register in the TMRB module. If the TMRB operation is executed and then disabled, the settings will be maintained in each register. | | 6-0 | _ | R | Read as "0". | Page 343 2023/07/21 11.4 Registers TMPM362F10FG ## 11.4.3 TBxRUN (RUN register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|--------|------|-------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | 1 | 1 | 1 | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | TBPRUN | 2-// | TBRUN | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------| | 31-3 | - | R | Read as "0". | | 2 | TBPRUN | R/W | Prescaler operation | | | | | 0: Stop & clear | | | | | 1: Count | | 1 | _ | R | Read as "0". | | 0 | TBRUN | R/W | Count operation | | | | | 0: Stop & clear | | | | | 1: Count | # 11.4.4 TBxCR (Control register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-------|----|--------|----|----------|--------------|------|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | TBWBF | - | TBSYNC | - | 12TB | > - | 2-// | - | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------| | 31-8 | _ | R | Read as "0" | | 7 | TBWBF | R/W | Double buffer | | | | | 0: Disable | | | | | 1: Enable | | 6 | _ | R/W | Write as "0". | | 5 | TBSYNC | R/W | Synchronous mode switching | | | | | 0: individual (unit of channel) | | | | | 1: synchronous | | 4 | _ | R | Read as "0". | | 3 | I2TB | R/W | Operation at IDLE mode | | | | | 0: Stop | | | | | 1:Operation | | 2 | _ | R | Read as "0". | | 1-0 | - | R/W | Write as "0". | Note: Do not modify TBxCR during operating TMRB. 11.4 Registers TMPM362F10FG # 11.4.5 TBxMOD (Mode register) x=0 to 2, 4 to F | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|------|-----|---------|----------|-------|-----| | bit symbol | - | - | - | - | - | - (( | 1- | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 23 | 22 | 21 | 20 | 19 | (187) | 17 | 16 | | bit symbol | - | - | - | - | - | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | <u> </u> | - | - | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | \d(\) | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 21/ | 0 | | bit symbol | - | - | TBCP | TBO | CPM (// | TBCLE | TBO | CLK | | After reset | 0 | 0 | 1 | 0 | 0 | 0 _ | | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | - | R | Read as "0". | | 6 | - | R/W | Write as "0". | | 5 | TBCP | w | Capture control by software 0: Capture by software 1: Don't care When "0" is written, the capture register 0 (TBxCP0) takes count value. Read as "1". | | 4-3 | TBCPM[1:0] | R/W | Capture timing 00: Disable 01: TBxIN0↑ TBxIN1↑ Takes count values into capture register 0 (TBxCP0) upon rising of TBxIN0 pin input. Takes count values into capture register 1 (TBxCP1) upon rising of TBxIN1 pin input. 10: TBxIN0↑ TBxIN0↓ Takes count values into capture register 0 (TBxCP0) upon rising of TBxIN0 pin input. Takes count values into capture register 1 (TBxCP1) upon falling of TBxIN0 pin input. 11: TBxOUT↑ TBxOUT↓ Takes count values into capture register 0 (TBxCP0) upon rising of 16-bit timer match output (TBxOUT) and into capture register 1 (TBxCP1) upon falling of TBxOUT. (TMRB1 to 3: TB4OUT , TMRB5 to 7: TB0OUT , TMRB9 to B: TBCOUT , TMRBD to F: TB8OUT) | | 2 | TBCLE | R/W) | Up-counter control 0: Disables clearing of the up-counter. 1: Enables clearing of the up-counter. Clears and controls the up-counter. When "0" is written, it disables clearing of the up-counter. When "1" is written, it clears up counter when there is a match with Timer Regsiter1 (TBxRG1). | | 1-0 | TBCLK[1:0] | R/W | Selects the TMRBx source clock. 00: TBxIN0 pin input 01: \( \psi T1 \) 10: \( \psi T4 \) 11: \( \psi T16 \) | Note: TMRB0, 3, 4, 8 and A does not have TBxIN0 input and TBxIN1 input. x=3 | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-----|----------|----------------|-----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 🚫 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | 1 | - | - (( | 1 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | $\binom{8}{2}$ | 0 | | | 15 | 14 | 13 | 12 | 11 | (10 7/ < | 9 | 8 | | bit symbol | - | - | - | - | - | | / - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | 1 | - ( | TBCLE | TBO | CLK | | After reset | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | - | R | Read as "0". | | 6 | - | R/W | Write as "0". | | 5 | - | W | Write as "1". | | 4-3 | - | R/W | Write as "00". | | 2 | TBCLE | R/W | Up-counter control 0: Disables clearing of the up-counter. 1: Enables clearing of the up-counter. Clears and controls the up-counter. When "0" is written, it disables clearing of the up-counter. When "1" is written, it clears up counter when there is a match with Timer Regsiter1 (TBxRG1). | | 1-0 | TBCLK[1:0] | R/W | Selects the TMRBx source clock. 00: SCLK3 pin input 01: \( \psi \tau \tau \tau \tau \tau \tau \tau \tau | Page 347 2023/07/21 11.4 Registers TMPM362F10FG # 11.4.6 TBxFFCR (Flip-flop control register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|--------|--------|----------|--------------|-----|-----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | TBC1T1 | TBC0T1 | TBE1T1 | TBE0T1 | TBF | F0C | | After reset | 1 | 1 | 0 | 0 | ((/o/ \) | 0_ | | 1 | | Bit | Bit Symbol | Туре | Function | |------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | _ | R | Read as "0". | | 7-6 | - | R | Read as "1". | | 5 | TBC1T1 | R/W | TBxFF0 reverse trigger when the up-counter value is taken into the TBxCP1. 0: Disable trigger 1: Enable trigger By setting "1", the timer-flip-flop reverses when the up-counter value is taken into the Capture register 1 (TBxCP1). | | 4 | TBC0T1 | R/W | TBxFF0 reverse trigger when the up-counter value is taken into the TBxCP0. 0: Disable trigger 1: Enable trigger By setting "1", the timer-flip-flop reverses when the up-counter value is taken into the Capture register 0 (TBxCP0). | | 3 | TBE1T1 | R/W | TBxFF0 reverse trigger when the up-counter value is matched with TBxRG1. 0: Disable trigger 1: Enable trigger By setting "1", the timer-flip-flop reverses when the up-counter value is matched with the Timer register 1 (TBxRG1). | | 2 | TBE0T1 | R/W | TBxFF0 reverse trigger when the up-counter value is matched with TBxRG0. 0: Disable trigger 1: Enable trigger By setting "1", the timer-flip-flop reverses when an up-counter value is matched with the Timer register 0 (TBxRG0). | | 1-0 | TBFF0C[1:0] | R/W | TBxFF0 control 00: Invert Reverses the value of TBxFF0 (reverse by using software). 01: Set Sets TBxFF0 to "1". 10: Clear Clears TBxFF0 to "0". 11: Don't care * This is always read as "11". | Note: Do not modify TBxFFCR during operating TMRB. # 11.4.7 TBxST (Status register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|--------------|--------|--------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | INTTBOF | INTTB1 | INTTB0 | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | - | R | Read as "0". | | 2 | INTTBOF | R | Overflow flag 0:No overflow occurs 1:Overflow occurs When an up-counter is overflow, "1" is set. | | 1 | INTTB1 | R | Match flag (TBxRG1) 0:No detection of a mach 1:Detects a match with TBxRG1 When a match with the timer register 1 (TBxRG1) is detected, "1" is set. | | 0 | INTTB0 | R | Match flag (TBxRG0) 0:No match is detected 1:Detects a match with TBxRG0 When a match with the timer register 0 (TBxRG0) is detected, "1" is set. | Note 1: The factors only which is not masked by TBxIM output interrupt request to the CPU. Even if the mask setting is done, the flag is set. Note 2: The flag is cleared by reading the TBxST register.To clear the flag, TBxST register should be read. 11.4 Registers TMPM362F10FG # 11.4.8 TBxIM (Interrupt mask register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|--------|-------|-------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | TBIMOF | TBIM1 | TBIM0 | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | - | R | Read as "0". | | 2 | ТВІМОГ | R/W | Overflow interrupt mask 0:Disable 1:Enable Sets the up-counter overflow interrupt to disable or enable. | | 1 | ТВІМ1 | R/W | Match interrupt mask (TBxRG1) 0:Disable 1:Enable Sets the match interrupt mask with the Timer register 1 (TBxRG1) to enable or disable. | | 0 | ТВІМО | R/W | Match interrupt mask (TBxRG0) 0:Disable 1:Enable Sets the match interrupt mask with the Timer register 0 (TBxRG0) to enable or disable. | # 11.4.9 TBxUC (Up counter capture register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|------|-----|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | ТВ | UC | | | | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | ТВ | UC | > | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|----------------------------------------------------------------------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-0 | TBUC[15:0] | R | Captures a value by reading up-counter out. If TBxUC is read, current up-counter value can be captured. | Note: When the counter is operated and TBxUC is read, the value of the up counter is captured and read. Page 351 2023/07/21 11.4 Registers TMPM362F10FG # 11.4.10 TBxRG0 (Timer register 0) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|-----|----------|------|-----|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | TBF | RG0 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | TBF | RG0 | > | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|-------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-0 | TBRG0[15:0] | R/W | Sets a value comparing to the up-counter. | # 11.4.11 TBxRG1 (Timer register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|----------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----|----|----|----| | bit symbol | - | . ( | | - < | (2) | - | - | - | | After reset | 0 | 0 ( | 0 🗸 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - / | <u> </u> | /<br>-<br></td <td><math>\langle (\overline{\cdot} ) \rangle</math></td> <td>) -</td> <td>-</td> <td>-</td> <td>-</td> | $\langle (\overline{\cdot} ) \rangle$ | ) - | - | - | - | | After reset | 0 | //0 | 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | ^ ^ | | | TBF | RG1 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 9 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | (4) | TBF | RG1 | | | | | After reset | | 0 | | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|-------------------------------------------| | 31-16 | ¥/ | R | Read as "0". | | 15-0 | TBRG1[15:0] | R/W | Sets a value comparing to the up-counter. | # 11.4.12 TBxCP0 (Capture register 0) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | TBO | CP0 | | | | | After reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | TBO | CP0 | > | 2// | | | After reset | Undefined | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|-----------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-0 | TBCP0[15:0] | R | A value captured from the up-counter is read. | ## 11.4.13 TBxCP1 (Capture register 1) | | 31 | 30 | 29 | 28 🤇 | 27 | 26 | 25 | 24 | |-------------|-----------|-----------|------------------------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - ( | 77 | - / | | - | - | - | | After reset | 0 | 0 | / ))0 | | | 0 | 0 | 0 | | | 23 | 22 | 21 | 20// < | 19 | 18 | 17 | 16 | | bit symbol | - < | | 7 - | | _ | - | - | - | | After reset | 0 | 9 | 0 | 6 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | TBO | CP1 | | | | | After reset | Undefined | | 7 | 6 | <b>\(\frac{1}{5}\)</b> | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | | TBO | CP1 | | | | | After reset | Undefined | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|-----------------------------------------------| | 31-16 | ->> | R | Read as "0". | | 15-0 | TBCP1[15:0] | R | A value captured from the up-counter is read. | Page 353 2023/07/21 #### 11.5 Description of Operations for Each Circuit ## 11.5 Description of Operations for Each Circuit The channels operate in the same way, except for the differences in their specifications as shown in Table 11-1. #### 11.5.1 Prescaler There is a 4-bit prescaler to generate the source clock for up-counter UC. The prescaler input clock $\phi$ T0 is fs, fperiph/1, fperiph/2, fperiph/4, fperiph/8, fperiph/16 or fperiph/32 selected by CGSYSCR<FPSEL1> in the CG. The peripheral clock, fperiph, is either fgear, a clock selected by CGSYSCR<FPSEL0> in the CG, or fc, which is a clock before it is divided by the clock gear. The operation or the stoppage of a prescaler is set with TBxRUN<TBPRUN> where writing "1" starts counting and writing "0" clears and stops counting. Below tables show prescaler output clock resolutions. Table 11-2 Prescaler Output Clock Resolutions (fc = 64MHz, fs = 32.768kHz) | Select φT0 | Select peripheral | Select gear clock | Select prescaler | Prescaler output clock function | | | | |------------------------------|-------------------------|-------------------|---------------------------------------------|---------------------------------|------------------------------|-------------------------------|--| | CGSYSCR<br><fpsel1></fpsel1> | CGSYSCR CGSYSCR CGSYSCR | | clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φT1 | O PT4 | φT16 | | | | | | 000 (fperiph/1) | fc/2 <sup>1</sup> (0.0312 μs) | fc/2 <sup>3</sup> (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | | | | | | 001 (fperiph/2) | fc/2² (0.0625 µs) | fc/2 <sup>4</sup> (0.25 μs) | fc/2 <sup>6</sup> (1.0 µs) | | | | | 000 (5:) | 010 (fperiph/4) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 µs) | | | | | 000 (fc) | 011 (fperiph/8) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 μs) | | | | | (( | 000 (fperiph/1) | fc/2² (0.0625 µs) | fc/2 <sup>4</sup> (0.25 μs) | fc/2 <sup>6</sup> (1.0 μs) | | | | | | 001 (fperiph/2) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | | | | | 100(5)(0) | 010 (fperiph/4) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | | | | | 100 (fc/2) | 011 (fperiph/8) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | | | | | (7/6) | 100 (fperiph/16) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | 0 | O (factor) | | 101 (fperiph/32) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | | | 0 | 0 (fgear) | | 000 (fperiph/1) | fc/2 <sup>3</sup> (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 μs) | | | | | | 001 (fperiph/2) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | | 104 (5-14) | 010 (fperiph/4) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | | | | $\wedge \wedge$ | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | 7 | ^ | 100 (fperiph/16) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | | | | | | 101 (fperiph/32) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0 µs) | | | $\wedge$ | | | 000 (fperiph/1) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | | | | | | 001 (fperiph/2) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 μs) | | | | ) (( | 110 (5-10) | 010 (fperiph/4) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>7</sup> (2.0 μs) | fc/2 <sup>9</sup> (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | | | | <b>&gt;</b> | | 100 (fperiph/16) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0 µs) | | | | | | 101 (fperiph/32) | fc/2 <sup>9</sup> (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | fc/2 <sup>13</sup> (128.8 µs) | | Table 11-2 Prescaler Output Clock Resolutions (fc = 64MHz, fs = 32.768kHz) | Select φT0 | Select peripheral clock | Select gear clock | Select prescaler | Pres | Prescaler output clock function | | | | |------------------------------|-------------------------|-------------------|------------------------------------------------------------------------|------------------------------|--------------------------------------|------------------------------|--|--| | CGSYSCR<br><fpsel1></fpsel1> | GSYSCR CGSYSCR CGSYSCR | | clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | | | | | | | 000 (fperiph/1) | fc/21 (0.0312 µs) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | | | | | | | 001 (fperiph/2) | fc/2² (0.0625 µs) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 μs) | | | | | | 000 (f-) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.125 µs) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 μs) | | | | | | 000 (fc) | 011 (fperiph/8) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 μs) | | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | | | | 000 (fperiph/1) | | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 μs) | | | | | | | 001 (fperiph/2) | fc/2² (0.0625 μs) | fc/2 <sup>4</sup> (0.25 μ <b>s</b> ) | fc/2 <sup>6</sup> (1.0 μs) | | | | | 1 (fc) | 400 (5-10) | 010 (fperiph/4) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 μs) | | | | | | 100 (fc/2) | 011 (fperiph/8) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 μs) | | | | | | | 101 (fperiph/32) fc/2 <sup>6</sup> (1.0 µs) fc/2 <sup>8</sup> (4.0 µs) | | | | | | | 0 | | | 000 (fperiph/1) | _ | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 μs) | | | | | | 104 (5 (1) | 001 (fperiph/2) | - ( | fc/2 <sup>4</sup> (0.25 μs) | fc/2 <sup>6</sup> (1.0 μs) | | | | | | | 010 (fperiph/4) | fc/2³ (0.125 µs) | ∕fc/2⁵ (0.5 μs) | fc/2 <sup>7</sup> (2.0 μs) | | | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.25 μs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 μs) | | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | | | | 000 (fperiph/1) | // | - | fc/2 <sup>5</sup> (0.5 μs) | | | | | | | 001 (fperiph/2) | | fc/2⁴ (0.25 μs) | fc/2 <sup>6</sup> (1.0 μs) | | | | | | 110 (50(9) | 010 (fperiph/4) | - | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 μs) | | | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | | | ((//5) | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 μs) | fc/2 <sup>9</sup> (8.0 µs) | | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | 1 | | * | | fs/2 (61µs) | fs/2³ (244 µs) | fc/2 <sup>5</sup> (977 μs) | | | Note 1: The prescaler output clock $\phi Tn$ must be selected so that $\phi Tn$ < fsys is satisfied (so that $\phi Tn$ is slower than fsys). Note 2: Do not change the clock gear while the timer is operating. Note 3: "." denotes a setting prohibited. "\*" denotes a don't care. Table 11-3 Prescaler Output Clock Resolutions (fc = 48MHz, fs = 32.768kHz) | Select φT0 | Select peripheral | Select gear clock | Select prescaler | Pres | scaler output clock fund | ction | |------------------------------|---------------------------------------|-------------------------------------------------|---------------------------------------------|------------------------------|-------------------------------|--------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | clock<br>CGSYSCR<br><fpsel0></fpsel0> | CGSYSCR<br><gear[2:0]></gear[2:0]> | clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | | | | | 000 (fperiph/1) | fc/21 (0.04 µs) | fc/2³ (0.17 µs) | fc/2 <sup>5</sup> (0.66 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>2</sup> (0.08 µs) | fc/24 (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | | | | 000 (f-) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.17 µs) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | | | | 000 (fc) | 011 (fperiph/8) | fc/24 (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.67 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 µs) | | | | | 000 (fperiph/1) | fc/2² (0.08 µs) | fc/24 (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>3</sup> (0.17 µs) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | | | | 100 (fo/2) | 010 (fperiph/4) | fc/24 (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/2 <sup>8</sup> (5.33 µs) | | | | 100 (fc/2) | 011 (fperiph/8) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2º (10.67 µs) | | | | | 100 (fperiph/16) | fc/26 (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 μs) | | 0 | 0 (5) | | 101 (fperiph/32) | fc/2 <sup>7</sup> (2.67 μs) | fc/2 <sup>9</sup> (10.67 µs) | fc/2 <sup>11</sup> (42.67 µs) | | 0 | 0 (fgear) | | 000 (fperiph/1) | fc/2³ (0.17 µs) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>4</sup> (0.33 μs) | fc/2 <sup>6</sup> (1.33 μs) | fc/2 <sup>8</sup> (5.33 µs) | | | | | 010 (fperiph/4) | fc/2 <sup>5</sup> (0.66 µs) | /fc/2 <sup>7</sup> (2.67 μs) | fc/29 (10.67 µs) | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>6</sup> (1.33 μs) | fc/2 <sup>8</sup> (5.33 µs) | fc/2 <sup>10</sup> (21.33 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.67 µs) | fc/2 <sup>11</sup> (42.67 µs) | | | | ( | 101 (fperiph/32) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 µs) | fc/2 <sup>12</sup> (85.33 µs) | | | | | 000 (fperiph/1) | fc/24 (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.67 µs) | | | | 140 (50) | 010 (fperiph/4) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 µs) | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.67 μs) | fc/2 <sup>11</sup> (42.67 µs) | | | | $( \langle // $ | 100 (fperiph/16) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 μs) | fc/2 <sup>12</sup> (85.33 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>9</sup> (10.67 µs) | fc/2 <sup>11</sup> (42.67 µs) | fc/2 <sup>13</sup> (170.67 µs) | Table 11-3 Prescaler Output Clock Resolutions (fc = 48MHz, fs = 32.768kHz) | Select φT0 | Select peripheral clock | Select gear clock | Select prescaler | Pres | scaler output clock fund | caler output clock function | | | |------------------------------|-------------------------|-------------------|--------------------------------------------------------------------------|-----------------------------|------------------------------|-------------------------------|--|--| | CGSYSCR<br><fpsel1></fpsel1> | CR CGSYSCR CGSYSCR | | clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | | | | | | | 000 (fperiph/1) | fc/21 (0.04 µs) | fc/2³ (0.17 μs) | fc/2 <sup>5</sup> (0.66 µs) | | | | | | | 001 (fperiph/2) | fc/2² (0.08 µs) | fc/2⁴ (0.33 μs) | fc/2 <sup>6</sup> (1.33 µs) | | | | | | 000 (f-) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.17 µs) | fc/2 <sup>5</sup> (0.66 μs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | | 000 (fc) | 011 (fperiph/8) | fc/24 (0.33 µs) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.67 µs) | | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 μs) | fc/2 <sup>8</sup> (5.33 μs) | fc/2 <sup>10</sup> (21.33 µs) | | | | | | | 000 (fperiph/1) | | fc/2³ (0.17 µs) | fc/2 <sup>5</sup> (0.66 µs) | | | | | | | 001 (fperiph/2) | fc/2² (0.08 μs) | fc/2 <sup>4</sup> (0.33 μs) | fc/2 <sup>6</sup> (1.33 µs) | | | | | 1 (fc) | 400 (5-10) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.17 µs) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | | 100 (fc/2) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/2 <sup>8</sup> (5.33 µs) | | | | | | | 100 (fperiph/16) fc/2 <sup>5</sup> (0.66 μs) fc/2 <sup>7</sup> (2.67 μs) | | | | | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 µs) | | | | 0 | | | 000 (fperiph/1) | - | fc/2³ (0.17 µs) | fc/2 <sup>5</sup> (0.66 µs) | | | | | | | 001 (fperiph/2) | · ( | fc/2 <sup>4</sup> (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | | | | | | | 010 (fperiph/4) | fc/2³ (0.17 µs) | /fc/2 <sup>5</sup> (0.66 μs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | | 101 (fc/4) | 011 (fperiph/8) | fc/24 (0.33 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.67 µs) | | | | | | 6 | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 µs) | | | | | | | 000 (fperiph/1) | | - | fc/2 <sup>5</sup> (0.66 µs) | | | | | | | 001 (fperiph/2) | | fc/2 <sup>4</sup> (0.33 μs) | fc/2 <sup>6</sup> (1.33 µs) | | | | | | 140 (5-(0) | 010 (fperiph/4) | - | fc/2 <sup>5</sup> (0.66 µs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.33 μs) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | | | | | | ((//5) | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.66 μs) | fc/2 <sup>7</sup> (2.67 μs) | fc/2 <sup>9</sup> (10.67 µs) | | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.33 µs) | | | | 1 | | * | | fs/2 (61µs) | fs/2³ (244 µs) | fc/2 <sup>5</sup> (977 μs) | | | Note 1: The prescaler output clock $\phi$ Tn must be selected so that $\phi$ Tn < fsys is satisfied (so that $\phi$ Tn is slower than fsys). Note 2: Do not change the clock gear while the timer is operating. Note 3: "." denotes a setting prohibited. "\*" denotes a don't care. Table 11-4 Prescaler Output Clock Resolutions (fc = 32MHz,fs = 32.768kHz) | Select φT0 | Select peripheral | Select gear clock | Select prescaler | Pres | scaler output clock fund | tion | |------------------------------|------------------------|------------------------|------------------------------------------------------------------------|-----------------------------|------------------------------|-------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | GSYSCR CGSYSCR CGSYSCR | | clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | | | | | 000 (fperiph/1) | fc/21 (0.0625 µs) | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1.0 μs) | | | | | 001 (fperiph/2) | fc/2² (0.125 µs) | fc/24 (0.5 µs) | fc/2 <sup>6</sup> (2.0 μs) | | | | 000 (fa) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 μs) | | | | 000 (fc) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | | 101 (fperiph/32) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | | 000 (fperiph/1) | fc/2² (0.125 µs) | fc/24 (0.5 µs) | fc/2 <sup>6</sup> (2.0 μs) | | | | | 001 (fperiph/2) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 μs) | | | 2// | 400 (5-10) | 010 (fperiph/4) | fc/2 <sup>4</sup> (0.5 µs) | fc/2 <sup>6</sup> (2.0 µs) | fc/2 <sup>8</sup> (8.0 μs) | | | | 100 (fc/2) | 011 (fperiph/8) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2º (16.0 µs) | | | | | 100 (fperiph/16) fc/2 <sup>β</sup> (2.0 μs) fc/2 <sup>β</sup> (8.0 μs) | | | | | | | | 101 (fperiph/32) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | 0 | 0 (fgear) | | 000 (fperiph/1) | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1,0 µs) | fc/2 <sup>7</sup> (4.0 μs) | | | | | 001 (fperiph/2) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | | 010 (fperiph/4) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 μs) | fc/29 (16.0 µs) | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | | 101 (fperiph/32) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 µs) | | | | | 000 (fperiph/1) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | 140 (5-)0) | 010 (fperiph/4) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | $(\langle // \rangle)$ | 100 (fperiph/16) | fc/2 <sup>8</sup> (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 μs) | | | | | 101 (fperiph/32) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | fc/2 <sup>13</sup> (256.0 µs) | Table 11-4 Prescaler Output Clock Resolutions (fc = 32MHz,fs = 32.768kHz) | Select φT0 | Select peripheral clock | Select gear clock | Select prescaler | Pres | scaler output clock function | | | |------------------------------|-------------------------|-------------------------------------------------|---------------------------------------------|----------------------------|------------------------------|------------------------------|--| | CGSYSCR<br><fpsel1></fpsel1> | SSYSCR CGSYSCR CGSYSCR | | clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | | | | | | 000 (fperiph/1) | fc/21 (0.0625 µs) | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | | | | | | 001 (fperiph/2) | fc/2² (0.125 µs) | fc/24 (0.5 µs) | fc/2 <sup>6</sup> (2.0 µs) | | | | | 000 (fp) | 010 (fperiph/4) | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 000 (fc) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | | 000 (fperiph/1) | | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | | | | | | 001 (fperiph/2) | fc/2² (0.125 µs) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | | | | 1 (fc) | 100 (fo/2) | 010 (fperiph/4) | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 100 (fc/2) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 µs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 μs) | | | 0 | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | 0 | | | 000 (fperiph/1) | | fc/2³ (0.25 μs) | fc/2 <sup>5</sup> (1.0 µs) | | | | | | 001 (fperiph/2) | · - | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | | | | | 404 (5-14) | 010 (fperiph/4) | fc/2³ (0.25 μs) | ∕fc/2⁵ (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 µs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/29 (16.0 µs) | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 µs) | fc/2 <sup>8</sup> (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | | 000 (fperiph/1) | | - | fc/2 <sup>5</sup> (1.0 µs) | | | | | | 001 (fperiph/2) | | fc/2 <sup>4</sup> (0.5 µs) | fc/2 <sup>6</sup> (2.0 µs) | | | | | 110 (50/9) | 010 (fperiph/4) | - | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 µs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | | $( \langle // $ | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | 1 | <b>*</b> | * | | fs/2 (61µs) | fs/2³ (244 µs) | fc/2 <sup>5</sup> (977 μs) | | Note 1: The prescaler output clock $\phi$ Tn must be selected so that $\phi$ Tn < fsys is satisfied (so that $\phi$ Tn is slower than fsys). Note 2: Do not change the clock gear while the timer is operating. Note 3: "." denotes a setting prohibited. "\*" denotes a don't care. #### 11.5.2 Up-counter (UC) UC is a 16-bit binary counter. · Source clock UC source clock, specified by TBxMOD<TBCLK[1:0]>, can be selected from either three types - $\phi$ T1, $\phi$ T4 and $\phi$ T16 - of prescaler output clock or the external clock of the TBxIN0 pin. Counter start / stop Counter operation is specified by TBxRUN<TBRUN>. UC starts counting if <TBRUN> = "1", and stops counting and clears counter value if <TBRUN> = "0". - Timing to clear UC - 1. When a match is detected. By setting TBxMOD<TBCLE> = "1", UC is cleared if when the comparator detects a match between counter value and the value set in TBxRG1. UC operates as a free-running counter if TBxMOD<TBCLE> = "0". 2. When UC stops UC stops counting and clears counter value if TBxRUN<TBRUN> = "0". · UC overflow If UC overflow occurs, the INTTBx overflow interrupt is generated. ## 11.5.3 Timer registers (TBxRG0, TBxRG1) TBxRG0 and TBxRG1 are registers for setting values to compare with up-counter values and two registers are built into each channel. If the comparator detects a match between a value set in this timer register and that in a UC up-counter, it outputs the match detection signal. TBxRG0 and TBxRG1 are consisted of the double-buffered configuration which are paired with register buffers. The double buffering is disabled in the initial state. Controlling double buffering disable or enable is specified by TBxCR<TBWBF> bit. If <TBWBF> = "0", the double buffering becomes disable. If <TBWBF> = "1", it becomes enable. When the double buffering is enabled, a data transfer from the register buffer to the timer register (TBxRG0/1) is done in the case that UC is matched with TBxRG1. When the counter is stopped even if double buffering is enabled, the double buffering operates as a single buffer, and an immediate data can be written to the TBxRG0 and TBxRG1. #### 11.5.4 Capture This is a circuit that controls the timing of latching values from the UC up-counter into the TBxCP0 and TBxCP1 capture registers. The timing with which to latch data is specified by TBxMOD<TBCPM[1:0]>. Software can also be used to import values from the UC up-counter into the capture register; specifically, UC values are taken into the TBxCP0 capture register each time "0" is written to TBxMOD<TBCP>. ### 11.5.5 Capture registers (TBxCP0, TBxCP1) This register captures an up-counter (UC) value. ### 11.5.6 Up-counter capture register (TBxUC) Other than the capturing functions shown above, the current count value of the UC can be captured by reading the TBxUC registers. ### 11.5.7 Comparators (CP0, CP1) This register compares with the up-counter (UC) and the value setting of the Timer Register (TBxRG0 and TBxRG1) to detect whether there is a match or not. If a match is detected, INTTBx is generated. ### 11.5.8 Timer Flip-flop (TBxFF0) The timer flip-flop (TBxFF0) is reversed by a match signal from the comparator and a latch signal to the capture registers. It can be enabled or disabled to reverse by setting the TBxFFCR<TBC1T1, TBC0T1, TBE1T1, TBE0T1>. The value of TBxFF0 becomes undefined after a reset. The flip-flop can be reversed by writing "00" to TBxFFCR<TBFF0C[1:0]>. It can be set to "1" by writing "01," and can be cleared to "0" by writing "10." The value of TBxFF0 can be output to the Timer output pin (TBxOUT). If the timer output is performed, the corresponding port settings must be programmed beforehand. ### 11.5.9 Capture interrupt (INTCAPx0, INTCAPx1) Interrupts INTCAPx0 and INTCAPx1 can be generated at the timing of latching values from the UC up-counter into the TBxCP0 and TBxCP1 capture registers. The interrupt timing is specified by the CPU. Page 361 2023/07/21 ## 11.6 Description of Operations for Each Mode #### 11.6.1 16-bit interval Timer Mode In the case of generating constant period interrupt, set the interval time to the Timer register (TBxRG1) to generate the INTTBx interrupt. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------------------------|------------|---|---|---|---|-------|--------|--------|---------------------------------------------------------------| | TBxEN | ← 1 | Χ | X | Χ | Χ | Χ | Χ | Χ | Enables TMRBx operation. | | TBxRUN | ← X | Х | Χ | Χ | Χ | 0 | Χ | 0 | Stops count operation. | | Interrupt Set-Enable<br>Register | ← * | * | * | * | * | * | * | * | Permits INTTBx interrupt by setting corresponding bit to "1". | | TBxFFCR | ← X | Х | 0 | 0 | 0 | 0 | 1 | 1 | Disable to TBxFF0 reverse trigger | | TBxMOD | ← X | 0 | 1 | 0 | 0 | 1 | * | * | Changes to prescaler output clock as input clock. Specifies | | | | | | | | (** = | 01, 10 | 0, 11) | capture function to disable. | | TBxRG1 | <b>←</b> * | * | * | * | * | * | * | * | Specifies a time interval. (16 bits) | | | ← * | * | * | * | * | * | * | * | | | TBxRUN | ← * | * | * | * | * | 1 | Χ | 1 | Starts TMRBx. | Note:X; Don't care -; No change ### 11.6.2 16-bit Event Counter Mode It is possible to make it the event counter by using an input clock as an external clock (TBxIN0 pin input). The up-counter counts up on the rising edge of TBxIN0 pin input. It is possible to read the count value by capturing value using software and reading the captured value. ### 11.6.3 16-bit PPG (Programmable Pulse Generation) Output Mode Square waves with any frequency and any duty (programmable square waves) can be output. The output pulse can be either low-active or high-active Programmable square waves can be output from the TBxOUT pin by triggering the timer flip-flop (TBxFF) to reverse when the set value of the up-counter (UC) matches the set values of the timer registers (TBxRG0 and TBxRG1). Note that the set values of TBxRG0 and TBxRG1 must satisfy the following requirement: Figure 11-3 Example of Output of Programmable Pulse Generation (PPG) In this mode, by enabling the double buffering of TBxRG0, the value of register buffer 0 is shifted into TBxRG0 when the set value of the up-counter matches the set value of TBxRG1. This facilitates handling of small duties. Figure 11-4 Register Buffer Operation Page 363 2023/07/21 The block diagram of this mode is shown below. Figure 11-5 Block Diagram of 16-bit PPG Mode Each register in the 16-bit PPG output mode must be programmed as listed below. Note:X; Don't care -; No change ### 11.6.4 Timer synchronous mode This mode enables the timers to start synchronously. If the mode is used with PPG output, the output can be applied to drive a motor. TMRB is consisted of pairs of 4-channel TMRB. If one channel starts, remaining 3 channels can be start synchronously. In the TMPM362F10FG, the following combinations allow to use. | _ | | | |---|----------------------------------------|-----------------------------------------------| | | Start trigger channel (Master channel) | Synchronous operation channel (Slave channel) | | | TMRB0 | TMRB1, TMRB2, TMRB3 | | | TMRB4 | TMRB5, TMRB6, TMRB7 | | | TMRB8 | TMRB9, TMRBA, TMRBB | | I | TMRBC | TMRBD, TMRBE, TMRBF | Use of the timer synchronous mode is specified in TBxCR<TBSYNC> bit. - <TBSYNC> = "0" : Timer operates individually. - <TBSYNC> = "1" : Timers operates synchronously. Set "0" to the <TBSYNC> bit in the master channel. If <TBSYNC>= "1" is set in the slave channel, the start timing is synchronized with master channel start timing. Setting of start timing for TBxRUN<TBPRUN, TBRUN> bit in the slave channel is not required. ### 11.7 Applications using the Capture Function The capture function can be used to develop many applications, including those described below: - 1. One-shot pulse output triggered by an external pulse - 2. Frequency measurement - 3. Pulse width measurement - 4. Time difference measurement ### 11.7.1 One-shot pulse output triggered by an external pulse One-shot pulse output triggered by an external pulse is carried out as follows: The 16-bit up-counter is made to count up by putting it in a free-running state using the prescaler output clock. An external pulse is input through the TBxIN0 pin. A trigger is generated at the rising of the external pulse by using the capture function and the value of the up-counter is taken into the capture registers (TBxCP0). The CPU must be programmed so that an interrupt INTCAPx0 is generated at the rising of an external trigger pulse. This interrupt is used to set the timer registers (TBxRG0) to the sum of the TBxCP0 value (c) and the delay time (d), (c + d), and set the timer registers (TBxRG1) to the sum of the TBxRG0 values and the pulse width (p) of one-shot pulse, (c + d + p). TBxRG1 change must be completed before the next match. In addition, the timer flip-flop control registers (TBxFFCR TBE1T1, TBE0T1>) must be set to "11". This enables triggering the timer flip-flop (TBxFF0) to reverse when UC matches TBxRG0 and TBxRG1. This trigger is disabled by the INTTBx interrupt after a one-shot pulse is output. Symbols (c), (d) and (p) used in the text correspond to symbols c, d and p in "Figure 11-6 One-shot Pulse Output (With Delay)". Figure 11-6 One-shot Pulse Output (With Delay) The followings show the settings in the case that 2 ms width one-shot pulse is output after 3ms by triggering TBxIN0 input at the rising edge. ( $\phi$ T1 is selected for counting.) If a delay is not required, TBxFF0 is reversed when data is taken into TBxCP0, and TBxRG1 is set to the sum of the TBxCP0 value (c) and the one-shot pulse width (p), (c + p), by generating the INTCAPx0 interrupt. TBxRG1 change must be completed before the next match. TBxFF0 is enabled to reverse when UC matches with TBxRG1, and is disabled by generating the INTTBx interrupt. Figure 11-7 One-shot Pulse Output Triggered by an External Pulse (Without Delay) Page 367 2023/07/21 ### 11.7.2 Frequency measurement The frequency of an external clock can be measured by using the capture function. To measure frequency, another 16-bit timer is used in combination with the 16-bit event counter mode. As an example, we explain with TMRB5 and TMRB0. TB0OUT of the 16-bit timer TMRB0 is used to specify the measurement time. TMRB5 count clock selects TB5IN0 input and performs count operation by using external clock input. If TB5MOD<TBCPM[1:0]> is set "11", TMRB5 count clock takes the counter value into the TB5CP0 at the rising edge of TB0OUT and takes the counter value into TB5CP1 at the falling edge of TB0OUT. This setting allows a count value of the 16-bit up-counter UC to be taken into the capture register (TB5CP0) upon rising of a timer flip-flop output (TB0OUT) of the 16-bit timer (TMRB0), and an UC counter value to be taken into the capture register (TB5CP1) upon falling of TB0OUT of the 16-bit timer (TMRB0). A frequency is then obtained from the difference between TB5CP0 and TB5CP1 based on the measurement, by generating the INTTB0 16-bit timer interrupt. For example, if the difference between TB5CP0 and TB5CP1 is 100 and the level width setting value of TB0OUT is 0.5 s, the frequency is 200 Hz ( $100 \div 0.5$ s = 200 Hz). Figure 11-8 Frequency Measurement #### 11.7.3 Pulse width measurement By using the capture function, the "High" level width of an external pulse can be measured. Specifically, by putting it in a free-running state using the prescaler output clock, an external pulse is input through the TBxIN0 pin and the up-counter (UC) is made to count up. A trigger is generated at each rising and falling edge of the external pulse by using the capture function and the value of the up-counter is taken into the capture registers (TBxCP0, TBxCP1). The CPU must be programmed so that INTCAPx1 is generated at the falling edge of an external pulse input through the TBxIN0 pin. The "High" level pulse width can be calculated by multiplying the difference between TBxCP0 and TBxCP1 by the clock cycle of an internal clock. For example, if the difference between TBxCP0 and TBxCP1 is 100 and the cycle of the prescaler output clock is 0.5 $\mu$ s, the pulse width is 100 $\times$ 0.5 $\mu$ s = 50 $\mu$ s. Caution must be exercised when measuring pulse widths exceeding the UC maximum count time which is dependant upon the source clock used. The measurement of such pulse widths must be made using software. The "Low" level width of an external pulse can also be measured. In such cases, the difference between C2 generated the first time and C1 generated the second time is initially obtained by performing the second stage of INTCAPx0 interrupt processing as shown in "Figure 11-9 Pulse Width Measurement" and this difference is multiplied by the cycle of the prescaler output clock to obtain the "Low" level width. Figure 11-9 Pulse Width Measurement #### 11.7.4 Time Difference Measurement The time difference of two events can be measured by the capture function. The up-counter (UC) is made to count up by putting it in a free-running state using the prescaler output clock. The value of UC is taken into the capture register (TBxCP0) at the rising edge of the TBxIN0 pin input pulse. The CPU must be programmed to generate INTCAPx0 interrupt at this time. The value of UC is taken into the capture register (TBxCP1) at the rising edge of the TBxIN1 pin input pulse. The CPU must be programmed to generate INTCAPx1 interrupt at this time. The time difference can be calculated by multiplying the difference between TBxCP1 and TBxCP0 by the clock cycle of an internal clock. Figure 11-10 Time Difference Measurement Page 369 2023/07/21 TOSHIBA TMPM362F10FG # 12. Serial Channel (SIO/UART) ## 12.1 Overview This device has two modes for the serial channel, one is the synchronous communication mode (I/O interface mode), and the other is the asynchronous communication mode (UART mode). Their features are described as follows. - · Transfer Clock - Generate the transfer clock by dividing the peripheral clock (φT0) frequency into 1/2, 1/8, 1/32, 1/128. - The prescaler output clock frequency can be divided by each of the numbers from 1 to 16. - The prescaler output frequency can be divided by each of the numbers from 1, N+m/16 (N=2-15, m=1-15), and 16. (only UART mode) - The system clock is usable. (only UART mode) - · Double buffer / FIFO The double buffer function and the FIFO buffers (total of transmit and receive) can be used up to 4bytes. - I/O Interface mode - Transfer Mode : the half duplex (transmit / receive) and the full duplex - Clock: Output (fixed rising edge) / Input (selectable rising / falling edge) - A time interval can be set within a range where continuous transmission is performed. - UART Mode - Data length: 7, 8, 9 bits - Add parity bit (to be against 9 bits data length) - Serial links to use wake-up function - Handshaking function with CTS pin In the following explanation, "x" represents channel number. # 12.2 Difference in the Specification of SIO Modules TMPM362F10FG has 12 channels. Each channel function is independent. The pins and interrupts for each channel are assigned as follows. Page 371 2023/07/21 Table 12-1 Differences for each channels of SIO Modules | | | Pin name | | Inte | rrupt | | | | |------------|-----|----------|------------|-------------------|--------------------|------------------------|---------|--| | | TXD | RXD | CTS / SCLK | Receive interrupt | Transmit interrupt | Timer for serial clock | DMA | | | channel 0 | PE4 | PE5 | PE6 | INTRX0 | INTTX0 | TB5OUT | support | | | channel 1 | PL4 | PL5 | PL6 | INTRX1 | INTTX1 | TB5OUT | support | | | channel 2 | PM1 | PM2 | PM0 | INTRX2 | INTTX2 | TB5OUT | support | | | channel 3 | PM5 | PM6 | PM4 | INTRX3 | INTTX3 | TB5OUT | support | | | channel 4 | PN0 | PN1 | PN2 | INTRX4 | INTTX4 | тв6оит | support | | | channel 5 | PN4 | PN5 | PN6 | INTRX5 | INTTX5 | TB6OUT | support | | | channel 6 | P00 | PO1 | PO2 | INTRX6 | INTTX6 | TB6OUT | support | | | channel 7 | PO4 | PO5 | P06 | INTRX7 | INTTX7 | TB6OUT | support | | | channel 8 | PC0 | PC1 | PC2 | INTRX8 | INTTX8 | TB9OUT | support | | | channel 9 | PC4 | PC5 | PC6 | INTRX9 | INTTX9 | TB9OUT | support | | | channel 10 | PD0 | PD1 | PD2 | INTRX10 | INTTX10 | | support | | | channel 11 | PD4 | PD5 | PD6 | INTRX11 | INTTX11 | TB9OUT | support | | Page 372 2023/07/21 # 12.3 Configuration Figure 12-1 shows SIO block diagram. Page 373 2023/07/21 #### 12.4 Registers Description # 12.4 Registers Description ## 12.4.1 Registers List in Each Channel The below table shows registers and addresses for each register. | Channel x | Base Address | |-----------|---------------| | Channel0 | 0x400E_1000 | | Channel1 | 0x400E _ 1100 | | Channel2 | 0x400E _ 1200 | | Channel3 | 0x400E _ 1300 | | Channel4 | 0x400E _ 1400 | | Channel5 | 0x400E _ 1500 | | Channel6 | 0x400E _ 1600 | | Channel7 | 0x400E _ 1700 | | Channel8 | 0x400E _ 1800 | | Channel9 | 0x400E _ 1900 | | Channel10 | 0x400E _ 1A00 | | Channel11 | 0x400E _ 1B00 | | | | $\sim$ $\sim$ $\sim$ | |----------------------------------------|----------|----------------------| | Register name (x=0 to 11) | | Address(Base+) | | Enable register | SCxEN | 0x0000 | | Buffer register | SCXBUF | 0x0004 | | Control register | SCxCR | 0x0008 | | Mode control register 0 | SCxMOD0 | 0x000C | | Baud rate generator control register | SCxBRCR | 0x0010 | | Baud rate generator control register 2 | SCxBRADD | 0x0014 | | Mode control register 1 | SCxMOD1 | 0x0018 | | Mode control register 2 | SCxMOD2 | 0x001C | | RX FIFO configuration register | SCxRFC | 0x0020 | | TX FIFO configuration register | SCxTFC | 0x0024 | | RX FIFO status register | SCxRST | 0x0028 | | TX FIFO status register | SCxTST | 0x002C | | FIFO configuration register | SCxFCNF | 0x0030 | | | | | Note 1: Do not modify any control register when data is being transmitted or received. Note 2: Do not clear SCxMOD0<RXE> when data is being received. Note 3: Do not clear SCxMOD1<TXE> when data is being transmitted. # 12.4.2 SCxEN (Enable Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|-----|--------|----------|-----|------| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | 1 | - | - | - | - < | (0 - 1) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 1 | - | - | 1 | - (( | <u> </u> | - | • | | After reset | 0 | 0 | 0 | 0 | ٥ | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | · | - | - | - / | | - | 2/- | SIOE | | After reset | 0 | 0 | 0 | 0 | (// 0) | _0 (( | | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | _ | R | Read as "0". | | 0 | SIOE | R/W | SIO operation | | | | | 0: disable | | | | | 1: Operation | | | | | Specifies the SIO operation. | | | | | To use the SIO, set <sioe> = "1".</sioe> | | | | | When the operation is disabled, no clock is supplied to the other registers in the SIO module. This can reduce the power consumption. | | | | | If the SIO operation is executed and then disabled, the settings will be maintained in each register except for SCxTFC <til>.</til> | Note 1: In case that SCxEN<SIOE>="0" (Stop SIO operation) or the operation mode is changed to IDLE mode with SCxMOD1<I2SC>="0" (Stop SIO operation in IDLE mode), SCxTFC is initialized again. Note 2: In the DMA transfer using transmit / receive interrupt of SIO, firstly generate software reset by setting SCxMOD2<SWRST[1:0]>, next, enable DMAC (DMA request waiting state), and then start transmit / receive of Page 375 2023/07/21 12.4 Registers Description TMPM362F10FG # 12.4.3 SCxBUF (Buffer Register) SCxBUF works as a transmit buffer or FIFO for write operation and as a receive buffer or FIFO for read operation | | | _ | _ | | | | | | |-------------|----|----|----|----|-------|----------|------|----| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | - | - | - | -(( | \} - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | )) o | 0 | | | 23 | 22 | 21 | 20 | 19 | (18) | 17 | 16 | | bit symbol | - | - | - | - | - ( ) | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | | <u> </u> | | - | | After reset | 0 | 0 | 0 | 0 | 46 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 2/1 | 0 | | bit symbol | | | | ТВ | (RB/ | _ (( | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | (0) | 0 | | | Bit | Bit Symbol | Туре | Function | |---|------|--------------|------|------------------------------------| | Ì | 31-8 | - | R | Read as "0". | | Ì | 7-0 | TB[7:0] / RB | R/W | [write] TB :Transmit buffer / FIFO | # 12.4.4 SCxCR (Control Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|------|----|------|--------|----------|-------|-----| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | <u> </u> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 7/3 | 2 | 1 | 0 | | bit symbol | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC | | After reset | 0 | 0 | 0 | 0 ( | (// 0) | 0 (( | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | _ | R | Read as "0". | | 7 | RB8 | R | Receive data bit 8 (For UART) 9th bit of the received data in the 9 bits UART mode. | | 6 | EVEN | R/W | Parity (For UART) 0: Odd 1: Even Selects even or odd parity. "0" :odd parity, "1" : even parity The parity bit can be used only in the 7-bit or 8-bit UART mode. | | 5 | PE | R/W | Adding parity (for UART) 0: Disabled 1: Enabled Controls enabling / disabling parity The parity bit can be used only in the 7-bit or 8-bit UART mode. | | 4 | OERR | R | Overrun error flag (Note) 0: Normal operation 1: Error | | 3 | PERR | R | Parity / Underrun error flag (Note) 0: Normal operation 1: Error | | 2 | FERR | R | Framing error flag (Note) 0: Normal operation 1: Error | | 1 | SCLKS | R/W | Selecting input clock edge (For I/O Interface) Set to "0" in the clock output mode. 0: Data in the transmit buffer is sent to TXDx pin one bit at a time on the falling edge of SCLKx. Data from RXDx pin isrecieved in the recieve buffer one bit at a time on the rising edge of SCLKx. In this case, the SCLKx starts from high level. 1: Data in the transmit buffer is sent to TXDx pin one bit at a time on the rising edge of SCLKx. Data from RXDx pin isrecieved in the recieve buffer one bit at a time on the falling edge of SCLKx. In this case, the SCLKx starts from low level. | | 0 | IOC | R/W | Selecting clock (For I/O Interface) 0: Baud rate generator 1: SCLK pin input | Page 377 2023/07/21 12.4 Registers Description TMPM362F10FG # 12.4.5 SCxMOD0 (Mode Control Register 0) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|------|-----|-----|--------|----------|-------|----| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | <u> </u> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | TB8 | CTSE | RXE | WU | S | М | 2 \ s | С | | After reset | 0 | 0 | 0 | 0 ( | (// 0) | _0 (( | | 0 | | Bit | Bit Symbol | Type | Function | |------|------------|------------|-------------------------------------------------------------------------------------------------------| | | , | Туре | | | 31-8 | - | R | Read as "0". | | 7 | TB8 | R/W | Transmit data bit 8 (For UART) | | | | | Writes the 9th bit of transmit data in the 9 bits UART mode. | | 6 | CTSE | R/W | Handshake function control (For UART) | | | | | 0: CTS disabled | | | | | 1: CTS enabled | | | | | Controls handshake function. | | | | | Setting "1" enables handshake function using CTS pin. | | 5 | RXE | R/W | Receive control (Note1) (Note2) | | | | | 0: Disabled | | | | | 1: Enabled | | 4 | wυ | R/W | Wake-up function (For UART) | | | | | 0; Disabled | | | // | | 1s Enabled | | | | 1 | This function is available only at 9-bit UART mode. In other mode, this function has no meaning. | | | | $\sqrt{/}$ | When it is set to be enabled, Interrupt occurs only when RB9 = "1" at 9-bit in the UART mode. | | 3-2 | SM[1:0] | R/W | Specifies transfer mode. | | | | | 00: I/O interface mode | | | | | 01: 7-bit length UART mode | | | 7/ | 7 | 10: 8-bit length UART mode | | | | | 11: 9-bit length UART mode | | 1-0 | SC[1:0] | R/W | Serial transfer clock (For UART) | | | | | 00: Timer TB 90UT Refer to Table 12-1. | | | | | 01: Baud rate generator | | | | | 10: Internal clock fsys | | | | 7 | 11: External clock (SCLK input) | | | | · · | (As for the I/O interface mode, the serial transfer clock can be set in the control register (SCxCR). | Note 1: Set <RXE> after specifying each of mode registers (SCxMOD0, SCxMOD1, SCxMOD2). Note 2: Do not clear SCxMOD0<RXE> when data is being received. # 12.4.6 SCxMOD1 (Mode Control Register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|------|----|----|-----|--------|----------|-----|----| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | <u> </u> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | I2SC | FD | PX | TXE | | SINT | 2// | - | | After reset | 0 | 0 | 0 | 0 ( | (// 0) | _0 (( | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | I2SC | R/W | IDLE 0: Stop 1: Operate Specifies the IDLE mode operation. | | 6-5 | FDPX[1:0] | R/W | Transfer mode setting 00: Transfer prohibited 01: Half duplex (Receive) 10: Half duplex (Transmit) 11: Full duplex Configures the transfer mode in the I/O interface mode. Also configures the FIFO if it is enabled. In the UART mode, it is used only to specify the FIFO configuration. | | 4 | TXE | R/W | Transmit control (Note1) (Note2) 0; Disabled 1: Enabled This bit enables transmission and is valid for all the transfer modes. | | 3-1 | SINT[2:0] | RW | Interval time of continuous transmission (For I/O interface) 000: None 001: 1SCLK 010: 2SCLK 011: 4SCLK 100: 8SCLK 101: 16SCLK 111: 64SCLK 111: 64SCLK This parameter is valid only for the I/O interface mode when SCLK pin output is selected. In other modes, this function has no meaning. Specifies the interval time of continuous transmission when double buffering or FIFO is enabled in the I/O interface mode. | | 0 | - | R/W | Write to "0". | Note 1: Specify all the modes first and then enable the <TXE> bit. Note 2: Do not stop the transmit operation (by setting <TXE> = "0") when data is being transmitted. Note 3: In the DMA transfer using transmit / receive interrupt of SIO, the full duplex transmission can not be used. Note 4: In case that SCxEN<SIOE>="0" (Stop SIO operation) or the operation mode is changed to IDLE mode with SCxMOD1<I2SC>="0" (Stop SIO operation in IDLE mode), SCxTFC is initialized again. Page 379 2023/07/21 12.4 Registers Description TMPM362F10FG # 12.4.7 SCxMOD2 (Mode Control Register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|-------|-------|-------|------------|------------|-----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | -(( | /> - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | <i>기</i> o | 0 | | | 15 | 14 | 13 | 12 | 11 | (10) | 9 | 8 | | bit symbol | - | - | - | - | - ( | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | ) /2 | 1 | 0 | | bit symbol | TBEMP | RBFLL | TXRUN | SBLEN | DRCHG | WBUF | SWRST | | | After reset | 1 | 0 | 0 | 0 | 46 | <b>)</b> 0 | 0 | . 0 | | Bit | Bit Symbol | Туре | Function | | | | | | | | | |------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31-8 | - | R | Read as "0". | | | | | | | | | | 7 | ТВЕМР | R | Transmit buffer empty flag. 0: Full 1: Empty If double buffering is disabled, this flag is insignificant. This flag shows that the transmit double buffers are empty. When data in the transmit double buffers is moved to the transmit shift register and the double buffers are empty, this bit is set to "1". Writing data again to the double buffers sets this bit to "0". | | | | | | | | | | 6 | RBFLL | R | Receive buffer full flag. 0: Empty 1: Full If double buffering is disabled, this flag is insignificant. This is a flag to show that the receive double buffers are full. When a receive operation is completed and received data is moved from the receive shift register to the receive double buffers, this bit changes to "1" while reading this bit changes it to "0". | | | | | | | | | | 5 | TXRUN | P | In transmission flag 0: Stop 1: Operate This is a status flag to show that data transmission is in progress. <txrun> and <tbemp> bits indicate the following status. CTXRUN&gt; <tbemp> Status 1 - Transmission in progress 1 Transmission completed 0 Wait state with data in transmit buffer.</tbemp></tbemp></txrun> | | | | | | | | | | 3 | SBLEN | R/W<br>R/W | STOP bit (For UART) 0: 1-bit 1: 2-bit This specifies the length of transmission stop bit in the UART mode. On the receive side, the decision is made using only a single bit regardless of the <sblen> setting. Setting transfer direction 0: LSB first 1: MSB first Specifies the direction of data transfer in the I/O interface mode. In the UART mode, set this bit to LSB first.</sblen> | | | | | | | | | | 2 | WBUF | R/W | Double buffer 0: Disabled 1: Enabled This parameter enables or disables the transmit / receive double buffers to transmit (in both SCLK output / input modes) and receive (in SCLK output mode) data in the I/O interface mode and to transmit data in the UART mode. When receiving data in the I/O interface mode (SCLK input) and UART mode, double buffering is enabled in both case that "0" or "1" is set to <wbuf> bit.</wbuf> | | | | | | | | | | Bit | Bit Symbol | Туре | | Function | | | | | | | | | |-----|------------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 1-0 | SWRST[1:0] | R/W | | rerwriting "01" in place of "10" generates a software reset. When this software reset is executed, the follow<br>bits are initialized and the transmit/receive circuit, the transmit circuit and the FIFO become initial states | | | | | | | | | | | | | Register | Bit | | | | | | | | | | l | | | SCxMOD0 | <rxe></rxe> | | | | | | | | | | | | | SCxMOD1 | <txe></txe> | | | | | | | | | | | | | SCxMOD2 | <tbemp>, <rbfll>, <txrun></txrun></rbfll></tbemp> | | | | | | | | | | | | | SCxCR | <oerr>, <perr>, <ferr></ferr></perr></oerr> | | | | | | | | | Note 1: While data transmission is in progress, any software reset operation must be executed twice in succession. Note 2: A software reset requires 2 clocks-duration at the time between the end of recognition and the start of execution of software reset instruction. Page 381 2023/07/21 # 12.4.8 SCxBRCR (Baud Rate Generator Control Register), SCxBRADD (Baud Rate Generator Control Register 2) The division ratio of the baud rate generator can be specified in the registers shown below. | SCxBRCR | | | | | | | <i>J</i> | | |-------------|----|--------|----|-----|---------|----------|----------|----| | | 31 | 30 | 29 | 28 | 27 | 26 🔷 | 25 | 24 | | bit symbol | - | - | - | - | - // | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | )18 | 17 | 16 | | bit symbol | - | - | - | - | | ) | | - | | After reset | 0 | 0 | 0 | 0 | 46 | <b>O</b> | d(0) | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 2 9 | 8 | | bit symbol | - | - | - | - ( | (// {}) | <u> </u> | | - | | After reset | 0 | 0 | 0 | 0 | | 0 | (0) | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | | 0 | | bit symbol | - | BRADDE | BR | RCK | | ВІ | RS | | | After reset | 0 | n | 0 | 0 | n | | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | - | R/W | Write to "0". | | 6 | BRADDE | R/W | N + (16 - K)/16 divider function (For UART) 0: Disabled 1: Enabled This division function can only be used in the UART mode. | | 5-4 | BRCK[1:0] | R/W | Select input clock to the baud rate generator: 00: \( \phi \tau \) 10: \( \phi \tau \) 11: \( \phi \tau \) 14: \( \phi \tau \) | | 3-0 | BRS[3:0] | R/W | Division ratio "N" 0000: 16 0001: 1 0010: 2 : 1111: 15 | #### SCxBRADD | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | |-------------|----|----|----|----|-----|------|------|----|--| | bit symbol | - | - | - | - | - | - | - | - | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | bit symbol | - | - | - | - | - | -(( | \ | - | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | )) o | 0 | | | | 15 | 14 | 13 | 12 | 11 | (10) | 9 | 8 | | | bit symbol | - | - | - | - | - ( | | - | - | | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | | 7 | 6 | 5 | 4 | 3 | ) >2 | 1 | 0 | | | bit symbol | - | - | - | - | BRK | | | | | | After reset | 0 | 0 | 0 | 0 | 40 | 0 | 0 | 0 | | | Bit | Bit Symbol | Туре | (// Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------| | 31-4 | _ | R | Read as "0". | | 3-0 | BRK[3:0] | R/W | Specify K for "N + (16 - K)/16" division (For UART) 0000: Prohibited 0001: K = 1 0010: K = 2 : 1111: K = 15 | Table 12-2 lists the setting of baud rate generator division ratio. Table 12-2 Setting division ratio | | <bradde> = "0"</bradde> | <bradde> = "1" (Note1)<br/>(Only UART mode)</bradde> | |----------------|-------------------------|------------------------------------------------------| | <brs></brs> | Specify " | N" (Note2) (Note3) | | <brk></brk> | No setting required | Specify "K" (Note4) | | Division ratio | Divide by N | $N + \frac{(16 - K)}{16}$ division | - Note 1: To use the "N + (16 K)/16" division function, be sure to set <BRADDE> to "1" after setting the K value to <BRK>. The "N + (16 K)/16" division function can only be used in the UART mode. - Note 2: As a division ratio, 1 ("0001") or 16 ("0000") can not be applied to N when using the "N + (16 K)/ - Note 3: The division ratio "1" of the baud rate generator can be specified only when the double buffering is used in the I/O interface mode. - Note 4: Specifying "K = 0" is prohibited. Page 383 2023/07/21 12.4 Registers Description TMPM362F10FG # 12.4.9 SCxFCNF (FIFO Configuration Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|------|--------|----------|---------|------| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | <u> </u> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | - | - | - | RFST | JFIE | RFIE | RXTXCNT | CNFG | | After reset | 0 | 0 | 0 | 0 ( | (// 0) | _ 0 (( | | 0 | | D:# | Dit Comebal | T | Function | | | | | | | | | |------|----------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | Bit | Bit Symbol | Туре | Function | | | | | | | | | | 31-8 | - | R | Read as "0". | | | | | | | | | | 7-5 | - | R/W | e sure to write "000". | | | | | | | | | | 4 | RFST | R/W | ytes used in RX FIFO : Maximum : Same as FILL level of RX FIFO When RX FIFO is enabled, the number of RX FIFO bytes to be used is selected (Note1) : The maximum number of bytes of the FIFO configured (see also <cnfg>). : Same as the fill level for receive interrupt generation specified by SCxRFC <ril[1:0]></ril[1:0]></cnfg> | | | | | | | | | | 3 | TFIE | R/W | TX interrupt for TX FIFO 0:Disabled 1:Enabled When TX FIFO is enabled, transmit interrupts are enabled or disabled by this parameter. | | | | | | | | | | 2 | RFIE | R/W | RX interrupt for RX FIFO 0:Disabled 1:Enabled When RX FIFO is enabled, receive interrupts are enabled or disabled by this parameter. | | | | | | | | | | 1 | RXTXCNT | R/W | Automatic disable of RXE / TXE | | | | | | | | | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | 0: None 1: Auto disabled Controls automatic disabling of transmission and reception. Setting "1" enables to operate as follows When receive shift register, the receive buffer and the RX FIFO are filled, | | | | | | | | | | | | | Half duplex RX SCxMOD0 <rxe> is automatically set to "0" to inhibit further reception.</rxe> | | | | | | | | | | | | | Half duplex TX When the TX FIFO, the transmit buffer and the transmit shift register is empty, SCxMOD1 <txe> is automatically set to "0" to inhibit further transmission.</txe> | | | | | | | | | | | | 7 | Full duplex When either of the above two conditions is satisfied, TXE/RXE are automatically set to "0" to inhibit further transmission and reception. | | | | | | | | | | 0 | CNFG | R/W | Enables FIFO | | | | | | | | | | | | | 0: Disabled | | | | | | | | | | | | | 1: Enabled | | | | | | | | | | | | | Enabled bit for FIFO. (note2) | | | | | | | | | | | | | If <cnfg> is set to "1", the SCxMOD1 <fdpx[1:0]> setting automatically configures FIFO as follows:</fdpx[1:0]></cnfg> | | | | | | | | | | | | | Half duplex RX RX FIFO 4 bytes | | | | | | | | | | | | | Half duplex TX TX FIFO 4 bytes | | | | | | | | | | | | | Full duplex RX FIFO 2 bytes + TX FIFO 2 bytes | | | | | | | | | Note 1: Regarding TX FIFO, the maximum number of bytes being configured is always available. The available number of bytes is the bytes already written to the TX FIFO. Note 2: The FIFO can not use in 9bit UART mode. Note 3: In the DMA transfer using transmit / receive interrupt of SIO, the FIFO function can not be used. Page 385 2023/07/21 12.4 Registers Description TMPM362F10FG # 12.4.10 SCxRFC (RX FIFO Configuration Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|------|------|----|-----|--------|----------|----|----| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | <u> </u> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | RFCS | RFIS | - | - / | | - | R | IL | | After reset | 0 | 0 | 0 | 0 ( | (// 0) | _0 (( | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | RFCS | W | RX FIFO clear (Note1) 1: Clear When SCxRFC <rfcs> is set to "1", the receive FIFO is cleared and SCxRST<rlvl> is "000". And also the read pointer is initialized.</rlvl></rfcs> | | 6 | RFIS | R/W | Select interrupt generation condition 0: when the data reaches to the specified fill level. 1: when the data reaches to the specified fill level or the data exceeds the specified fill level at the time data is read. | | 5-2 | - | R | Read as "0". | | 1-0 | RIL[1:0] | RW | FIFO fill level to generate RX interrupts Half duplex Full duplex 00 4 bytes 2 bytes 01 1 byte 1 byte 10 2 bytes 2 bytes 11 3 bytes 1 byte | Note 1: To use TX/RX FIFO buffer, TX / RX FIFO must be cleared after setting the SIO transfer mode (half duplex / full duplex) and enabling FIFO (SCxFCNF<CNFG> = "1"). Note 2: DMA transfer is not started by an interrupt generated in the fill level of FIFO. # 12.4.11 SCxTFC (TX FIFO Configuration Register) (Note2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|------|------|----|-----|--------|----------|-------|----| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - ( | <u> </u> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | TFCS | TFIS | - | - / | | - | Z / T | IL | | After reset | 0 | 0 | 0 | 0 ( | (// 0) | _0 (( | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | TFCS | W | TX FIFO clear (Note1) 1: Clear When SCxTST <tfcs> is set to "1", the transmit FIFO is cleared and SCxTST<tlvl> is "000". And also the write pointer is initialized.</tlvl></tfcs> | | 6 | TFIS | R/W | Selects interrupt generation condition. 0: An interrupt is generated when the data reaches to the specified fill level. 1: An interrupt is generated when the data reaches to the specified fill level or the data can not reach the specified fill level at the time data is read. | | 5-2 | - | R | Read as "0". | | 1-0 | TIL[1:0] | R/W | Fill level which transmit interrupt is occurred. Half duplex Full duplex O0 Empty Empty O1 1 byte 1 byte 10 2 bytes Empty 11 3 bytes 1 byte | Note 1: To use TX/RX FIFO buffer, TX/RX FIFO must be cleared after setting the SIO transfer mode (half duplex/full duplex) and enabling FIFO (SCxFCNF<CNFG> = "1"). Note 2: After you perform the following operations, configure the SCxTFC register again. SCxEN<SIOE> = "0" (SIO operation stop) Conditions are as follows:SCxMOD1<I2SC> = "0" (operation is prohibited in IDLE mode) and releasing the low power consumption mode which is started by the WFI (Wait For Interrupt) instruction. Note 3: DMA transfer is not started by an interrupt generated in the fill level of FIFO. Page 387 2023/07/21 12.4 Registers Description TMPM362F10FG # 12.4.12 SCxRST (RX FIFO Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|----|----|-----|--------|----------|------|----| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 1 | - | - | - | - (( | <u> </u> | - | • | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 6 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | ROR | - | - | - / | | | RLVL | | | After reset | 0 | 0 | 0 | 0 ( | (// 0) | _0 (( | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------------------------------------------------------------------------------| | 31-8 | _ | R | Read as "0". | | 7 | ROR | R | RX FIFO Overrun (Note) 0: Not generated 1: Generated | | 6-3 | _ | R | Read as "0". | | 2-0 | RLVL[2:0] | R | Status of RX FIFO fill level 000: Empty 001: 1 byte 010: 2 bytes 011: 3 bytes 100: 4 bytes | Note: The <ROR> bit is cleared to "0" when receive data is read from the SCxBUF register. # 12.4.13 SCxTST (TX FIFO Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|----|----|-----|--------|----------|------|----| | bit symbol | - | - | - | - | - | / _ | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (0.7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 1 | - | - | - | - (( | <u> </u> | - | • | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 6 | 0 | | | 7 | 6 | 5 | 4 | 43 | 2 | 1 | 0 | | bit symbol | TUR | - | - | - / | | | TLVL | | | After reset | 1 | 0 | 0 | 0 ( | (// 0) | _0 (( | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------------| | 31-8 | - | R | Read as "0". | | 7 | TUR | R | TX FIFO Under run (Note) | | | | | 0: Not generated | | | | | 1: Generated | | 6-3 | - | R | Read as "0". | | 2-0 | TLVL[2:0] | R | Status of TX FIFO level | | | | | 000: Empty | | | | | 001: 1 byte ( ) | | | | | 010: 2 byte | | | | | 011: 3 byte | | | | | 100: 4 byte | #### 12.5 Operation in Each Mode # 12.5 Operation in Each Mode Table 12-3 shows the modes and data format. Table 12-3 Mode and Data format | Mode | Mode type | Data length | Transfer direction | Specifies whether to use parity bits STOP bit length (Transmit) | |--------|----------------------------------------------------|-------------|-----------------------|------------------------------------------------------------------| | Mode 0 | Synchronous communication mode (IO interface mode) | 8 bit | LSB first / MSB first | | | Mode 1 | Asynchronous communication | 7 bit | | • | | Mode 2 | mode | <u> </u> | | o 1 bit or 2 bit | | Mode 3 | (UART mode) | 9bit | | (x) | Mode 0 is synchronous communication and can be used to extend I/O. This mode transmits and receives data in synchronization with SCLK. SCLK can be used for both input and output. The direction of data transfer can be selected from LSB first and MSB first. This mode is not allowed either to add a parity or STOP bits. The mode 1, mode 2 and mode 3 are asynchronous modes and the transfer direction is fixed to the LSB first. Parity bits can be added in the mode 1 and mode 2. The mode 3 has a wake-up function in which the master controller can start up slave controllers via the serial link (multi-controller system). STOP bit in transmission can be selected from 1 bit and 2 bits. The STOP bit length in reception is fixed to a one bit. TMPM362F10FG ## 12.6 Data Format ## 12.6.1 Data Format List Page 391 2023/07/21 12.6 Data Format TMPM362F10FG ## 12.6.2 Parity Control The parity bit can be added only in the 7- or 8-bit UART mode. Setting "1" to SCxCR<PE> enables the parity. The SCxCR<EVEN> selects either even or odd parity. #### 12.6.2.1 Transmission Upon data transmission, the parity control circuit automatically generates the parity with the data in the transmit buffer. After data transmission is complete, the parity bit will be stored in SCxBUF<TB7> in the 7-bit UART mode SCxMOD<TB8> in the 8-bit UART mode. The <PE> and <EVEN> settings must be completed before data is written to the transmit buffer. ## 12.6.2.2 Receiving Data If the received data is moved from the receive shift register to the receive buffer, a parity is generated. In the 7-bit UART mode, the generated parity is compared with the parity stored in SCxBUF<RB7>, while in the 8-bit UART mode, it is compared with the one in SCxCR<RB8>. If there is any difference, a parity error occurs and the <PERR> of the SCxCR register is set to "1". In use of the FIFO, <RERR> indicates that a parity error was generated in one of the received data. ## 12.6.3 STOP Bit Length The length of the STOP bit in the UART transmission mode can be selected from one bit or two bits by setting the SCxMOD2<SBLEN>. The length of the STOP bit data is determined as one-bit when it is received regardless of the setting of this bit. ## 12.7 Clock Control #### 12.7.1 Prescaler There is a 7-bit prescaler to divide a prescaler input clock $\phi T0$ by 2, 8, 32 and 128. Use the CGSYSCR register in the clock / mode control block to select the input clock φT0 of the prescaler. The prescaler becomes active only when the baud rate generator is selected as a transfer clock by SCxMOD0 < SC[1:0] > = "01". Table 12-4 (operation frequency 64MHz), Table 12-5 (operation frequency 48MHz) and Table 12-6 (operation frequency 32MHz) show the resolution of the input clock to the baud rate generator. Table 12-4 Clock resolution to the Baud Rate Generator fc = 64 MHz, fs = 32.768kHz | φT0 selection | Peripheral | Clock gear | Prescaler clock se- | | Prescaler output | clock resolution | | |------------------------------|-------------------------------------------|---------------------------------------------|-----------------------------------------------|-----------------------------|------------------------------|-------------------------------|-------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | clock selection CGSYSCR <fpsel0></fpsel0> | value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | lection<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | Φ11 | φΤ4 | φΤ16 | φΤ64 | | | | | 000 (fperiph/1) | fc/2¹ (0.0312 µs) | fc/2³ (0.125 μs) | fc/2⁵ (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | | | | | 001 (fperiph/2) | fc/2² (0.0625 µs) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | 000 (5.) | 010 (fperiph/4) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | | | | 000 (fc) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.25 μs) | fc/26 (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0 µs) | | | | | 000 (fperiph/1) | fc/2² (0.0625 µs) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | | 001 (fperiph/2) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | | | | 400 (5-10) | 010 (fperiph/4) | fc/2 <sup>4</sup> (0.25 µs) | c/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | 100 (fc/2) | 011 (fperiph/8) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 μs) | fc/2 <sup>9</sup> (8.0 μs) | fc/2 <sup>11</sup> (32.0 µs) | | | / | | 100 (fperiph/16) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 μs) | fc/2 <sup>12</sup> (64.0 µs) | | | 0 (50000) | | 101 (fperiph/32) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | fc/2 <sup>13</sup> (128.0 µs) | | 0 | 0 (fgear) | | 000 (fperiph/1) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | | | | | 001 (fperiph/2) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | <\? | 404 (5: (4) | 010 (fperiph/4) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0µs) | | | | | 100 (fperiph/16) | fc/2 <sup>7</sup> (2.0 μs) | fc/29 (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | fc/2 <sup>13</sup> (128.0 µs) | | | | | 101 (fperiph/32) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0µs) | fc/2 <sup>14</sup> (256.0 µs) | | | | $\langle \rangle$ | 000 (fperiph/1) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (12.8 µs) | fc/2 <sup>11</sup> (32.0 µs) | | | | | 010 (fperiph/4) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 μs) | fc/2 <sup>12</sup> (64.0µs) | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>7</sup> (2.0 μs) | fc/29 (8.0 µs) | fc/2 <sup>11</sup> (32.0 μs) | fc/2 <sup>13</sup> (128.0 µs) | | | | | 100 (fperiph/16) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0µs) | fc/2 <sup>14</sup> (256.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>9</sup> (8.0 μs) | fc/2 <sup>11</sup> (32.0 µs) | fc/2 <sup>13</sup> (128.0 μs) | fc/2 <sup>15</sup> (512.0 μs) | Page 393 2023/07/21 Table 12-4 Clock resolution to the Baud Rate Generator fc = 64 MHz, fs = 32.768kHz | φT0 selection | Peripheral | Clock gear | Prescaler clock se- | | Prescaler output | clock resolution | | |------------------------------|-------------------------------------------|---------------------------------------------|-----------------------------------------|-------------------------------|------------------------------|------------------------------|------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | clock selection CGSYSCR <fpsel0></fpsel0> | value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | lection CGSYSCR <prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | φΤ64 | | | | | 000 (fperiph/1) | fc/21 (00312 µs) | fc/2 <sup>3</sup> (0.125 µs) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>2</sup> (0.0625 µs) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | | | | 000 (5.) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (8.0 µs) | | | | 000 (fc) | 011 (fperiph/8) | fc/24 (0.25 µs) | fc/26 (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 μs) | fc/2 <sup>12</sup> (64.0 µs) | | | | | 000 (fperiph/1) | - | fc/2 <sup>3</sup> (0.125 µs) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 µs) | | | | | 001 (fperiph/2) | fc/2² (0.0625 µs) | fc/2 <sup>4</sup> (0.25 µs) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | | | | 100 (fc/2) | 010 (fperiph/4) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | | | 1 (fc) | | 011 (fperiph/8) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 µs) | fc/2 <sup>8</sup> (4.0 µs) | fc/2 <sup>10</sup> (16.0 μs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (8.0 µs) | fc/2 <sup>11</sup> (32.0 µs) | | 0 | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0 µs) | | 0 | | 101 (fc/4) | 000 (fperiph/1) | | fc/2 <sup>3</sup> (0.2 µs) | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (3.2 µs) | | | | | 001 (fperiph/2) | | fc/2 <sup>4</sup> (0.25 μs) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | | | | | 010 (fperiph/4) | fc/2³ (0.125 µs) | fc/2 <sup>5</sup> (0.5 μs) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (8.0 µs) | | | | | 011 (fperiph/8) | fc/24 (0.25 µs) | fc/26 (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | fc/2 <sup>11</sup> (32.0 μs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0 µs) | | | | | 000 (fperiph/1) | - | \/ | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (2.0 µs) | | | | | 001 (fperiph/2) | - < | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | | | | 440 (5-(0) | 010 (fperiph/4) | | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/29 (8.0 µs) | | | | 110 (fc/8) | 011 (fperiph/8) | fc/24 (0.25 µs) | fc/2 <sup>6</sup> (1.0 μs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 μs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.5 µs) | fc/2 <sup>7</sup> (2.0 µs) | fc/2 <sup>9</sup> (8.0 µs) | fc/2 <sup>11</sup> (32 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.0 µs) | fc/28 (4.0 µs) | fc/2 <sup>10</sup> (16.0 µs) | fc/2 <sup>12</sup> (64.0 µs) | | 1 | * << | | 7 * | fs/2 (61µs) | fs/2³ (244 µs) | fs/2 <sup>5</sup> (977 μs) | fs/2 <sup>7</sup> (3.91 ms) | Note 1. The prescaler output clock φTn must be selected so that the relationship "φTn ≤ fsys/2" is satisfied (so that φTn is slower than fsys). Note 2: Do not change the clock gear while SIO is operating. Note 3: The "-" indicates that the setting is prohibited and the "\*" indicates don't care in the above table. Table 12-5 Clock resolution to the Baud Rate Generator fc = 48 MHz, fs = 32.768kHz | φT0 selection | Peripheral | Clock gear | Prescaler clock se- | | Prescaler output | clock resolution | | |------------------------------|-------------------------------------------|---------------------------------------------|-----------------------------------------------|-------------------------------|------------------------------|------------------------------|------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | clock selection CGSYSCR <fpsel0></fpsel0> | value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | lection<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | φΤ64 | | | | | 000 (fperiph/1) | fc/21 (0.0417 µs) | fc/2 <sup>3</sup> (0.167 µs) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | 001 (fperiph/2) | fc/2² (0.0833 µs) | fc/2 <sup>4</sup> (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | 000 (5-) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.167 µs) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/29 (10.7 µs) | | | | 000 (fc) | 011 (fperiph/8) | fc/24 (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 μs) | fc/2 <sup>12</sup> (85.3 µs) | | | | | 000 (fperiph/1) | fc/2 <sup>2</sup> (0.0833 µs) | fc/2 <sup>4</sup> (0.333 μs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>3</sup> (0.167 µs) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | | | ." | 100 (fc/2) | 010 (fperiph/4) | fc/2 <sup>4</sup> (0.333 μs) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | | | | | 011 (fperiph/8) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | fc/29 (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>6</sup> (1.33 µs) | fc/2 <sup>8</sup> (5.33 µs) | fc/2 <sup>10</sup> (21.3 μs) | fc/2 <sup>12</sup> (85.3 µs) | | 0 | | | 101 (fperiph/32) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | fc/2 <sup>13</sup> (171 µs) | | 0 | 0 (fgear) | | 000 (fperiph/1) | fc/2³ (0.167 µs) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | fc/29 (10.7 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>4</sup> (0.333 μs) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | | | | | 010 (fperiph/4) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | fc/2 <sup>12</sup> (85.3 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 μs) | fc/2 <sup>11</sup> (42.7 µs) | fc/2 <sup>13</sup> (171 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>8</sup> (5.33 μs) | fc/2 <sup>10</sup> (21.3 µs) | fc/2 <sup>12</sup> (85.3µs) | fc/2 <sup>14</sup> (341 µs) | | | | | 000 (fperiph/1) | fc/24 (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | | | 440 (5-10) | 010 (fperiph/4) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | fc/2 <sup>12</sup> (85.3 µs) | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 μs) | fc/2 <sup>11</sup> (42.7 µs) | fc/2 <sup>13</sup> (171 µs) | | | | | 100 (fperiph/16) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | fc/2 <sup>12</sup> (85.3µs) | fc/2 <sup>14</sup> (341 µs) | | | / | | 101 (fperiph/32) | fc/2 <sup>9</sup> (10.7 μs) | fc/2 <sup>11</sup> (42.7 µs) | fc/2 <sup>13</sup> (171 µs) | fc/2 <sup>15</sup> (683 µs) | Table 12-5 Clock resolution to the Baud Rate Generator fc = 48 MHz, fs = 32.768kHz | φT0 selection | Peripheral | Clock gear | Prescaler clock se- | | Prescaler output | clock resolution | | |----------------------------------------------|-------------------------------------------|---------------------------------------------|-----------------------------------------------|-------------------------------|------------------------------|------------------------------|------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | clock selection CGSYSCR <fpsel0></fpsel0> | value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | lection<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φТ4 | φT16 | φΤ64 | | | | | 000 (fperiph/1) | fc/21 (0.0417 µs) | fc/2 <sup>3</sup> (0.167 µs) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>2</sup> (0.0833 µs) | fc/2 <sup>4</sup> (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | 000 (5.) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.167 µs) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 μs) | fc/2 <sup>9</sup> (10.7 μs) | | | | 000 (fc) | 011 (fperiph/8) | fc/24 (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/2 <sup>8</sup> (5.33 µs) | fc/2 <sup>10</sup> (21.3 μs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 μs) | fc/2 <sup>12</sup> (85.3 µs) | | | | | 000 (fperiph/1) | - | fc/23 (0.167 µs) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | 001 (fperiph/2) | fc/2² (0.0833 µs) | fc/2⁴ (0.333 μs) | fc/2 <sup>6</sup> (1.33 µs) | fc/2 <sup>8</sup> (5.33 µs) | | | | 400 (5: (0) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.167 µs) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 μs) | | | 1 (fc) | 100 (fc/2) | 011 (fperiph/8) | fc/24 (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 μs) | fc/29 (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | | | | 101 (fperiph/32) | fc/26 (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | fc/2 <sup>12</sup> (85.3 µs) | | 0 | | 101 (fc/4) | 000 (fperiph/1) | | fc/2 <sup>3</sup> (0.167 µs) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | 001 (fperiph/2) | - C/- A | fc/2 <sup>4</sup> (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | | 010 (fperiph/4) | fc/2³ (0.167 μs) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 μs) | | | | | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.333 μs) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 μs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | fc/29 (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 µs) | fc/2 <sup>12</sup> (85.3 µs) | | | | | 000 (fperiph/1) | - | \-/- | fc/2 <sup>5</sup> (0.667 μs) | fc/2 <sup>7</sup> (2.67 µs) | | | | | 001 (fperiph/2) | - ^ | fc/2 <sup>4</sup> (0.333 µs) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | | | | 440 (5: (0) | 010 (fperiph/4) | | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.333 μs) | fc/2 <sup>6</sup> (1.33 μs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 μs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (0.667 µs) | fc/2 <sup>7</sup> (2.67 µs) | fc/2 <sup>9</sup> (10.7 µs) | fc/2 <sup>11</sup> (42.7 µs) | | <u>. </u> | / | | 101 (fperiph/32) | fc/2 <sup>6</sup> (1.33 µs) | fc/28 (5.33 µs) | fc/2 <sup>10</sup> (21.3 μs) | fc/2 <sup>12</sup> (85.3 µs) | | 1 | * << | | 7 * | fs/2 (61µs) | fs/2 <sup>3</sup> (244 µs) | fs/2 <sup>5</sup> (977 μs) | fs/2 <sup>7</sup> (3.91 ms) | Note 1: The prescaler output clock $\phi Tn$ must be selected so that the relationship " $\phi Tn \leq fsys/2$ " is satisfied (so that $\phi Tn$ is slower than fsys). Note 2: Do not change the clock gear while SIO is operating. Note 3: The "-" indicates that the setting is prohibited and the "\*" indicates don't care in the above table. Table 12-6 Clock resolution to the Baud Rate Generator fc = 32 MHz, fs = 32.768kHz | φT0 selection | Peripheral | Clock gear | Prescaler clock se- | | Prescaler output | clock resolution | | |------------------------------|-------------------------------------------|---------------------------------------------|-----------------------------------------------|-----------------------------|------------------------------|--------------------------------|-------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | clock selection CGSYSCR <fpsel0></fpsel0> | value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | lection<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φT4 < | φΤ16 | φΤ64 | | | | | 000 (fperiph/1) | fc/21 (0.0625 µs) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 001 (fperiph/2) | fc/2² (0.125 µs) | fc/24 (0.5 µs) | fc/26 (2.0 µs) | fc/28 (8.0 µs) | | | | 000 (5-) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/29 (16.0 µs) | | | | 000 (fc) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 µs) | fc/26 (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | y fc/2 <sup>10</sup> (32.0 μs) | fc/2 <sup>12</sup> (128.0 μs) | | | | | 000 (fperiph/1) | fc/2² (0.125 µs) | fc/24 (0.5 µs) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | 100 (fc/2)<br>0 (fgear) | 010 (fperiph/4) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 011 (fperiph/8) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 μs) | fc/29 (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | fc/2¹⁰ (32.0 μs) | fc/2 <sup>12</sup> (128.0 μs) | | 0 | 0 (facer) | | 101 (fperiph/32) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | fc/2 <sup>13</sup> (256.0 µs) | | 0 | 0 (igear) | | 000 (fperiph/1) | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/29 (16.0 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | fc/2 <sup>8</sup> (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 010 (fperiph/4) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 μs) | | | | | 100 (fperiph/16) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | fc/2 <sup>13</sup> (256.0 µs) | | | | | 101 (fperiph/32) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 µs) | fc/2 <sup>14</sup> (512.0 µs) | | | | | 000 (fperiph/1) | fc/2 <sup>4</sup> (0.5 μs) | fc/26 (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | 110 (fc/8) | 010 (fperiph/4) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 µs) | | | | | 011 (fperiph/8) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 μs) | fc/2 <sup>11</sup> (64.0 µs) | fc/2 <sup>13</sup> (256.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>8</sup> (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 µs) | fc/2 <sup>14</sup> (512.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | fc/2 <sup>13</sup> (256.0 µs) | fc/2 <sup>15</sup> (1024 µs) | Table 12-6 Clock resolution to the Baud Rate Generator fc = 32 MHz, fs = 32.768kHz | φT0 selection | Peripheral | Clock gear | Prescaler clock se- | | Prescaler output | clock resolution | | |------------------------------|-------------------------------------------|---------------------------------------------|-----------------------------------------------|------------------------------|-----------------------------|------------------------------|-------------------------------| | CGSYSCR<br><fpsel1></fpsel1> | clock selection CGSYSCR <fpsel0></fpsel0> | value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | lection<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1 | φΤ4 | φΤ16 | φΤ64 | | | | | 000 (fperiph/1) | fc/21 (0.0625 µs) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 001 (fperiph/2) | fc/2 <sup>2</sup> (0.125 µs) | fc/24 (0.5 µs) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | | | | 000 (5.) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | 000 (fc) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 μs) | fc/26 (2.0 µs) | fc/2 <sup>8</sup> (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 µs) | fc/2 <sup>8</sup> (8.0 µs) | fc/2 <sup>10</sup> (32.0 μs) | fc/2 <sup>12</sup> (128.0 µs) | | | | | 000 (fperiph/1) | - | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 001 (fperiph/2) | fc/2² (0.125 µs) | fc/2 <sup>4</sup> (0.5 µs) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | | | | 400 (5-10) | 010 (fperiph/4) | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | 100 (fc/2) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 µs) | fc/2 <sup>8</sup> (8.0 μs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2º (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | 0 | 4 (5-) | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 µs) | | 0 | 1 (fc) | 1 (fc) | 000 (fperiph/1) | | fc/2 <sup>3</sup> (0.25 µs) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 001 (fperiph/2) | | fc/24 (0.5 µs) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | | | | 404 (5:44) | 010 (fperiph/4) | fc/2³ (0.25 µs) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | 101 (fc/4) | 011 (fperiph/8) | fc/2⁴ (0.5 μs) | fc/26 (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | fc/2 <sup>12</sup> (128.0 µs) | | | | | 000 (fperiph/1) | - | \/ | fc/2 <sup>5</sup> (1.0 μs) | fc/2 <sup>7</sup> (4.0 µs) | | | | | 001 (fperiph/2) | - ^ | fc/2 <sup>4</sup> (0.5 μs) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | | | | | 010 (fperiph/4) | | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | | | | 110 (fc/8) | 011 (fperiph/8) | fc/2 <sup>4</sup> (0.5 µs) | fc/2 <sup>6</sup> (2.0 μs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 µs) | | | | | 100 (fperiph/16) | fc/2 <sup>5</sup> (1.0 µs) | fc/2 <sup>7</sup> (4.0 µs) | fc/2 <sup>9</sup> (16.0 µs) | fc/2 <sup>11</sup> (64.0 µs) | | | | | 101 (fperiph/32) | fc/2 <sup>6</sup> (2.0 µs) | fc/28 (8.0 µs) | fc/2 <sup>10</sup> (32.0 μs) | fc/2 <sup>12</sup> (128.0 µs) | | 1 | * << | | 7 * | fs/2 (61µs) | fs/2³ (244 µs) | fs/2 <sup>5</sup> (977 μs) | fs/2 <sup>7</sup> (3.91 ms) | Note 1: The prescaler output clock $\phi Tn$ must be selected so that the relationship " $\phi Tn \leq fsys/2$ " is satisfied (so that $\phi Tn$ is slower than fsys). Note 2: Do not change the clock gear while SIO is operating. Note 3: The "-" indicates that the setting is prohibited and the "\*" indicates don't care in the above table. #### 12.7.2 Serial Clock Generation Circuit The serial clock circuit is a block to generate transmit and receive clocks (SIOCLK) and consists of the circuits in which clocks can be selected by the settings of the baud rates generator and modes. #### 12.7.2.1 Baud Rate Generator The baud rate generator generates transmit and receive clocks to determine the serial channel transfer rate. ## (1) Buad Rate Generator input clock The input clock of the baud rate generator is selected from the prescaler outputs divided by 2, 8, 32 and 128. This input clock is selected by setting the SCxBRCR<BRCK> #### (2) Baud Rate Generator output clock The frequency division ratio of the output clock in the baud rate generator is set by SCxBRCR and SCxBRADD. The following frequency divide ratios can be used; 1/N frequency division in the I/O interface mode, either 1/N or N + (16-K)/16 in the UART mode. The table below shows the frequency division ratio which can be selected. | Mode | Divide Function Setting SCxBRCR <bradde></bradde> | Divide by N<br>SCxBRCR <brs></brs> | Divide by K<br>SCxBRADD <brk></brk> | |---------------|---------------------------------------------------|------------------------------------|-------------------------------------| | I/O interface | Divide by N | 1 to 16 (Note) | - | | LIADT | Divide by N | 1 to 16 | - | | UART | N + (16-K)/16 division | 2 to 15 | 1 to 15 | Note: 1/N (N=1)frequency division ratio can be used only when a double buffer is enabled. #### 12.7.2.2 Clock Selection Circuit A clock can be selected by setting the modes and the register. Modes can be specified by setting the SCxMOD0<SM>. The input clock in I/O interface mode is selected by setting SCxCR. The clock in UART mode is selected by setting SCxMOD0<SC>. #### (1) Transfer Clock in I/O interface mode Table 12-7 shows clock selection in I/O interface mode. Page 399 2023/07/21 | Tahla | 12-7 | Clock | selection | in I/O | interface | Mode | |-------|------|-------|-----------|----------|-----------|------| | I au | 12-1 | CHUCK | Selection | 111 1/() | unenace | MUCH | | Mode<br>SCxMOD0 <sm></sm> | Input / Output<br>selection<br>SCxCR <ioc></ioc> | Clock edge selection<br>SCxCR <sclks></sclks> | Clock of use | |---------------------------|--------------------------------------------------|-----------------------------------------------|------------------------------------------------| | I/O interface mode | SCLK output | Set to "0" (Fixed to the rising edge) | Divided by 2 of the baud rate generator output | | | CCLK innut | Rising edge | SCLK input rising edge | | | SCLK input | Falling edge | SCLK input falling edge | To get the highest baud rate, the baud rate generator must be set as below. Note: When deciding clock settings, make sure that AC electrical character is satisfied. - · Clock / mode control block settings - fc = 40MHz - fgear = 40MHz (CGSYSCR<GEAR[2:0]> = "000" ; fc selected) - φT0=40Mhz (CGSYSCR<PRCK[2:0:]>="000" : 1 division ratio) - SIO settings (if double buffer is used) - Clock (SCxBRCR<BRCK[1:0]> = "00" : φT1 selected) = 20MHz - Divided clock frequency (SCxBRCR<BRS[3:0]> = "0001":1 division ratio) = 20MHz 1 division ratio can be selected if double buffer is used. In this case, baud rate is 10Mbps because 20MHz is divided by 2. - SIO settings (if double buffer is not used) - Clock (SCxBRCR<BRCK[1:0]> = "00":φT1 selected) = 20MHz - Divided clock frequency (SCxBRCR<BRS[3:0]> = "0010" : 2 division ratio) = 10MHz 2 division ratio is the highest if double buffer is not used. In this case, baud rate is 5Mbps because 10MHz is divided by 2. To use SCLK input, the following conditions must be satisfied. - If double buffer is used - SCLK cycle > 6/fsys The highest buad rate is less than $40 \div 6 = 6.66$ Mbps. - · If double buffer is not used - SCLK cycle > 8/fsys The highest band rate is less than $40 \div 8 = 5.0$ Mbps. #### (2) Transfer clock in the UART mode Table 12-8 shows the clock selection in the UART mode. In the UART mode, selected clock is divided by 16 in the receive counter or the transmit counter before use. Table 12-8 Clock selection in UART Mode | Mode<br>SCxMOD0 <sm></sm> | Clock selection<br>SCxMOD0 <sc></sc> | |---------------------------|--------------------------------------| | | Timer output | | LIADT Made | Baud rate generator | | UART Mode | fsys | | | SCLK input | The examples of baud rate in each clock settings. - · If baud rate generator is used. - fc = 40MHz - fgear = 40MHz (CGSYSCR<GEAR[2:0]> = "000": fc selected) - $\phi$ T0 = 40MHz (CGSYSCR<PRCK[2:0]> = "000" : 1 division ratio) - Clock = $\varphi$ T1 = 20MHz (SCxBRCR<BRCK[1:0]> = "00" : $\varphi$ T1 selected) The highest baud rate is 1.25MHz because 20MHz is divided by 16. Table 12-9 shows examples of baud rate when the baud rate generator is used with the following clock settings. - fc = 9.8304MHz - fgear = 9.8304MHz (CGSYSCR<GEAR[2:0]> = "000" : fc selected) - $\Phi$ T0 = 4.9152MHz (CGSYSCR<PRCK[2:0]> = "001" : 2 division ratio) Table 12-9 Example of UART Mode Baud Rate (Using the Baud Rate Generator) | fc [MHz] | Division ratio N<br>(SCxBRCR <brs[3:0]>)</brs[3:0]> | φT1<br>(fc/4) | φT4<br>(fc/16) | φT16<br>(fc/64) | φT64<br>(fc/256) | |----------|-----------------------------------------------------|---------------|----------------|-----------------|------------------| | | //_2 | 76.800 | 19.200 | 4.800 | 1.200 | | 9.830400 | 4 | 38.400 | 9.600 | 2.400 | 0.600 | | 9.630400 | 8 | 19.200 | 4.800 | 1.200 | 0.300 | | | 16 | 9.600 | 2.400 | 0.600 | 0.150 | Unit : kbps ## · If the SCLK input is used To use SCLK input, the following conditions must be satisfied. - SCLK cycle > 2/fsys The highest baud rate must be less than $40 \div 2 \div 16 = 1.25$ Mbps. #### · If fsys is used Since the highest value of fsys is 40MHz, the highest band rate is $40 \div 16 = 2.5$ Mbps. #### · If timer output is used To enable the timer output, the following condition must be set: a timer flip-flop output inverts when the value of the counter and that of TBxRG1 match. The SIOCLK clock frequency is "Setting value of TBxRG1 $\times$ 2". Baud rate can be obtained by using the following formula. Page 401 2023/07/21 #### Baud rate calculation Transfer rate = Clock frequency selected by CGSYSCR<PRCK[1:0]> (TBxRG1 x 2) x 2 x 16 In the case the timer prescaler clock fT1(2 divition ratio) is selected One clock cycle is a period that the timer flip-flop is inverted twice. Table 12-10 shows the examples of baud rates when the timer output is used with the following clock settings. - fc = 32MHz / 9.8304MHz / 8MHz - fgear = 32MHz / 9.8304MHz / 8MHz (CGSYSCR<GEAR[2:0]> = "000" :fc selected) - $\phi T0 = 16MHz / 4.9152MHz / 4MHz (CGSYSCR < PRCK[2:0] > = "001" : 2 division)$ - Timer count clock - = 4MHz / 1.2287MHz / 1MHz (TBxMOD<TBCLK[1:0]> = "01" : $\varphi$ T1 selected) Table 12-10 Example of UART Mode Baud Rate (Using the Timer Output) | TDvDC sotting | | fc | | | | |---------------|--------|-----------|--------------|--|--| | TBxRG setting | 32MHz | 9.8304MHz | 8MHz | | | | 0x0001 | 250 | 76.8 | 62.5 | | | | 0x0002 | 125 | 38.4 | 31.25 | | | | 0x0003 | ((- \) | 25.6 | \\\ <u>-</u> | | | | 0x0004 | 62.5 | 19.2 | 15.625 | | | | 0x0005 | 50 | 15.36 | 12.5 | | | | 0x0006 | )) | 12.8 | - | | | | 0x0008 | 31.25 | 9.6 | - | | | | 0x000A | 25 | 7.68 | 6.25 | | | | 0x0010 | 15.625 | 4.8 | - | | | | 0x0014 | 12.5 | 3.84 | 3.125 | | | Unit : kbps ## 12.8 Transmit / Receive Buffer and FIFO ## 12.8.1 Configuration Figure 12-3 shows the configuration of transmit buffer, receive buffer and FIFO. Appropriate settings are required for using buffer and FIFO. The configuration may be predefined depending on the mode. Figure 12-3 The Configuration of Buffer and FIFO ## 12.8.2 Transmit / Receive Buffer Transmit buffer and receive buffer are double-buffered. The buffer configuration is specified by SCxMOD2<WBUF>. In the case of using a receive buffer, if SCLK input is set to generate clock output in the I/O interface mode or the UART mode is selected, it's double buffered despite the <WBUF> settings. In other modes, it's according to the <WBUF> settings. Table 12-11 shows correlation between modes and buffers. SCxMOD2<WBUF> Mode "0" "1" Transmit Single Double UART Receive Double Double Transmit Single Double I/O interface (SCLK input) Double Double Receive Transmit Single Double I/O interface (SCLK output) Receive Single Double Table 12-11 Mode and buffer Composition #### 12.8.3 FIFO In addition to the double buffer function above described, 4-byte FIFO can be used. To enable FIFO, enable the double buffer by setting SCxMOD2<WBUF> to "1" and SCxFCNF<CNFG> to "1". The FIFO buffer configuration is specified by SCxMOD1<FDPX[1:0]>. Page 403 2023/07/21 12.9 Status Flag TMPM362F10FG Note: To use TX/RX FIFO buffer, TX/RX FIFO must be cleared after setting the SIO transfer mode (half duplex/ full duplex) and enabling FIFO (SCxFCNF<CNFG> = "1"). Table 12-12 shows correction between modes and FIFO. Table 12-12 Mode and FIFO Composition | | SCxMOD1 <fdpx[1:0]></fdpx[1:0]> | RX FIFO | TX FIFO | |----------------|---------------------------------|---------|---------| | Half duplex RX | "01" | 4byte | | | Half duplex TX | "10" | - < | 4byte | | Full duplex | "11" | 2byte | 2byte | # 12.9 Status Flag The SCxMOD2 register has two types of flag. This bit is significant only when the double buffer is enabled. <RBFLL> is a flag to show that the receive buffer is full. When one frame of data is received and the data is moved from the receive shift register to the receive buffers, this bit changes to "1" while reading this bit changes it to "0". <TBEMP> shows that the transmit buffers are empty. When data in the transmit buffers is moved to the transmit shift register, this bit is set to "1" When data is set to the transmit buffers, the bit is cleared to "0". # 12.10 Error Flag Three error flags are provided in the SCxCR register. The meaning of the flags is changed depending on the modes. The table below shows the meaning in each mode. These flags are cleared to "0" after reading the SCxCR register. | | Mode | | Flag | | |---------|--------------------------------|---------------|-----------------------------------------------------------|---------------| | | Wiode | <oerr></oerr> | <perr></perr> | <ferr></ferr> | | | UART | Overrun error | Parity error | Framing error | | / | I/O interface | | Underrun error<br>(When using double buffer<br>or FIFO) | Fired to HOU | | / / | (SCLK input) | Overrun error | Fixed to "0"<br>(When a double buffer and<br>FIFO unused) | Fixed to "0" | | // | I/O interface<br>(SCLK output) | Undefined | Undefined | Fixed to "0" | ## 12.10.1 OERR Flag In both UART and I/O interface modes, this bit is set to "1" when an error is generated by completing the reception of the next frame of receive data before the receive buffer has been read. If the receive FIFO is enabled, the received data is automatically moved to the receive FIFO and no overrun error will be generated until the receive FIFO is full (or until the usable bytes are fully occupied). In the I/O interface with SCLK output mode, the SCLK output stops upon setting the flag. Note: To switch the I/O interface SCLK output mode to other modes, read the SCxCR register and clear the overrun flag. ## 12.10.2 PERR Flag This flag indicates a parity error in the UART mode and an under-run error in the I/O interface mode. In the UART mode, <PERR> is set to "1" when the parity generated from the received data is different from the parity received. In the I/O interface mode, <PERR> is set to "1" under the following conditions when a double buffer is enabled. In the SCLK input mode, <PERR> is set to "1" when the SCLK is input after completing data output of the transmit shift register with no data in the transmit buffer. In the SCLK output mode, <PERR> is set to "1" after completing output of all data and the SCLK output stops. Note: To switch the I/O interface SCLK output mode to other modes, read the SCxCR register and clear the underrun flag. ## 12.10.3 FERR Flag A framing error is generated if the corresponding stop bit is determined to be "0" by sampling the bit at around the center. Regardless of the stop bit length settings in the SCxMOD2<SBLEN>register, the stop bit status is determined by only 1. This bit is fixed to "0" in the I/O interface mode 12.11 Receive TMPM362F10FG #### 12.11 Receive #### 12.11.1 Receive Counter The receive counter is a 4-bit binary counter and is up-counted by SIOCLK. In the UART mode, sixteen SIOCLK clock pulses are used in receiving a single data bit and the data symbol is sampled at the seventh, eighth, and ninth pulses. From these three samples, majority logic is applied to decide the received data. #### 12.11.2 Receive Control Unit #### 12.11.2.1 I/O interface mode In the SCLK output mode with SCxCR <IOC> set to "0", the RXD pin is sampled on the rising edge of the shift clock outputted to the SCLK pin. In the SCLK input mode with SCxCR <IOC> set to "1", the serial receive data RXD pin is sampled on the rising or falling edge of SCLK input signal depending on the SCxCR <SCLKS> setting. #### 12.11.2.2 UART Mode The receive control unit has a start bit detection circuit, which is used to initiate receive operation when a normal start bit is detected. ## 12.11.3 Receive Operation #### 12.11.3.1 Receive Buffer The received data is stored by 1 bit in the receive shift register. When a complete set of bits has been stored, the interrupt INTTRX is generated. When the double buffer is enabled, the data is moved to the receive buffer (SCxBUF) and the receive buffer full flag (SCxMOD2<RBFLL>) is set to "1". The receive buffer full flag is "0" cleared by reading the receive buffer. The receive buffer flag does not have any value for the single buffer. 12.11 Receive TMPM362F10FG ### 12.11.3.2 Receive FIFO Operation When FIFO is enabled, the received data is moved from receive buffer to receive FIFO and the receive buffer full flag is cleared immediately. An interrupt will be generated according to the SCxRFC<RIL> setting. Note: When the data with parity bit are received in UART mode by using the FIFO, the parity error flag is shown the occurring the parity error in the received data. The configurations and operations in the half duplex RX mode are described as follows. SCxMOD1[6:5] =01 :Transfer mode is set to half duplex mode SCxFCNF[4:0] = 10111 :Automatically inhibits continuous reception after reaching the fill level. : The number of bytes to be used in the receive FIFO is the same as the interrupt generation fill lev- el. SCxRFC[1:0] = 00 :The fill level of FIFO in which generated receive interrupt is set to 4-byte SCxRFC[7:6] = 11 :Clears receive FIFO and sets the condition of interrupt generation. After setting of the above FIFO configuration, the data reception is started by writing "1" to the SCxMOD0<RXE>. When the data is stored all in the receive shift register, receive buffer and receive FIFO, SCxMOD0<RXE> is automatically cleared and the receive operations finished. In the above condition, if the cutaneous reception after reaching the fill level is enabled, it becomes possible to receive a data continuously by reading the data in the FIFO. Figure 12-5 Receive FIFO Operation #### 12.11.3.3 I/O interface mode with SCLK output In the I/O interface mode and SCLK output setting, SCLK output stops when all received data is stored in the receive buffer and FIFO. Thus, in this mode, the overrun error flag has no meaning. The timing of SCLK output stop and re-output depends on receive buffer and FIFO. ### (1) Case of single buffer Stop SCLK output after receiving a data. In this mode, I/O interface can transfer each data with the transfer device by hand-shake. When the data in a buffer is read, SCLK output restarts. ### (2) Case of double buffer Stop SCLK output after receiving the data into a receive shift register and a receive buffer. When the data is read, SCLK output restarts. #### (3) Case of FIFO Stop SCLK output after receiving the data into a shift register, received buffer and FIFO. When one byte data is read, the data in the received buffer is transferred into FIFO and the data in the receive shift register is transferred into the received buffer and SCLK output restarts. And if SCxFCNF<RXTXCNT>is set to "1", SCLK stops and receive operation stops with clearing SCxMOD0<RXE> bit, too. #### 12.11.3.4 Read Received Data In spite of enabling or disabling FIFO, read the received data from the receive buffer (SCxBUF). When receive FIFO is disabled, the buffer full flag SCxMOD2<RBFLL> is cleared to "0" by this reading. In the case of the next data can be received in the receive shift register before reading a data from the receive buffer. The parity bit to be added in the 8-bit UART mode as well as the most significant bit in the 9-bit UART mode will be stored in SCxCR<RB8>. When the receive FIFO is available, the 9-bit UART mode is prohibited because up to 8-bit data can be stored in FIFO. In the 8-bit UART mode, the parity bit is lost but parity error is determined and the result is stored in SCxCR<PERR>. ### 12.11.3.5 Wake-up Function In the 9-bit UART mode, the slave controller can be operated in the wake-up mode by setting the wake-up function SCxMOD0 <WU> to "1". In this case, the interrupt INTRXx will be generated only when SCxCR<RB8> is set to "1". Page 409 2023/07/21 12.11 Receive TMPM362F10FG ### 12.11.3.6 Overrun Error When FIFO is disabled, the overrun error occurs and an overrun error is without completing reading data before receiving the next data. When an overrun error occurs, a content of receive buffer and SCxCR<RB8> is not lost, but a content of receive shift register is lost. When FIFO is enabled, overrun error is occurred and set overrun flag by no reading the data before moving the next data into received buffer when FIFO is full. In this case, the contents of FIFO are not lost. In the I/O interface mode with SCLK output setting, the clock output automatically stops, so this flag has no meaning. Note: When the mode is changed from I/O interface SCLK output mode to the other mode, read SCxCR and clear overrun flag. TMPM362F10FG ### 12.12 Transmission ### 12.12.1 Transmission Counter The transmit counter is a 4-bit binary counter and is counted by SIOCLK as in the case of the receive counter. In UART mode, it generates a transmit clock (TXDCLK) on every 16th clock pulse. Figure 12-6 Generation of Transmission Clock in UART Mode ### 12.12.2 Transmission Control ### 12.12.2.1 I/O interface Mode In the SCLK output mode with SCxCR<IOC> set to "0", each bit of data in the transmit buffer is outputted to the TXD pin on the falling edge of the shift clock outputted from the SCLK pin. In the SCLK input mode with SCxCR<IOC> set to "1", each bit of data in the transmit buffer is outputted to the TXD pin on the rising or falling edge of the SCLK input signal according to the SCxCR<SCLKS> setting. ### 12.12.2.2 UART Mode When the transmit data is written in the transmit buffer, data transmission is initiated on the rising edge of the next TXDCLK and the transmit shift clock signal is also generated. 12.12 Transmission TMPM362F10FG ### 12.12.3 Transmit Operation ### 12.12.3.1 Operation of Transmission Buffer If double buffering is disabled, the CPU writes data only to Transmit shift Buffer and the transmit interrupt INTTXx is generated upon completion of data transmission. If double buffering is enabled (including the case the transmit FIFO is enabled), data written to the transmit buffer is moved to the transmit shift register. The INTTXx interrupt is generated at the same time and the transmit buffer empty flag (SCxMOD2<TBEMP>) is set to "1". This flag indicates that the next transmit data can be written. When the next data is written to the transmit buffer, the <TBEMP> flag is cleared to "0". Figure 12-7 Operation of Transmission Buffer (Double buffer is enabled) ### 12.12.3.2 Transmit FIFO Operation When FIFO is enabled, the maximum 5-byte data can be stored using the transmit buffer and FIFO. Once transmission is enabled, data is transferred to the transmit shift register from the transmit buffer and start transmission. If data exists in the FIFO, the data is moved to the transmit buffer immediately, and the <TBEMP> flag is cleared to "0". Note: To use TX FIFO buffer, TX FIFO must be cleared after setting the SIO transfer mode (half duplex) full duplex) and enabling FIFO (\$CxFCNF<CNFG>="1"). Settings and operations to transmit 4-byte data stream by setting the transfer mode to half duplex are shown as below. SCxMOD1[6:5] = 10 SCxFCNF[4:0] = 11011 :Transfer mode is set to half duplex. :Transmission is automatically disabled if FIFO becomes empty. :The number of bytes to be used in the receive FIFO is the same as the interrupt igeneration fill level. SCxTFC[1:0] = 00 SCxTFC[7:6] = 11 SCxFCNF[0] = 1 :Enable FIFO :Transfer mode is set to half duplex. :Transmission is automatically disabled if FIFO becomes empty. :Transfer mode is set to half duplex. :Transfer mode is set to half duplex. :Transfer mode is set to half duplex. :Transfer mode is set to half duplex. :Transfer mode is set to half duplex. :Transfer mode is set to half duplex. :Transfer mode is set to hal After above settings are configured, data transmission can be initiated by writing 5 bytes of data to the transmit buffer or FIFO, and setting the SCxMOD1<TXE> bit to "1". When the last transmit data is moved to the transmit buffer, the transmit FIFO interrupt is generated. When transmission of the last data is completed, the clock is stopped and the transmission sequence is terminated. Once above settings are configured, if the transmission is not set as auto disabled, the transmission should lasts writing transmit data. | Transmit FIFO fourth stage | DATA 5 | | | | | | |-----------------------------|--------|--------|--------|------------|---------------|--------------------| | Third stage | DATA 4 | DATA 5 | | | | | | Second stage | DATA 3 | DATA 4 | DATA 5 | | | | | First stage | DATA 2 | DATA 3 | DATA 4 | DATA 5 | | ) > | | | | | 1 | 1 | | | | Transmit buffer | DATA 1 | DATA 2 | DATA 3 | DATA 4 | DATA 5 | | | ! | , | | , | | | | | Transmit shift register | | DATA 1 | DATA 2 | DATA 3 | DATA 4 | DATA 5 | | | | | | | | | | | | | | | | | | SCxMOD1 <txe></txe> | | | | 4( | $\rightarrow$ | 7( )r | | OO MODO TREMP | | | ٦ . | | | | | SCxMOD2 <tbemp></tbemp> | | | | | | )) | | T (1) (1) (1) (1) (1) | | | | | | $\exists U \cap )$ | | Transmit interrupt (INTTXx) | | | | | | 70/ | | | | | | | | $\searrow$ | | | | | (1) | $\Diamond$ | | | ### 12.12.3.3 I/O interface Mode/Transmission by SCLK Output If SCLK is set to generate clock in the I/O interface mode, the SCLK output automatically stops when all data transmission is completed and underrun error will not occur. The timing of suspension and resume of SCLK output is different depending on the buffer and FIFO usage. ### (1) Single Buffer The SCLK output stops each time one frame of data is transferred. Handshaking for each data with the other side of communication can be enabled. The SCLK output resumes when the next data is written in the buffer. ### (2) Double Buffer The SCLK output stops upon completion of data transmission of the transmit shift register and the transmit buffer. The SCLK output resumes when the next data is written in the buffer. ### (3) FIFO The transmission of all data stored in the transmit shift register, transmit buffer and FIFO is completed, the SCLK output stops. The next data is written, SCLK output resumes. If SCxFCNF<RXTXCNT> is configured, SCxMOD0<TXE> bit is cleared at the same time as SCLK stop and the transmission stops. 12.12 Transmission TMPM362F10FG ### 12.12.3.4 Underrun Error If the transmit FIFO is disabled in the I/O interface SCLK input mode and if no data is set in transmit buffer before the next frame clock input, which occurs upon completion of data transmission from transmit shift register, an under-run error occurs and SCxCR<PERR> is set to "1". In the I/O interface mode with SCLK output setting, the clock output automatically stops, so this flag has no meaning/ ### 12.13 Handshake Function The function of the handshake is to enable frame-by-frame data transmission by using the CTS (Clear to send) pin and to prevent overrun errors. This function can be enabled or disabled by SCxMOD0<CTSE>. When the $\overline{\text{CTS}}$ pin is set to "High" level, the current data transmission can be completed but the next data transmission is suspended until $\overline{\text{CTS}}$ pin returns to the "Low" level. However in this case, the INTTXx interrupt is generated in the normal timing, the next transmit data is written in the transmit buffer, and it waits until it is ready to transmit data. - Note 1: If the CTS signal is set to "High" during transmission, the next data transmission is suspended after the current transmission is completed. - Note 2: Data transmission starts on the first falling edge of the TXDCLK clock after CTS is set to "Low". Although no $\overline{RTS}$ pin is provided, a handshake control function can easily implemented by assigning one bit of the port for the $\overline{RTS}$ function. By setting the port to "High" level upon completion of data reception (in the receive interrupt routine), the transmit side can be requested to suspend data transmission. Figure 12-8 Handshake Function Figure 12-9 CTS Signal timing Page 415 2023/07/21 #### 12.14 Interrupt / Error Generation Timing ### 12.14 Interrupt / Error Generation Timing ### 12.14.1 RX Interrupt Figure 12-10 shows the data flow of receive operation and the route of read. Figure 12-10 Receive Buffer / FIFO Configuration Diagram ### 12.14.1.1 Single Buffer / Double Buffer RX interrupts are generated at the time depends on the transfer mode and the buffer configurations, which are given follows. | Buffer Configuration | UART modes | I/O interface modes | |----------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Single Buffer | - (7) | Immediately after the raising / falling edge of the last SCLK (Rising or falling is determined according to SCxCR <sclks> setting.)</sclks> | | Double Buffer | Around the center of the first stop bit | Immediately after the raising / falling edge of the last SCLK (Rising or falling is determined according to SCxCR <sclks> setting.) On data transfer from the shift register to the buffer by reading buffer.</sclks> | Note: Interrupts are not generated when an overrun error occurs. ### 12.14.1.2 FIFO When the FIFO is used, a receive interrupt occurs depending on the timing described in Table 12-13 and the condition specified with SCxRFC<RFIS>. Table 12-13 Receive Interrupt Conditions in use of FIFO | SCxRFC<br><rfis></rfis> | Interrupt conditions | Interrupt generation timing | |-------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | "0" | When FIFO fill level (SCxRST <rlvl[2:0]>) = Receive FIFO fill level to generate receive interrupt <ril[1:0]></ril[1:0]></rlvl[2:0]> | When received data is transferred from receive buffer to receive FIFO | | "1" | When FIFO fill level (SCxRST <rlvl[2:0]>) ≥ Receive FIFO fill level to generate receive interrupt <ril[1:0]></ril[1:0]></rlvl[2:0]> | When received data is transferred from receive buffer to receive FIFO When received data is read from receive FIFO | ### 12.14.2 TX interrupt Figure 12-11 shows the data flow of transmit operation and the route of read. Figure 12-11 Transmit Buffer / FIFO Configuration Diagram ### 12.14.2.1 Single Buffer / Double Buffer TX interrupts are generated at the time depends on the transfer mode and the buffer configurations, which are given as follows. | Buffer Configuration | UART modes | I/O interface modes | |----------------------|--------------------------------------|------------------------------------------------------------------------------| | Single Buffer | Just before the stop bit is sent | Immediately after the raising / falling edge of the last SCLK | | Single Bullet | bust before the stop bit is sent | Rising or falling is determined according to SCxCR <sclks> setting.)</sclks> | | Double Buffer | When a data is moved from the transr | nit buffet to the transmit shift register. | Note: If double buffer is enabled, a interrupt is also generated when the data is moved from the buffer to the shift register by writing to the buffer. 12.14.2.2 FIFO When the FIFO is used, a transmit interrupt occurs depending on the timing described in Table 12-14 and the condition specified with SCxTFC<TFIS>. Table 12-14 Transmit Interrupt conditions in use of FIFO | SCxTFC<br><tfis></tfis> | Interrupt condition | Interrupt generation timing | |-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | "0" | When FIFO fill level (SCxTST <tlvl[2:0]>) = Transmit FIFO fill level to generate transmit interrupt <til[1:0]></til[1:0]></tlvl[2:0]> | When transmitted data is transferred from transmit FIFO to transmit buffer | | "1" | When FIFO fill level (SCxTST <tlvl[2:0]>) ≤ Transmit FIFO fill level to generate transmit interrupt <til[1:0]></til[1:0]></tlvl[2:0]> | When transmitted data is transferred from transmit FIFO to transmit buffer When transmit data is write into transmit FIFO | Page 417 2023/07/21 12.15 Software Reset TMPM362F10FG ### 12.14.3 Error Generation ### 12.14.3.1 UART Mode | Modes | 9 bits | 7 bits<br>8 bits<br>7 bits + parity | |---------------|---------------|-------------------------------------| | | | 8bits + parity | | Framing error | Around the co | nter of stop bit | | Overrun error | Around the ce | Ther of stop bit | | Parity Error | _ | Around center of parity bit | ### 12.14.3.2 I/O Interface Mode | Overrun error | Immediately after the raising / falling edge of the last SCLK (Rising or falling is determined according to SCxCR <sclks> setting.)</sclks> | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | Underrun error | Immediately after the rising or falling edge of the next SCLK. (Rising or falling is determined according to SCxCR <sclks> setting.)</sclks> | Note: Over-run error and Under-run error have no meaning in SCLK output mode. ### 12.15 Software Reset Software reset is generated by writing SCxMOD2<SWRST[1:0]> as "10" followed by "01". As a result, SCxMOD0<RXE>, SCxMOD1<TXE>, SCxMOD2<TBEMP><RBFLL><TXRUN>, SCxCR<OERR><PERR> <FERR> are initialized. And the receive circuit, the transmit circuit and the FIFO become initial state. Other states are maintained. TOSHIBA TMPM362F10FG ### 12.16 Operation in Each Mode ### 12.16.1 Mode 0 (I/O Interface Mode) Mode 0 consists of two modes, the SCLK output mode to output synchronous clock and the SCLK input mode to accept synchronous clock from an external source. The following operational descriptions are for the case use of FIFO is disabled. For details of FIFO operation, refer to the previous sections describing receive/transmit FIFO functions. ### 12.16.1.1 Transmitting Data ### (1) SCLK Output Mode • If the transmit double buffer is disabled (SCxMOD2<WBUF> = "0" Data is output from the TXD pin and the clock is output from the SCLK pin each time the CPU writes data to the transmit buffer. When all data is output, an interrupt (INTTXx) is generated. • If the transmit double buffer is enabled (SCxMOD2<WBUF> = "1") Data is moved from the transmit buffer to the transmit shift register when the CPU writes data to the transmit buffer while data transmission is halted or when data transmission from the transmit buffer (shift register) is completed. Simultaneously, the transmit buffer empty flag SCxMOD2<TBEMP> is set to "1", and the INTTXx interrupt is generated. When data is moved from the transmit buffer to the transmit shift register, if the transmit buffer has no data to be moved to the transmit shift register, INTTXx interrupt is not generated and the SCLK output stops. Page 419 2023/07/21 Figure 12-12 Transmit Operation in the I/O Interface Mode (SCLK Output Mode) ### (2) SCLK Input Mode • If double buffering is disabled (SCxMOD2<WBUF> = "0") If the SCLK is input in the condition where data is written in the transmit buffer, 8-bit data is outputted from the TXD pin. When all data is output, an interrupt INTTXx is generated. The next transmit data must be written before the timing point "A" as shown in Figure 12-13. • If double buffer is enabled (SCxMOD2<WBUF> = "1") Data is moved from the transmit buffer to the transmit shift register when the CPU writes data to the transmit buffer before the SCLK input becomes active or when data transmission from the transmit shift register is completed. Simultaneously, the transmit buffer empty flag SCxMOD2<TBEMP> is set to "1" and the INTTXx interrupt is generated. If the SCLK input becomes active while no data is in the transmit buffer, although the internal bit counter is started, an under-run error occurs and 8-bit dummy data (0xFF) is sent. Page 421 2023/07/21 Figure 12-13 Transmit Operation in the I/O Interface Mode (SCLK Input Mode) #### 12.16.1.2 Receive ### (1) SCLK Output Mode The SCLK output can be started by setting the receive enable bit \$CxMOD0<RXE> to "1". • If double buffer is disabled (SCxMOD2<WBUF> = "0") A clock pulse is outputted from the SCLK pin and the next data is stored into the shift register each time the CPU reads received data. When all the 8 bits are received, the INTRXx interrupt is generated. If double buffer is enabled (SCxMOD2<WBUF> = "1") Data stored in the shift register is moved to the receive buffer and the receive buffer can receive the next frame. A data is moved from the shift register to the receive buffer, the receive buffer full flag SCxMOD2<RBFLL> is set to "1" and the INTRXx is generated. While data is in the receive buffer, if the data cannot be read from the receive buffer before completing reception of the next 8 bits, the INTRXx interrupt is not generated and the SCLK output stops. In this state, reading data from the receive buffer allows data in the shift register to move to the receive buffer and thus the INTRXx interrupt is generated and data reception resumes. Page 423 2023/07/21 Figure 12-14 Receive Operation in the I/O Interface Mode (SCLK Output Mode) ### (2) SCLK Input Mode In the SCLK input mode, receiving double buffering is always enabled, the received frame can be moved to the receive buffer from the shift register, and the receive buffer can receive the next frame successively. The INTRXx receive interrupt is generated each time received data is moved to the receive buffer. Figure 12-15 Receive Operation in the I/O Interface Mode (SCLK Input Mode) Page 425 2023/07/21 ### 12.16.1.3 Transmit and Receive (Full duplex) ### (1) SCLK Output Mode If SCxMOD2<WBUF> is set to "0" and the double buffers are disabled SCLK is outputted when the CPU writes data to the transmit buffer. Subsequently, 8 bits of data are shifted into receive buffer and the INTRXx receive interrupt is generated. Concurrently, 8 bits of data written to the transmit buffer are outputted from the TXD pin, the INTTXx transmit interrupt is generated when transmission of all data bits has been completed. Then, the SCLK output stops. The next round of data transmission and reception starts when the data is read from the receive buffer and the next transmit data is written to the transmit buffer by the CPU. The order of reading the receive buffer and writing to the transmit buffer can be freely determined. Data transmission is resumed only when both conditions are satisfied. • If SCxMOD2<WBUF> is set to "1" and the double buffers are enabled SCLK is outputted when the CPU writes data to the transmit buffer. 8 bits of data are shifted into the receive shift register, moved to the receive buffer, and the INTRXx interrupt is generated. While 8 bits of data is received, 8 bits of transmit data is outputted from the TXD pin. When all data bits are sent out, the INTTXx interrupt is generated and the next data is moved from the transmit buffer to the transmit shift register. If the transmit buffer has no data to be moved to the transmit buffer (SCxMOD2<TBEMP> = 1) or when the receive buffer is full (SCxMOD2<RBFULL> = 1), the SCLK output is stopped. When both conditions, receive data is read and transmit data is written, are satisfied, the SCLK output is resumed and the next round of data transmission and reception is started. Figure 12-16 Transmit / Receive Operation in the I/O Interface Mode (SCLK Output Mode) Page 427 2023/07/21 ### (2) SCLK Input Mode • If SCxMOD2<WBUF> is set to "0" and the transmit double buffer is disabled When receiving data, double buffer is always enabled regardless of the SCxMOD2 <WBUF> settings. 8-bit data written in the transmit buffer is outputted from the TXD pin and 8 bit of data is shifted into the receive buffer when the SCLK input becomes active. The INTTXx interrupt is generated upon completion of data transmission. The INTTRXx interrupt is generated when the data is moved from shift register to receive buffer after completion of data reception. Note that transmit data must be written into the transmit buffer before the SCLK input for the next frame (data must be written before the point A in Figure 10-17). Data must be read before completing reception of the next frame data. If SCxMOD2<WBUF> is set to "1" and the double buffer is enabled. The interrupt INTRXx is generated at the timing the transmit buffer data is moved to the transmit shift register after completing data transmission from the transmit shift register. At the same time, data received is shifted to the shift register, it is moved to the receive buffer, and the INTRXx interrupt is generated. Note that transmit data must be written into the transmit buffer before the SCLK input for the next frame (data must be written before the point A in Figure 12-17). Data must be read before completing reception of the next frame data. Upon the SCLK input for the next frame, transmission from transmit shift register (in which data has been moved from transmit buffer) is started while receive data is shifted into receive shift register simultaneously. If data in receive buffer has not been read when the last bit of the frame is received, an overrun error occurs. Similarly, if there is no data written to transmit buffer when SCLK for the next frame is input, an under-run error occurs. Figure 12-17 Transmit / Receive Operation in the I/O Interface Mode (SCLK Input Mode) Page 429 2023/07/21 ### 12.16.2 Mode 1 (7-bit UART Mode) The 7-bit UART mode can be selected by setting the serial mode control register (SCxMOD<SM[1:0]>) to "01". In this mode, parity bits can be added to the transmit data stream; the serial mode control register (SCxCR<PE>) controls the parity enable/disable setting. When <PE> is set to "1" (enable), either even or odd parity may be selected using the SCxCR<EVEN> bit. The length of the stop bit can be specified using SCxMOD2<SBLEN>. The following table shows the control register settings for transmitting in the following data format. ### 12.16.3 Mode 2 (8-bit UART Mode) The 8-bit UART mode can be selected by setting SCxMOD0<SM[1:0]> to "10". In this mode, parity bits can be added and parity enable/disable is controlled using SCxCR<PE>. If <PE> = "1" (enabled), either even or odd parity can be selected using SCxCR<EVEN>. The control register settings for receiving data in the following format are as follows: | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------------------|--------|-----|---|---|---|---|---|---|---|---------------------| | SCxMOD0 | ← | х | 0 | 0 | 0 | 1 | 0 | 0 | 1 | Set 8-bit UART mode | | SCxCR | ← | х | 0 | 1 | х | х | х | 0 | 0 | Odd parity enabled | | SCxBRCR | ← | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | Set 9600bps | | SCxMOD0 | ← | - | - | 1 | - | - | - | - | - | Reception enabled | | x : don't care - : | no cha | nge | | | | | | | | | ### 12.16.4 Mode 3 (9-bit UART Mode) The 9-bit UART mode can be selected by setting SCxMOD0 < SM[1:0] > to "11". In this mode, parity bits must be disabled (SCxCR < PE > = "0"). The most significant bit (9th bit) is written to bit 7 <TB8> of the serial mode control register 0 (SCxMOD0) for transmitting data. The data is stored in bit 7 <RB8> of the serial control register SCxCR. When writing or reading data to/from the buffers, the most significant bit must be written or read first before writing or reading to/from SCxBUF. The stop bit length can be specified using SCxMOD2<SBLEN>. ### 12.16.4.1 Wake-up Function In the 9-bit UART mode, slave controllers can be operated in the wake-up mode by setting the wake-up function control bit SCxMOD0<WU> to "1". In this case, the interrupt INTRXx will be generated only when SCxCR<RB8> is set to "1". Note: The TXD pin of the slave controller must be set to the open drain output mode using the ODE register. Figure 12-18 Serial Links to Use Wake-up Function Page 431 2023/07/21 ### 12.16.4.2 Protocol - 1. Select the 9-bit UART mode for the master and slave controllers. - 2. Set SCxMOD<WU> to "1" for the slave controllers to make them ready to receive data. - 3. The master controller is to transmit a single frame of data that includes the slave controller select code (8 bits). In this, the most significant bit (bit 8) <TB8> must be set to "1". - 4. Each slave controller receives the above data frame; if the code received matches with the controller's own select code, it clears the <WU> bit to "0". - 5. The master controller transmits data to the designated slave controller (the controller of which SCxMOD<WU> bit is cleared to "0"). In this, the most significant bit (bit 8) <TB8> must be set to "0". 6. The slave controllers with the <WU> bit set to "1" ignore the receive data because the most significant bit (bit 8) <RB8> is set to "0" and thus no interrupt (INTRXx) is generated. Also, the slave controller with the <WU> bit set to "0" can transmit data to the master controller to inform that the data has been successfully received. # 13. Synchronous Serial Port (SSP) # 13.1 Overview This LSI contains the SSP (Synchronous Serial Port) with 1 channel. This channel has the following features. | | | Three types of synchronous serial ports including the SPI | |---------------------|------------------|-----------------------------------------------------------| | Communica | tion protocol | Motorola SPI (SPI) frame format | | Communica | tion protocol | TI synchronous (SSI) frame format | | | | National Microwire (Microwire) frame format | | Operation | on mode | Master/slave mode | | Transn | nit FIFO | 16bits wide / 8 tiers deep | | Receiv | re FIFO | 16bits wide / 8 tiers deep | | Transmitted/red | ceived data size | 4 to 16 bits | | | | Transmit interrupt | | Intorn | ent turno | Receive interrupt | | interio | pt type | Receive overrun interrupt | | | | Time-out interrupt | | Communication and | In master mode | fsys (64MHz)/ 4 (max. 16Mbps) | | Communication speed | In slave mode | fsys (64MHz)/ 12 (max. 5.3Mbps) | | D | MA | Supported | | Internal te | est function | The internal loopback test mode is available. | | Cont | rol pin | SPCLK,SPFSS,SPDO,SPDI | | | | | Page 433 2023/07/21 13.2 Block Diagram TMPM362F10FG ### 13.2 Block Diagram Figure 13-1 SSP block diagram TMPM362F10FG ## 13.3 Register ### 13.3.1 Register List Base Address = 0x4004\_0000 | Register Name | | Address (Base+) | |-------------------------------------------------------------|----------|------------------| | Control register 0 | SSPCR0 | 0x0000 | | Control register 1 | SSPCR1 | 0x0004 | | Receive FIFO (read) and transmit FIFO (write) data register | SSPDR | 0x0008 | | Status register | SSPSR | 0x000C | | Clock prescale register | SSPCPSR | 0x0010 | | Interrupt enable/disable register | SSPIMSC | 0x0014 | | Pre-enable interrupt status register | SSPRIS | 0x0018 | | Post-enable interrupt status register | SSPMIS | 0x001C | | Interrupt clear register | SSPICR | 0x0020 | | DMA control register | SSPDMACR | 0x0024 | | Reserved | <u>.</u> | 0x0028 to 0x0FFC | Note 1: These registers in the above table allows to access only word (32 bits) basis. 13.3 Register TMPM362F10FG # 13.3.2 SSPCR0(Control register 0) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (-0/< | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | SO | CR | | | | | After Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | SPH | SPO | Fi | RF | | Ds | ss / | | | After Reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | | | | | | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31-16 | - | W | Write as "0". | | | | | | | 15-8 | SCR[7:0] | R/W | For serial clock rate setting. Parameter: 0x00 to 0xFF. Bits to generate the SSP transmit bit rate and receive bit rate. This bit rate can be obtained by the following equation. Bit rate = f <sub>sys</sub> / ( <cpsdvsr> × (1+ <scr>)) <cpsdvsr> is an even number between 2 to 254, which is programmed by the SSPCPSR register, and <scr> takes a value between 0 to 255.</scr></cpsdvsr></scr></cpsdvsr> | | | | | | | 7 | SPH | R/W | SPCLK phase: 0 : Captures data at the 1st clock edge. 1 : Captures data at the 2nd clock edge. This is applicable to Motorola SPI frame format only. Refer to Section "Motorola SPI frame format" | | | | | | | 6 | SPO | R/W | SPCLK polarity: 0:SPCLK is in Low state. 1:SPCLK is in High state. This is applicable to Motorola SPI frame format only. Refer to Section "Motorola SPI frame format" | | | | | | | 5-4 | FRF[1:0] | R/W | Frame format: 00: SPI frame format 01: SSI serial frame format 10: Microwire frame format 11: Reserved, undefined operation | | | | | | | 3-0 | DSS[3:0] | R/W | Data size select: | | | | | | | (= | | ( | 0000: Reserved, undefined op-<br>eration 1000: 9 bits data | | | | | | | | | | 0001: Reserved, undefined operation 1001: 10 bits data | | | | | | | | | | 0010: Reserved, undefined operation 1010: 11 bits data | | | | | | | | | | 0011: 4 bits data 1011: 12 bits data | | | | | | | | | | 0100: 5 bits data 1100: 13 bits data | | | | | | | | | | 0101: 6 bits data 1101: 14 bits data | | | | | | | | | | 0110: 7 bits data 1110: 15 bits data | | | | | | | | | | 0111: 8 bits data 1111: 16 bits data | | | | | | Note: Set a clock prescaler to $\underline{SSPCR0 < SCR[7:0]} > = 0x00$ , $\underline{SSPCPSR < CPSDVSR[7:0]} > = 0x02$ , when slave mode is selected. # 13.3.3 SSPCR1(Control register1) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (-0) | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> Y | - | - | | After Reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | SOD | MS | SSE | LBM | | After Reset | Undefined | Undefined | Undefined | Undefined | ((/o/ \) | 0 | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | - | W | Write as "0". | | 3 | SOD | R/W | Slave mode SPDO output control: 0: Enable 1: Disable Slave mode output disable. This bit is relevant only in the slave mode ( <ms>="1").</ms> | | 2 | MS | R/W | Master/slave mode select: (Note) 0: Device configured as a master. 1: Device configured as a slave. | | 1 | SSE | R/W | SSP enable/disable 0: Disable 1: Enable | | 0 | LBM | R/W | Loop back mode 0: Normal serial port operation enabled. 1: Output of transmit serial shifter is connected to input of receive serial shifter internally. | Note: This bit is for switching between master and slave. Be sure to configure in the following steps in slave mode and in transmission. :<MS>=1 2) Set transmit data in FIFO :<DATA>=0x\*\*\*\* 3) Set SSP to Enable. :<SSE>=1 13.3 Register TMPM362F10FG # 13.3.4 SSPDR(Data register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | DA | TA | | | | | After Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | DA | TA | > | 2// | | | After Reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | - | W | Write as "0". | | 15-0 | DATA[15:0] | R/W | Transmit/receive FIFO data: 0x0000 to 0xFFFF | | | | | Read: Receive FIFO | | | | | Write: Transmit FIFO | | | | | If the data size used in the program is less than 16bits, write the data to fit LSB. The transmit control circuit ignores unused bits of MSB side. The receive control circuit receives the data to fit LSB automatically. | # 13.3.5 SSPSR(Status register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After Reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | BSY | RFF | RNE | TNF | TFE | | After Reset | Undefined | Undefined | Undefined | 0 | ((/o/ \) | 0_ | | 1 | | Bit | Bit Symbol | Type | Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------------------| | BIL | Bit Symbol | Туре | Function | | 31-5 | - | W | Write as "0". | | 4 | BSY | R | Busy flag: | | | | | 0: Idle | | | | | 1: Busy | | | | | <bsy>="1" indicates that the SSP is currently transmitting and/or receiving a frame or the transmit FIFO is not empty.</bsy> | | 3 | RFF | R | Receive FIFO full flag: | | | | | 0: Receive FIFO is not full. | | | | | 1: Receive FIFO is full. | | 2 | RNE | R | Receive FIFO empty flag: | | | | | 0: Receive FIFO is empty. | | | | | 1: Receive FIFO is not empty. | | 1 | TNF | R | Transmit FIFO full flag: | | | | | 0: Transmit FIFO is full. | | | | | )1: Transmit FIFO is not full. | | 0 | TFE | R | Transmit FIFO empty flag: | | | | | 0: Transmit FIFO is not empty: | | | | | 1: Transmit FIFO is empty. | 13.3 Register TMPM362F10FG # 13.3.6 SSPCPSR (Clock prescale register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - / | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After Reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | CPSI | OVSR | > | 2 | | | After Reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | W | Write as "0". | | 7-0 | CPSDVSR[7:0] | R/W | Clock prescale divisor: Set an even number from 2 to 254. Clock prescale divisor: Must be an even number from 2 to 254, depending on the frequency of fsys. The least significant bit always returns zero when read. | # 13.3.7 SSPIMSC (Interrupt enable/disable register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After Reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | TXIM | RXIM | RTIM | RORIM | | After Reset | Undefined | Undefined | Undefined | Undefined | ((/9/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | _ | W | Write as "0". | | 3 | TXIM | R/W | Transmit FIFO interrupt enable: 0: Disable 1: Enable Enable or disable a conditional interrupt to occur if the transmit FIFO is half empty or less. | | 2 | RXIM | R/W | Receive FIFO interrupt enable: 0: Disable 1: Enable Enable or disable a conditional interrupt to occur if the receive FIFO is half full or less. | | 1 | RTIM | R/W | Receive time-out interrupt enable: 0: Disable 1: Enable Enable or disable a conditional interrupt to indicate that data exists in the receive FIFO to the time-out period and data is not read. | | 0 | RORIM | R/W | Receive overrun interrupt enable: 0: Disable 1: Enable Enable or disable a conditional interrupt to indicate that data was written when the receive FIFO was in the full condition. | 13.3 Register TMPM362F10FG # 13.3.8 SSPRIS (Pre-enable interrupt status register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | - / | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After Reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | TXRIS | RXRIS | RTRIS | RORRIS | | After Reset | Undefined | Undefined | Undefined | Undefined | ((/1/5) | 0_ | (0) | 0 | | | _ | | | |------|------------|------|-----------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-4 | _ | W | Write as "0". | | 3 | TXRIS | R | Pre-enable transmit interrupt flag: 0: Interrupt not present 1: Interrupt present | | 2 | RXRIS | R | Pre-enable receive interrupt flag: 0: Interrupt not present 1: Interrupt present | | 1 | RTRIS | R | Pre-enable timeout interrupt flag: 0: Interrupt not present 1: Interrupt present | | 0 | RORRIS | R | Pre-enable overrun interrupt flag: 0: Interrupt present 1: Interrupt present | # 13.3.9 SSPMIS (Post-enable interrupt status register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After Reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | TXMIS | RXMIS | RTMIS | RORMIS | | After Reset | Undefined | Undefined | Undefined | Undefined | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------------------| | 31-4 | - | W | Write as "0". | | 3 | TXMIS | R | Post-enable transmit interrupt flag: 0: Interrupt not present 1: Interrupt present | | 2 | RXMIS | R | Post-enable receive interrupt flag: 0: Interrupt not present 1: Interrupt present | | 1 | RTMIS | R | Post-enable time-out interrupt flag: 0: Interrupt not present 1: Interrupt present | | 0 | RORMIS | R | Post-enable overrun interrupt flag: 0: Interrupt not present 1: Interrupt present | Page 443 2023/07/21 13.3 Register TMPM362F10FG # 13.3.10 SSPICR (Interrupt clear register) | | 31 | 30 | 29 | 28 | 27 | 26 < | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|-----------| | bit symbol | - | - | - | - | - | - > | _ | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (-0/< | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> Y | - | - | | After Reset | Undefined | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | <u>-</u> | RTIC | RORIC | | After Reset | Undefined | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------------------------------------------| | 31-2 | _ | W | Write as "0". | | 1 | RTIC | W | Clear the time-out interrupt flag: 0: Invalid 1: Clear | | 0 | RORIC | W | Clear the overrun interrupt flag: 0: Invalid 1: Clear | # 13.3.11 SSPxDMACR (DMA control register) | | 31 | 30 | 29 | 28 7 / 2 | 27 | 26 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | - ( | 1 | 7 - < | | - | - | - | - | | After Reset | Undefined | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | - | - | - | - | - | - | - | | After Reset | Undefined | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | ((-)) | - | | - | - | - | - | - | | After Reset | Undefined | | 7 | (6, ) | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | 3// | ) . | - | - | - | TXDMAE | RXDMAE | | After Reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------| | 31-2 | - | W | Write as "0". | | 1 | TXDMAE | R/W | Transmit FIFO DMA control: 0:Disable 1:Enable | | 0 | RXDMAE | R/W | Transmit FIFO DMA control: 0:Disable 1:Enable | ### 13.4 Overview of SSP This LSI contains the SSP with 1channels. The SSP is an interface that enables serial communications with the peripheral devices with three types of synchronous serial interface functions. The SSP performs serial-parallel conversion of the data received from a peripheral device. The transmit buffers data in the independent 16-bit wide and 8-layered transmit FIFO in the transmit mode, and the receive buffers data in the 16-bit wide and 8-layered receive FIFO in receive mode. Serial data is transmitted via SPDO and received via SPDI. The SSP contains a programmable prescaler to generate the serial output clock SPCLK from the input clock fsys. The operation mode, frame format, and data size of the SSP are programmed in the control registers SSPCR0 and SSPCR1. ## 13.4.1 Clock prescaler When configured as a master, a clock prescaler comprising two free-running serially linked counters is used to provide the serial output clock SPCLK. You can program the clock prescaler through the SSPCPSR register, to divide fsys by a factor of 2 to 254 in steps of two. Because the least significant bit of the SSPCPSR register is not used, division by an odd number is not possible. The output of the prescaler is further divided by a factor of 1 to 256, which is obtained by adding 1 to the value programmed in the SSPCR0 register, to give the master output clock SPCLK. ## 13.4.2 Transmit FIFO This is a 16-bit wide, 8-layered transmit FIFO buffer, which is shared in master and slave modes. ### 13.4.3 Receive FIFO This is a 16-bit wide 8-layered receive FIFO buffer, which is shared in master and slave modes. Page 445 2023/07/21 13.4 Overview of SSP TMPM362F10FG ### 13.4.4 Interrupt generation logic The interrupts, each of which can be masked separately, are generated. | Transmit interrupt | A conditional interrupt to occur when the transmit FIFO has free space more than (including half) of the entire capacity. (Number of valid data items in the transmit FIFO ≤ 4) | |--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Receive interrupt | A conditional interrupt to occur when the receive FIFO has valid data more than half (including half) the entire capacity. (Number of valid data items in the receive FIFO ≥ 4) | | Time-out interrupt | A conditional interrupt to indicate that the data exists in the receive FIFO to the time-out period. | | Overrun interrupt | Conditional interrupts indicating that data is written to receive FIFO when it is full. | Also, The individual masked sources are combined into a single interrupt. When any of the above interrupts is asserted, the combined interrupt INTSSP is asserted. ### a. Transmit interrupt The transmit interrupt is asserted when there are four or fewer valid entries in the transmit FIFO. The transmit interrupt is also generated when the SSP operation is disabled (SSPCR1 <SSE> = "0"). The first transmitted data can be written in the FIFO by using this interrupt. ### b. Receive interrupt The receive interrupt is asserted when there are four or more valid entries in the receive FIFO. #### c. Time-out interrupt The time-out interrupt is asserted when the receive FIFO is not empty and the SSP has remained idle for a fixed 32-bit period (bit rate). This mechanism ensures that the user is aware that data is still present in the receive FIFO and requires servicing. This operation occurs in both master and slave modes. When the time-out interrupt is generated, read all data from the receive FIFO. Even if all the data is not read, data can be transmitted / received if the receive FIFO has a free space and the number of data to be transmitted does not exceed the free space of the receive FIFO. When transfer starts, the timeout interrupt will be cleared. If data is transmitted / received when the receive FIFO has no free space, the time-out interrupt will not be cleared and an overrun interrupt will be generated. Page 447 2023/07/21 13.4 Overview of SSP TMPM362F10FG #### d. Overrun interrupt When the next data (9th data item) is received when the receive FIFO is already full, an overrun interrupt is generated immediately after transfer. The data received after the overrun interrupt is generated (including the 9th data item) will become invalid and be discarded. However, if data is read from the receive FIFO while the 9th data item is being received (before the interrupt is generated), the 9th received data will be written in the receive FIFO as valid data. To perform transfer properly when the overrun interrupt has been generated, write "1" to SSPICR<RORIC> register, and then read all data from the receive FIFO. Even if all the data is not read, data can be transmitted / received if the receive FIFO has free space and the number of data to be transmitted does not exceed the free space of the receive FIFO. Note that if the receive FIFO is not read (provided that the receive FIFO is not empty) within a certain 32-bit period (bit rate) after the overrun interrupt is cleared, a time-out interrupt will be generated. ### 13.4.5 DMA interface The DMA operation of the SSP is controlled through SSPxDMACR register. When there are more data than the watermark level (half of the FIFO) in the receive FIFO, the receive DMA request is asserted. When the amount of data left in the transmit FIFO is less than the watermark level (half of the FIFO), the transmit DMA request is asserted. To clear the transmit/receive DMA request, an input pin for the transmit/receive DMA request clear signals, which are asserted by the DMA controller, is provided. Set the DMA burst length to four words. Note: For the remaining three words, the SSP does not assert the burst request. Each request signal remains asserted until the relevant DMA clear signal is asserted. After the request clear signal is deasserted, a request signal can become active again, depending on the conditions described above. All request signals are deasserted if the SSP is disabled or the DMA enable signal is cleared. The following table shows the trigger points for DMABREQ, for both the transmit and receive FIFOs. | ~ / | | | | | | | | |---------------|----------------|----|--------------------------------------|-------------------------------------------|--|--|--| | | | 1 | Burst length | | | | | | | Watermark leve | el | Transmit (number of empty locations) | Receive (number of fil-<br>led locations) | | | | | $\mathcal{D}$ | 1/2 | > | 4 | 4 | | | | TMPM362F10FG # 13.5 SSP operation ## 13.5.1 Initial setting for SSP Settings for the SSP communication protocol must be made with the SSP disabled. Control registers SSPCR0 and SSPCR1 need to configure this SSP as a master or slave operating under one of the following protocols. In addition, make the settings related to the communication speed in the clock prescale registers SSPCPSR and SSPCR0 <SCR>. This SSP supports the following protocols: - · SPI - · SSI - · Microwire # 13.5.2 Enabling SSP The transfer operation starts when the operation is enabled with the transmitted data written in the transmit FIFO, or when transmitted data is written in the transmit FIFO with the operation enabled. However, if the transmit FIFO contains only four or fewer entries when the operation is enabled, a transmit interrupt will be generated. This interrupt can be used to write the initial data. Note: When the SSP is in the SPI slave mode and the SPFSS pin is not used, be sure to transmit data of one byte or more in the FIFO before enabling the operation. If the operation is enabled with the transmit FIFO empty, the transfer data will not be output correctly. ### 13.5.3 Clock ratios When setting a frequency for fsys, the following conditions must be met. In master mode $$f_{SPCLK}$$ (maximum) $\rightarrow f_{sys}/4$ $$f_{SPCLK}$$ (minimum) $\rightarrow f_{sys}/(254 \times 256)$ · In/slave mode $$f_{SPCLK}$$ (maximum) $\rightarrow f_{sys} / 12$ $$f_{SPCLK}$$ (minimum) $\rightarrow f_{sys}$ /(254×256) Note: The maximum baud-rate in the master mode is equal or less than 16Mbps. Page 449 2023/07/21 13.6 Frame Format TMPM362F10FG # 13.6 Frame Format Each frame format is between 4 and 16 bits wide depending on the size of data programmed, and is transmitted starting from the MSB. · Serial clock (SPCLK) Signals remain "Low" in the SSI and Microwire formats and as inactive in the SPI format while the SSP is in the idle state. In addition, data is output at the set bit rate only during data transmission. Serial frame (SPFSS) In the SPI and Microwire frame formats, signals are set to "Low" active and always asserted to "Low" during frame transmission. In the SSI frame format, signals are asserted only during 1 bit rate before each frame transmission. In this frame format, output data is transmitted at the rising edge of SPCLK and the input data is received at its falling edge. Refer to Section "13.6.1" to "13.6.3" for details of each frame format. ### 13.6.1 SSI frame format In this mode, the SSP is in idle state, SPCLK and SPFSS are forcedly set to "Low", and the transmit data line SPDO becomes Hi-Z. When data is written in the transmit FIFO, the master outputs "High" pulses of 1 SPCLK to the SPFSS line. The transmitted data will be transferred from the transmit FIFO to the transmit serial shift register. Data of 4 to 16 bits will be output from the SPDO pin at the next rising edge of SPCLK. Likewise, the received data will be input starting from the MSB to the SPDI pin at the falling edge of SPCLK. The received data will be transferred from the serial shift register into the receive FIFO at the rising edge of SPCLK after its LSB data is latched. Figure 13-2 SSI frame format (transmission/reception during single transfer) Figure 13-3 SSI frame format (transmission/reception during continuous transfer) - Note 1: When transmission is disable, SPDO terminal doesn't output and is high impedance status. This terminal needs to add suitable pull-up/down resistance to valid the voltage level. - Note 2: SPDI terminal is always input and internal gate is open. In case of transmission signal will be high impedance status, this terminal needs to add suitable pull-up/down resistance to valid the voltage level. Page 451 2023/07/21 13.6 Frame Format TMPM362F10FG ### 13.6.2 SPI frame format The SPI interface has 4 lines. SPFSS is used for slave selection. One of the main features of the SPI format is that the <SPO> and <SPH> bits in the SSPCR0 register can be used to set the SPCLK operation timing. SSPCR0 <SPO> is used to set the level at which SPCLK in idle state is held. SSPCR0 <SPH> is used to select the clock edge at which data is latched. | | SSPCR0 <spo></spo> | SSPCR0 <sph></sph> | |---|--------------------|-------------------------------------| | 0 | "Low" state | Capture data at the 1st clock edge. | | 1 | "High" state | Capture data at the 2nd clock edge. | Figure 13-4 SPI frame format (single transfer, <SPO>="0" & <SPH>="0") Figure 13-5 SPI frame format (continuous transfer, <SPO>="0" & <SPH>="0") Note 1: When transmission is disable, SPDO terminal doesn't output and is high impedance status. This terminal needs to add suitable pull-up/down resistance to valid the voltage level. Note 2: SPDI terminal is always input and internal gate is open. In case of transmission signal will be high impedance status, this terminal needs to add suitable pull-up/down resistance to valid the voltage level. With this setting <SPO>="0", during the idle period: - · The SPCLK signal is set to "Low". - · SPFSS is set to "High". - The transmit data line SPDO is set to "Low". If the SSP is enabled and valid data exists in the transmit FIFO, the SPFSS master signal driven by "Low" notifies of the start of transmission. This enables the slave data in the SPDI input line of the master. When a half of the SPCLK period has passed, valid master data is transferred to the SPDO pin. Both the master data and slave data are now set. When another half of SPCLK has passed, the SPCLK master clock pin becomes "High". After that, the data is captured at the rising edge of the SPCLK signal and transmitted at its falling edge. In the single transfer, the SPFSS line will return to the idle "High" state when all the bits of that data word have been transferred, and then one cycle of SPCLK has passed after the last bit was captured. However, for continuous transfer, the SPFSS signal must be pulsed at HIGH between individual data word transfers. This is because change is not enabled when the slave selection pin freezes data in its peripheral register and the <SPH> bit is logical 0. Therefore, to enable writing of serial peripheral data, the master device must drive the SPFSS pin of the slave device between individual data transfers. When the continuous transfer is completed, the SPFSS pin will return to the idle state when one cycle of SPCLK has passed after the last bit is captured. Page 453 2023/07/21 13.6 Frame Format TMPM362F10FG #### 13.6.3 Microwire frame format The Microwire format uses a special master/slave messaging method, which operates in half-duplex mode. In this mode, when a frame begins, an 8-bit control message is transmitted to the slave. During this transmission, no incoming data is received by the SSP. After the message has been transmitted, the slave decodes it, and after waiting one serial clock after the last bit of the 8-bit control message has been sent, it responds with the requested data. The returned data can be 4 to 16 bits in length, making the total frame length anywhere from 13 to 25 bits. Figure 13-6 Microwire frame format (single transfer) - Note 1: When transmission is disabled, SPDO terminal doesn't output and is high impedance status. This terminal needs to add suitable pull-up/down resistance to fix the voltage level. - Note 2: SPDI terminal is always input and internal gate is open. In case of transmission signal will be high impedance status, this terminal needs to add suitable pull-up/down resistance to fix the voltage level. Though the Microwire format is similar to the SPI format, it uses the master/slave message transmission method for half-duplex communications. Each serial transmission is started by an 8-bit control word, which is sent to the off-chip slave device. During this transmission, the SSP does not receive input data. After the message has been transmitted, the off-chip slave decodes it, and after waiting one serial clock after the last bit of the 8-bit control message has been sent, responds with the requested data. The returned data can be 4 to 16 bits in length, making the total frame length anywhere from 13 to 25 bits. With this configuration, during the idle period: - The SPCLK signal is set to "Low". - SPFSS is set to "High". - The transmit data line SPDO is set to "Low". A transmission is triggered by writing a control byte to the transmit FIFO. The falling edge of SPFSS causes the value stored in the bottom entry of the transmit FIFO to be transferred to the serial shift register for the transmit logic, and the MSB of the 8-bit control frame to be shifted out onto the SPDO pin. SPFSS remains "Low" and the SPDI pin remains tristated during this transmission. The off-chip serial slave device latches each control bit into its serial shifter on the rising edge of each SPCLK. After the last bit is latched by the slave device, the control byte is decoded during a one clock wait-state, and the slave responds by transmitting data back to the SSP. Each bit is driven onto SPDI line on the falling edge of SPCLK. The SSP in turn latches each bit on the rising edge of SPCLK. At the end of the frame, for single transfers, the SPFSS signal is pulled "High" one clock period after the last bit has been latched in the receive serial shifter, which causes the data to be transferred to the receive FIFO. Note: The off-chip slave device can tristate the receive line either on the falling edge of SPCLK after the LSB has been latched by the receive shifter, or when the SPFSS pin goes "High". Figure 13-7 Microwire frame format (continuous transfer) - Note 1: When transmission is disabled, SPDO terminal doesn't output and is high impedance status. This terminal needs to add suitable pull-up/down resistance to fix the voltage level. - Note 2: SPDI terminal is always input and internal gate is open. In case of transmission signal will be high impedance status, this terminal needs to add suitable pull-up/down resistance to fix the voltage level. For continuous transfers, data transmission begins and ends in the same manner as a single transfer. However, the SPFSS line is continuously asserted (held Low) and transmission of data occurs back to back. The control byte of the next frame follows directly after the LSB of the received data from the current frame. Each of the received values is transferred from the receive shifter on the falling edge of SPCLK, after the LSB of the frame has been latched into the SSP. Note: [Example of connection] The SSP does not support dynamic switching between the master and slave in the system. Each sample SSP is configured and connected as either a master or slave. Page 455 2023/07/21 13.6 Frame Format TMPM362F10FG # 14. Serial Bus Interface (I2C/SIO) The TMPM362F10FG contains 5 Serial Bus Interface (I2C/SIO) channels, in which the following two operating modes are included: - I2C bus mode (with multi-master capability) - · Clock-synchronous 8-bit SIO mode In the I2C bus mode, the I2C/SIO is connected to external devices via SCL and SDA. In the clock-synchronous 8-bit SIO mode, the I2C/SIO is connected to external devices via SCK, SI and SO. The following table shows the programming required to put the I2C/SIO in each operating mode. Table 14-1 Port settings for using serial bus interface | channel | Operating mode | pin | Port Function Reg-<br>ister | Port Output Control Register | Port Input Control Register | Port Open Drain<br>Output Control<br>Register | |---------|-----------------|-----------------------------------|-----------------------------|-------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------| | | I2C<br>bus mode | SCL0 :PL1<br>SDA0 :PL0 | PLFR1[1:0] = 11 | PLCR[1:0] = 11 | PLIE[1:0] = 11 | PLOD[1:0] = 11 | | SBI0 | SIO mode | SCK0 :PL2<br>SI0 :PL1<br>SO0 :PL0 | PLFR1[2:0] = 111 | PLCR[2:0] = 101(SCK0 output) PLCR[2:0] = 001(SCK0 input) | PLIE[2:0] = 010(SCK0 output)<br>PLIE[2:0] = 110(SCK0 input) | PLOD[2:0] = xxx | | | I2C<br>bus mode | SCL1 :PG1<br>SDA1 :PG0 | PGFR1[1:0] = 11 | PGCR[1:0] = 11 | PGIE[1:0] = 11 | PGOD[1:0] = 11 | | SBI1 | SIO mode | SCK1 :PG2<br>SI1 :PG1<br>SO1 :PG0 | PGFR1[2:0] = 111 | PGCR[2:0] = 101(SCK1 output)<br>PGCR[2:0] = 001(SCK1 input) | PGIE[2:0] = 010(SCK1 output)<br>PGIE[2:0] = 110(SCK1 input) | PGOD[2:0] = xxx | | | I2C<br>bus mode | SCL2 :PG5<br>SDA2 :PG4 | PGFR1[5:4] = 11 | PGCR[5:4] = 11 | PGIE[5:4] = 11 | PGOD[5:4] = 11 | | SBI2 | SIO mode | SCK2 :PG6<br>SI2 :PG5<br>SO2 :PG4 | PGFR1[6:4] = 111 | PGCR[6:4] = 101(SCK2 output)<br>PGCR[6:4] = 001(SCK2 input) | PGIE[6:4] = 010(SCK2 output)<br>PGIE[6:4] = 110(SCK2 input) | PGOD[6:4] = xxx | | | I2C<br>bus mode | SCL3 :PH1<br>SDA3 :PH0 | PHFR1[1:0] = 11 | PHCR[1:0] = 11 | PHIE[1:0] = 11 | PHOD[1:0] = 11 | | SBI3 | SIO mode < | SCK3 :PH2<br>SI3 :PH1<br>SO3 :PH0 | PHFR1[2:0] = 111 | PHCR[2:0] = 101(SCK3 output)<br>PHCR[2:0] = 001(SCK3 input) | PHIE[2:0] = 010(SCK3 output)<br>PHIE[2:0] = 110(SCK3 input) | PHOD[2:0] = xxx | | | I2C<br>bus mode | SCL4 :PH5<br>SDA4 :PH4 | PHFR1[5:4] = 11 | PHCR[5:4] = 11 | PHIE[5:4] = 11 | PHOD[5:4] = 11 | | SBI4 | SIO mode | SCK4 :PH6<br>SI4 :PH5<br>SO4 :PH4 | PHFR1[6:4] = 111 | PHCR[6:4] = 101(SCK4 output)<br>PHCR[6:4] = 001(SCK4 input) | PHIE[6:4] = 010(SCK4 output)<br>PHIE[6:4] = 110(SCK4 input) | PHOD[6:4] = xxx | Note:x: Don't care Page 457 2023/07/21 4.1 Configuration TMPM362F10FG # 14.1 Configuration The configuration is shown in Figure 14-1. # 14.2 Register The following registers control the serial bus interface and provide its status information for monitoring. The register below performs different functions depending on the mode. For details, refer to "14.4 Control Registers in the I2C Bus Mode" and "14.7 Control register of SIO mode". # 14.2.1 Registers for each channel The tables below show the registers and register addresses for each channel. | Channel x | Base Address | | |-----------|--------------|--| | Channel0 | 0x400E_0000 | | | Channel1 | 0x400E_0100 | | | Channel2 | 0x400E_0200 | | | Channel3 | 0x400E_0300 | | | Channel4 | 0x400E_0400 | | | | Register name(x=0,1,2,3,4) | | Address(Base+) | |--------------------------|----------------------------|-------------------|----------------| | Control register 0 | | SBIxCR0 | 0x0000 | | Control register 1 | | SBIxCR1 | 0x0004 | | Data buffer register | | SBIxDBR | 0x0008 | | I2C bus address register | | SBIxI2CAR | 0x000C | | Control register 2 | | SBIxCR2 (writing) | 0::0040 | | Status register | | SBIxSR (reading) | 0x0010 | | Baud rate register 0 | | SBIxBR0 | 0x0014 | 14.3 I2C Bus Mode Data Format TMPM362F10FG ## 14.3 I2C Bus Mode Data Format Figure 14-2 shows the data formats used in the I2C bus mode. # 14.4 Control Registers in the I2C Bus Mode The following registers control the serial bus interface in the I2C bus mode and provide its status information for monitoring. # 14.4.1 SBIxCR0(Control register 0) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|----|----|------|------|--------|------|----| | bit symbol | - | - | - | - | - | (-0) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | ) 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | (( -)> | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | | - | Q-\\ | - | | After reset | 0 | 0 | 0 | 0 | (0/1 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 75/1 | 0 | | bit symbol | SBIEN | - | - | - (( | 1/- | - ( | 1 50 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 9 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7 | SBIEN | R/W | Serial bus interface operation 0:Disable 1:Enable To use the serial bus interface, enable this bit first. For the first time in case of setting to enable, the relevant SBI registers can be read or written. Since all clocks except SBIxCR0 stop if this bit is disabled, power consumption can be reduced by disabling this bit. If this bit is disabled after it's been enabled once, the settings of each register are retained. | | 6-0 | - | R | Read as 0. | Note: To use the serial bus interface, enable this bit first. ### 14.4 Control Registers in the I2C Bus Mode # 14.4.2 SBIxCR1(Control register 1) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|-----|-----|--------------|------|------------------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (-0) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | ВС | | ACK | | SCK2 | SCK1 | SCK0 /<br>SWRMON | | After reset | 0 | 0 | 0 | 0 | | 0 | 0 | 1(Note3) | | Bit | Bit Symbol | Туре | Function (V) | |------|------------|------|-----------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7-5 | BC[2:0] | R/W | Select the number of bits per transfer (Note 1) | | | | | When <ack> = 0 When <ack> = 1</ack></ack> | | | | | <bc> Number of Data Number of Data</bc> | | | | | clock cycles length clock cycles length | | | | | 000 8 8 9 8 | | | | | 001 1 1 2 1 | | | | | 010 2 2 3 2 | | | | | 014 3 3 4 3 | | | | | 100 4 4 5 4 | | | | | 101 5 5 6 5 | | | | | 110 6 6 7 6 | | | < | | 111 7 7 8 7 | | 4 | ACK | R/W | Master mode | | | | | 0: Acknowledgement clock pulse is not generated. | | | | | 1: Acknowledgement clock pulse is generated. | | | 7/ | N | Slave mode | | | | | O: Acknowledgement clock pulse is not counted. 1: Acknowledgement clock pulse is counted. | | 3 | | R | Read as 1. | | 2-1 | CCV(2).41 | R/W | Select internal SCL output clock frequency (Note 2). | | 0 | SCK[2:1] | ( | | | 0 | SCK[0] | W | | | | | | 001 | | | | | 011 | | | | | 101 | | | | | 100 11 = 9 110 kHz Clock gear : fc/1 101 n = 10 58 kHz | | | | | 110 | | | | | | | | | | 111 reserved | | | SWRMON | R | On reading <swrmon>: Software reset status monitor</swrmon> | | | | | 0:Software reset operation is in progress. | | | | | 1:Software reset operation is not in progress. | | | | | - | - Note 1: Clear <BC[2:0]> to "000" before switching the operation mode to the SIO mode. - Note 2: For details on the SCL line clock frequency, refer to "14.5.1 Serial Clock". - Note 3: After a reset, the <SCK[0]/SWRMON> bit is read as "1". However, if the SIO mode is selected at the SBIxCR2 register, the initial value of the <SCK[0]> bit is "0". - Note 4: The initial value for selecting a frequency is <SCK[2:0]>=000 and is independent of the read initial value. - Note 5: When <BC[2:0]>="001" and <ACK>="0" in master mode, SCL line may be fixed to "L" by falling edge of SCL line after generation of STOP condition and the other master devices can not use the bus. In the case of bus which is connected with several master devices, the bumber of bits per transfer should be set equal or more than 2 before generation of STOP condition. Page 463 2023/07/21 # 14.4.3 SBIxCR2(Control register 2) This register serves as SBIxSR register by reading it. | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|----|-----|-----------|--------|-------|-----| | bit symbol | - | - | - | - | - | - 2 | 1 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | ((///< | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )° | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | \d/ ( | > 0 | | bit symbol | MST | TRX | ВВ | PIN | SE | BIM | SW | RST | | After reset | 0 | 0 | 0 | 1 | ( ( 0 ) ) | 0 > | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7 | MST | W | Select master/slave | | | | | 0: Slave mode | | | | | 1: Master mode | | 6 | TRX | W | Select transmit/ receive | | | | | 0: Receive | | | | | 1: Transmit | | 5 | ВВ | W | Start/stop condition generation | | | | | 0: Stop condition generated | | | | | 1: Start condition generated | | 4 | PIN | W | Clear INTSBIx interrupt request | | | | | 0: - | | | | | 1: Clear interrupt request | | 3-2 | SBIM[1:0] | W | Select serial bus interface operating mode (Note) | | | < | | 00: Port mode (Disables a serial bus interface output) | | | | | 01: SIO mode | | | | | 10: J2C bus mode | | | | | 11: Reserved | | 1-0 | SWRST[1:0] | W | Software reset generation | | | | 5 | Write "10" followed by "01" to generate a reset. | | | | | When writing, set <sbim[1:0]> to "10"; I2Cbus mode.</sbim[1:0]> | Note: Make sure that modes are not changed during a communication session. Ensure that the bus is free before switching the operating mode to the port mode. Ensure that the port is at the "High" level before switching the operating mode from the port mode to the I2C bus or clock-synchronous 8-bit SIO mode. # 14.4.4 SBIxSR (Status Register) This register serves as SBIxCR2 by writing to it. | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----|-----|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | bit symbol | - | - | - | - | - | | | - | | After reset | 0 | 0 | 0 | 0 | 0 ^ | (0/// | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11( | 10 | 9 | 8 | | bit symbol | - | - | - | - | - </td <td>_</td> <td>\\ \langle \la</td> <td></td> | _ | \\ \langle \la | | | After reset | 0 | 0 | 0 | 0 | | 0 | 9 | 0 | | | 7 | 6 | 5 | 4 | ( (3 ) ) | 2 | $(\bigcirc_1)$ | 0 | | bit symbol | MST | TRX | ВВ | PIN | AL | AAS | ADO | LRB | | After reset | 0 | 0 | 0 | 1( | 0 | 0 | 0 | 0 | | | | | , , , , , , , , , , , , , , , , , , , | |------|------------|------|----------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-8 | - | R | Read as 0. | | 7 | MST | R | Master/slave selection monitor 0: Slave mode 1: Master mode | | 6 | TRX | R | Transmit/receive selection monitor 0: Receive 1: Transmit | | 5 | ВВ | R | I2C bus state monitor 0: Free 1: Busy | | 4 | PIN | R | INTSBlx interrupt request monitor 0:Interrupt request generated 1: Interrupt request cleared | | 3 | AL 🔷 | R | Arbitration lost detection 0: - 1:Detected | | 2 | AAS | R) | Slave address match detection 0: - 1: Detected (This bit is set when the general call is detected as well.) | | 1 | ADO | R ( | General call detection 0: - 1:Detected | | 0 | LRB | R | Last received bit monitor 0:Last received bit "0" 1:Last received bit "1" | Page 465 2023/07/21 #### 14.4 Control Registers in the I2C Bus Mode # 14.4.5 SBIxBR0(Serial bus interface baud rate register 0) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|-------|----|----|----------|--------------|------|----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | I2SBI | - | - | | <del>-</del> | 2-// | - | | After reset | 1 | 0 | 1 | 1 | ((/1/ \) | 1_ | | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------| | 31-8 | - | R | Read as 0. | | 7 | - | R | Read as 1. | | 6 | I2SBI | R/W | Operation at the IDLE mode 0: Stop 1: Operate | | 5-1 | - | R | Read as 1. | | 0 | - | R/W | Be sure to write "0". | # 14.4.6 SBIxDBR (Serial bus interface data buffer register) | | 31 | /30 | 7 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----------------------------------------|------------|----------|----|----|----|----|----| | bit symbol | - | | | | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | ⟨23√⟩ | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 5 | $\wedge$ | - | - | - | - | - | | After reset | 0 | ·<br>) | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | $\Diamond$ | | 1 | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6/ | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | | D | В | | | _ | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------------------------------|------------------------------| | 31-8 | - | R | Read as 0. | | 7-0 | DB[7:0] | R (Receive)/<br>W (Transmit) | Receive data / Transmit data | Note 1: The transmission data must be written in to the register from the MSB (bit 7). The received data is stored in the LSB. Note 2: Since SBIxBDR has independent buffers for writing and reading, a written data cannot be read. Thus, read-modify-write instructions, such as bit manipulation, cannot be used. # 14.4.7 SBIxI2CAR (I2Cbus address register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|----|-------|-----|-----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 1-3 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | - | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | | SA | | | | ALS | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 70( | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7-1 | SA[6:0] | R/W | Set the slave address when the SBI acts as a slave device. | | 0 | ALS | R/W | Specify address recognition mode. 0: Recognize its slave address. 1: Do not recognize its slave address (free-data format). | Note 1: Please set the bit 0 <ALS> of I2C bus address register SBIxI2CAR to "0", except when you use a free data format. It operates as a free data format when setting it to "1". Selecting the master fixes to transmission. Selecting the slave fixes to reception. Note 2: Do not set SBIxI2CAR to "0x00" in slave mode. (If SBIxI2CAR is set to "0x00", it's recognized that the slave address matches the START byte ("0x01") of the I2C standard received in slave mode.) Page 467 2023/07/21 14.5 Control in the I2C Bus Mode TMPM362F10FG ### 14.5 Control in the I2C Bus Mode ### 14.5.1 Serial Clock #### 14.5.1.1 Clock source SBIxCR1<SCK[2:0]> specifies the maximum frequency of the serial clock to be output from the SCL pin in the master mode. Figure 14-3 Clock source Note: The maximum speeds in the standard and high-speed modes are specified to 100kHz and 400kHz respectively following the communications standards. Notice that the internal SCL clock frequency is determined by the fsys used and the calculation formula shown above. ### 14.5.1.2 Clock Synchronization The I2C bus is driven by using the wired-AND connection due to its pin structure. The first master that pulls its clock line to the "Low" level overrides other masters producing the "High" level on their clock lines. This must be detected and responded by the masters producing the "High" level. Clock synchronization assures correct data transfer on a bus that has two or more master. For example, the clock synchronization procedure for a bus with two masters is shown below. Figure 14-4 Example of Clock Synchronization At the point a, Master A pulls its internal SCL output to the "Low" level, bringing the SCL bus line to the "Low" level. Master B detects this transition, resets its "High" level period counter, and pulls its internal SCL output level to the "Low" level. Master A completes counting of its "Low" level period at the point b, and brings its internal SCL output to the "High" level. However, Master B still keeps the SCL bus line at the "Low" level, and Master A stops counting of its "High" level period counting. After Master A detects that Master B brings its internal SCL output to the "High" level and brings the SCL bus line to the "High" level at the point c, it starts counting of its "High" level period. After that Master finishes counting the "High" level period, the Master pulls the SCL pin to "Low" and the SCL bus line becomes "Low". This way, the clock on the bus is determined by the master with the shortest "High" level period and the master with the longest "Low" level period among those connected to the bus. # 14.5.2 Setting the Acknowledgement Mode Setting SBIxCR1<ACK> to "1" selects the acknowledge mode. When operating as a master, the SBI adds one clock for acknowledgement signal. In slave mode, the clock for acknowledgement signals is counted. In transmitter mode, the SBI releases the SDAx pin during clock cycle to receive acknowledgement signals from the receiver. In receiver mode, the SBI pulls the SDAx pin to the "Low" level during the clock cycle and generates acknowledgement signals. Also in slave mode, if a general-call address is received, the SBI pulls the SDAx pin to the "Low" level during the clock cycle and generates acknowledgement signals. By setting <ACK> to "0", the non-acknowledgment mode is activated. When operating as a master, the SBI does not generate clock for acknowledgement signals. In slave mode, the clock for acknowledgement signals is counted. # 14.5.3 Setting the Number of Bits per Transfer SBIxCR1<BC[2:0]> specifies the number of bits of the next data to be transmitted or received. Under the start condition, <BC[2:0]> is set to "000", causing a slave address and the direction bit to be transferred in a packet of eight bits. At other times, <BC[2:0]> keeps a previously programmed value. ### 14.5.4 Slave Addressing and Address Recognition Mode Setting "0" to SBIxI2CAR<ALS> and a slave address in SBIxI2CAR<SA[6:0]> sets addressing format, and then the SBI recognizes a slave address transmitted by the master device and receives data in the addressing format. If <ALS> is set to "1", the SBI does not recognize a slave address and receives data in the free data format. In the case of free data format, a slave address and a direction bit are not recognized; they are recognized as data immediately after generation of the start condition. ### 14.5.5 Operating mode The setting of SBIxCR2<SBIM[1:0]> controls the operating mode. To operate in I2C mode, ensure that the serial bus interface pins are at "High" level before setting <SBIM[1:0]> to "10". Also, ensure that the bus is free before switching the operating mode to the port mode. Page 469 2023/07/21 ## 14.5.6 Configuring the SBI as a Transmitter or a Receiver Setting SBIxCR2<TRX> to "1" configures the SBI as a transmitter. Setting <TRX> to "0" configures the SBI as a receiver. At the slave mode: - when data is transmitted in the addressing format. - when the received slave address matches the value specified at SBIxI2CAR. - · when a general-call address is received; i.e., the eight bits following the start condition are all zeros. If the value of the direction bit $(R/\overline{W})$ is "1", $\langle TRX \rangle$ is set to "1" by the hardware. If the bit is "0", $\langle TRX \rangle$ is set to "0". As a master device, the SBI receives acknowledgement from a slave device. If the direction bit of "1" is transmitted, <TRX> is set to "0" by the hardware. If the direction bit is "0", <TRX> changes to "1". If the SBI does not receive acknowledgement, <TRX> retains the previous value. <TRX> is cleared to "0" by the hardware when it detects the stop condition on the bus or the arbitration lost. If SBI is used in free data format, <TRX> is not changed by the hardware. # 14.5.7 Configuring the SBI as a Master or a Slave Setting SBIxCR2<MST> to "1" configures the SBI to operate as a master device. Setting <MST> to "0" configures the SBI as a slave device. <MST> is cleared to "0" by the hardware when it detects the stop condition on the bus or the arbitration lost. # 14.5.8 Generating Start and Stop Conditions When SBIxSR<BB> is "0", writing "1" to SBIxCR2<MST, TRX, BB, PIN> causes the SBI to start a sequence for generating the start condition and to output the slave address and the direction bit prospectively written in/the data buffer register. <ACK> must be set to "1" in advance. Figure 14-5 Generating the Start Condition and a Slave Address When <BB> is "1", writing "1" to <MST, TRX, PIN> and "0" to <BB> causes the SBI to start a sequence for generating the stop condition on the bus. The contents of <MST, TRX, BB, PIN> should not be altered until the stop condition appears on the bus. If SCL bus line is pulled "Low" by other devices when the stop condition is generated, the stop condition is generated after the SCL line is released. Figure 14-6 Generating the Stop Condition SBIxSR<BB> can be read to check the bus state. <BB> is set to "1" when the start condition is detected on the bus (the bus is busy), and cleared to "0" when the stop condition is detected (the bus is free). # 14.5.9 Interrupt Service Request and Release In master mode, a serial bus interface request (INTSBIx) is generated when the transfer of the number of clock cycles set by <BC> and <ACK> is completed. In slave mode, INTSBIx is generated under the following conditions. - After output of the acknowledge signal which is generated when the received slave address matches the slave address set to SBIx12CAR<SA[6:0]>. - · After the acknowledge signal is generated when a general-call address is received. - When the slave address matches or a data transfer is completed after receiving a general-call address. In the address recognition mode (<ALS> = "0"), INTSBIx is generated when the received slave address matches the values specified at SBIxI2CAR or when a general-call (eight bits data following the start condition is all "0") is received. When an interrupt request (INTSBIx) is generated, SBIxCR2<PIN> is cleared to "0". While <PIN> is cleared to "0", the SBI pulls the SCL line to the "Low" level. <PIN> is set to "1" when data is written to or read from SBIxDBR. It takes a period of $t_{LOW}$ for the SCL line to be released after <PIN> is set to "1". When the program writes "1" to <PIN>, it is set to "1". However, writing "0" does not clear this bit to "0". Note: When arbitration is lost in master mode, <PIN> is not cleared to "0" if the slave address does not match (INTSBIx is generated). ### 14.5.10 Arbitration Lost Detection Monitor The I2C bus has the multi-master capability (there are two or more masters on a bus), and requires the bus arbitration procedure to ensure correct data transfer. A master that attempts to generate the start condition while the bus is busy loses bus arbitration, with no start condition occurring on the SDA and SCL lines. The I2C-bus arbitration takes place on the SDA line. The arbitration procedure for two masters on a bus is shown below. 14.5 Control in the I2C Bus Mode Up until the point a, Master A and Master B output the same data. At the point a, Master A outputs the "Low" level and Master B outputs the "High" level. Then Master A pulls the SDA bus line to the "Low" level because the line has the wired-AND connection. When the SCL line goes high at the point b, the slave device reads the SDA line data, i.e., data transmitted by Master A. At this time, data transmitted by Master B becomes invalid. This condition of Master B is called "Arbitration Lost". Master B releases its SDA pin, so that it does not affect the data transfer initiated by another master. If two or more masters have transmitted exactly the same first data word, the arbitration procedure continues with the second data word. Figure 14-7 Lost Arbitration A master compares the SDA bus line level and the internal SDA output level at the rising of the SCL line. If there is a difference between these two values, Arbitration Lost occurs and SBIxSR<AL> is set to "1". When <AL> is set to "1", SBIxSR<MST, TRX> are cleared to "0", causing the SBI to operate as a slave receiver. Therefore, the serial bus interface circuit stops the clock output during data transfer after <AL> is set to "1". <AL> is cleared to "0" when data is written to or read from SBIxDBR or data is written to SBIxCR2. Figure 14-8 Example of Master B Lost Arbitration (D7A = D7B, D6A = D6B) ### 14.5.11 Slave Address Match Detection Monitor When the SBI operates as a slave device in the address recognition mode (SBIxI2CAR<ALS>="0"), SBIxSR<AAS> is set to "1" on receiving the general-call address or the slave address that matches the value specified at SBIxI2CAR. When <ALS> is "1", <AAS> is set to "1" when the first data word has been received. <AAS> is cleared to "0" when data is written to or read from SBIxDBR. ### 14.5.12 General-call Detection Monitor When the SBI operates as a slave device, SBIxSR<ADO> is set to "1" when it receives the general-call address; i.e., the eight bits following the start condition are all zeros. <ADO> is cleared to "0" when the start or stop condition is detected on the bus. ### 14.5.13 Last Received Bit Monitor SBIxSR<LRB> is set to the SDA line value that was read at the rising of the SCL line. In the acknowledgment mode, reading SBIxSR<LRB> immediately after generation of the INTSBIx interrupt request causes ACK signal to be read. ### 14.5.14 Data Buffer Register (SBIxDBR) Reading or writing SBIxDBR initiates reading received data or writing transmitted data. When the SBI is acting as a master, setting a slave address and a direction bit to this register generates the start condition. 14.5 Control in the I2C Bus Mode TMPM362F10FG # 14.5.15 Baud Rate Register (SBIxBR0) The SBIxBR0<I2SBI> register determines if the SBI operates or not when it enters the IDLE mode. This register must be programmed before executing an instruction to switch to the standby mode. ### 14.5.16 Software Reset If the serial bus interface circuit locks up due to external noise, it can be initialized by using a software reset. Writing "10" followed by "01" to SBIxCR2<SWRST[1:0]> generates a reset signal that initializes the serial bus interface circuit. When writing, set <SBIM[1:0]> to "10"; 12Cbus mode. After a reset, all control registers and status flags are initialized to their reset values. When the serial bus interface is initialized, <SWRST> is automatically cleared to "0". Note: A software reset causes the SBI operating mode to switch from the I2C mode to the port mode. TMPM362F10FG ### 14.6 Data Transfer Procedure in the I2C Bus Model2C ### 14.6.1 Device Initialization First, program SBIxCR1<ACK, SCK[2:0]>. Writing "000" to SBIxCR1<BC[2:0]> at the time. Next, program SBIxI2CAR by specifying a slave address at <SA[6:0]> and an address recognition mode at <ALS>. (<ALS> must be cleared to "0" when using the addressing format). To configure the Serial Bus Interface as a slave receiver, ensure that the serial bus interface pin is at "High" first. Then write "0" to SBIxCR2<MST, TRX, BB>, "1" to <PIN>, "10" to <SBIM[1:0]> and "0" to the bit 1 and 0. Note: Initialization of the serial bus interface circuit must be completed within a period that any device does not generate start condition after all devices connected to the bus were initialized. If this rule is not followed, data may not be received correctly because other devices may start transfer before the initialization of the serial bus interface circuit is completed. | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------|--------------|---|---|---|---|---|---|---|---|------------------------------------------------------------| | SBIxCR1 | $\leftarrow$ | 0 | 0 | 0 | Χ | 0 | Χ | Χ | Χ | Specifies ACK and SCL clock. | | SBIxI2CAR | ← | Χ | Χ | Χ | Χ | Χ | Χ | Χ | Χ | Specifies a slave address and an address recognition mode. | | SBIxCR2 | $\leftarrow$ | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Configures the SBI as a slave receiver. | Note:X; Don't care ## 14.6.2 Generating the Start Condition and a Slave Address #### 14.6.2.1 Master mode In the master mode, the following steps are required to generate the start condition and a slave address. First, ensure that the bus is free (<BB> = "0"). Then, write "1" to SBIxCR1<ACK> to select the acknowledgment mode. Write to SBIxDBR a slave address and a direction bit to be transmitted. When <BB> = "0", writing "1111" to SBIxCR2<MST, TRX, BB, PIN> generates the start condition on the bus. Following the start condition, the SBI generates nine clocks from the SCL pin. The SBI outputs the slave address and the direction bit specified at SBIxDBR with the first eight clocks, and releases the SDA line in the ninth clock to receive an acknowledgment signal from the slave device. The INTSBIx interrupt request is generated on the falling of the ninth clock, and <PIN> is cleared to "0". In the master mode, the SBI holds the SCL line at the "Low" level while <PIN> is = "0".<TRX> changes its value according to the transmitted direction bit at generation of the INTSBIx interrupt request, provided that an acknowledgment signal has been returned from the slave device. Note:To output salve address, check with software that the bus is free before writing to SBIxDBR. If this rule is not followed, data being output on the bus may get ruined. Page 475 2023/07/21 ### Settings in main routine #### 14.6.2.2 Slave mode In the slave mode, the SBI receives the start condition and a slave address. After receiving the start condition from the master device, the SBI receives a slave address and a direction bit from the master device during the first eight clocks on the SCL line. If the received address matches its slave address specified at SBIxI2CAR or is equal to the general-call address, the SBI pulls the SDA line to the "Low" level during the ninth clock and outputs an acknowledgment signal. The INTSBIx interrupt request is generated on the falling of the ninth clock, and <PIN> is cleared to "0". In the slave mode, the SBI holds the SCL line at the "Low" level while <PIN> is "0". Figure 14-9 Generation of the Start Condition and a Slave Address # 14.6.3 Transferring a Data Word At the end of a data word transfer, the INTSBIx interrupt is generated to test <MST> to determine whether the SBI is in the master or slave mode. ### 14.6.3.1 Master mode (<MST> = "1") Test <TRX> to determine whether the SBI is configured as a transmitter or a receiver. (1) Transmitter mode (<TRX> = "1") Test <LRB>. If <LRB> is "1", that means the receiver requires no further data. The master then generates the stop condition as described later to stop transmission. If <LRB> is "0", that means the receiver requires further data. If the next data to be transmitted has eight bits, the data is written into SBIxDBR. If the data has different length, <BC[2:0]> and <ACK> are programmed and the transmit data is written into SBIxDBR. Writing the data makes <PIN> to "1", causing the SCL pin to generate a serial clock for transferring a next data word, and the SDA pin to transfer the data word. After the transfer is completed, the INTSBIx interrupt request is generated, <PIN> is cleared to "0", and the SCL pin is pulled to the "Low" level. To transmit more data words, test <LRB> again and repeat the above procedure. ### INTSBIx interrupt if MST = 0 Then go to the slave-mode processing. if TRX = 0 Then go to the receiver-mode processing if LRB = 0 Then go to processing for generating the stop condition. SBIxCR1 $\leftarrow$ X X X X 0 X X X SBIXDBR $\leftarrow$ X X X X End of interrupt processing. Specifies the number of bits to be transmitted and specify whether ACK is required. Writes the transmit data. Note:X; Don't care Page 477 2023/07/21 Figure 14-10 <BC[2:0]>= "000", <ACK>= "1" (Transmitter Mode) ### (2) Receiver mode (<TRX> = "0") If the next data to be transmitted has eight bits, the transmit data is written into SBIxDBR. If the data has different length, <BC[2:0]> and <ACK> are programmed and the received data is read from SBIxDBR to release the SCL line. (The data read immediately after transmission of a slave address is undefined.)On reading the data, <PIN> is set to "1", and the serial clock is output to the SCL pin to transfer the next data word. In the last bit, when the acknowledgment signal becomes the "Low" level, "0" is output to the SDA pin. After that, the INTSBIx interrupt request is generated, and <PIN> is cleared to "0", pulling the SCL pin to the "Low" level Each time the received data is read from SBIxDBR, one-word transfer clock and an acknowledgement signal are output. Figure 14-11 <BC[2:0]>= "000",<ACK>= "1" (Receiver Mode) To terminate the data transmission from the transmitter, <ACK> must be cleared to "0" immediately before reading the data word second to last. This disables generation of an acknowledgment clock for the last data word. When the transfer is completed, an interrupt request is generated. After the interrupt processing, <BC[2:0]> must be set to "001" and the data must be read so that a clock is generated for 1-bit transfer. At this time, the master receiver holds the SDA bus line at the "High" level, which signals the end of transfer to the transmitter as an acknowledgment signal. In the interrupt processing for terminating the reception of 1-bit data, the stop condition is generated to terminate the data transfer. Figure 14-12 Terminating Data Transmission in the Master Receiver Mode Example: When receiving N data word INTSBIx interrupt (after data transmission) INTSBIx interrupt (first to (N-2)th data reception) INTSBIx interrupt ((N-1)th data reception) INTSBIx interrupt (Nth data reception) INTSBIx interrupt (after completing data reception) Processing to generate the stop condition. Terminates the data transmission. End of interrupt Note: X; Don't care # 14.6.3.2 Slave mode (<MST> = "0") In the slave mode, the SBI generates the INTSBIx interrupt request on four occasions: - 1) when the SBI has received any slave address from the master. - 2) when the SBI has received a general-call address. - 3) when the received slave address matches its address. - 4) when a data transfer has been completed in response to a general-call. Also, if the SBI detects Arbitration Lost in the master mode, it switches to the slave mode. Upon the completion of data word transfer in which Arbitration Lost is detected, the INTSBIx interrupt request is generated, <PIN> is cleared to "0", and the SCL pin is pulled to the "Low" level. When data is written to or read from SBIxDBR or when <PIN> is set to "1", the SCLx pin is released after a period of t<sub>LOW</sub>. In the slave mode, the normal slave mode processing or the processing as a result of Arbitration Lost is carried out. SBIxSR<AL>, <TRX>, <AAS> and <ADO> are tested to determine the processing required. "Table 14-2 Processing in Slave Mode" shows the slave mode states and required processing. Example: When the received slave address matches the SBI's own address and the direction bit is "1" in the slave receiver mode. #### INTSBIx interrupt if TRX = 0 Then go to other processing. if AL = 0 Then go to other processing if AAS = 0 Then go to other processing. Sets the number of bits to be transmitted. Sets the transmit data. Note:X; Don't care Table 14-2 Processing in Slave Mode | <trx></trx> | <al></al> | <aas></aas> | <ado></ado> | State | Processing | | | |-------------|-----------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | 1 | 1 | 0 | Arbitration Lost is detected while the slave address was being transmitted and the SBI received a slave address with the direction bit "1" transmitted by another master. | Set the number of bits in a data word to <bc[2:0]></bc[2:0]> | | | | 1 | | 1 | 0 | In the slave receiver mode, the SBI received a slave address with the direction bit "1" transmitted by the master. | and write the transmit data into SBIxDBR. | | | | | 0 0 | | 0 | In the slave transmitter mode, the SBI has completed a transmission of one data word. | Test LRB. If it has been set to "1", that means the receiver does not require further data. Set <pin> to 1 and reset <trx> to 0 to release the bus. If <lrb> has been reset to "0", that means the receiver requires further data. Set the number of bits in the data word to <bc[2:0]> and write the transmit data to the SBIxDBR.</bc[2:0]></lrb></trx></pin> | | | | | 1 | 1 | 1/0 | Arbitration Lost is detected while a slave address is being transmitted, and the SBI receives either a slave address with the direction bit "0" or a general-call address transmitted by another master. | | | | | 0 | | 0 | 0 | Arbitration Lost is detected while a slave address or a data word is being transmitted, and the transfer is terminated. | Read the SBIxDBR (a dummy read) to set <pin> to 1, or write "1" to <pin>.</pin></pin> | | | | | 0 | 1 | 1/0 | In the slave receiver mode, the SBI received either a slave address with the direction bit "0" or a general-call address transmitted by the master. | | | | | | | 0 | 1/0 | In the slave receiver mode, the SBI has completed a reception of a data word. | Set the number of bits in the data word to <bc [2:0]=""> and read the received data from SBIxDBR.</bc> | | | ### 14.6.4 Generating the Stop Condition When SBIxSR<BB> is "1", writing "1" to SBIxCR2<MST, TRX, PIN> and "0" to <BB> causes the SBI to start a sequence for generating the stop condition on the bus. Do not alter the contents of <MST, TRX, BB, PIN> until the stop condition appears on the bus. If another device is holding down the SCL bus line, the SBI waits until the SCL line is released. After that, the SDA pin goes "High", causing the stop condition to be generated. Figure 14-13 Generating the Stop Condition ### 14.6.5 Restart Procedure Restart is used when a master device changes the data transfer direction without terminating the transfer to a slave device. The procedure of generating a restart in the master mode is described below. First, write SBIxCR2<MST, TRX, BB> to "0" and write "1" to <PIN> to release the bus. At this time, the SDAx pin is held at the "High" level and the SCLx pin is released. Because no stop condition is generated on the bus, other devices recognize that the bus is busy. Then, test SBIxSR<BB> and wait until it becomes "0" to ensure that the SCLx pin is released. Next, test <LRB> and wait until it becomes "1" to ensure that no other device is pulling the SCLx bus line to the "Low" level. Once the bus is determined to be free by following the above procedures, follow the procedures described in "14.6.2 Generating the Start Condition and a Slave Address" to generate the start condition. To satisfy the setup time of restart, at least $4.7\mu s$ wait period (in the standard mode) must be created by the software after the bus is determined to be free. Note 1: Do not write <MST> to "0" when it is "0". (Restart cannot be initiated.) Note 2: When the master device is acting as a receiver, data transmission from the slave device which serves as a transmitter must be completed before generating a restart. To complete data transfer, slave device must receive a "High" level acknowledge signal. For this reason, <LBR> before generating a restart becomes "1", the rising edge of the SCL line is not detected even <LBR>= "1" is confirmed by following the restart procedure. To check the status of the SCL line, read the port. Figure 14-14 Timing Chart of Generating a Restart #### 14.7 Control register of SIO mode # 14.7 Control register of SIO mode The following registers control the serial bus interface in the clock-synchronous 8-bit SIO mode and provide its status information for monitoring. ## 14.7.1 SBIxCR0(control register 0) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|----|----|------|--------------------|----------|-----|----| | bit symbol | - | - | - | - | - < | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ( | (-) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 9 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | | <u> </u> | | - | | After reset | 0 | 0 | 0 | 0 | (V <sub>0</sub> )) | 0 🔷 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 40/ | 0 | | bit symbol | SBIEN | - | - | - 6 | | -6 | | - | | After reset | 0 | 0 | 0 | ol ( | 0 | | ) 0 | 0 | | | _ | | | |------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function (// ) | | 31-8 | - | R | Read as 0. | | 7 | SBIEN | R/W | Serial bus interface operation. 0:Disable 1: Enable Enable this bit before using the serial bus interface. If this bit is disabled, power consumption can be reduced because all clocks except SBIxCR0 stop. If the serial bus interface operation is enabled and then disabled, the settings will be maintained in each register. | | 6-0 | - | R | Read as 0. | ## 14.7.2 SBIxCR1(Control register 1) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|------|--------|-----|----|------|-------|-----|-----------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | SIOS | SIOINH | SIG | OM | | > | SCK | | | After reset | 0 | 0 | 0 | 0 | ((// | 0_ | 0 | 0(Note 1) | | Bit | Bit Symbol | Туре | Function | |------|----------------------------------------|------|---------------------------------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7 | SIOS | R/W | Transfer Start/Stop | | | | | 0: Stop | | | | | 1: Start | | 6 | SIOINH | R/W | Transfer | | | | | 0: Continue 1: Forced termination | | 5-4 | SIOM[1:0] | R/W | Select transfer mode | | 3-4 | GIOW[1.0] | IVV | 00: Transmit mode | | | | | 01: Reserved | | | | | 10:Transmit/receive mode | | | | | 11:Receive mode | | 3 | - | R | Read as 1. | | 2-0 | SCK[2:0] | R/W | On writing <sck[2:0]>; Select serial clock frequency. (Note 1)</sck[2:0]> | | | _ | | 000 n = 3 4 MHz | | | | | 001 n = 4 2 MHz | | | | | 010 n = 5 1 MHz (System clock: fsys | | | | | 011 | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | 100 n = 7 250 kHz Clock gear: fc/1 | | | | | 101 | | < | | ) | 110 n = 9 62.5 kHz | | | | ( | – External clock | Note 1: After a reset, the <SCK[0]> bit is read as "1". However, if the SIO mode is selected at the SBIxCR2 register, the initial value is read as "0". In this document, the value written in the column "after reset" is the value after setting the SIO mode in the initial state. The descriptions of the SBIxCR2 register and the SBIxSR register are the same. Note 2: Set <SIOS> to "0" and <SIOINH> to "1" before programming the transfer mode and the serial clock. Page 485 2023/07/21 #### 14.7 Control register of SIO mode ## 14.7.3 SBIxDBR (Data buffer register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|-----|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | D | В | > | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | | Fund | etion | |------|------------|------|---------------|------|-------| | 31-8 | - | R | Read as 0. | | | | 7-0 | DB[7:0] | R | Receive data | | | | | | W | Transmit data | | (7) | Note 1: The transmission data must be written in to the register from the MSB (bit 7). The received data is stored in the LSB. Note 2: Since SBIxDBR has independent buffers for writing and reading, a written data cannot be read. Thus, read-modify-write instructions, such as bit manipulation, cannot be used. ## 14.7.4 SBIxCR2(Control register 2) This register serves as SBIxSR register by writing to it. | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|-------|--------|-----------|-----------| | bit symbol | - | - | - | - | - | - 2 | , | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | 1 | | ((///< | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | )° | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | \d\(\) | > 0 | | bit symbol | - | - | - | - | SE | BIM | 74-11 | , - | | After reset | 1(Note 1) | 1(Note 1) | 1(Note 1) | 1(Note 1) | ((0)) | 0 | 1(Note 1) | 1(Note 1) | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7-4 | - | R | Read as 1. (Note 1) | | 3-2 | SBIM[1:0] | W | Select serial bus interface operating mode (Note 2) 00: Port mode 01: SIO mode 10: I2Cbus mode 11: Reserved | | 1-0 | - | R | Read as 1. (Note 1) | Note 1: In this document, the value written in the column "after reset" is the value after setting the SIO mode in the initial state. Note 2: Make sure that modes are not changed during a communication session. Page 487 2023/07/21 ### 14.7 Control register of SIO mode ## 14.7.5 SBIxSR (Status Register) This register serves as SBIxCR2 by writing to it. | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-----------|-----------|-----------|-----------|--------------------------------------------------------------------------------|-------|----------------------------------------|-----------| | bit symbol | - | - | - | - | - | | (( | - | | After reset | 0 | 0 | 0 | 0 | 0 _ | (0/// | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - </td <td>-</td> <td>\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\</td> <td>→ -</td> | - | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | → - | | After reset | 0 | 0 | 0 | 0 | 9 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | ( (3)) | 2 | $(\bigcirc_1)$ | 0 | | bit symbol | - | - | - | - ( | SIOF | SEF | 74/// | - | | After reset | 1(Note 1) | 1(Note 1) | 1(Note 1) | 1(Note 1) | 0 | 0 | 1(Note 1) | 1(Note 1) | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7-4 | - | R | Read as 1.(Note 1) | | 3 | SIOF | R | Serial transfer status monitor. 0: Completed 1: In progress | | 2 | SEF | R | Shift operation status monitor 0: Completed. 1: In progress | | 1-0 | - | R | Read as 1. (Note 1) | Note: In this document, the value written in the column "after reset" is the value after setting the SIO mode in the initial state. # 14.7.6 SBIxBR0 (Baud rate register 0) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|-------|----|----|--------|-------|------|----| | bit symbol | - | - | - | - | - | - | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (0) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | 1 | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 7 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | - | I2SBI | - | - | | > - | 2-// | - | | After reset | 1 | 0 | 1 | 1 | ((//^^ | 1_ | | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------------------------------| | 31-8 | - | R | Read as 0. | | 7 | - | R | Read as 1. | | 6 | I2SBI | R/W | Operation in IDLE mode. 0: Stop 1: Operate | | 5-1 | - | R | Read as 1. | | 0 | - | R/W | Make sure to write "0". | Page 489 2023/07/21 14.8 Control in SIO mode TMPM362F10FG ### 14.8 Control in SIO mode ### 14.8.1 Serial Clock #### 14.8.1.1 Clock source Internal or external clocks can be selected by programming SBIxCR1<SCK[2:0]>. #### (1) Internal clocks In the internal clock mode, one of the seven frequencies can be selected as a serial clock, which is output to the outside through the SCKx pin. At the beginning of a transfer, the SCKx pin output becomes the "High" level. If the program cannot keep up with this serial clock rate in writing the transmit data or reading the received data, the SBI automatically enters a wait period. During this period, the serial clock is stopped automatically and the next shift operation is suspended until the processing is completed. Figure 14-15 Automatic Wait ### (2) External clock (<SCK[2:0]> = "111") The SBI uses an external clock supplied from the outside to the SCKx pin as a serial clock. For proper shift operations, the serial clock at the "High" and "Low" levels must have the pulse widths as shown below. Figure 14-16 Maximum Transfer Frequency of External Clock Input ### 14.8.1.2 Shift Edge Leading-edge shift is used in transmission. Trailing-edge shift is used in reception. - Leading-edge shift Data is shifted at the leading edge of the serial clock (or the falling edge of the SCKx pin in-put/output). - Trailing-edge shift Data is shifted at the trailing edge of the serial clock (or the rising edge of the SCKx pin input/output). Figure 14-17 Shift Edge Page 491 2023/07/21 14.8 Control in SIO mode TMPM362F10FG #### 14.8.2 Transfer Modes The transmit mode, the receive mode or the transmit/receive mode can be selected by programming SBIxCR1<SIOM[1:0]>. #### 14.8.2.1 8-bit transmit mode Set the control register to the transmit mode and write the transmit data to SBIxDBR. After writing the transmit data, writing "1" to SBIxCR1<SIOS> starts the transmission. The transmit data is moved from SBIxDBR to a shift register and output to the SO pin, with the least-significant bit (LSB) first, in synchronization with the serial clock. Once the transmit data is transferred to the shift register, SBIxDBR becomes empty, and the INTSBIx (buffer-empty) interrupt is generated, requesting the next transmit data. In the internal clock mode, the serial clock will be stopped and automatically enter the wait state, if next data is not loaded after the 8-bit data has been fully transmitted. The wait state will be cleared when SBIxDBR is loaded with the next transmit data. In the external clock mode, SBIxDBR must be loaded with data before the next data shift operation is started. Therefore, the data transfer rate varies depending on the maximum latency between when the interrupt request is generated and when SBIxDBR is loaded with data in the interrupt service program. At the beginning of transmission, the same value as in the last bit of the previously transmitted data is output in a period from setting SBIxSR<SIOF> to "1" to the falling edge of SCK. Transmission can be terminated by clearing <SIOS> to "0" or setting <SIOINH> to "1" in the IN-TSBIx interrupt service program. If <SIOS> is cleared, remaining data is output before transmission ends. The program checks SBIxSR<SIOF> to determine whether transmission has come to an end. <SIOF> is cleared to "0" at the end of transmission. If <SIOINH> is set to "1", the transmission is aborted immediately and <SIOF> is cleared to "0". When in the external clock mode, <SIOS> must be cleared to "0" before next data shifting. If <SIOS> does not be cleared to "0" before next data shifting, SBI output dummy data and stopped. Page 493 2023/07/21 14.8 Control in SIO mode TMPM362F10FG #### 14.8.2.2 8-bit receive mode Set the control register to the receive mode. Then writing "1" to SBIxCR1<SIOS> enables reception.Data is taken into the shift register from the SI pin, with the least-significant bit (LSB) first, in synchronization with the serial clock. Once the shift register is loaded with the 8-bit data, it transfers the received data to SBIxDBR and the INTSBIx (buffer-full) interrupt request is generated to request reading the received data. The interrupt service program then reads the received data from SBIxDBR. In the internal clock mode, the serial clock will be stopped and automatically be in the wait state until the received data is read from SBIxDBR. In the external clock mode, shift operations are executed in synchronization with the external clock. The maximum data transfer rate varies, depending on the maximum latency between generating the interrupt request and reading the received data Reception can be terminated by clearing <SIOS> to "0" or setting <SIOINH> to "1" in the INTSBIx interrupt service program. If <SIOS> is cleared, reception continues until all the bits of received data are written to SBIxDBR. The program checks SBIxSR<SIOF> to determine whether reception has come to an end.<SIOF> is cleared to "0" at the end of reception. After confirming the completion of the reception, last received data is read. If <SIOINH> is set to "1", the reception is aborted immediately and <SIOF> is cleared to "0". (The received data becomes invalid, and there is no need to read it out.) Note: The contents of SBIxDBR will not be retained after the transfer mode is changed. The ongoing reception must be completed by clearing <SIOS> to "0" and the last received data must be read before the transfer mode is changed. Figure 14-19 Receive Mode (Example: Internal Clock) #### 14.8.2.3 8-bit transmit/receive mode Set the control register to the transfer/receive mode. Then writing the transmit data to SBIxDBR and setting SBIxCR1<SIOS> to "1" enables transmission and reception. The transmit data is output through the SOx pin at the falling of the serial clock, and the received data is taken in through the SI pin at the rising of the serial clock, with the least-significant bit (LSB) first. Once the shift register is loaded with the 8-bit data, it transfers the received data to SBIxDBR and the INTSBIx interrupt request is generated. The interrupt service program reads the received data from the data buffer register and writes the next transmit data. Because SBIxDBR is shared between transmit and receive operations, the received data must be read before the next transmit data is written. In the internal clock operation, the serial clock will be automatically in the wait state until the received data is read and the next transmit data is written. In the external clock mode, shift operations are executed in synchronization with the external serial clock. Therefore, the received data must be read and the next transmit data must be written before the next shift operation is started. The maximum data transfer rate for the external clock operation varies depending on the maximum latency between when the interrupt request is generated and when the transmit data is written. At the beginning of transmission, the same value as in the last bit of the previously transmitted data is output in a period from setting <SIOF> to "1" to the falling edge of SCK. Transmission and reception can be terminated by clearing <SIOS> to "0" or setting SBIxCR1<SIOINH> to "1" in the INTSBIx interrupt service program. If <SIOS> is cleared, transmission and reception continue until the received data is fully transferred to SBIxDBR. The program checks SBIxSR<SIOF> to determine whether transmission and reception have come to an end. <SIOF> is cleared to "0" at the end of transmission and reception.If <SIOINH> is set to "1", the transmission and reception is aborted immediately and <SIOF> is cleared to "0". Note: The contents of SBIxDBR will not be retained after the transfer mode is changed. The ongoing transmission and reception must be completed by clearing <SIOS> to "0" and the last received data must be read before the transfer mode is changed. Page 495 2023/07/21 14.8 Control in SIO mode TMPM362F10FG Figure 14-20 Transmit/Receive Mode (Example: Internal Clock) ### 14.8.2.4 Data retention time of the last bit at the end of transmission Under the condition SBIxCR1<SIOS>= "0", the last bit of the transmitted data retains the data of SCK rising edge as shown below. Transmit mode and transmit/receive mode are the same. Figure 14-21 Data retention time of the last bit at the end of transmission TMPM362F10FG # 15. Consumer Electronics Control (CEC) ### 15.1 Outline The CEC function transmits and receives data that conforms to Consumer Electronics Control (hereafter referred to as CEC) protocol. It can operate conformably to HDMI 1.3a specifications. ### 15.1.1 Reception - · Clock sampling at fs clock or TBAOUT which is output of 16bit Timer/Event counters - -Adjustable noise canceling time - · Data reception per 1byte - -Flexible data sampling point - -Data reception is available even when an address discrepancy is detected - · Error detection - -Cycle error (min./max.) - -ACK collision - -Waveform error #### 15.1.2 Transmission - Data transmission per 1byte - -Triggered by auto-detection of bus free state - Flexible waveform - -Adjustable rising edge and cycle - Error detection - -Arbitration lost - -ACK response error ### 15.1.3 Precautions When data reception at logical address discrepancy is enabled(CECRCR1<CECOTH> = "1"), if the initiator sends a new message beginning with the start bit without having sent the last block with EOM="1", a maximum cycle error is determined for the ACK bit and an interrupt is generated. Then, the receive operation is performed in the usual way. Page 497 2023/07/21 15.2 Block Diagram TMPM362F10FG ## 15.2 Block Diagram Figure 15-1 shows the Block Diagram of CEC Figure 15-1 Block Diagram of CEC # 15.3 Registers ## 15.3.1 Register List The control registers and address for CEC are as follows. | Rase | Address | = 0x4 | LOOF | 2000 | |------|---------|-------|-------|-------| | Dase | Auuless | - 0X4 | ·00L_ | _2000 | | Registers | | Address (Base+) | |--------------------------------------|----------|-----------------| | CEC Enable Register | CECEN | ()\0x0000 | | Logical Address Register | CECADD | 0x0004 | | Software Reset Register | CECRESET | 0x0008 | | Receive Enable Register | CECREN | 0x000C | | Receive Buffer Register | CECRBUF | 0x0010 | | Receive Control Register 1 | CECRCR1 | 0x0014 | | Receive Control Register 2 | CECRCR2 | 0x0018 | | Receive Control Register 3 | CECRCR3 | 0x001C | | Transmit Enable Register | CECTEN | 0x0020 | | Transmit Buffer Register | CECTBUF | 0x0024 | | Transmit Control Register | CECTCR | 0x0028 | | Receive Interrupt Status Register | CECRSTAT | 0x002C | | Transmit Interrupt Status Register | CECTSTAT | 0x0030 | | CEC Sampling Clock Selected Register | CECFSSEL | 0x0034 | # 15.3.2 CECEN (CEC Enable Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|------|-------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | CECEN | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | - | R | Read as 0. | | 2 | - | R/W | Write "0". | | 1 | - | R/W | Write as "1". | | 0 | CECEN | R/W | CEC operation 0 : Disabled 1 : Enabled Specifies the CEC operation. Enable CEC before using. When the CEC operation is disabled, no clocks are supplied to the CEC module except for the CECEN register. Thus power consumption can be reduced. | | | | | When CEC is disabled after it was enabled, each register setting is maintained. | ## 15.3.3 CECADD (Logical Address Register ) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|-------|----------|--------------|-----|----| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | CECAD | D[15:8] | $(\bigcirc)$ | - | | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | | | | CECAI | DD[7:0] | > | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|--------------|------|--------------------------------------------------------------------------------------------| | 31-16 | _ | R | Read as 0. | | 15-0 | CECADD[15:0] | R/W | Logical address 15 to 0 | | | | | Specifies the logical address assigned to CEC. | | | | | Multiple addresses can be set simultaneously since each bit corresponds with each address. | Note: A broadcast message is received regardless of the register setting. By allocating a logical address of a device to 15, logical "0" is sent as an ACK response to the broadcast message. Page 501 2023/07/21 # 15.3.4 CECRESET (Software Reset Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-----|-------|-----|----------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 1-3 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | _ | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | - | - ( | ) | - | CECRESET | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 70( | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | - | R | Read as 0 | | 0 | CECRESET | W | Software reset 0: Disabled 1: Enabled Stops all the CEC operation and initializes the register. Setting this bit to "1" affects as follows: Reception: Stops immediately. The received data is discarded. Transmission (including the CEC line): Stops immediately. Register: All the registers other than CECEN are initialized. Read as 0. | ## 15.3.5 CECREN (Receive Enable Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|-------|-----------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | 1 | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | CECREN | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | Undefined | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | - | R | Read as 0 | | 0 | CECREN | R/W | Reception control [Write] 0 : Disabled | | | | | 1 : Enabled [Read] 0 : Stopped 1 : In operation | | | | | Controls the reception operation of CEC. Writing "0" or "1" to this bit enables or disables data reception. This bit becomes ready for data reception by writing "1". The state of the reception circuit is monitored by reading this bit. It enables you to check if what you set has properly been reflected. | Note 1: Enable the <CECREN> bit after setting the CECRCR1, CECRCR2 and CECRCR3. Note 2: It takes a little time to reflect the setting of the <CECREN> bit to the circuit. Make sure that the register is under suspension when you try to change settings or to enable disableed-settings. Page 503 2023/07/21 ## 15.3.6 CECRBUF (Receive Buffer Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|------|------|-------|--------|--------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 < | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | 1 | - (( | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107/ | 9 | 8 | | bit symbol | - | - | - | - | - | | CECACK | CECEOM | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | | CECI | RBUF | | | | | After reset | 0 | 0 | 0 | 0 | 01 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|--------------|------|--------------------------------------------------------| | 31-10 | - | R | Read as 0. | | 9 | CECACK | R | ACK bit | | | | | Reads the received ACK bit. | | 8 | CECEOM | R | EOM bit | | | | | Reads the received EOM bit. | | 7-0 | CECRBUF[7:0] | R | Received data | | | | | Reads one byte of data received. The bit 7 is the MSB. | Note 1: Writing to this register is ignored. Note 2: Read this register as soon as a receive interrupt is generated. The subsequent reading data may not be ensured. # 15.3.7 CECRCR1 (Receive Control Register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|--------|-----|-----|-------|----------|-----------| | bit symbol | - | - | - | - | - | - | - | CECACKDIS | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | CEC | HNC | - | (( | CECLNC | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | | CECMIN | - | _ | | CECMAX | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | | CECDAT | | CEC | TOUT | CECRIHLD | CECOTH | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | VQ ( | 0 | | Bit | Bit Symbol | Туре | Function | |----------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | - | R | Read as 0. | | 24 | CECACKDIS | R/W | Logical "0" as ACK response | | | | | 0: send | | | | | 1: not send | | | | | Specifies if logical "0" is sent or not as an ACK response to the data block when destination address | | | | | corresponds with the address set in the logical address register. | | | | | (Logical "0" is sent to the header block as an ACK response regardless of the bit setting when detecting the | | | | | addresses corresponding) | | 23-22 | - | R | Read as 0. | | 21-20 | CECHNC[1:0] | R/W | The number of "High" samplings for noise cancellation. | | | | | 00: None (one time of fs clock observed.) | | | | | 01: 1/fs (two consecutive fs clocks observed.) | | | | | 10: 2/fs (three consecutive fs clocks observed.) | | | | | 11: 3/fs (four consecutive fs clocks observed.) | | | | | Specifies the time of the noise cancellation for each 1/fs when detecting "High". | | 40 | _ / | // | It is considered as noise if "High"s of the same number as the specified cycles are not sampled. | | 19 | | Ŕ | Read as 0. | | 18-16 | CECLNC[2:0] | R/W | The number of "Low" samplings for noise cancellation. | | | | | 000: None (one time of fs clock observed.) 100: - (Reserved) | | | $\wedge \wedge$ | | 001: 1/fs (two consecutive fs clocks observed) 101: - (Reserved) 010: 2/fs (three consecutive fs clocks observed) 110: - (Reserved) | | | 7/ | \ N | 010: 2/fs (three consecutive fs clocks observed) 110: - (Reserved) 011: 3/fs (four consecutive fs clocks observed.) 111: - (Reserved) | | | l v | | Specifies the time of the noise cancellation for each 1/fs when detecting "Low". | | _ | | \ | It is considered as noise if "Low"s of the same number as the specified cycles are not sampled. | | 15 | | R | Read as 0. | | 14-12 | CECMIN[2:0] | R/W ( | Time to identify as minimum cycle error | | 14-12 | CLCIMIN[2.0] | l KW | 000: 67/fs (approx.2.045ms) 100: 67/fs - 1/fs | | | | | 001: 67/fs + 1/fs 101: 67/fs - 2/fs | | | | | 010: 67/fs + 2/fs 110: 67/fs - 3/fs | | | | | 011: 67/fs + 3/fs 111: 67/fs - 4/fs | | | | | Specifies the minimum time to identify a valid bit. | | | | | Base time is 67/fs (approx.2.045) ms. Enables to specify it between the ranges -4/fs to +3/fs by the unit | | | | | of 1/fs. | | | | | An interrupt is generated and "Low" is output to CEC for approx. 3.63 ms when one bit cycle is shorter than the | | | | | specified time. | | 11 | _ | R | Read as 0. | | <u> </u> | | L'\ | 11000 00 | Page 505 2023/07/21 | Bit | Bit Symbol | Туре | Function | |------|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10-8 | CECMAX[2:0] | R/W | Time to identify as maximum cycle error 000: 90/fs (approx. 2.747ms) 100: 90/fs – 1/fs 001: 90/fs + 1/fs 101: 90/fs – 2/fs 010: 90/fs + 2/fs 110: 90/fs – 3/fs 011: 90/fs + 3/fs 111: 90/fs – 4/fs Specifies the maximum time to identify as a valid bit. Base time is 90/fs (approx.2.747 ms). Enables to specify it between the ranges –4/fs to +3/fs by the unit | | | | | of 1/fs. An interrupt is generated when one bit cycle is longer than the specified time. | | 7 | - | R | Read as 0. | | 6-4 | CECDAT[2:0] | R/W | Point of determining the data as 0 or 1. 000: 34/fs (approx. 1.038ms) 100: 34/fs - 2/fs 001: 34/fs + 2/fs 100: 34/fs - 4/fs 110: 34/fs - 6/fs 111: Reserved Specifies the point of determining the data as logical "0" or logical "1". Base time is 34/fs (approx.1.038 ms). Enables to specify it within ±6/fs by the unit of 2/fs. | | 3-2 | CECTOUT[1:0] | R/W | Cycle to identify timeout 00: 1 bit cycle 01: 2 bit cycle 10: 3 bit cycle 11: Reserved Specifies the time to determine a timeout. Enables to specify it between 1 bit and 3 bits for each bit cycle. This setting is used to detect a timeout when the <cecrihld> bit is valid.</cecrihld> | | 1 | CECRIHLD | R/W | Error interrupt suspend 0: Not suspended 1: Suspended Specifies whether to suspend a receive error interrupt (maximum cycle error, buffer overrun and waveform error). Setting "1" generates no interrupt at the error detection. If data continues to an ACK bit, an ACK response is executed by a reversed logic. If the subsequent bits are interrupted, it is determined as a timeout, based on the setting in <cectout>. After the ACK response or the timeout determination, an interrupt is generated.</cectout> | | 0 | СЕСОТН | RW | Data-reception at logical address discrepancy 0: Not received 1: Received Specifies whether to receive data when the destination address does not correspond with the address set in the CECADD register. | - Note 1: The settings in <CECHNC>, <CECLNC> and <CECDAT> are also used in receiving an ACK response at transmission. - Note 2: Changing the configurations during transmission or reception may harm its proper operation. Before the change, set the CECREN <CECREN> bit to disable the reception and read the <CECREN> bit and the CECTEN <CECTRANS> bit to ensure that the operation is stopped. - Note 3: A broadcast message is received regardless of the <CECOTH> register setting. - Note 4: <CECLNC> must be used under the same setting as CECTCR<CECDTRS>. #### 15.3.8 CECRCR2 (Receive Control Register 2) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----------|----|----------|------|----------|----| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (0) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | CECSWAV3 | | - | | CECSWAV2 | | | After reset | 0 | 0 | 0 | 0 | 0 | 7 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | - | | CECSWAV1 | | | > | CECSWAV0 | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Fund | ction | |-------|-----------------|--------|---------------------------------------|--------------------| | 31-15 | - | R | Read as 0. | | | 14-12 | CECSWAV3[2:0] | R/W | Max. cycle to detect start bit. | | | | | | 000: 154/fs (approx. 4.700 ms) | 100: 154/fs + 4/fs | | | | | 001: 154/fs + 1/fs | 101: 154/fs + 5/fs | | | | | 001: 154/fs + 2/fs | 110: 154/fs + 6/fs | | | | | 011: 154/fs + 3/fs | 111: 154/fs + 7/fs | | 11 | - | R | Read as 0. | | | 10-8 | CECSWAV2[2:0] | R/W | Min. cycle to detect start bit. | <u></u> | | | | | 000: 141/fs (approx, 4.303 ms) | 100: 141/fs - 4/fs | | | | | 001: 141/fs - 1/fs | 101: 141/fs - 5/fs | | | | | 001: 141/fs - 2/fs | 110: 141/fs - 6/fs | | | | | 011: 141/fs - 3/fs | 111: 141/fs - 7/fs | | 7 | - | R | Read as 0. | | | 6-4 | CECSWAV1[2:0] | (R/W ) | Max. time of start bit rising timing. | | | | | \// | 000: 128/fs (approx. 3.906 ms) | 100: 128/fs + 4/fs | | | | | 001: 128/fs + 1/fs | 101: 128/fs + 5/fs | | | | | 001: 128/fs + 2/fs | 110: 128/fs + 6/fs | | | $\wedge \wedge$ | | 011: 128/fs + 3/fs | 111: 128/fs + 7/fs | | 3 | - | R | Read as 0. | | | 2-0 | CECSWAV0[2:0] | R/W | Min. time of start bit rising timing. | | | ^ | | | 000: 115/fs (approx. 3.510 ms) | 100: 115/fs - 4/fs | | | | | 001: 115/fs - 1/fs | 101: 115/fs - 5/fs | | | | | 001: 115/fs - 2/fs | 110: 115/fs - 6/fs | | | | ( | 011: 115/fs - 3/fs | 111: 115/fs - 7/fs | <CECSWAV3>: Specifies the cycles to detect a start bit. <CECSWAV3> is for the maximum cycles. The base time is 154/fs (approx.4.700 ms). Enables to specify it between the rang-<CECSWAV2>: es 0 to +7/fs by the unit of 1/fs. <CECSWAV2> is for the minimum cycles. The base time is 141/fs (approx.4.303 ms). Enables to specify it between the rang- es 0 to -7/fs by the unit of 1/fs. <CECSWAV1>: Specifies the rising timing of a start bit in its detection. <CECSWAV0>: <CECSWAV1> is for the maximum time of the rising timing. The base time is 128/fs (approx.3.906 ms). Enables to specify it between the ranges 0 to +7/fs by the unit of 1/fs. <CECSWAV0> is for the minimum time of the rising timing. The base time is 115/fs (approx.3.510 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs. Page 507 2023/07/21 Note: Changing the configurations during reception may harm its proper operation. Before the change, set CECREN <CECREN> to disable the reception and read the <CECREN> bit to ensure that the operation is stopped. # 15.3.9 CECRCR3 (Receive Control Register 3) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|---------|----|-----|---------|---------|----------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | | CECWAV3 | | - | (( | CECWAV2 | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107/ | 9 | 8 | | bit symbol | - | | CECWAV1 | | - | | CECWAV0 | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | - | - ( | <u></u> | - | CECWAVEN | | After reset | 0 | 0 | 0 | 0 | 01 | 0 | 70 | 0 | | Bit Bit Symbol Type Function | | | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------|------|----------------------------------------------------|------------------------------------------------------------------------| | CECWAV3[2:0] R/W The latest rising timing of logical "0" determined as proper waveform. | Bit | Bit Symbol | Туре | $\bigvee$ | Function | | 000: 56/fs (approx. 1.709 ms) 100: 56/fs + 4/fs 001: 56/fs + 1/fs 101: 56/fs + 5/fs 101: 56/fs + 5/fs 110: 56/fs + 5/fs 110: 56/fs + 5/fs 110: 56/fs + 5/fs 111: 56/fs + 5/fs 111: 56/fs + 3/fs 111: 56/fs + 5/fs 111: 56/fs + 5/fs 111: 56/fs + 3/fs 111: 56/fs + 7/fs 111: 56/fs + 7/fs 111: 56/fs + 7/fs 111: 56/fs + 7/fs 111: 56/fs + 7/fs 111: 56/fs + 7/fs 111: 56/fs + 5/fs 110: 43/fs - 5/fs 110: 43/fs - 5/fs 110: 43/fs - 5/fs 110: 43/fs - 5/fs 110: 43/fs - 5/fs 111: 43/fs - 7/fs 111: 43/fs - 7/fs 111: 26/fs + 5/fs 110: 26/fs + 4/fs 111: 26/fs + 5/fs 110: 26/fs + 4/fs 111: 26/fs + 5/fs 110: 26/fs + 5/fs 110: 26/fs + 6/fs 111: 13/fs - 6/fs 111: 13/fs - 5/fs 110: 13/fs - 6/fs 111: 13/fs - 5/fs 110: 13/fs - 6/fs 111: 13/fs - 5/fs 110: 13/fs - 6/fs 111: 13/fs - 7/fs | 31-23 | - | R | Read as 0. | | | 001: 56/fs + 1/fs | 22-20 | CECWAV3[2:0] | R/W | The latest rising timing of logical "0" determined | as proper waveform. | | 19 | | | | 000: 56/fs (approx. 1.709 ms) | 100: 56/fs + 4/fs | | 19 | | | | 001: 56/fs + 1/fs | 101: 56/fs + 5/fs | | 19 | | | | 001: 56/fs + 2/fs | 110: 56/fs + 6/fs | | 18-16 CECWAV2[2:0] R/W The fastest rising timing of logical "0" determined as proper. 000: 43/fs 43/fs 51/fs 101: 43/fs 51/fs 101: 43/fs 51/fs 101: 43/fs 51/fs 101: 43/fs 51/fs 101: 43/fs 51/fs 101: 43/fs 71/fs 101: 43/fs 71/fs 101: 43/fs 71/fs 101: 43/fs 71/fs 101: 43/fs 71/fs 101: 43/fs 71/fs 101: 26/fs 41/fs | | | | 011: 56/fs + 3/fs | 111: 56/fs + 7/fs | | 000: 43/fs (approx.1.312 ms) 100: 43/fs - 4/fs 101: 43/fs - 5/fs 101: 43/fs - 1/fs 101: 43/fs - 5/fs 110: 43/fs - 6/fs 111: 43/fs - 7/fs 110: 43/fs - 6/fs 111: 43/fs - 7/fs 100: 26/fs + 4/fs 100: 26/fs + 4/fs 101: 26/fs + 5/fs 101: 26/fs + 5/fs 110: 26/fs + 6/fs 111: 26/fs + 7/fs 27/fs 2 | 19 | - | R | Read as 0. | | | 001: 43/fs - 1/fs | 18-16 | CECWAV2[2:0] | R/W | The fastest rising timing of logical "0" determine | ed as proper. | | 010: 43/fs = 2/fs 110: 43/fs = 6/fs 011: 43/fs = 3/fs 111: 43/fs = 7/fs 14-12 | | | | 000: 43/fs (approx.1.312 ms) | 100: 43/fs - 4/fs | | 11: 43/fs - 3/fs 111: 43/fs - 7/fs | | | | 001: 43/fs - 1/fs | 101: 43/fs - 5/fs | | 15 | | | | 010: 43/fs - 2/fs | 110: 43/fs - 6/fs | | 14-12 CECWAV1[2:0] R/W The latest rising timing of logical "1" determined as proper waveform. 000; 26/fs (approx. 0.793 ms) 100; 26/fs + 4/fs 101; 26/fs + 5/fs 101; 26/fs + 5/fs 101; 26/fs + 6/fs 111; 26/fs + 7/fs 27/fs 27 | | | | 011: 43/fs - 3/fs | 111: 43/fs - 7/fs | | 000; 26/fs (approx. 0.793 ms) 100; 26/fs + 4/fs 001; 26/fs + 1/fs 101; 26/fs + 5/fs 001; 26/fs + 2/fs 110; 26/fs + 6/fs 011; 26/fs + 3/fs 111; 26/fs + 7/fs 10-8 | 15 | _ | R | Read as 0. | | | D01: 26/fs + 1/fs | 14-12 | CECWAV1[2:0] | R/W | The latest rising timing of logical "1" determined | as proper waveform. | | 001; 26/fs + 2/fs 110; 26/fs + 6/fs 111; 26/fs + 7/fs | | | | 000: 26/fs (approx. 0.793 ms) | 100: 26/fs + 4/fs | | 11 - R Read as 0 10-8 CECWAY0[2:0] R/W The fastest rising timing of logical "1" determined as proper. 000: 13/fs (approx. 0.396 ms) 100: 13/fs - 4/fs 001: 13/fs - 1/fs 101: 13/fs - 5/fs 010: 13/fs - 2/fs 110: 13/fs - 6/fs 011: 13/fs - 3/fs 111: 13/fs - 7/fs 7-2 - R Read as 0. 1 CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | / | | 001: 26/fs + 1/fs | 101: 26/fs + 5/fs | | 11 - R Read as 0 10-8 CECWAV0[2:0], R/W The fastest rising timing of logical "1" determined as proper. 000: 13/fs (approx. 0.396 ms) 100: 13/fs - 4/fs 001: 13/fs - 1/fs 101: 13/fs - 5/fs 010: 13/fs - 2/fs 110: 13/fs - 6/fs 011: 13/fs - 3/fs 111: 13/fs - 7/fs 7-2 R Read as 0. 1 CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | 001: 26/fs + 2/fs | 110: 26/fs + 6/fs | | 10-8 CECWAV0[2:0] R/W The fastest rising timing of logical "1" determined as proper. 000: 13/fs (approx. 0.396 ms) 100: 13/fs – 4/fs 001: 13/fs – 1/fs 101: 13/fs – 5/fs 010: 13/fs – 2/fs 110: 13/fs – 6/fs 011: 13/fs – 3/fs 111: 13/fs – 7/fs 7-2 R Read as 0. 1 CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | ~~< | 011: 26/fs + 3/fs | 111: 26/fs + 7/fs | | 000: 13/fs (approx. 0.396 ms) 100: 13/fs - 4/fs 001: 13/fs - 1/fs 101: 13/fs - 5/fs 110: 13/fs - 6/fs 111: 13/fs - 7/fs 7-2 R Read as 0. R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | 11 | - | R | Read as 0 | | | 001: 13/fs - 1/fs 101: 13/fs - 5/fs 110: 13/fs - 6/fs 110: 13/fs - 6/fs 111: 13/fs - 7/fs 7-2 - R Read as 0. 1 CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav1></cecwav0> | 10-8 | CECWAV0[2:0] | R/W | The fastest rising timing of logical "1" determine | d as proper. | | 010: 13/fs - 2/fs 011: 13/fs - 6/fs 011: 13/fs - 7/fs 7-2 R Read as 0. 1 CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav1></cecwav0> | | >,< | _ | 000: 13/fs (approx. 0.396 ms) | 100: 13/fs - 4/fs | | 011: 13/fs - 3/fs 7-2 R Read as 0. CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav1></cecwav0> | | | | 001: 13/fs - 1/fs | 101: 13/fs - 5/fs | | 7-2 R Read as 0. 1 CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | 010: 13/fs - 2/fs | 110: 13/fs - 6/fs | | 1 CECRSTAEN R/W Start bit detection 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | 011: 13/fs - 3/fs | 111: 13/fs - 7/fs | | 1: Enable 0: Disable Detects a reception of start bit and generates interrupt. 0 CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | 7-2 | | R | Read as 0. | | | 0: Disable Detects a reception of start bit and generates interrupt. R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | 1 | CECRSTAEN | R/W | Start bit detection | | | Detects a reception of start bit and generates interrupt. R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | 1: Enable | | | O CECWAVEN R/W Waveform error detection 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | 0: Disable | | | 1: Enable 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | Detects a reception of start bit and generates in | terrupt. | | 0: Disable Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | 0 | CECWAVEN | R/W | Waveform error detection | | | Detects a received waveform does not identical to the one defined and generates waveform error interrupt. If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | 1: Enable | | | If enabled, an error is detected according to the setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | | | 0: Disable | | | | | | | Detects a received waveform does not identical t | to the one defined and generates waveform error interrupt. | | <cfc wav3=""></cfc> | | | | If enabled, an error is detected according to the | setting of <cecwav0> <cecwav1> <cecwav2></cecwav2></cecwav1></cecwav0> | | 020 111100 . | | | | <cec wav3="">.</cec> | | Page 509 2023/07/21 <CECWAV3>: This setting is enabled when the <CECWAVEN> bit is set to "1". By setting these bits, an error is detected if rising edge of the received waveform comes later than that of proper logical "0". Base time is 56/fs (approx. 1.709ms). Enables to specify it between the ranges 0 to +7/fs by the unit of 1/fs. The received waveform is considered to be an error if a rising edge is not detected from the start point of the bit to the val- ue specified in <CECWAV3>. <CECWAV2>: This setting is enabled when the <CECWAVEN> bit is set to "1". <CECWAV1>: By setting these bits, an error is detected if rising edge of the received waveform comes faster than logical "0" and later than that of proper logical "1". Base time for <CECWAV1> bit is 26/fs (approx. 0.793ms). Enables to specify it between the ranges 0 to +7/fs by the unit Base time for <CECWAV2> bit is 43/fs (approx.1.312ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs. If a rising edge is detected during <CECWAV2> bit and <CECWAV1> bit setting, an error occurs. <CECWAV0>: This setting is enabled when the <CECWAVEN> bit is set to "1". By setting these bits, an error is detected if rising edge of the received waveform comes faster than that of proper logical "1". Base time is 13/fs (approx. 0.396ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs. The received waveform is considered to be an error if a rising edge is not detected from a start point of the bit to the value specified in <CECWAV0>. Note: Changing the configurations during reception may harm its proper operation. Before the change, set CECREN <CECREN> to disable the reception and read the <CECREN> bit to ensure that the operation is stopped. Page 510 2023/07/21 ## 15.3.10 CECTEN (Transmit Enable Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|-----|---------|----------|-----------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 1-3 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107/ | 9 | 8 | | bit symbol | - | - | - | - | _ | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | - | - ( | <u></u> | CECTRANS | CECTEN | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | 0 | Undefined | | Bit | Bit Symbol | Туре | Funcțion | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | R | Read as 0. | | 1 | CECTRANS | R | Transmission state 0: not in progress 1:in progress Indicates whether the transmission is in progress or not. It indicates "1" upon starting the transmission of the start bit. It indicates "0" if transmission is completed or an interrupt is generated. Writing to this bit is ignored. | | 0 | CECTEN | W | Transmission control 0: Disable 1: Enable Controls the CEC transmission. Writing this bit enables or disables the transmission. Writing "1" to this bit initiates the transmission. This bit is automatically cleared by a transmit completion interrupt or an error interrupt. | Note 1: Set <CECTEN> after setting the CECTBUF and CECTCR register. Note 2: Stop transmission and reception before changing the settings or enabling the transmission and reception. # 15.3.11 CECTBUF (Transmit Buffer Register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|---------|----|----|----|----|-------|-----|---------| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 13 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | - | | ) - | CECTEOM | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | CECTBUF | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 70( | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|-------------------------------------------------------------| | 31-9 | - | R | Read as 0. | | 8 | СЕСТЕОМ | R/W | EOM bit | | | | | Specifies the EOM bit to transmit. | | 7-0 | CECTBUF[7:0] | R/W | Transmitted data | | | | | Specifies a byte of data to transmit. The bit 7 is the MSB. | # 15.3.12 CECTCR (Transmit Control Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|---------|----|--------|----------|---------|-----|----| | bit symbol | - | - | - | - | - | - > | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 6 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | CECSTRS | | | - < | CECSPRD | | | | After reset | 0 | 0 | 0 | 0 | 0 | | ) 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | CECDTRS | | | CECDPRD | | | | | After reset | 0 | 0 | 0 | 0 | 0 | ٦ | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | CECBRD | | CECI | REE | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | (0) | 0 | | 31-23 | | | _ | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------------|------|------------------------------------------------------|------------------------------------------------------------| | 22-20 CECSTRS[2:0] R/W Rising timing of start bit. 000: Base time 100: Base time 101: Base time 101: Base time 107: 117: Base time 117: Base time 117: Base time 117: Base time 117: Base time 117: Base time 107: tim | Bit | Bit Symbol | Туре | Fi | unction | | 100: Base time | 31-23 | - | R | Read as 0. | | | 001: Base time - 1/fs 010: Base time - 2/fs 011: Base time - 2/fs 011: Base time - 3/fs 110: Base time - 6/fs 111: Base time - 7/fs Specifies the rising timing of a start bit. Base time is 121/fs (approx. 3.693 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1 fs. 19 - R Read as 0. 18-16 CECSPRD[2:0] R/W Start bit. cycle 000': Base time - 2/fs 110: Base time - 4/fs 110: Base time - 4/fs 110: Base time - 4/fs 110: Base time - 4/fs 111: Base time - 5/fs 111: Base time - 7/fs Specifies a cycle of a start bit. Base time is 147/fs (approx. 4.486 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1 fs. 15 - R Read as 0. 14-12 CECDTRS[2:0] R/W Rising timing of data bit. 000: Base time - 2/fs 010: Base time - 2/fs 110: Reserved 001: Base time - 2/fs 110: Reserved 001: Base time - 2/fs 110: Reserved 001: Base time - 2/fs 110: Reserved 011: Base time - 2/fs 110: Reserved 011: Base time - 2/fs 110: Base time - 1/fs 010: 011: Base time - 1/fs 011: Base time - 1/fs 011: Base time - 1/fs 0 | 22-20 | CECSTRS[2:0] | R/W | Rising timing of start bit. | | | 010: Base time - 2/fs 011: Base time - 3/fs 111: Base time - 7/fs Specifies the rising (timing of a start bit. Base time is 121/fs (approx.) 3.693 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1 fs. | | | | 000: Base time | 100: Base time- 4/fs | | 011: Base time - 3/fs 111: Base time - 7/fs Specifies the rising (liming of a start bit. Base time is 121/fs (approx.) 3.693 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs 18-16 CECSPRD[2:0] R/W Start bit. cycle 000: Base time 001: Base time - 2/fs 101: Base time - 5/fs 010: Base time - 2/fs 110: Base time - 6/fs 011: Base time - 2/fs 110: Base time - 7/fs 111: Base time - 7/fs Specifies a cycle of a start bit. Base time is 147/fs (approx. 4.486 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs 101: Base time - | | | | 001: Base time- 1/fs | 101: Base time - 5/fs | | Specifies the rising (timing of a start bit. | | | | 010: Base time- 2/fs | 110: Base time- 6/fs | | Base time is 121/fs (approx. 3.693 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs. | | | | 011: Base time- 3/fs | 111: Base time- 7/fs | | 19 | | | | Specifies the rising timing of a start bit. | | | 19 | | | | Base time is 121/fs (approx. 3.693 ms). Enables to | specify it between the ranges 0 to -7/fs by the unit of 1/ | | 18-16 CECSPRD[2:0] R/W Start bit cycle 000/8 ase time 1/5 101: Base time - 1/ | | | | fs. | <u> </u> | | 100: Base time | 19 | - | R | Read as 0. | | | 001. Base time- 1/fs 101. Base time- 5/fs 110. Base time- 6/fs 111. Base time- 2/fs 110. Base time- 6/fs 111. Base time- 7/fs Specifies a cycle of a start bit. Base time is 147/fs (approx. 4.486 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of fs. | 18-16 | CECSPRD[2:0] | R/W | Start bit cycle | \<br>\ | | 010: Base time - 2/fs | | | | 000: Base time | 100: Base time- 4/fs | | 011: Base time - 3/fs Specifies a cycle of a start bit. Base time is 147/fs (approx. 4.486 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1 fs. 15 | | | | 001. Base time- 1/fs | 101: Base time- 5/fs | | Specifies a cycle of a start bit. Base time is 147/fs (approx. 4.486 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs. 15 - R Read as 0. 14-12 CECDTRS[2:0] R/W Rising timing of data bit. 000: Base time 1/fs 101: Reserved 001: Base time 2/fs 110: Reserved 011: Base time 3/fs 111: Reserved 011: Base time is 20/fs (approx. 0.610 ms, when logical "1") or 49/fs (approx. 1.495 ms, when logical "0"). Enable to specify it between the ranges 0 to -3/fs by the unit of 1/fs. 11-8 CECDPRD[2:0] R/W Data bit cycle 0000: Base time 0001: Base time 1/fs 1001: Base time 9/fs 0010: Base time 2/fs 1010: Base time - 10/fs 0011: Base time - 3/fs 1011: Base time - 11/fs 0101: Base time - 3/fs 1101: Base time - 11/fs 0101: Base time - 5/fs 1101: Base time - 11/fs 0110: Base time - 6/fs 1110: Base time - 14/fs 0111: Base time - 7/fs 1111: Base time - 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | 010: Base time- 2/fs | 110: Base time- 6/fs | | Base time is 147/fs (approx. 4.486 ms). Enables to specify it between the ranges 0 to -7/fs by the unit of 1/fs. 15 - R Read as 0. 14-12 CECDTRS[2:0] R/W Rising timing of data bit. 000: Base time 1/fs 101: Reserved 010: Base time 2/fs 110: Reserved 011: Base time 2/fs 111: Reserved 011: Base time is 20/fs (approx. 0.610 ms, when logical "1") or 49/fs (approx. 1.495 ms, when logical "0"). Enable to specify it between the ranges 0 to -3/fs by the unit of 1/fs. 11-8 CECDPRD[2:0] R/W Data bit cycle 0000: Base time 0001: Base time 1000: Base time 8/fs 1001: Base time 9/fs 1001: Base time -1/fs 1001: Base time -10/fs 1001: Base time -11/fs 1001: Base time -11/fs 1001: Base time -11/fs 1101: | | < | | 011: Base time- 3/fs | 111: Base time- 7/fs | | 15 | | | | Specifies a cycle of a start bit. | | | 15 | | | | | specify it between the ranges 0 to -7/fs by the unit of 1/ | | 14-12 CECDTRS[2:0] R/W Rising timing of data bit. 000: Base time 100: Reserved 001: Base time 2/fs 110: Reserved 010: Base time 2/fs 110: Reserved 011: Base time 2/fs 111: Reserved 011: Base time 3/fs 111: Reserved Specifies the rising timing of a data bit Base time is 20/fs (approx. 0.610 ms, when logical "1") or 49/fs (approx. 1.495 ms, when logical "0"). Enable to specify it between the ranges 0 to -3/fs by the unit of 1/fs. 11-8 CECDPRD[2:0] R/W Data bit cycle 0000: Base time 0001: Base time 8/fs 0001: Base time 0001: Base time 10/fs 1001: Base time 9/fs 0010: Base time 10/fs 1010: Base time 10/fs 0011: Base time 3/fs 1011: Base time 11/fs 0100: Base time 13/fs 1100: Base time 13/fs 0110: Base time 5/fs 1110: Base time 14/fs 0111: Base time 15/fs 1111: Base time 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1/fs 1111: Base time 15/fs 1 | | | | fs. | | | 000: Base time 100: Reserved 001: Base time 101: Reserved 010: Base time 2/fs 110: Reserved 011: Base time 3/fs 111: Reserved 011: Base time 3/fs 111: Reserved Reser | 15 | - </th <th>R</th> <th>Read as 0.</th> <th></th> | R | Read as 0. | | | 001: Base time - 1/fs 101: Reserved 110: Reserved 110: Reserved 111: Res | 14-12 | CECDTRS[2:0] | R/W) | Rising timing of data bit. | | | 010: Base time - 2/fs | | | | 000: Base time | 100: Reserved | | 011: Base time 3/fs 111: Reserved | | ( ) | ) | 001: Base time- 1/fs | 101: Reserved | | Specifies the rising timing of a data bit Base time is 20/fs (approx. 0.610 ms, when logical "1") or 49/fs (approx. 1.495 ms, when logical "0"). Enable to specify it between the ranges 0 to -3/fs by the unit of 1/fs. 11-8 CECDPRD[2:0] R/W Data bit cycle 0000: Base time 0001: Base time- 1/fs 0010: Base time- 2/fs 1010: Base time- 9/fs 0011: Base time- 2/fs 1010: Base time- 10/fs 0011: Base time- 11/fs 1100: Base time- 12/fs 0101: Base time- 13/fs 0110: Base time- 13/fs 1101: Base time- 14/fs 1110: Base time- 14/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1/fs | | | / | 010: Base time- 2/fs | 110: Reserved | | Base time is 20/fs (approx. 0.610 ms, when logical "1") or 49/fs (approx. 1.495 ms, when logical "0"). Enable to specify it between the ranges 0 to -3/fs by the unit of 1/fs. 11-8 CECDPRD[2:0] R/W Data bit cycle 0000: Base time 0001: Base time- 1/fs 1001: Base time- 9/fs 0010: Base time- 2/fs 1010: Base time- 10/fs 0011: Base time- 3/fs 1011: Base time- 11/fs 0100: Base time- 11/fs 1100: Base time- 12/fs 1101: Base time- 12/fs 0101: Base time- 5/fs 1101: Base time- 13/fs 1101: Base time- 14/fs 0110: Base time- 6/fs 1110: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | ( | 011: Base time- 3/fs | 111: Reserved | | to specify it between the ranges 0 to -3/fs by the unit of 1/fs. 11-8 CECDPRD[2:0] R/W Data bit cycle 0000: Base time 0001: Base time- 1/fs 1001: Base time- 9/fs 0010: Base time- 2/fs 1010: Base time- 10/fs 0011: Base time- 3/fs 1011: Base time- 11/fs 0100: Base time- 4/fs 1100: Base time- 12/fs 0101: Base time- 5/fs 1101: Base time- 13/fs 0110: Base time- 6/fs 1110: Base time- 14/fs 0111: Base time- 7/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | /_ | | | Specifies the rising timing of a data bit | | | 11-8 CECDPRD[2:0] R/W Data bit cycle 0000: Base time | | | | Base time is 20/fs (approx. 0.610 ms, when logical " | 1") or 49/fs (approx. 1.495 ms, when logical "0"). Enables | | 0000: Base time | | | | to specify it between the ranges 0 to -3/fs by the u | nit of 1/fs. | | 0001: Base time- 1/fs 0010: Base time- 2/fs 1010: Base time- 10/fs 1011: Base time- 11/fs 1010: Base time- 11/fs 1100: Base time- 12/fs 1100: Base time- 12/fs 1101: Base time- 13/fs 1101: Base time- 13/fs 1101: Base time- 13/fs 1110: Base time- 14/fs 1110: Base time- 15/fs 1111: Base time- 15/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | 11-8 | CECDPRD[2:0] | R/W | Data bit cycle | | | 0010: Base time- 2/fs 0011: Base time- 3/fs 1011: Base time- 11/fs 1010: Base time- 11/fs 1100: Base time- 12/fs 1100: Base time- 12/fs 1101: Base time- 13/fs 1101: Base time- 13/fs 1110: Base time- 14/fs 1110: Base time- 14/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | 0000: Base time | 1000: Base time- 8/fs | | 0011: Base time- 3/fs 0100: Base time- 4/fs 0100: Base time- 4/fs 0101: Base time- 5/fs 0101: Base time- 5/fs 0110: Base time- 13/fs 0110: Base time- 6/fs 1110: Base time- 14/fs 0111: Base time- 7/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | 0001: Base time- 1/fs | 1001: Base time- 9/fs | | 0100: Base time- 4/fs 0101: Base time- 5/fs 0101: Base time- 5/fs 1101: Base time- 13/fs 0110: Base time- 6/fs 1110: Base time- 14/fs 0111: Base time- 7/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | 0010: Base time- 2/fs | 1010: Base time- 10/fs | | 0101: Base time- 5/fs 0110: Base time- 6/fs 0110: Base time- 6/fs 1110: Base time- 14/fs 0111: Base time- 7/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | 0011: Base time- 3/fs | 1011: Base time- 11/fs | | 0110: Base time- 6/fs 0111: Base time- 7/fs 1110: Base time- 14/fs 0111: Base time- 7/fs 1111: Base time- 15/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | 0100: Base time- 4/fs | 1100: Base time- 12/fs | | 0111: Base time- 7/fs Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | 0101: Base time- 5/fs | 1101: Base time- 13/fs | | Specifies a cycle of a data bit. Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to -15/fs by the unit of 1 | | | | | | | Base time is 79/fs (approx. 2.411 ms). Enables to specify it between the ranges 0 to −15/fs by the unit of 1 | | | | 0111: Base time- 7/fs | 1111: Base time- 15/fs | | | | | | Specifies a cycle of a data bit. | | | | | | | | pecify it between the ranges 0 to -15/fs by the unit of 1/ | Page 513 2023/07/21 | Bit | Bit Symbol | Туре | | Function | |-----|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------| | 7-5 | - | R | Read as 0. | | | 4 | CECBRD | R/W | Broadcast transmission 0: Not broadcast transmission 1: Broadcast transmission Set this bit to "1" when transmitting | g a broadcast message. | | 3-0 | CECFREE[3:0] | R/W | Time of bus to be free 0000: 1bit cycle 0001: 2bit cycle 0001: 2bit cycle 1001: 10bit cycle 1010: 11bit cycle 1011: 12bit cycle 1010: 5bit cycle 1100: 13bit cycle 1101: 14bit cycle 1101: 14bit cycle 1101: 15bit cycle 1101: 15bit cycle 1111: 16bit cycle 1111: 16bit cycle Specifies time of a bus to be free that checked before transmission. Start transmission after checking the CEC line kept inactive during the specified cycles. | | # 15.3.13 CECRSTAT (Receive Interrupt Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----------|---------|----------|----------|-----------------------------------------|----------|----------| | | 31 | 30 | 29 | 20 | 21 | 20 | 23 | 24 | | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | 1 | - | - | - | - | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \ | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | 1 | - | - | - | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | 1 | CECRIWAV | CECRIOR | CECRIACK | CECRIMIN | CECRIMAX | CECRISTA | CECRIEND | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | - | R | Read as 0. | | 6 | CECRIWAV | R | Interrupt flag 0: No wave form error 1: Wave form error Indicates that waveform error is detected. The error occurs when waveform error detection is enabled in CECRCR3 <cecwaven>.</cecwaven> | | 5 | CECRIOR | R | Interrupt flag 0: No receive buffer overrun 1:Receive buffer overrun Indicates the receive buffer receives next data before reading the data that had already been set. | | 4 | CECRIACK | R | Interrupt flag 0: No ACK collision 1: ACK collision Indicates "0" is detected after the specified time to output ACK bit "0". | | 3 | CECRIMIN | R | Interrupt flag 0: No minimum cycle error 1:Minimum cycle error Indicates one bit cycle is shorter than the minimum cycle error detection time specified in CECRCR1 <cecmin>.</cecmin> | | 2 | CECRIMAX | R ( | Interrupt flag 0: No maximum cycle error 1: Maximum cycle error Indicates one bit cycle is longer than the maximum cycle error detection time specified in CECRCR1 <cecmax>.</cecmax> | | 1 | CECRISTA | R | Interrupt flag 0: No start bit detection 1: Start bit detection Indicates a start bit is detected. | | 0 | CECRIEND | R | Interrupt flag 0: Not one byte data reception completed 1: Completion of 1 byte data reception Indicates 1 byte of data reception is completed. | Note: Writing to this bit is ignored. Page 515 2023/07/21 # 15.3.14 CECTSTAT (Transmit Interrupt Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|---------|----------|--------------|----------|----------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | CECTIUR | CECTIACK | CECTIAL | CECTIEND | CECTISTA | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-5 | - | R | Read as 0. | | 4 | CECTIUR | R | Interrupt flag 0: No transmit buffer underrun 1: Transmit buffer underrun Indicates next data has not set to the transmission buffer within a byte of data transmission. | | 3 | CECTIACK | R | Interrupt flag 0: No ACK error detection 1: ACK error detection Indicates one of the following conditions occurs. • When logical "0" is not detected in transmission to the specific address. • When logical "1" is not detected in transmission of a broadcast message. | | 2 | CECTIAL | R | Interrupt flag 0: No arbitration lost 1: Arbitration lost occurs Indicates "Low" is detected while outputting "High". | | 1 | CECTIEND | R | Interrupt flag 0: No data transmission completion 1: data transmission is completed Indicates data transmission including the EOM bit is completed. | | 0 < | CECTISTA | R | Interrupt flag 0: No start transmission 1: Start transmission Indicates 1 byte of data transmission is started. | Note: Writing to this bit is ignored. ## 15.3.15 CECFSSEL(CEC Sampling Clock Select Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|--------------|------|--------| | bit symbol | - | - | - | - | - | - | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ٦ | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | CECCLK | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | - | R | Read as 0. | | 0 | CECCLK | R/W | CEC sampling clock 0: Low-speed clock (fs) 1: TBAOUT Sets the sampling clock for CEC function.Enables to select either low-speed clock (fs) or timer output as of CEC sampling clock.Timer output range is 30kHz to 34kHz by setting TBAOUT. | Note: When changing sampling clock by CECFSSEL register, stop (prohibit) CEC operation by CECEN<CE-CEN> register once. Then set CECFSSEL register first prior to other CEC related registers after starting (permitting) the CEC operation again. And also in the case of software reset by CECRESET register, set CECFSSEL register first prior to other CEC related registers when changing sampling clock. Page 517 2023/07/21 ### 15.4 Operations #### 15.4.1 Sampling clock CEC lines are sampled by a 32.768kHz of low speed clock (fs) or TBAOUT which is output of 16bit Timer/Event counters. The sampling clock is configurable with the <CECCLKC> bits of the CECFSSEL register. ### 15.4.2 Reception #### 15.4.2.1 Basic Operation If a start bit is detected, a start bit interruption generates. By generating start bit interruption, CECR-STAT<CECRISTA> is set. The start bit interrupt is generated when the CECRCR3<CECRSTA> is set to "1". If one byte data, EOM bit and ACK bit are received, the received data is stored in CECRBUF register, and a received interruption generates. By generating the received interruption, CECRSTAT<CE-CRIEND> is set. In the CECRBUF register, 8 bit data, EOM bit and ACK bit are stored. The ACK bit is not generated in the CEC circuit internally. This bit is generated from a observation of CEC signal same as other data. After one data block is received, receiving operation continues until detecting the last block of data with EOM bit set to"1". Detecting the end of last block, CEC becomes the start bit waiting mode. Detecting an error during data reception causes an error interrupt, and CEC waits for the next start bit. The received data is discarded. Note: Regarding data reception, please carefully read "15.1.3 Precautions". #### 15.4.2.2 Preconfiguration Before receiving data, reception settings to the Logical Address Register <CECADD>, the Receive Control Register 1 <CECRCR1>, the Receive Control Register 2 <CECRCR2> and the Receive Control Register 3 <CECRCR3> are required. #### (1) Logical Address Configuration Configure logical address assigned to this product to the CECADD register. Multiple addresses can be set simultaneously since every bit in this register corresponds with each address. Note: A broadcast message is received regardless of the CECADD register setting. By allocating a logical address of a device to 15, logical "0" is sent as an ACK response to the broadcast message. #### (2) Noise Cancellation Time The noise cancellation time is configurable with the <CECHNC> and <CECLNC> bits of the CECRCR1 register. It is considered as noise if "High" or "Low" of the same number as the specified value are not sampled. You can configure the time to detect "High" and "Low" respectively. A CEC line is monitored at each rising edge of a sampling clock. In the case that the CEC line is changed from "High" to "Low", the change is fully recognized if "Low"s of the same number as specified in the <CECLNC> bit are monitored. In the case that the CEC line is changed from "Low" to "High", the change is fully recognized if "High" of the same number as specified in the <CECHNC> bit are sampled. Note: Use <CECLNC> in the same settings used for CECTCR<CECDTRS>. The following illustrates the operation of a case that a noise cancelling is configured as <CECHNC [1:0]> = "10" (3 samplings) and <CECLNC[2:0]> = "011" (4 samplings). By cancelling the noise, a signal "1" shifts to "0" after "0" is sampled four times. The signal "0" shifts to "1" after "1" is sampled three times. Page 519 2023/07/21 #### (3) Cycle error Configure CECRCR1<CECMIN> and <CECMAX> bits to detect a cycle error. A cycle error can be detected from each sampling clock cycle between the ranges -4/fs to +3/fs by the unit of 1/fs from the minimum value (67/fs, approx. 2.045ms) or the maximum value (90/fs approx. 2.747ms). Detecting an error during data reception causes an error interrupt, and CEC waits for the next start bit. The received data is discarded. #### (4) Point of Determining Data Configure the CECRCR1 <CECDAT> bit for the point of determining the data as "0" or "1". Base time is 34/fs (approx.1.038ms) from the start point and also configurable $\pm 6$ /fs by the unit of 2/fs. #### Data sampring timing that specification recommends #### (5) ACK Response Configuring the CECRCRI <CECACKDIS> bit enables you to specify if logical "0" is sent or not as an ACK response to the data block when destination address corresponds with the address set in the logical address register. Logical "0" issent to the header block as an ACK response regardless of the bit setting of <CE-CACKDIS>. The following lists the ACK responses. "Yes" indicates that CEC outputs "0" as a response to the ACK signal from a transmission device (ACK bit: logical "0"). "No" indicates that CEC does not output "0" as a response to the ACK signal from a transmission device (ACK bit: logical "1"). | De | egister actting | Header blo | ck address | Data block address | | | |-------------------------|-------------------------------------|------------------------|------------|--------------------|-------------|--| | RE | egister setting | Conformity Discrepancy | | Conformity | Discrepancy | | | CECRCR1 | "0"<br>(responding logical "0") | W | | Yes | No | | | <cecackdis></cecackdis> | "1"<br>(not responding logical "0") | Yes | No | No | No | | The following describes the ACK response timing. When the falling edge of the ACK bit from the initiator is detected, this IP outputs "Low" for approximately 1.526 ms. The start time of outputting "Low" is specified with CECRCR1<CECLNC> bit that sets the noise cancelling time. Note: Use <CECLNC> in the same settings used for CECTCR<CECDTRS> #### (6) Receive Error Interrupt Suspend Configure the CECRCR1 < CECRIHLD > bit to specify if a receive error interrupt (maximum cycle error, buffer overrun and waveform error) is suspended or not. Setting "1" generates no interrupt at the error detection. If data continues to the ACK bit, an ACK response is executed by a reversed logic. If the subsequent bits are interrupted, it is determined as a timeout, based on the setting in <CECTOUT> of the CECRCR1 register. After the ACK response or the timeout determination, an interrupt is generated. Page 521 2023/07/21 #### (7) Cycles to Identify Timeout Configure the CECRCR1<CECTOUT> bit to specify the time to determine a timeout. This is used when the setting of a receive error interrupt suspension, which is specified in CECRCR1 <CECRIHLD>, is valid. #### (8) Data Reception at Logical Address Discrepancy By setting CECRCR1 <CECOTH>, you can specify if data is received or not when destination address does not correspond with the address set in the CECADD register. In this case, an ordinary data reception is performed and an interrupt is generated by detecting an error. An ACK response is , however, not performed, neither the header block nor the data block. Note 1: A broadcast message is received regardless of the <CECOTH> register setting. Note 2: If the initiator sends a new message beginning with the start bit without having sent the last block with EOM="1", a maximum cycle error is determined for the ACK bit and an interrupt is generated. Then, the receive operation is performed in the usual way. #### (9) Start Bit Detection Configuring the CECRCR2 register allows you to specify the rising timing and a cycle of the start bit detection respectively. <CECSWAV0> is to specify the fastest start bit rising timing. <CECSWAV1> is to specify the latest start bit rising timing (the period that 1. indicates in the figure shown below). <CECSWAV2> is to specify the minimum cycle of a start bit. <CECSWAV3> is to specify the maximum cycle of a start bit (the period that 2. indicates in the figure shown below). If a rising edge during the period 1, and a falling edge during the period 2, are detected, the start bit is considered to be valid. #### Permissible value of signal transition timing on specification (Start bit) #### (10) Waveform Error Detection To detect an error when a received waveform is out of the defined tolerance range, configure the CECRCR3 register. An error is detected when the <CECWAVEN> bit of the CECRCR3 register is enabled. You can specify the detection time in the <CECWAV0>, <CECWAV1>, <CECWAV2> and <CECWAV3> bits If the rising edge is detected during the period 1. or 2 shown below, or not detected in the timing described in 3., a waveform error interrupt is generated. - 1. A period between the beginning of a bit and the fastest logical "1" rising timing - 2. A period between the latest logical "1" rising timing and the fastest logical "0" rising timing. - 3. The latest logical "0" rising timing. #### Permissible value of signal transition timing on specification (Data bit) Page 523 2023/07/21 #### 15.4.2.3 Enabling Reception After configuring the CECADD, CECRCR1, CECRCR2 and CECRCR3 registers, CEC is ready for reception by enabling the CECREN < CECREN bit. Detecting a start bit initiates the reception. Note: Changing the configurations of the CECADD, CECRCR1, CECRCR2 and CECRCR3 registers during reception may harm its proper operation. Before the change of the registers shown below, set the CECREN <CECREN> bit to disable the reception and read the <CECREN> bit and the CECTEN <CECTRANS> bit to ensure that the operation is stopped. | Register name | Bit Symbol | Setting item | | | |--------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------|--|--| | CECADD <cecadd[15:0]></cecadd[15:0]> | | Logical address | | | | | <cechnc><ceclnc></ceclnc></cechnc> | Noise cancellation time | | | | CECRCR1 | <cecmin><cecmax></cecmax></cecmin> | Time to identify cycle error | | | | ozonom: | <cecoth></cecoth> | Data reception at logical address discrepancy | | | | CECRCR2 | <cecswav0><cecswav1> <cecswav2><cecswav3></cecswav3></cecswav2></cecswav1></cecswav0> | Start bit detection | | | | CECRCR3 | <cecwav0><cecwav1><br/><cecwav2><cecwav3></cecwav3></cecwav2></cecwav1></cecwav0> | Waveform error detection (when enabled) | | | #### 15.4.2.4 Detecting Error Interrupt Detecting an error during data reception causes an error interrupt, and CEC waits for the next start bit. The received data is discarded. It is possible to suspend a receive error interrupt (maximum cycle error, receive buffer overrun and waveform error), continue reception and send the reversed ACK response. You can check the interrupt factor by monitoring the bit of the CECRSTAT register corresponding to interrupts. #### 15.4.2.5 Details of reception error #### Cycle error Period between the falling edges of the two sequential bits is measured during reception. If the period does not comply with the specified minimum or maximum value, a cycle error interrupt is generated. A setting of maximum cycle and minimum cycle time is specified by CECRCR1<CECMIN> and <CECMAX> bits. Maximum value is 90/fs (approx.2.747ms) and minimum value is 67/fs (approx. 2.045ms). It can be specified between the ranges -4/fs to +3/fs by the unit of 1/fs to detect cycle errors. The CECRSTAT <CECRIMIN> bit or the <CECRIMAX> bit is set if a cycle error interrupt is generated. The minimum cycle error causes CEC to output "Low" for approx. 3.63 ms. Note 1: When minimum cycle error is detected, "Low" is output after "Low" detecting noise cancellation time. Note 2: If the initiator sends a new message beginning with the start bit without having sent the last block with EOM="1", a maximum cycle error is determined for the ACK bit and an interrupt is generated. For detailed information, refer to "15.1.3 Precautions". #### (2) ACK Collision At an ACK response, detecting "Low" after the specified period to output generates an ACK collision interrupt or a minimum cycle error interrupt. The ACK collision interrupt sets the CECRSTAT <CECRIACK > bit. The minimum cycle error interrupt sets the CECRSTAT <CECRIMIN > bit. The following describes the period and method of detection. Detection starts approx. 0.3 ms after the end of the period of outputting "Low" and ends approx 2.0 ms from the starting point (the falling edge) of the ACK bit. At 0.3 ms from the end of the period of outputting "Low", CEC checks if the CEC line is "0" or not. If it is "Low", an ACK collision interrupt is generated. If it is "High", and "Low" is detected during the detection period, the minimum cycle error interrupt is generated. The minimum cycle error causes CEC to output "Low" for approx. 3.63ms. #### (3) Receive Buffer Overrun A receive buffer overrun interrupt is generated when the next data reception is completed before reading the data stored in the receive buffer. The interrupt sets the CECRSTAT <CECRIOR> bit. #### (4) Waveform Error A waveform error occurs when waveform error detection is enabled in CECRCR3. Detecting a waveform, which does not identical to the defined, results in the waveform error. The interrupt is generated. The interrupt sets the CECRSTAT <CECRIWAV> bit. Page 525 2023/07/21 #### (5) Suspending Receive Error Interrupt You can specify if a maximum cycle error, a buffer overrun and a waveform error to be suspended without generating an interrupt when an erro is detected. This can be set in the CECRCR1 <CE-CRIHLD> bit. To enable the setting, a timeout setting with the CECRCR1 <CECTOUT> bit is required. Under suspend-enable condition, if CEC keeps receiving the next bit and the entire reception including the ACK bit is completed, CEC generates an interrupt after a reversed ACK response is executed. "1" is set to the bits of the CECRSTAT register: the CECRIEND bit that indicates the reception completion, and the bits corresponding to the detected errors. If the reception of the next bit is interrupted, CEC starts to measure the timeout period, and an interrupt is generated after the timeout. "1" is set to the bits of the CECRSTAT register corresponding to the detected error. The timeout is measured from the end of the last bit received as is the case with wait time of a bus to be free in transmission. The information that the interrupts are suspended is held until the EOM bit is received or the timeout occurs. Thus, an interrupt is generated in each reception of a byte of data if multiple bytes are received while interrupts are suspended. "I" is set to the bits of the CECRSTAT register: the <CE-CRIEND> bit that indicates the reception completion, and the bits corresponding to the detected errors. The flags of the suspended interrupts and the reception completion are set to the bits of the CECR-STAT register. - Note 1: A minimum cycle error interrupt is generated upon detecting a minimum cycle error in the next received bit while interrupts are suspended. "Low" is output to CEC for approx. 3.63 ms. The flags of the suspended interrupts and the minimum cycle error are set to the bits of the CECR-STAT register. - Note 2: If an interrupt other than a minimum cycle error interrupt is generated while interrupts are suspended, CEC continues reception until the ACK response or the timeout. All the flags of the detected interrupts are set to the bits of the CECRSTAT register. #### 15.4.2.6 Stopping Reception Writing "0" to the CECREN < CECREN bit disables data reception. If the data reception is disabled during data reception, receiving operation stops and the received data is discarded. Note: If the reception is disabled while "Low" is sent as a signal of minimum cycle error, the "Low" output is stopped as well. #### 15.4.3 Transmission #### 15.4.3.1 Basic Operation In the transmission setting, the CEC firstly confirms the bus free wait status; it checks whether a CEC falling edge signal does not exit for specified bit cycles, and then sends a start bit. The confirmation of bus free wait is performed all the time. Thus once bus free wait condition is satisfied, a transmission will start soon when transmission setting is done. After transmitting a start bit, CEC transmits one byte data and EOM data that are stored in the transmit buffer to the shift register. When the transmission of the first bit of the one byte data begins, transmission interrupt is generates, and CECTSTAT<CECTISTA> is set. After transmission interrupt generation, next one byte data is prepared to the transmit data buffer. One byte data transmission completes in order of transmission of 8 bits data, EOM bit, ACK bit transmission and ACK bit response confirmation. Data transmission continues until EOM is set to "1" If EOM is set to "1", the end of transmission interrupt generates after confirmation of data, EOM, ACK bit transmission and ACK bit response. By the end of transmission interrupt generates, CECT-STAT<CECTIEND> is set. Interrupt generation ends a series of transmission process, and CECTEN < CECTEN > is cleared. If an error is generated during transmission, an error interrupt is generates to stop transmission. Even if reception is enabled, no reception is executed during transmission. Page 527 2023/07/21 #### 15.4.3.2 Preconfiguration Before transmitting data, transmission settings to the Transmit Control Register (CECTCR) and the Transmit Buffer Register (CECTBUF) are required. #### (1) Bus Free Wait Time Specify the bus free wait time in the CECTCR<CECFREE> bits. It can be specified in a range of 1 to 16 bit cycles. Counting of the bus free wait time begins one bit cycle after the falling edge of the final bit. If the signal stays high for the specified number of bit cycles, transmission starts. #### (2) Transmitting Broadcast Message Set the CECTCR <CECBRD> bit when transmitting a broadcast message. If this bit is set, logical "0" response during an ACK cycle results in an error. If not, logical "1" response during an ACK cycle results in an error. #### (3) Adjusting Transmission Waveform Both start bit and data bit are capable of adjusting the rising timing and cycle. With the CECTCR <CECSTRS> <CECSPRD> <CECDTRS> <CECDPRD> bits, the timing can be specified between the defined fastest rising/cycle timing and the reference value. The following figures show how the waveforms differ according to the configurations of the start bit, logical "0" and logical "1" Note: Use <CECDTRS> in the same settings used for CECRCR1<CECLNC>. ### (4) Preparing Transmission Data Configure a byte of transmission data and EOM data with the CECTBUF register. Page 529 2023/07/21 #### 15.4.3.3 Detecting Transmission Error Error detection during transmission generates an interrupt and stops transmission. It clears the CECT-EN <CECTEN> bit. To identify an error factor, the CECTSTAT register has bits that correspond with each interrupt. You can identify the interrupt factor by checking these bits. Note: An attempt to stop transmission by an error may cause an improper waveform output to CEC. This is because output is stopped immediately after the error occurs. #### 15.4.3.4 Details of Transmission Error #### (1) Arbitration Lost An arbitration lost error occurs when CEC detects "Low" on completion of appropriate low duration. Detecting an arbitration lost error sets the CECTSTAT <CECTIAL> bit. Two types of the arbitration lost detection periods are shown below. #### (2) ACK error An ACK error interrupt occurs when an ACK response does not conform to the configuration specified in the CECTCR <CECBRD> bit. When the ACK error interrupt occurs, the CECTSTAT <CECTIACK> bit is set. The ACK error is detected in the following cases. | Configuration | Determined as an ACK error when | |----------------------------------------------------|---------------------------------| | <cecbrd> = 0 Broadcast transmission?: No</cecbrd> | ACK response is logical "1" | | <cecbrd> = 1 Broadcast transmission?: Yes</cecbrd> | ACK response is logical "0" | #### (3) Transmit Buffer Underrun A transmit buffer underrun error is caused by the following sequence. - 1. Data in the transmit buffer is transmit to the shift register. - 2. An interrupt occurs. - 3. A byte of data is transmitted. - 4. No data is set to the transmit buffer before starting transmission of a byte of subsequent data. When an underrun error occurs, the CECTSTAT <CECTIUR> bit is set. #### (4) Order of ACK Error and Transmit Buffer Overrun If interrupt factors of the ACK error and transmit buffer underrun are detected at the end of transmission of a byte of data, the transmit buffer underrun has priority. The transmit buffer underrun interrupt occurs first and then the ACK error interrupt occurs. #### 15.4.3.5 Stopping Transmission To stop transmission, send data including the EOM bit that indicates "1". This generates a transmit completion interrupt. Please note that proper operation is not ensured if the start bit of transmission is set to "0" during transmission. #### 15.4.3.6 Retransmission Transmission is stopped by error detection. To retry the transmission, configure the condition and data of starting the transmission. Page 531 2023/07/21 #### 15.4.4 Software Reset The entire CEC function can be initialized by software. Setting "1" to the CECRESET < CECRESET> bit causes the following operations. - · Reception: Immediately stops. The received data is discarded. - · Transmission: Immediately stops including output to the CEC line. - · Register: All the registers other than CECEN are initialized. Please note that software reset during transmission may cause the CEC line waveform that does not identical to the defined. TOSHIBA TMPM362F10FG # 16. Remote control signal preprocessor(RMC) ## 16.1 Basic operation Remote control signal preprocessor (hereafter referred to as RMC) receives a remote control signal of which carrier is removed. ### 16.1.1 Reception of Remote Control Signal · A sampling clock can be selected from either low frequency clock (32.768kHz) or Timer output. · Leader detection Batch reception up to 72bit of data ## 16.2 Block Diagram Figure 16-1 shows the block diagram of RMC. Figure 16-1 Block diagram of RMC Page 533 2023/07/21 # 16.3 Registers # 16.3.1 Register List Addresses and names of RMC control registers are shown below. | Channel x | Base Address | | | | |-----------|--------------|--|--|--| | Channel0 | 0x400E_3000 | | | | | Channel1 | 0x400E_3100 | | | | | Register (x=0,1) | | Address(Base+) | |-----------------------------------|-----------|----------------| | Enable Register | RMCxEN | 0x0000 | | Receive Enable Register | RMCxREN | 0x0004 | | Receive Data Buffer Register 1 | RMCxRBUF1 | 0x0008 | | Receive Data Buffer Register 2 | RMCxRBUF2 | 0x000C | | Receive Data Buffer Register 3 | RMCxRBUF3 | 0x0010 | | Receive Control Register 1 | RMCxRCR1 | 0x0014 | | Receive Control Register 2 | RMCxRCR2 | 0x0018 | | Receive Control Register 3 | RMCxRCR3 | 0x001C | | Receive Control Register 4 | RMCxRCR4 | 0x0020 | | Receive Status Register | RMCxRSTAT | 0x0024 | | Receive End bit Number Register 1 | RMCxEND1 | 0x0028 | | Receive End bit Number Register 2 | RMCxEND2 | 0x002C | | Receive End bit Number Register 3 | RMCxEND3 | 0x0030 | | Source Clock selection Register | RMCxFSSEL | 0x0034 | # 16.3.2 RMCxEN(Enable Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|-------|-------| | bit symbol | - | - | - | - | - | - > | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | RMCEN | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | - | R | Read as 0. | | 1 | - | R/W | Write as "1". | | 0 | RMCEN | R/W | Controls RMC operation. 0: Disabled 1:Enabled To allow RMC to function, enable the RMCEN bit first. If the operation is disabled, all the clocks for RMC except for the enable register are stopped, and it can reduce power consumption. If RMC is enabled and then disabled, the settings in each register remain intact. | Page 535 2023/07/21 # 16.3.3 RMCxREN(Receive Enable Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|------|--------| | bit symbol | - | - | - | - | - | - > | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | RMCREN | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------------------------------------------------------------------------------------------| | 31-1 | _ | R | Read as 0. | | 0 | RMCREN | R/W | Reception 0: Disabled 1: Enabled Controls reception of RMC. Setting this bit to "1" enables reception. | Note: Enable the <RMCREN> bit after setting the RMCxRCR1, RMCxRCR2, and RMCxRCR3. ## 16.3.4 RMCxRBUF1(Receive Data Buffer Register 1) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|-------------------------------------|----|-----------------|------------------|-----------------------------------------|-------|----| | bit symbol | | RMCRBUF(Received data 31 to 24 bit) | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | | RM | /ICRBUF(Receive | ed data 23 to 16 | bit) | | | | After reset | 0 | 0 | 0 | 0 | 0 | \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \ | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | R | MCRBUF(Receiv | ed data 15 to 8b | oit) | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | - | R | MCRBUF(Receiv | ed data 7 to 0 b | it) | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|---------------|------|-----------------------------------------------| | 31-0 | RMCRBUF[31:0] | R | Received data (31 to 0 bit) | | | | | Reads 4 bytes of received data. (31 to 0 bit) | ## 16.3.5 RMCxRBUF2(Receive Data Buffer Register 2) | | 31 | 30 | 29 🔷 | 28 | 27 | 26 | 25 | 24 | |-------------|----|------|------|-----------------|------------------|------|----|----| | bit symbol | | | RN | /ICRBUF(Receive | ed data 63 to 54 | bit) | | | | After reset | 0 | 0 | 7/0 | 0 < | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | | RN | /ICRBUF(Receive | data 55 to 48 | bit) | | | | After reset | 0 | | 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | RN | /ICRBUF(Receive | ed data 47 to 40 | bit) | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | J) 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | RN | //CRBUF(Receive | ed data 39 to 32 | bit) | | | | After reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit Bit Symbol | Type | Function | |---------------------|------|-----------------------------------------------------------------------------| | 31-0 RMCRBUF[63:32] | R | Received data (63 to 32 bit) Reads 4 bytes of received data. (63 to 32 bit) | Page 537 2023/07/21 ## 16.3.6 RMCxRBUF3(Receive Data Buffer Register 3) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|-----------------|------------------|--------------|-----|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | | - | RN | /ICRBUF(Receive | ed data 71 to 64 | bit) | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|----------------|------|------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7-0 | RMCRBUF[71:64] | R | Received data (71 to 64 bit). | | | | | Reads 1 byte of received data, (71 to 64 bit). | Note: The received bit is stored in the data buffer register in MSB-first order, and the last received bit is stored in the LSB (bit 0). If the remote control signal is received in the LSB first algorithm, the received data is stored in reverse sequence. # 16.3.7 RMCxRCR1(Receive Control Register 1) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|--------------|----|----|------|----------|-------|-----|----| | bit symbol | bol RMCLCMAX | | | | | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | | | | RMCL | CMIN | (0/4) | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | RMCL | LMAX | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | - | | RMCI | LMIN | > | 2 | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | RMCLCMAX[7:0] | R/W | Specifies a maximum cycle of leader detection. Calculating formula of the maximum cycle: <rmclcmax> × 4/fs [s].</rmclcmax> | | 23-16 | RMCLCMIN[7:0] | R/W | Specifies a minimum cycle of leader detection. Calculating formula of the minimum cycle: <rmclcmin> × 4/fs [s].</rmclcmin> | | 15-8 | RMCLLMAX[7:0] | R/W | Specifies a maximum low width of leader detection. Calculating formula of the maximum low width: <rmcllmax> × 4/fs [s]</rmcllmax> | | 7-0 | RMCLLMIN[7:0] | R/W | Specifies a minimum low width of leader detection. Calculating formula for the minimum low width: <rmcllmin> × 4/fs [s] When RMCxRCR2<rmcld> = 1, a value of the low-pulse width is less than the specified value, it is defined as data bit.</rmcld></rmcllmin> | Note: When you configure the register, you must follow the rule shown below. | Leader | Rules | |------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Low width + High width | <pre><rmclcmax[7:0]> &gt; <rmclcmin[7:0]> <rmcllmax[7:0]> &gt; <rmcllmin[7:0]> <rmclcmin[7:0]> &gt; <rmcllmax[7:0]></rmcllmax[7:0]></rmclcmin[7:0]></rmcllmin[7:0]></rmcllmax[7:0]></rmclcmin[7:0]></rmclcmax[7:0]></pre> | | Only high width | <pre><rmclcmax[7:0]> &gt; <rmclcmin[7:0]> <rmcllmax[7:0]> = 0x00 <rmcllmin[7:0]> = don't care</rmcllmin[7:0]></rmcllmax[7:0]></rmclcmin[7:0]></rmclcmax[7:0]></pre> | | No Leader | <pre><rmclcmax[7:0]> = 0x00 <rmclcmin[7:0]> = don't care <rmcllmax[7:0]> = don't care <rmcllmin[[7:0]> = don't care</rmcllmin[[7:0]></rmcllmax[7:0]></rmclcmin[7:0]></rmclcmax[7:0]></pre> | Page 539 2023/07/21 # 16.3.8 RMCxRCR2(Receive Control Register 2) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|---------|----------|----|------|----------|---------------|-------|--------| | bit symbol | RMCLIEN | RMCEDIEN | - | - | - | - > | RMCLD | RMCPHM | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | RM | CLL | | | | | After reset | 1 | 1 | 1 | 1 | 1 | $\overline{}$ | 1 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | RMCI | DMAX | > | 2// | | | After reset | 1 | 1 | 1 | 1 | ((/1/ \) | 1_ | | 1 | | Bit | Bit Symbol | Туре | Function | |-------|--------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RMCLIEN | R/W | Leader detection interrupt 0: Not generated 1: Generated | | 30 | RMCEDIEN | R/W | Remote control input falling edge interrupt 0: Not generated 1: Generated | | 29-26 | _ | R | Read as 0. | | 25 | RMCLD | R/W | Receiving remote control signal with or without leader 0: Disabled 1: Enabled | | 24 | RMCPHM | R/W | Receiving a remote control signal by a phase modulation 0: Not receiving a remote control signal by a phase modulation. (receive by a cycle modulation) 1: Receive remote control signal by a fixed-frequency pulse modulation. To receive a fixed-frequency remote control signal by a pulse modulation, set this bit to "1". | | 23-16 | - < | R / | Read as 0. | | 15-8 | RMCLL[7:0] | R/W | Excess low width that triggers reception completion and interrupt generation. 0000_0000 to 1111_110: Reception completion and interrupt generation at <rmcll> × 1/fs [s]. 1111_1111: not to use as the trigger</rmcll> | | 7-0 | RMCDMAX[7:0] | R/W | Maximum data bit cycle that triggers reception completion and interrupt generation. 0000_0000 to 1111_1110: Reception completion and interrupt generation at <rmcdmax> × 1/fs [s]. 1111_1111: not to use as the trigger</rmcdmax> | ## 16.3.9 RMCxRCR3(Receive Control Register 3) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|------|-------|----| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | | | | RMCDATH | | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | | | | RMCDATL | > | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | | | | | | |-------|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31-15 | - | R | Read as 0. | | | | | | | 14-8 | RMCDATH[6:0] | R/W | Larger threshold to determine a signal pattern in a phase method | | | | | | | | | | Calculating formula of the threshold: <rmcdath> × 1/fs [s]</rmcdath> | | | | | | | | | | Specifies a larger threshold (within a range of 1.5T and 2T) to determine a pattern of remote control signal | | | | | | | | | | in a phase method. If the measured cycle exceeds the threshold, the bit is determined as "10". If not, the bit | | | | | | | | | | is determined as "01". | | | | | | | 7 | - | R | Read as 0. | | | | | | | 6-0 | RMCDATL[6:0] | R/W | Threshold to determine 0 or 1 smaller threshold to determine a signal pattern in a phase method. | | | | | | | | | | Calculating formula of the threshold: <rmcdatl> × 1/fs [s]</rmcdatl> | | | | | | | | | | Specifies two kinds of thresholds: a threshold to determine whether a data bit is 0 or 1; a smaller threshold (within a range of 1T and 1.5T) to determine a pattern of remote control signal in a phase method. | | | | | | | | | | As for the determination of data bit, if the measured cycle exceeds the threshold, the bit is determined as "1". | | | | | | | | | | If not, the bit is determined as "0", Calculating formula of the threshold: <rmcdatl> × 1/fs [s].</rmcdatl> | | | | | | | | / | | As for the determination of a remote control signal pattern in a phase method, if the measured cycle exceeds | | | | | | | | | | the threshold, the bit is determined as "01". If not, the bit is determined as "00". | | | | | | Note: If the <RMCPHM> bit of the Receive Control Register 2 is "0", <RMCDATH[6:0]> are not enabled. The bits are enabled when <RMCPHM> is "1". # 16.3.10 RMCxRCR4(Receive Control Register 4) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-------|----|----|----|----------|-------|-----|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | RMCPO | - | - | - | | RM | CNC | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as 0. | | 7 | RMCPO | R/W | Remote control input signal 0: Not reversed 1: Reversed | | 6-4 | - | R | Read as 0. | | 3-0 | RMCNC[3:0] | R/W | Specifies noise cancellation time. 0000: No cancellation 0001 to 11/1: cancellation Calculating formula of noise cancellation time: <rmcnc> × 1/fs [s]</rmcnc> | ## 16.3.11 RMCxRSTAT(Receive Status Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|---------|---------|-----------|---------|----------|-------|-----|----| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | RMCRLIF | RMCLOIF | RMCDMAXIF | RMCEDIF | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | RMCRLDR | | | | RMCRNUM | > | 2// | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|--------------|------|-----------------------------------------------------------------------------------------------------| | 31-16 | - | R | Read as 0. | | 15 | RMCRLIF | R | Interrupt source flag 0: No leader detection interrupt generated. | | | | | Leader detection interrupt generated. Leader detection interrupt generated. | | 14 | RMCLOIF | R | Interrupt source flag | | | | | No low width detection interrupt generated. Low width detection interrupt generated. | | 13 | RMCDMAXIF | R | Interrupt source flag | | | | | 0: No maximum data bit cycle interrupt generated. | | | | | 1: Maximum data bit cycle interrupt generated. | | 12 | RMCEDIF | R | Interrupt source flag | | | | | 0: No falling edge interrupt generated. | | | | / | 1: Falling edge interrupt generated. | | 11-8 | - | R | Read as 0. | | 7 | RMCRLDR | R | Leader detection. | | | | | 0: Disable leader detection. | | | $\sim \sim$ | | 1: Enable leader detection. | | 6-0 | RMCRNUM[6:0] | R | The number of received data bit | | | | | 000_0000:no data bit (only with leader) | | | | | 000_0001 to 100_1000: 1 to 72bit | | | | | 100_1001 to 111_1111: 73bit and more | | | | | Indicates the number of bits received as remote control signal data. The number cannot be monitored | | | | | during reception. On completion of reception, the number is stored. | Note 1: This register is updated every time an interrupt is generated. Writing to this register is ignored. Note 2: RMC keeps receiving 73 bit or more data unless reception is completed by detecting the maximum data bit cycle or the excess low width. In this case, the received data in the data buffer may not be ensured. Page 543 2023/07/21 ## 16.3.12 RMCxEND1(Receive End bit Number Register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|----|----|---------|-------|----------|----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | <u>-</u> | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | - | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | | | | RMCEND1 | | | | | After reset | 0 | 0 | 0 | 0 | o/ | 0 | ,d( | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | - | R | Read as 0. | | 6-0 | RMCEND1[6:0] | R/W | Specifies that the number of receive data bit 000_0000: No specifically the receive data bit 000_0001 to 100_1000: Specifies that the number of receive data bit(1 to 72bit) 100_1001 to 111_1111: Don't set the value | # 16.3.13 RMCxEND2(Receive End bit Number Register 2) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|------|---------------------------------------|---------------|-----------|---------|----|----|----| | bit symbol | - | - ( | | - ~ | | - | - | - | | After reset | 0 | 0 (/ | / <b>()</b> 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | (20 7 / < | 19 | 18 | 17 | 16 | | bit symbol | - < | 1 | 7 - < | | ) - | - | - | - | | After reset | 0 | 9 | 0 | | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | <-\^ | - | - | <u> </u> | 1 | - | - | - | | After reset | 0 | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | Q | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | | | | | RMCEND2 | _ | | | | After reset | | 0, | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | - | R | Read as 0. | | 6-0 | RMCEND2[6:0] | R/W | Specifies that the number of receive data bit 000_0000 : No specifically the receive data bit 000_0001 to 100_1000 : Specifies that the number of receive data bit(1 to 72bit) 100_1001 to 111_1111 : Don't set the value | ## 16.3.14 RMCxEND3(Receive End bit Number Register 3) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|---------|----|----|----------|-------|-------|----| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | 1 | 1 | 1 | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | RMCEND3 | | | | | | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | - | R | Read as 0. | | 6-0 | RMCEND3[6:0] | R/W | Specifies the number of receive data bit 000_0000 : No specifically the receive data bit 000_0001 to 100_1000 : Specifies that the number of receive data bit(1 to 72bit) 100_1001 to 111_1111 : Don't set the value | Note 1: As specified to RMCxEND1, RMCxEND2 and RMCxEND3, it is able to set three kinds of the receive data bit. Note 2: To use the RMCxEND1, RMCxEND2 and RMCxEND3 is in combination with the maximum data bit cycle. Page 545 2023/07/21 ## 16.3.15 RMCxFSSEL(Source Clock selection Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|------|--------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | RMCCLK | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | - | R | Read as 0. | | 0 | RMCCLK | R/W | Specifies that Sampling clock of RMC function 0 : Low frequency Clock (32,768kHz) 1 : Timer output(TBBOUT) | | | | | For the Sampling of RMC function, It is able to set the Low Frequency Clock (32.768kHz) or Timer output (TBBOUT). The Setting range of Timer output by TBBOUT is from 30 to 34kHz. | ### 16.4 Operation Description #### 16.4.1 Reception of Remote Control Signal #### 16.4.1.1 Sampling clock A remote control signal is sampled by using low-speed 32.768kHz clock (fs). #### 16.4.1.2 Basic operation RMC set RMCxRSTAT<RMCRLDR> bit when a leader is detected. At this time, if you set the RMCxRCR2<RMCLIEN> bit, leader detection will generate a leader detection interrupt. When a leader detection interrupt occurs, RMCxRSTAT<RMCRLIF> bit is set. After the leader detecting, each data bit is determined as "0" or "1" in sequence. The results are stored in RMCxRBUF1, RMCxRBUF2 and RMCxRBUF3 registers up to 72 bits. By setting RMCxRCR2< RMCEDIEN> bit, a remote control signal input falling edge interrupt can be generated in each falling edge of data bit. When a remote control signal input falling edge interrupt is generated, RMCxRSTAT< RMCEDIF > bit is set. Data reception stops when the maximum data bit cycle is detected and low-width matches the setting value, and then, an interrupt occurs. If <RMCEND1>, <RMCEND2> nad <RMCEND3> of the register RMCxEND1, RMCxEND2 and RMCEND3 have been configured, data reception stops and an interrupt occurs only in the case that the number of bits received before maximum data bit cycle is detected. The condition of RMC can be checked by reading the remote control receive status register. To check the status of RMC if reception is completed, read the remote control receive status register. On completion of reception, RMC is waiting for the next leader. By setting RMC to receive a signal without a leader, RMC recognizes the received as data and starts reception without detecting a leader. If the next data reception is completed before reading the preceding received data, the preceding data is overwritten by the next one. Page 547 2023/07/21 16.4 Operation Description TMPM362F10FG #### 16.4.1.3 Preparation Before starting receiving process, configure how to receive remote control signal using the Remote Control Signal Receive Control Registers (RMCxRCR1, RMCxRCR2 and RMCxRCR3, RMCxRCR4). #### (1) Settings of Noise Cancelling Time Configure noise cancelling time with the RMCxRCR4 < RMCNC[3:0] > bit. Noise canceling is applied to remote control signals sampled by the sampling clock. RMC monitors a sampled remote control signal in each rising edge of a sampling clock. If "High" is monitored, RMC recognizes that the signal was changed to "Low" after monitoring cycles of "Low"s specified in <RMCNC>. If "Low" is monitored, RMC recognizes that the signal was changed to "High" after monitoring cycles of "High" specified in <RMCNC>. The following figure shows how RMC operates according to the noise cancel setting of <RMCNC [3:0]> = "0011" (3 cycles). Subsequent to noise cancellation, the signal is changed from "High" to "Low" upon monitoring 3 cycles of "Low", and the signal is changed from "Low" to "High" upon monitoring 3 cycles of "High". #### (2) Settings of Detecting Leader Set the leader cycle and a low width of the leader to RMCxRCR1 <RMCLLMIN[7:0]> <RMCLLMAX[7:0]> <RMCLCMIN[7:0]> <RMCLCMAX[7:0]> bits. When you configure those above, follow the rule shown below. | Leader | Rules | |---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Low width + High<br>Width | <pre><rmclcmax[7:0]> &gt; <rmclcmin[7:0]> <rmcllmax[7:0]> &gt; <rmcllmin[7:0]> <rmclcmin[7:0]> &gt; <rmcllmax[7:0]></rmcllmax[7:0]></rmclcmin[7:0]></rmcllmin[7:0]></rmcllmax[7:0]></rmclcmin[7:0]></rmclcmax[7:0]></pre> | | Only high width | <pre><rmclcmax[7:0]> &gt; <rmclcm[n[7:0]> <rmcllmax[7:0]> = 0y00000000 <rmcllmin[7:0]> = don't care</rmcllmin[7:0]></rmcllmax[7:0]></rmclcm[n[7:0]></rmclcmax[7:0]></pre> | | No leader | <pre><rmclcmax[7:0]> = 0y00000000 <rmclcmin[7:0]> = don't care <rmcllmax[7:0]> = don't care <rmcllmin[7:0]> = don't care</rmcllmin[7:0]></rmcllmax[7:0]></rmclcmin[7:0]></rmclcmax[7:0]></pre> | The following shows a leader waveform and the RMCxRCR1 register settings. If you want to generate an interrupt when detecting a leader, configure the RMCxRCR2 <RMCLIEN> bit. A remote control signal without a leader cannot generate a leader detection interrupt. Page 549 2023/07/21 6.4 Operation Description TMPM362F10FG #### (3) Setting of 0/1 determination data bit Based on a falling edge cycle, the data bit is determined as 0 or 1. There are two kinds of determinations: #### 1. Determination by threshold. Configure a threshold value to RMCxRCR3<RMCDATL[6:0]> bit which determines data bit as "0" or "1." If the determination value is equal to threshold value or more, it is determined as "1." If the determination value is less than threshold value, it is determined as "0." #### 2. Determination by falling edge interrupt inputs By setting "1" to the RMCxRCR2<RMCEDIEN> bit, a remote control signal input falling edge interrupt can be generated in each falling edge of the data bit. Using this interrupt together with a timer enables the determination to be done by software. The followings shows the determination model of data bit. Threshold of 0/1 determination is set to 2.5T with the <RMCDATL[6:0]>bit As for data bit determination of a remote control signal in a phase method, see 16.4.1.8 Receiving a Remote Control Signal in a Phase Method". #### (4) Settings of Reception Completion To complete data reception, settings of detecting the maximum data bit cycle and excess low width are required. If multiple factors are specified, reception is completed by the factor detected first. Make sure to configure the reception completion settings. #### 1. Completetion by the maximum data bit cycle To complete reception by detecting a maximum data bit cycle, you need to configure the RMCxRCR2 <RMCDMAX[7:0]> bits. If the falling edge of the data bit cycle isn't monitored after time specified as threshold in the <RMCDMAX[7:0]> bits, a maximum data bit cycle is detected. The detection completes reception and generates an interrupt. After interrupt inputs generated, RMCxRSTAT< RMCDMAXIF > bit is set to "1". To complete reception by setting the number of receive data is set a RMCxEND 1 to 3 register of each <RMCEND1>, <RMCEND2>, <RMCEND3>. In this case when the number of set reception bit agreed with the number of bit which received at the time of the outbreak of MAX on the number of receive data is set a RMCxEND 1 to 3 register of each <RMCEND1>, <RMCEND2>, <RMCEND3>, it occurs by an MAX interrupt in data bit pe- As specified to RMCxEND3 to 1, it is able to set three kinds of the receive data bit. When it can receive the Maximum Data bit, the number of bit is not match the setting value in <RMCEND1>, <RMCEND2>, <RMCEND3>, it wait for Leader Reception. If the falling edge of the data bit cycle is not monitored after time specified as threshold, a maximum data bit cycle is detected. The detection completes reception and generates an interrupt. #### Completetion by detecting low width To complete reception by detecting the low width, you need to configure the RMCxRCR2 <RMCLL[7:0]> bits. After the falling edge of the data bit is detected, if the signal stays low longer than specified, excess low width is detected. The detection completes reception and generates an inter- After interrupt inputs generated, RMCxRSTAT<RMCLOIF> bit is set to "1." Page 551 2023/07/21 16.4 Operation Description TMPM362F10FG ### 16.4.1.4 Enabling Reception By enabling the RMCxREN <RMCREN> bit after configuring the RMCxRCR1, RMCxRCR2, RMCxRCR3 and RMCxRCR4 registers, RMC is ready for reception. Detecting a leader initiates reception. Note: Changing the configurations of the RMCxRCR1, RMCxRCR2, RMCxRCR3 and RMCxRCR4 registers during reception may harm their proper operation. Be careful if you change them during reception. ### 16.4.1.5 Stopping Reception RMC stops reception by clearing the RMCxREN <RMCREN bit to "0" (reception disabled). Clearing this bit during reception stops reception immediately and the received data is discarded. #### 16.4.1.6 Receiving Remote Control Signal without Leader in Waiting Leader Setting RMCxRCR2 <RMCLD> enables RMC to receive signals with or without a leader. By setting RMCxRCR2 <RMCLD>, RMC starts receiving data if it recognizes a signal of which low width is shorter than a maximum low width of leader detection specified in the RMCxRCR1 <RMCLLMAX [7:0]> bits. RMC keeps receiving data until the final data bit is received. If RMCxRCR2 <RMCLD> is enabled, the same settings of error detection, reception completion and data bit determination of 0 or 1 are applied regardless of whether a signal has a leader or not. Thus receivable remote control signals are limited. Page 553 2023/07/21 6.4 Operation Description TMPM362F10FG #### 16.4.1.7 A Leader only with Low Width The figure shown below illustrates a remote control signal that starts with a leader of which waveform only has low width. This signal starts with a leader that only has low width and a data bit cycle starts from the rising edge. To enable the signal, it must be sent after being reversed by setting the RMCxRCR4 < RMCPO bit to "1". This is because RMC is configured to detect a data bit cycle from the falling edge To detect a leader, configure only low-pulse width of the leader with the <RMCLLMAX[7ÅF0] >=0y0000 \_ 0000, <RMCLCMAX[7:0]>><RMCLCMIN[7:0]>. In this case, the value of <RMCLLMIN[7:0]> is set as "don't care". To detect whether data "0" or data "1", configure the threshold of 0/1 detection with the RMCxRCR3 <RMCDATL[6:0]>. The maximum data bit cycle is configured with the <RMCDMAX[7:0]> of the RMCxRCR2. To complete data reception, configure the maximum data bit cycle with <RMCDMAX[7:0]> of the RMCxRCR2, and configure the low-pulse width detection with <RMCLL[7:0]>. After detecting the maximum data bit cycle and confirming the low-pulse with which is specified after receiving the last bit, receiving data is completed. The RMC generates an interrupt and waits for the next leader. ### 16.4.1.8 Receiving a Remote Control Signal in a Phase Method RMC is capable of receiving a remote control signal in a phase method of which signal cycle is fixed. A signal in the phase method has three waveform patterns (see the figure shown below). By setting two thresholds a remote control signal pattern is determined. RMC converts the signal into data "0" or "1". On completion of reception, received data "0" and "1" are stored in the RMCxRBUF1, RMCxRBUF 2 and RMCxRBUF3. By setting RMCxRCR2<RMCPHM> = "1", RMC enables to receive a remote control signal in the phase method. Each threshold can be configured with the RMCxRCR3 <RMCDATL[6:0]> bits and <RMCDATH[6:0]> bits. Two thresholds are used to distinguish three waveform patterns. On condition that a cycle between two falling edges is "T", three patterns show cycles of 1T, 1.5T and 2T. Details of the two thresholds are shown below. | | Determined by | Threshold | Register bits to set | |-------------|-----------------------|------------|----------------------------------------| | Threshold 1 | Pattern 1 & pattern 2 | 1T to 1.5T | RMCxRCR3 <rmcdatl[6:0]></rmcdatl[6:0]> | | Threshold 2 | Pattern 2 & pattern 3 | 1.5T to 2T | RMCxRCR3 <rmcdath[6:0]></rmcdath[6:0]> | To determine a remote control signal in the phase method, three patterns of data waveform and preceding data are required. In addition, the signal needs to start from data "11". Page 555 2023/07/21 TOSHIBA TMPM362F10FG # 17. Watchdog Timer(WDT) The watchdog timer (WDT) is for detecting malfunctions (runaways) of the CPU caused by noises or other disturbances and remedying them to return the CPU to normal operation. If the watchdog timer detects a runaway, it generates a INTWDT interrupt or reset. Note: INTWDT interrupt is a factor of the non-maskable interrupts (NMI). Also, the watchdog timer notifies of the detecting malfunction to the external peripheral devices from the watchdog timer pin (WDTOUT) by outputting "Low". ### 17.1 Configuration Figure 17-1shows the block diagram of the watchdog timer. Figure 17-1 Block Diagram of the Watchdog Timer Page 557 2023/07/21 17.2 Register TMPM362F10FG ### 17.2 Register The followings are the watchdog timer control registers and addresses. Base Address = 0x400F\_2000 | Register name | Address(Base+) | | |---------------------------------|----------------|--------| | Watchdog Timer Mode Register | WDMOD | 0x0000 | | Watchdog Timer Control Register | WDCR | 0x0004 | ### 17.2.1 WDMOD(Watchdog Timer Mode Register) | | | | | | $\overline{}$ | | | | |-------------|------|----|------|-------|---------------|---------|------------|----| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | bit symbol | - | - | - | - | -// | - | 75/ | - | | After reset | 0 | 0 | 0 | 0 | 9 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | (/19)) | 18 | (17) | 16 | | bit symbol | - | - | - | - ( | | - < | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0/ | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | ) 9 | 8 | | bit symbol | - | - | - | | · - | | ) <u>-</u> | - | | After reset | 0 | 0 | 0 | ( 0 ) | 0 | ((/o')) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | WDTE | | WDTP | | <u> </u> | 12WDT | RESCR | - | | After reset | 1 | 0 | 0 | 0 | 0 | )) 0 | 1 | 0 | | Bit | Bit Symbol | Type | Function | |------|------------|----------------------------------------|-------------------------------------------------------| | 31-8 | _ | R | Read as 0. | | 7 | WDTE | R/W | Enable/Disable control | | | | | 0:Disable | | | | | 1:Enable | | 6-4 | WDTP[2:0] | R/W | Selects WDT detection time(Refer toTable 17-1) | | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 000: 2 <sup>15</sup> /fsys 100: 2 <sup>23</sup> /fsys | | | | | 001; 2 <sup>17</sup> /fsys 101; 2 <sup>25</sup> /fsys | | | ^ ^ | | 010: 2 <sup>19</sup> /fsys 110:Setting prohibited. | | | | | 011: 2 <sup>21</sup> /fsys 111:Setting prohibited. | | 3 | - | $R \cup $ | Read as 0. | | 2 | I2WDT | R/W | Operation when IDLE mode | | ( | | ) | 0: Stop | | | | | 1:In operation | | 1/ | RESCR | R/W | Operation after detecting malfunction | | | | | 0: INTWDT interrupt request generates. (Note) | | | | | 1: Reset | | 0 | | R/W | Write 0. | Note: INTWDT interrupt is a factor of the non-maskable interrupts (NMI). Table 17-1 Detection time of watchdog timer (fc = 64MHz) | Clock gear value | WDMOD <wdtp[2:0]></wdtp[2:0]> | | | | | | | | | |---------------------------------|-------------------------------|----------|----------|-----------|-----------|-----------|--|--|--| | CGSYSCR <gear[2:0]></gear[2:0]> | 000 | 001 | 010 | 011 | 100 | 101 | | | | | 000 (fc) | 0.51 ms | 2.05 ms | 8.19 ms | 32.77 ms | 131.07 ms | 524.29 ms | | | | | 100 (fc/2) | 1.02 ms | 4.10 ms | 16.38 ms | 65.54 ms | 262.14 ms | 1.05 s | | | | | 101 (fc/4) | 2.05 ms | 8.19 ms | 32.77 ms | 131.07 ms | 524.29 ms | 2.10 s | | | | | 110 (fc/8) | 4.10 ms | 16.38 ms | 65.54 ms | 262.14 ms | 1.05 s | 4.19 s | | | | Page 559 2023/07/21 17.2 Register TMPM362F10FG ### 17.2.2 WDCR (Watchdog Timer Control Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | | | | |-------------|----|------|----|----|--------|-------|----|----|--|--|--| | bit symbol | - | - | - | - | - | - > | - | - | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | bit symbol | - | 1 | ı | 1 | - | ( ) } | - | - | | | | | After reset | 0 | 0 | 0 | 0 | 0 | ٦ | 0 | 0 | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | | | | bit symbol | | WDCR | | | | | | | | | | | After reset | - | - | - | - | ((///) | | | - | | | | TMPM362F10FG ### 17.3 Operations ### 17.3.1 Basic Operation The Watchdog timer is consists of the binary counters that work using the system clock (fsys) as an input. Detecting time can be selected between 2<sup>15</sup>, 2<sup>17</sup>, 2<sup>19</sup>, 2<sup>21</sup>, 2<sup>23</sup> and 2<sup>25</sup> by the WDMOD<WDTP[2:0]>. The detecting time as specified is elapsed, the watchdog timer interrupt (INTWDT) generates, and the watchdog timer out pin (WDTOUT) output "Low". To detect malfunctions (runaways) of the CPU caused by noise or other disturbances, the binary counter of the watchdog timer should be cleared by software instruction before INTWDT interrupt generates. If the binary counter is not cleared, the non-maskable interrupt generates by INTWDT. Thus CPU detects malfunction (runway), malfunction countermeasure program is performed to return to the normal operation. Additionally, it is possible to resolve the problem of a malfunction (runaway) of the CPU by connecting the watchdog timer out pin to reset pins of peripheral devices. ### 17.3.2 Operation Mode and Status The watchdog timer begins operation immediately after a reset is cleared If not using the watchdog timer, it should be disabled. The watchdog timer cannot be used as the high-speed frequency clock is stopped. Before transition to below modes, the watchdog timer should be disabled. In IDLE2 mode, its operation depends on the WDMOD <I2WDT> setting. - STOP mode - SLEEP mode - SLOW mode - BACKUP STOP mode - BACKUP SLEEP mode Also, the binary counter is automatically stopped during debug mode. Page 561 2023/07/21 ### 17.4 Operation when malfunction (runaway) is detected ### 17.4.1 INTWDT interrupt generation In the Figure 17-2 shows the case that INTWDT interrupt generates (WDMOD<RESCR>="0"). When an overflow of the binary counter occurs, INTWDT interrupt generates. It is a factor of non-maskable interrupt (NMI). Thus CPU detects non-maskable interrupt and performs the countermeasure program. The factor of non-maskable interrupt is the plural. CGNMIFLG identifies the factor of non-maskable interrupts. In the case of INTWDT interrupt, CGNMIFLG<NMIFLG0> is set. When INTWDT interrupt generates, simultaneously the watchdog timer out ( $\overline{WDTOUT}$ ) output "Low". $\overline{WDTOUT}$ becomes "High" by the watchdog timer clearing that is writing clear code 0x4E to the WDCR register. Figure 17-2 INTWDT interrupt generation ### 17.4.2 Internal reset generation Figure 17-3 shows the internal reset generation (WDMOD<RESCR>="1"). MCU is reset by the overflow of the binary counter. In this case, reset status continues for 32 states. A clock is initialized so that input clock (fsys) is the same as a high-speed frequency clock (fosc). This means fsys = fosc. Figure 17-3 Internal reset generation Page 563 2023/07/21 17.5 Control register TMPM362F10FG ### 17.5 Control register The watchdog timer (WDT) is controlled by two control registers WDMOD and WDCR. ### 17.5.1 Watchdog Timer Mode Register (WDMOD) Specifying the detection time of the watchdog timer <WDTP[2:0]>. Set the watchdog timer detecting time to WDMOD<WDTP[2:0]>. After reset, it is initialized to WDMOD<WDTP[2:0]> = "000". 2. Enabling/disabling the watchdog timer <WDTE>. When resetting, WDMOD <WDTE> is initialized to "1" and the watchdog timer is enabled. To disable the watchdog timer to protect from the error writing by the malfunction, first <WDTE> bit is set to "0", and then the disable code (0xB1) must be written to WDCR register. To change the status of the watchdog timer from "disable" to "enable," set the WDTE> bit to 3. Watchdog timer out reset connection <RESCR> This register specifies whether WDTOUT is used for internal reset or interrupt. After reset, WDMOD<RESCR> is initialized to "1", the internal reset is generated by the overflow of binary counter. ### 17.5.2 Watchdog Timer Control Register(WDCR) This is a register for disabling the watchdog timer function and controlling the clearing function of the binary counter. ### 17.5.3 Setting example ### 17.5.3.1 Disabling control By writing the disable code (0xB1) to this WDCR register after setting WDMOD <WDTE> to "0," the watchdog timer can be disabled and the binary counter can be cleared. ### 17.5.3.2 Enabling control Set WDMOD <WDTE> to "1". ### 17.5.3.3 Watchdog timer clearing control Writing the clear code (0x4E) to the WDCR register clears the binary counter and it restarts counting. WDCR $$\leftarrow$$ 0 1 0 0 1 1 0 Writes the clear code (0x4E). ### 17.5.3.4 Detection time of watchdog timer In the case that 2<sup>21</sup>/fsys is used, set "011" to WDMOD<WDTP[2:0]>. Page 565 2023/07/21 17.5 Control register TMPM362F10FG TOSHIBA TMPM362F10FG ### 18. Key-on Wakeup ### 18.1 Outline - TMPM362F10FG has 4 key input, KWUP0 to KWUP3, which can be used for releasing STOP mode or for external interrupts. Note that interrupt processing is executed with one interrupt factor for 4 inputs. (This is programmed in the CG block) Each key input can be configured to be used or not, by programming (KWUPCRn<KEYnEN>). - The active state of each input can be configured to the rising edge, the falling edge, both edge, the high level or the low level, by programming KWUPCRn<KEYn>. - An interrupt request is cleared by programming the key interrupt request clear register KWUPCLR in the interrupt processing. - The KWUP input pins have pull-up functions, which can be switched between static pull-up and dynamic pull-up by programming the KWUPCRn<DPEn>. This programming is needed for each of 4 inputs. Figure 18-1 Key-on Wakeup Block Diagram Page 567 2023/07/21 18.3 Register in detail TMPM362F10FG ### 18.3 Register in detail ### 18.3.1 Register list Base Address = 0x400F\_1000 | Register name | Address(Base+) | | | |------------------------------|----------------|--------|--| | Control register 0 | KWUPCR0 | 0x0000 | | | Control register 1 | KWUPCR1 | 0x0004 | | | Control register 2 | KWUPCR2 | 0x0008 | | | Control register 3 | KWUPCR3 | 0x000C | | | Port monitor register | KWUPPKEY | 0x0080 | | | Pull-up cycle register | KWUPCNT | 0x0084 | | | Interrupt all clear register | KWUPCLR | 0x0088 | | | Interrupt monitor register | KWUPINT | 0x008C | | # 18.3.2 KWUPCR0 (Control register 0) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|--------|-------|--------------|------|-----|--------------|----|--------| | bit symbol | - | - | - < | | | | - | - | | After reset | 0 | 0 | 0 | 0 | //0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | ) 18 | 17 | 16 | | bit symbol | - | - | _[( | )) - | | <b>/</b> / - | - | - | | After reset | 0 | 0 | ( | 0 | _ 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - ( | | - ~ | | - | - | - | | After reset | 0 | 0 ((/ | / <b>\</b> 0 | 0 | 3/0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 477 | 3 | 2 | 1 | 0 | | bit symbol | DPE0 < | | KEY0 | | ) - | 1 | - | KEY0EN | | After reset | 0 | 0 | 1 | | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | DPE0 | R/W | Selected static pull-up or dynamic pull-up. | | | | ĺ , | 0: Static pull-up | | | | ( | 1: Dynamic pull-up | | 6-4 | KEY0[2:0] | R/W | Selected the input active status of KWUP0. | | | | | 000:"Low" level | | | | | 001:"High" level | | | | | 010: falling edge | | | | | 011: rising edge | | | | | 100: Both edge | | | | | Except above: Reserved | | 3-1 | - | R | Read as "0". | | 0 | KEY0EN | R/W | Selected enable or disable KWUP interrupt of KWUP0. | | | | | 0: Disable | | | | | 1: Enable | # 18.3.3 KWUPCR1 (Control register 1) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|------|----|------|----|----------|-------|-------|--------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (0) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | 1 | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 7 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | DPE1 | | KEY1 | | | > - | 2-// | KEY1EN | | After reset | 0 | 0 | 1 | 0 | ((/o/ \) | 0 | ( ) ( | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | DPE1 | R/W | Selected static pull-up or dynamic pull-up. | | | | | 0: Static pull-up | | | | | 1: Dynamic pull-up | | 6-4 | KEY1[2:0] | R/W | Selected the input active status of KWUP1. | | | | | 000:"Low" level | | | | | 001:"High" level | | | | | 010: falling edge | | | | | 011: rising edge | | | | | 100: Both edge | | | | | Except above: Reserved | | 3-1 | _ | R | Read as "0". | | 0 | KEY1EN | /R/W | Selected enable or disable KWUP interrupt of KWUP1. | | | < | | 0: Disable | | | | | 1: Enable | 18.3 Register in detail TMPM362F10FG # 18.3.4 KWUPCR2 (Control register 2) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|------|----|------|----|----------|--------------|------|--------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | DPE2 | | KEY2 | | | <del>-</del> | 2-// | KEY2EN | | After reset | 0 | 0 | 1 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | DPE2 | R/W | Selected static pull-up or dynamic pull-up. | | | | | 0: Static pull-up | | | | | 1: Dynamic pull-up | | 6-4 | KEY2[2:0] | R/W | Selected the input active status of KWUP2. | | | | | 000:"Low" level | | | | | 001:"High" level | | | | | 010: falling edge | | | | | 011: rising edge | | | | | 100: Both edge | | | | | Except above: Reserved | | 3-1 | - | R | Read as "0" | | 0 | KEY2EN | R/W | Selected enable or disable KWUP interrupt of KWUP2. | | | | | 0: Disable | | | | | 1: Enable | # 18.3.5 KWUPCR3 (Control register 3) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|------|----|------|----|----------|-------|------|--------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | DPE3 | | KEY3 | - | | > - | 2-// | KEY3EN | | After reset | 0 | 0 | 1 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | | | | | | |------|------------|------|-----------------------------------------------------|--|--|--|--|--| | 31-8 | - | R | Read as "0". | | | | | | | 7 | DPE3 | R/W | Selected static pull-up or dynamic pull-up. | | | | | | | | | | 0: Static pull-up | | | | | | | | | | 1: Dynamic pull-up | | | | | | | 6-4 | KEY3[2:0] | R/W | Selected the input active status of KWUP3. | | | | | | | | | | 000:"Low" level | | | | | | | | | | 001:"High" level | | | | | | | | | | 010: falling edge | | | | | | | | | | 1: rising edge | | | | | | | | | | 100: Both edge | | | | | | | | | | Except above: Reserved | | | | | | | 3-1 | - | R | Read as "0". | | | | | | | 0 | KEY3EN | R/W | Selected enable or disable KWUP interrupt of KWUP3. | | | | | | | | < | | 0: Disable | | | | | | | | | | 1: Enable | | | | | | 18.3 Register in detail TMPM362F10FG ### 18.3.6 KWUPPKEY (Port monitor register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|-------|-------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | 1 | 1 | - | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | PKEY3 | PKEY2 | PKEY1 | PKEY0 | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | - | R | Read as "0". | | 3-0 | PKEY3 to<br>PKEY0 | R | PORT status 0:"Low" 1:"High" For port status, it can be monitored the external status with KWUPPKEY <pkeyn>. The monitoring is sampled in dynamic pull-up period.</pkeyn> | ### 18.3.7 KWUPCNT (Pull-up cycle register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|--------------|------|----| | bit symbol | - | - | - | - | - | - | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ٦ | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | Tź | 2S | 1 | 18 | 2-// | - | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-6 | - | R | Read as "0". | | 5-4 | T2S[1:0] | R/W | Dynamic pull-up cycle 00: 256/fs (7.8 ms @ fs = 32.768 kHz) 01: 512/fs (15.6 ms @ fs = 32.768 kHz) 10: 1024/fs (31.3 ms @ fs = 32.768 kHz) 11: 2048/fs (62.5 ms @ fs = 32.768 kHz) Repeats dynamic pull-up operation for the T2 cycle by <t2s[1:0]>.</t2s[1:0]> | | 3-2 | T1S[1:0] | R/W | Dynamic pull-up period 00: 2/fs (61.0 μs @fs = 32.768 kHz) 01: 4/fs (122.1 μs @fs = 32.768 kHz) 10: 8/fs (244.1 μs @fs = 32.768 kHz) 11: 16/fs (488.3 μs @fs = 32.768 kHz) Activate the pull-up during T1 period by <ts[1:0]>, the remaining period is not activated.</ts[1:0]> | | 1-0 | - | R | Read as "0". | Dynamic pull-up operation is as following. Figure 18-2 Dynamic pull-up operation Note 1: Activate fs during the dynamic pull-up used. Note 2: After changed dynamic pull-up setting, wait key input for a T1 period. Page 573 2023/07/21 18.3 Register in detail TMPM362F10FG ### 18.3.8 KWUPCLR (All interrupt request clear register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|--------------|-----|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | KEY | CLR | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------|------|-------------------------------------------------------------| | 31-4 | - | R | Read as "0". | | 3-0 | KEYCLR[3:0] | W | All interrupt request of KWUP is cleared by writing "1010". | ### 18.3.9 KWUPINT (Interrupt monitor register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|---------|---------|---------| | bit symbol | - | - | - | - | - | - > | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | 1 | - | (()) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | KEYINT3 | KEYINT2 | KEYINT1 | KEYINT0 | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|-----------------------|------|----------------------| | 31-4 | - | R | Read as "0". | | 3-0 | KEYINT3 to<br>KEYINT0 | R | Interrupt 0:No 1:Yes | When KWUPCRn<KEYnEN>="1" and activated signal into the key-on wakeup port, the <KEYINTn> corresponding channel of KWUPINT will be set to "1" for the interrupt execution. KWUPINT is read only register, due to the reading this register corresponding bit set to "1" and interrupt request will becleared. That one all can be cleared at once by the KWUPCLR register. When setting the active status to "Level" input by KWUPCRn<KEYn>, KWUPINT corresponding bit for a key-on wakeup is kept "1" in reading without changing a external input setting function to nothing. Page 575 2023/07/21 #### 18.4 Key-on Wakeup Operation ### 18.4 Key-on Wakeup Operation TMPM362F10FG has 4 key input pins, KEY0 to KEY3. Program the CGIMCGF<INTLEN> register in the CG to determine whether to use the key inputs for releasing the STOP mode or for normal interrupts. Setting <INTLEN> to "1" causes all the key inputs, KEY0 to KEY3, to be used for interrupts for releasing the STOP mode. Program KWUPCRn<KEYnEN> to enable or disable interrupt inputs for each key input pin. Also, program KWUPCRn<KEYn> to define the active state of each key input pin to be used. Detection of key inputs is carried out in the KWUP block, and the detection results are notified to the CGIMCGF in the CG as the active high level. Therefore, program CGIMCGF<EMCGL[2:0]> to "001" to determine the detection level to the high level. Setting CGINCGF<INTLEN> to "0" (default) configures all the input pins, KEY0 to KEY3 to the normal interrupts. In this case, to be detected interrupt request by the CPU, "High" pulse or "High" level signal must be input. Program KWUPCRn in the same way to enable or disable each key input and define their active states. Writing "1010" to KWUPCLR<KEYCLR[3:0]> during interrupt processing clears all the key interrupt requests. Note: If two or more key inputs are generated, all the key input requests will be cleared by clearing interrupt requests. ### 18.5 Pull-up Function Each key input has the pull-up function and can be programmed by setting the register in the port. When a static pull-up is set, it can not be depend on KWUPCRn<KEYnEN> and the pull-up be used. Regarding to dynamic pull-up, refer to "18.3.7 KWUPCNT (Pull-up cycle register)". ### 18.5.1 In case of using KWUP inputs with pull-up enabled a. When you make the first setting after turning the power on (Example; port J7 withe interrupt at both edge) ``` PJFR2<PJ7F2> The function is set to KWUP3 PJPUP<PJ7UP> Pull-up on control Enable input function PJIE<PJ7IE> : Disable interrupt KWUPCR3<KEY3EN> Change active status (both edge) KWUPCR3<KEY3[2:0]> Wait completing pull-up Clear interrupt request KWUPCLR<KEYCLR[3:0]> KWUPCR3<KEY3EN> : Enable interrupt : Change active level ("High" level) CGIMCGF<EMCGL[2:0]> Enable INTKWUP CGIMCGF<INTLEN> ``` b. When changing the active state of KWUP input during operation ``` Interrupt enable clear register 2 [1] : Disable INTKWUP KWUPCR3<KEY3EN> Disable interrupt KWUPCR3<KEY3[2:0]> 0 : Change active status ("Low" level) KWUPCLR<KEYCLR[3:0]> : Clear interrupt request KWUPCR3<KEY3EN> : Enable interrupt : Set interrupt priority Interrupt priority setting register <PRI_33> (***= 000 to 111) Interrupt enable set register 2 [1] : Enable INTKWUP ``` c. When enabling KWUP input during operation ``` Interrupt enable clear register 2 [1] : Disable INTKWUP KWUPCR3<KEY3EN> : Disable interrupt KWUPCR3<KEY3[2:0]> : Set active status (***= 000 to 100) KWUPCLR<KEYCLR[3:0]> : Clear interrupt request KWUPCR3<KEY3EN> : Enable interrupt : Set interrupt priority Interrupt priority setting register <PRI 33> (***= 000 to 111) : Enable INTKWUP Interrupt enable set register 2 [1] ``` Page 577 2023/07/21 ### 18.5.2 In case of using KWUP inputs with pull-up disabled a. When you make the first setting after turning the power on PJFR2<PJ7F2> : The function is set to KWUP3 PJPUP<PJ7UP> : Pull-up off control PJIE<PJ7IE> : Enable input function : Disable interrupt KWUPCR3<KEY3EN> : Set active status ("Low" level) KWUPCR3<KEY3[2:0]> : Clear interrupt request KWUPCLR<KEYCLR[3:0]> KWUPCR3<KEY3EN> : Interrupt enable CGIMCGF<EMCGL[2:0]> ; Change active level ("High" level) : Enable INTKWUP CGIMCGF<INTLEN> b. When changing the active sate of KWUP input during operation : Disable INTKWUP Interrupt enable clear register 2 [1] KWUPCR3<KEY3EN> : Disable interrupt KWUPCR3<KEY3[2:0]> : Change active status (\*\*\*= 000 to 100) KWUPCLR<KEYCLR[3:0]> : Clear interrupt request KWUPCR3<KEY3EN> Enable interrupt Set interrupt priority Interrupt priority setting register <PRI\_33> (\*\*\*= 000 to 111) Interrupt enable set register 2 [1] :Enable INTKWUP c. When enabling KWUP input during operation Interrupt enable clear register 2 [1] : Disable INTKWUP KWUPCR3<KEY3EN> : Disable interrupt KWUPCR3<KEY3[2:0]> : Change active status (\*\*\*= 000 to 100) KWUPCLR<KEYCLR[3:0]> : Clear interrupt request KWUPCR3<KEY3EN> : Enable interrupt : Set interrupt priority Interrupt priority setting register <PRI\_33> (\*\*\*= 000 to 111) Interrupt enable set register 2 [1] : Enable INTKWUP TMPM362F10FG ### 18.6 KWUP input Detection Timing 1. PJPUP<PJnUP>="1", KWUPCRn<DPEn>="0" with always pull-up The active state of each key input can be defined to the high or low level or to the rising or falling edges by setting KWUPCRn<KEYn>. The active state of key inputs are continuously detected. 2. PJPUP<PJnUP>="1", KWUPCRn<DPEn>="1" with dynamic pull-up Detection of the active state of each key input (interrupt detection) is carried out at the edge one-clock before fs at the end of the T1 period. Therefore, a key input not shorter than the T2 period is needed. There is a delay up to the T2 period before key input detection. The figure below shows an example of defining the active state to the falling edge. Page 579 2023/07/21 TOSHIBA TMPM362F10FG ### 19. Backup module ### 19.1 Features The BACKUP mode, one of the system operation modes, enable the MCU to operate in the low power consumption. By cutting electricity to the entire block, such as CPU or other peripheral IPs, other than the backup module, this mode significantly reduces power consumption. The BACKUP mode contains two modes: - BACKUP SLEEP mode (enabling low frequency oscillator) - BACKIUP STOP mode (disabling low frequency oscillator) Power shutdown blocks in the BACKUP mode ### 19.2 Block Diagram Figure 19-1 Power shutdown blocks in the backup mode Page 581 2023/07/21 19.3 BACKUP Mode Operation TMPM362F10FG ### 19.3 BACKUP Mode Operation The BACKUP mode only corresponds to the single chip mode (MCU starts from the built-in flash memory after reset). In the BACKUP mode, single boot mode (MCU starts from built-in boot ROM after reset) is not supported. ### 19.3.1 Operable peripherals in the BACKUP mode · In the BACKUP SLEEP mode Port output, Key-on-wakeup (KWUP), CEC, remote control circuit (RMC), real-time clock (RTC), low speed oscillator, data in BACKUP RAM (8KB) · In the BACKUP STOP mode Port output, Key-on-wakeup (KWUP), data in BACKUP RAM (8KB) #### 19.3.1.1 Transition to the BACKUP mode Figure 19-2 shows the state transition between NORMAL mode, SLOW mode and BACKUP mode (BACKUP SLEEP and BACKUP STOP). The BACKUP mode (BACKUP SLEEP and BACKUP STOP) will return the preceding mode of transition by release source. In addition, each mode changes to the reset processing routine if the reset operation occurs. Figure 19-2 BACKUP Mode Transition Diagram Note 1: In case that low-speed oscillator is stopped in the NORMAL mode, make sure to start the low-speed oscillation and confirm the stable oscillation before changing to BACKUP SLEEP mode. Note 2: The program for changing to the BACKUP mode must be executed in the built-in flash ROM or built-in RAM. Note 3: Do not release BACKUP mode by reset. #### 19.3.1.2 Backup Transition Flow ### (1) Preparing for BACKUP mode The preparation program for changing to the backup mode must be executed in the built-in flash ROM or built-in RAM. #### 1. Stopping peripherals and saving data Both in the NORMAL mode and SLOW mode stop peripheral function including DMAC, SMC and WDT. In case of transition to BACKUP SLEEP mode, no need to stop peripheral functions (CEC, RMC, RTC and KWUP) which are used in BACKUP SLEEP mode. It is necessary to save data to preserved in BACKUP RAM. BACKUP RAM is used only 8KB data from 0x2000\_E000 to 0x2000\_FFFF. #### 2. Prohibit the interrupt To prevent from obstruction a transition to BACKUP mode, interrupt request set to disable if needed. It is note that NMI interrupt and INTRTC interrupt request cannot be disabled so that these interrupt requests must be avoided in advance. ### 3. Setting of port keep function (CGSTBYCR<PTKEEP>) Port keep function retains the port status of the momentary when CGSTBCR<PTKEEP> is set to "1". Object ports are A to H, K, O, P, SWDIO, $\overline{\text{NMI}}$ . Port keep function is capable of retaining input enable / disable, port 0 / 1 output status and on / off status of pull-up / pull-down register. By these settings made before the transition to the BACKUP mode, port keep function can hold the port status. When using the port keep function, port register of each port must be set properly. The input / output status of port I, J, L, M and N are depend on the port register regardless the port keep function. The interrupt of BACKUP mode is set by using these ports. All unnecessary ports must be set to disable by the input enable control register. #### 4. Clock related setting and warm up time Stop PLL circuit by setting CGOSCCR<PLLON>="0". Set high-speed clock to fc (1/1) by CGSYSCR<GEAR[2:0]>="000". Using BACKUP SLEEP is needed for starting low-speed oscillator by CGOSCCR<XTEN>. In addition, it is necessary to setting warm up time returning from BACKUP mode by CGOSCCR<WUPT[11:0]><WUPTL[2:0]>. The warm up time is referred to the section "Clock / Mode control". Page 583 2023/07/21 ### (2) Transition to BACKUP mode 1. Setting modes and clearing release source of BACKUP mode By the CGSTBYCR<STBY> register, set to the BACKUP STOP mode or BACKUP SLEEP mode. 2. Transition to the BACKUP mode Clear the interrupt which releases from BACKUP mode, then execute WFI instruction Precautions for the use of the BACKUP mode (about debug tool) The communication with debug tool is disconnected, if MCU changes to the BACKUP mode. In this case, it is necessary to reconnect to debug tool. - (3) Returning from backup mode (Releasing) - 1. Releasing source of BACKUP mode Releasing source of BACKUP STOP and BACKUP SLEEP shown as below. | BACKUP mode | Releasing source of BACKUP mode | |--------------|-------------------------------------------------------------------------------------| | BACKUP STOP | INT0 to 4,8,E,F, INTKWUP (Static) | | BACKUP SLEEP | INT0 to 4,8,E,F, INTKWUP (Dynamic / Static), INTRTC, INTCECRX, INTRMCRX0, INTRMCRX1 | 2. Releasing operation by releasing source of BACKUP mode If the event of releasing source are received, regulator starts to supply power to the shut down block. Depending on the returned modes, high-speed oscillator and low-speed oscillator will start operation. The warm up timer will starts when the oscillation becomes stable. During warm up time, internal reset signal of power shut down block which returned from BACKUP mode is continuing active level. Internal reset is cleared after warm up time has elapsed, and then MCU returns to the preceding mode of BACKUP mode. Precaution after BACKUP mode released - By reading CGRSTFLG register, it can be found which reset are occurred. - Make sure to perform the port A, B, C, D, E, F, G, H, K, O and P setting before releasing port keep function by (CGSTBYCR<PTKEEP>="0"). #### 19.3.1.3 Transition Flowchart Page 585 2023/07/21 ### 19.3.1.4 BACKUP Mode Timing Chart Figure 19-4 BACKUP mode sequence Note: "Figure 19-4 BACKUP mode sequence" shows the transition modes ; NORMAL→BACKUP STOP→NORMAL of NORMAL→BACKUP SLEEP→NORMAL. In this transition, a clock for warm up counter is used high-speed oscillator. The warm up time must be set 500Éps or more. TOSHIBA TMPM362F10FG # 20. Analog / Digital Converter (ADC) ## 20.1 Outline TMPM362F10FG has a 10-bit, sequential-conversion analog / digital converter (AD converter). This AD converter is equipped with 16 analog input channel. These 16 analog input channels (pins AIN0~AIN15) are also used as input / output ports. Note 1: To assure conversion accuracy, the specified value must be set to the ADCBAS register. Note 2: If it is necessary to reduce a power current by operating the TMPM362F10FG in IDLE or STOP mode and if either case shown below is applicable, you must first stop the AD converter and then execute the instruction to put the TMPM362F10FG into standby mode. Page 587 2023/07/21 20.2 Configuration TMPM362F10FG ## 20.2 Configuration Figure 20-1 shows the block diagram of this AD converter. Figure 20-1 AD Converter Block Diagram ## 20.3 Registers ## 20.3.1 Register list The control registers and addresses of the AD converter are as follows. The AD converter is controlled by the AD mode control registers (ADMOD0 through ADMOD5). The result of AD conversion is stored in the eight AD conversion result registers, ADREG08 through ADREG7F. The highest-priority conversion result is stored in the register ADREGSP. To assure conversion accuracy, the specified value must be set to the ADCBAS register. Base Address = 0x400F\_0000 | Register name | | Address (Base+) | |-----------------------------------------|---------|-----------------| | Conversion Clock Setting Register | ADCLK | 0x0000 | | Mode Control Register 0 | ADMOD0 | 0x0004 | | Mode Control Register 1 | ADMOD1 | 0x0008 | | Mode Control Register 2 | ADMOD2 | 0x000C | | Mode Control Register 3 | ADMOD3 | 0x0010 | | Mode Control Register 4 | ADMOD4 | 0x0014 | | Mode Control Register 5 | ADMOD5 | 0x0018 | | Conversion Accuracy Setting Register | ADCBAS | 0x0020 | | Reserved | - | 0x0024 | | Reserved | √ /-/ | 0x0028 | | Conversion Result Register 08 | ADREG08 | 0x0030 | | Conversion Result Register 19 | ADREG19 | 0x0034 | | Conversion Result Register 2A | ADREG2A | 0x0038 | | Conversion Result Register 3B | ADREG3B | 0x003C | | Conversion Result Register 4C | ADREG4C | 0x0040 | | Conversion Result Register 5D | ADREG5D | 0x0044 | | Conversion Result Register 6E | ADREG6E | 0x0048 | | Conversion Result Register 7F | ADREG7F | 0x004C | | Conversion Result Register SP | ADREGSP | 0x0050 | | Conversion Result Comparison Register 0 | ADCMP0 | 0x0054 | | Conversion Result Comparison Register 1 | ADCMP1 | 0x0058 | Note: Access to the "Reserved" address is prohibited. # 20.3.2 ADCBAS (Conversion Accuracy Setting Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|-----|---------|-------|-------|----| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( ) } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | | | ADC | BAS | > | 2// | | | After reset | 0 | 0 | 1 | 1 | ((// \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | | Function | | |------|-------------|------|------------------|----------|------| | 31-8 | - | R | Read as "0". | | (Co) | | 7-0 | ADCBAS[7:0] | R/W | Write as "0x58". | | | # 20.3.3 ADCLK (Conversion Clock Setting Register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|-------|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | | TS | SH | | | > | ADCLK | | | After reset | 1 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|---------------------------------| | 31-8 | _ | R | Read as "0". | | 7-4 | TSH[3:0] | R/W | Select the AD sample hold time. | | | | | 1000: 8 conversion clock | | | | | 1001: 16 conversion clock | | | | | 1010: 24 conversion clock | | | | | 1011: 32 conversion clock | | | | | 0011: 64 conversion clock | | | | | 1100: 128 conversion clock | | | | | 1101: 512 conversion clock | | | | | Others : Reserved | | 3 | _ | R | Read as "0". | | 2-0 | ADCLK[2:0] | R/W | Select the AD conversion clock | | | | | 000: fc/ | | | | | 001: fc/2 | | | | | 010: fc/4 | | | 4 | | 011: fe/8 | | | | | 100: fc/16 | | | | | Others : Reserved | A clock count required for conversion is 46 clocks at the minimum. Examples of sample hold time and conversion time as shown as below. (Example : If fc = 64MHz) | 4TOLUE 035 | County by Idd History | Conversion time( <adclk[2:0]> setting)</adclk[2:0]> | | | | | | | |-----------------------------|-----------------------|-----------------------------------------------------|------------|------------|------------|-------------|--|--| | <tsh[3:0]></tsh[3:0]> | Sample hold time | 000 (fc) | 001 (fc/2) | 010 (fc/4) | 011 (fc/8) | 100 (fc/16) | | | | 1000 (8 conversion clock) | 0.125 µs | Reserved | 1.44µs | 2.88µs | 5.75µs | 11.5µs | | | | 1001 (16 conversion clock) | 0.25 µs | Reserved | 1.69µs | 3.38µs | 6.75µs | 13.5µs | | | | 1010 (24 conversion clock) | 0.375 µs | Reserved | 1.94µs | 3.88µs | 7.75µs | 15.5µs | | | | 1011 (32 conversion clock) | 0.5 µs | Reserved | 2.19µs | 4.38µs | 8.75µs | 17.5µs | | | | 0011 (64 conversion clock) | 1.0 µs | Reserved | 3.19µs | 6.38µs | 12.75µs | 25.5µs | | | | 1100 (128 conversion clock) | 2.0 µs | Reserved | 5.19µs | 10.38µs | 20.75µs | 41.5µs | | | | 1101 (512 conversion clock) | 8.0 µs | Reserved | 17.19µs | 34.38µs | 68.75µs | 137.5µs | | | Page 591 2023/07/21 ## (Example : If fc = 40MHz) | 4TOLUGAGE | Caranta hald time | Conversion time( <adclk[2:0]> setting)</adclk[2:0]> | | | | | | | | |-----------------------------|-------------------|-----------------------------------------------------|------------|------------|------------|-------------|--|--|--| | <tsh[3:0]></tsh[3:0]> | Sample hold time | 000 (fc) | 001 (fc/2) | 010 (fc/4) | 011 (fc/8) | 100 (fc/16) | | | | | 1000 (8 conversion clock) | 0.2 μs | 1.15µs | 2.3µs | 4.6µs | 9.2µs | 18.4µs | | | | | 1001 (16 conversion clock) | 0.4 µs | 1.35µs | 2.7µs | 5.4µs | 10.8µs | 21.6µs | | | | | 1010 (24 conversion clock) | 0.6 µs | 1.55µs | 3.1µs | 6.2µs | 12.4µs | 24.8µs | | | | | 1011 (32 conversion clock) | 0.8 μs | 1.75µs | 3.5µs | 7.0µs | 14.0µs | 28.0µs | | | | | 0011 (64 conversion clock) | 1.6 µs | 2.55µs | 5.1µs | 10.2µs | 20.4µs | 40.8µs | | | | | 1100 (128 conversion clock) | 3.2 µs | 4.15µs | 8.3µs | 16.6µs | 33.2µs | 66.4µs | | | | | 1101 (512 conversion clock) | 12.8 µs | 13.75µs | 27.5µs | 55.0µs | 110.0µs | 220.0µs | | | | Note 1: Do not change the setting of the AD conversion clock during AD conversion. ## 20.3.4 ADMOD0 (Mode Control Register 0) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|-------|-------|----|----|----|--------|------|-----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | 1 | - | - (( | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | _ | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | EOCFN | ADBFN | - | IT | M | REPEAT | SCAN | ADS | | After reset | 0 | 0 | 0 | 0 | o/ | 0 | 0 | 0 | | Bit | Bit Symbol | Type | Function | |------|------------|---------------------------|-------------------------------------------------------------------------------------------------| | | Bit Symbol | Туре | | | 31-8 | - | R | Read as "0". | | 7 | EOCFN | R | Normal AD conversion completion flag (note1) | | | | | 0: Before or during conversion | | | | | 1: Completion | | 6 | ADBFN | R | Normal AD conversion busy flag | | | | | 0: Conversion stop | | | | | 1: During conversion | | 5 | _ | R | Read as "0". | | 4-3 | ITM[1:0] | R/W | Specify interrupt in fixed channel repeat conversion mode (refer to the table below and note 2) | | 2 | REPEAT | R/W | Specify repeat mode | | | | | 0: Single conversion mode | | | | | 1: Repeat conversion mode | | 1 | SCAN | R/W | Specify scan mode | | | | | 0: Fixed channel mode | | | | | 1: Channel scan mode | | 0 | ADS | /R/W | Start AD conversion start (note3) | | Ī | | $\langle \langle \rangle$ | 0: Don't care | | | | | 1: Start conversion | | | | | Always read as "0". | Specify AD conversion interrupt in fixed channel repeat conversion mode | | Fixed channel repeat conversion mode | |-----------------------|--------------------------------------------------| | <itm[1:0]></itm[1:0]> | <scan> = "0", <repeat> = "1"</repeat></scan> | | 00 | Generate interrupt once every single conversion. | | 01 | Generate interrupt once every 4 conversions. | | 10 | Generate interrupt once every 8 conversions. | | 11 | Setting prohibited | - Note 1: This bit is "0" cleared when it is read. - Note 2: It is valid only when it's specified in the fixed channel repeat mode (<REPEAT> ="1", <SCAN> = "0"). - Note 3: Conversion must be started after setting the mode. - Note 4: When DMA transfer is executed by utilizing AD conversion completion interrupts, perform software reset first. Then startup a DMA operation (DMA request wait mode), and start ADC setting. Page 593 2023/07/21 ## 20.3.5 ADMOD1 (Mode Control Register 1) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|--------|------|-------|----|----|-------|-----|----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 < | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 3 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | - | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | VREFON | I2AD | ADSCN | - | | AD | CH | | | After reset | 0 | 0 | 0 | 0 | 0/ | 0 | Q | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|-----------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | VREFON | R/W | VREF application control(Note1 and Note2) 0: OFF 1: ON | | 6 | I2AD | R/W | Specify operation mode in IDLE mode 0: STOP 1: Operation | | 5 | ADSCN | R/W | Specify operation mode in channel scan mode 0: 4 channel scan 1: 8 channel scan | | 4 | - | R/W | Write as "0". | | 3-0 | ADCH[3:0] | R/W | Select analog input channel (Refer to the below table.) | ## Select Analog Input Channel | ADMOD0 <scan></scan> | 0 | 1 | 1 | |--------------------------------|---------------|------------------------|------------------------| | | Fixed channel | Channel scan | Channel scan | | ADMOD1 <adch[3:0]></adch[3:0]> | | ( <adscn> = 0)</adscn> | ( <adscn> = 1)</adscn> | | 0000 | AIN0 | AIN0 | AIN0 | | 0001 | AIN1 | AIN0 to AIN1 | AIN0 to AIN1 | | 0010 | AIN2 | AIN0 to AIN2 | AIN0 to AIN2 | | 0011 | AIN3 | AIN0 to AIN3 | AIN0 to AIN3 | | 0100 | AIN4 | AIN4 | AIN0 to AIN4 | | 0101 | AIN5 | AIN4 to AIN5 | AIN0 to AIN5 | | 0110 | AIN6 | AIN4 to AIN6 | AIN0 to AIN6 | | 0111 | AIN7 | AIN4 to AIN7 | AIN0 to AIN7 | | 1000 | AIN8 | AIN8 | AIN8 | | 1001 | AIN9 | AIN8 to AIN9 | AIN8 to AIN9 | | 1010 | AIN10 | AIN8 to AIN10 | AIN8 to AIN10 | | 1011 | AIN11 | AIN8 to AIN11 | AIN8 to AIN11 | | 1100 | AIN12 | AIN12 | AIN8 to AIN12 | | 1101 | AIN13 | AIN12 to AIN13 | AIN8 to AIN13 | | 1110 | AIN14 | AIN12 to AIN14 | AIN8 to AIN14 | | 1111 | AIN15 | AIN12 to AIN15 | AIN8 to AIN15 | Note 1: Before starting AD conversion, write "1" to the <VREFON> bit, wait for 3µs during which time the internal reference voltage should stabilize, and then write "1" to the ADMOD0<ADS>. Note 2: Set <VREFON> to "0" to go into standby mode upon completion of AD conversion. # 20.3.6 ADMOD2 (Mode Control Register 2) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|--------|--------|--------|----|----------|------|-----|----| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (()) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | EOCFHP | ADBFHP | HPADCE | - | | HPA | DCH | | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |------|-------------|------|---------------------------------------------------------------------------------------------------| | 31-8 | _ | R | Read as "0". | | 7 | EOCFHP | R | Top-priority AD conversion completion flag (Note1) 0: Before or during conversion 1: Completion | | 6 | ADBFHP | R | Top-priority AD conversion BUSY flag 0: During conversion halts 1: During conversion | | 5 | HPADCE | R/W | Activate top-priority conversion 0: Don't care 1: Start conversion "0" is always read. | | 4 | _ | R/W | Write as "0". | | 3-0 | HPADCH[3:0] | R/W | Select analog input channel when activating top-priority conversion. (See the table below) | | <hpadch[3:0]></hpadch[3:0]> | Analog input channel when executing top-priority conversion | |-----------------------------|-------------------------------------------------------------| | 0000 | AIN0 | | 0001 | AIN1 | | 0010 | AIN2 | | 0011 | AIN3 | | 0100 | AIN4 | | 0101 | AIN5 | | 0110 | AIN6 | | 0111 | AIN7 | | 1000 | AIN8 | | 1001 | AIN9 | | 1010 | AIN10 | | 1011 | AIN11 | | 1100 | AIN12 | | 1101 | AIN13 | | 1110 | AIN14 | | 1111 | AIN15 | Note 1: This bit is "0" cleared when it is read. Page 595 2023/07/21 Note 2: Specify <HDADCE> after selecting channel. # 20.3.7 ADMOD3 (Mode Control Register 3) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|---------|----|----------|-------|-------|---------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | ADOBIC0 | | ADRI | EGS0 | 2// | ADOBSV0 | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |--------|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | _ | R | Read as "0". | | 7 | _ | R/W | Write as "0". | | 6 | _ | R | Read as "0". | | 5 | ADOBIC0 | R/W | Set the AD monitor function interrupt 0 0: If the value of the conversion result is smaller than the comparison register 0, an interrupt is generated. 1: If the value of the conversion result is bigger than the comparison register 0, an interrupt is generated. | | 4 to 1 | ADREGS0[3:0] | R/W | Select a target conversion result register when using the AD monitor function 0 (See the below table). | | 0 | ADOBSV0 | R/W | AD monitor function 0 0: Disable 1: Enable | ## 20.3.8 ADMOD4 (Mode Control Register 4) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-------|--------|------|-------|----------|------|-------|-----| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | (\)Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4( | 0 | | bit symbol | HADHS | HADHTG | ADHS | ADHTG | | · - | ADI | RST | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------------------------------------------------------------------------------------| | 31-8 | - | R | Read as "0". | | 7 | HADHS | R/W | H/W source for activating top-priority AD conversion 0: External trigger 1: Match with timer register 0 (TB5RG0) | | 6 | HADHTG | R/W | H/W for activating top-priority AD conversion 0: Disable 1: Enable | | 5 | ADHS | R/W | H/W source for activating normal AD conversion (note1) 0: External trigger 1: Match with timer register (TB6RG0) | | 4 | ADHTG | R/W | H/W for activating normal AD conversion 0: Disable 1: Enable | | 3-2 | - | R | Read as "0". | | 1-0 | ADRST[1:0] | (W | Overwriting "10" with "01" allows ADC to be software reset.(note 2) | Note 1: The external trigger cannot be used for H/W activation of AD conversion when it is used for H/W activation of top priority AD conversion. Note 2: A software reset initializes all the registers except for ADCLK<ADCLK>. Note 3: The disables the external trigger used for H/W activation. Therefore "0" cannot be set to <HADHS> and <ADHS>. # 20.3.9 ADMOD5 (Mode Control Register 5) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----|----|---------|------------|----|-------|---------|----| | bit symbol | - | - | - | - | - | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - | - (( | 13 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | | | 15 | 14 | 13 | 12 | 11 | (107) | 9 | 8 | | bit symbol | - | - | - | - | _ | | ) - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | ADOBIC1 | ADREGS1 AD | | | ADOBSV1 | | | After reset | 0 | 0 | 0 | 0 | o/ | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-6 | - | R | Read as "0". | | 5 | ADOBIC1 | R/W | Set the AD monitor function interrupt 1. 0: If the value of the conversion result is smaller than the comparison register 1, an interrupt is generated. 1: If the value of the conversion result is bigger than the comparison register 1, an interrupt is generated. | | 4-1 | ADREGS1[3:0] | R/W | Select a target conversion result register when using the AD monitor function 1 (See the below table). | | 0 | ADOBSV1 | R/W | AD monitor function1 0: Disable 1: Enable | # 20.3.10 ADREG08 (Conversion Result Register 08) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|------|----|----|----|----------|------|------|--------| | bit symbol | - | - | - | - | - | - > | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AD | R0 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | ADR0 | | - | - | | > - | OVR0 | ADR0RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ы | Dit Syllibol | Type | Luicuoti | | 31-16 | _ | R | Read as "0". | | 15-6 | ADR0[9:0] | R | AD conversion result | | | | | Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | - | R | Read as "0". | | 1 | OVR0 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr0>, "1" is set. This bit is "0" cleared when it is read.</adr0> | | 0 | ADR0RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.11 ADREG19 (AD Conversion Result Register 19) | | 31 | 30 | 29 | 28 | 27 | 26 🚫 | 25 | 24 | |-------------|----|------|----|----|----------|--------------|------|--------| | bit symbol | - | - | - | - | - | - | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | | (7/3 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AC | R1 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 9 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | AD | ADR1 | | - | | <del>-</del> | ØVR1 | ADR1RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-6 | ADR1[9:0] | R | AD conversion result Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | _ | R | Read as "0". | | 1 | OVR1 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr1>, "1" is set. This bit is "0" cleared when it is read.</adr1> | | 0 | ADR1RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.12 ADREG2A (AD Conversion Result Register 2A) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|--------------|-------|--------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AD | R2 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | AD | R2 | - | - | | <del>-</del> | ØVR2 | ADR2RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | ( ) 0 | 0 | | D:4 | Dit Comehal | T | Franklin 90/ | |-------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-16 | _ | R | Read as "0". | | 15-6 | ADR2[9:0] | R | AD conversion result | | | | | Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | - | R | Read as "0". | | 1 | OVR2 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr2>, "1" is set. This bit is "0" cleared when it is read.</adr2> | | 0 | ADR2RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.13 ADREG3B (AD Conversion Result Register 3B) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|------|------|--------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AD | R3 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | AD | R3 | - | - | | · - | OVR3 | ADR3RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | _ | R | Read as "0". | | 15-6 | ADR3[9:0] | R | AD conversion result Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | - | R | Read as "0". | | 1 | OVR3 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr3>, "1" is set. This bit is "0" cleared when it is read.</adr3> | | 0 | ADR3RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.14 ADREG4C (AD Conversion Result Register 4C) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|-----|----|----|----------|--------------|------|--------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AD | R4 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | AD | )R4 | - | - | | <del>-</del> | OVR4 | ADR4RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | | | _ | | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function | | 31-16 | _ | R | Read as "0". | | 15-6 | ADR4[9:0] | R | AD conversion result | | | | | Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | - | R | Read as "0". | | 1 | OVR4 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr4>, "1" is set. This bit is "0" cleared when it is read.</adr4> | | 0 | ADR4RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.15 ADREG5D (AD Conversion Result Register 5D) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|------|----|----|----------|--------------|------|--------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AD | R5 | $(\bigcirc)$ | | | | After reset | 0 | 0 | 0 | 0 | 0 | ) | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | AD | ADR5 | | - | | > - | OVR5 | ADR5RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-6 | ADR5[9:0] | R | AD conversion result Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | _ | R | Read as "0". | | 1 | OVR5 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr5>, "1" is set. This bit is "0" cleared when it is read.</adr5> | | 0 | ADR5RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.16 ADREG6E (AD Conversion Result Register 6E) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|-----|----|----|----------|------|-------|--------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AD | PR6 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | AD | PR6 | - | - | | · - | OVR6 | ADR6RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | ( ) 0 | 0 | | | | _ | | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Type | Function | | 31-16 | _ | R | Read as "0". | | 15-6 | ADR6[9:0] | R | AD conversion result Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | _ | R | Read as "0". | | 1 | OVR6 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr6>, "1" is set. This bit is "0" cleared when it is read.</adr6> | | 0 | ADR6RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.17 ADREG7F (AD Conversion Result Register 7F) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|------|-------|--------| | bit symbol | - | - | - | - | - | - > | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | AD | R7 | | - | | | After reset | 0 | 0 | 0 | 0 | 0 | 7 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3/ | 2 | 4 | 0 | | bit symbol | AD | R7 | - | - | | > - | OVR7 | ADR7RF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | ( ) 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | _ | R | Read as "0". | | 15-6 | ADR7[9:0] | R | AD conversion result Conversion result is stored. For information about the correlation between the conversion channel and the conversion result register, refer to the Table 20-2 in 20.4.5.7. | | 5-2 | _ | R | Read as "0". | | 1 | OVR7 | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adr7>, "1" is set. This bit is "0" cleared when it is read.</adr7> | | 0 | ADR7RF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | # 20.3.18 ADREGSP (AD Conversion Result Register SP) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----|-----|----|-----|----------|------|-------|---------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | ( V) | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | ADI | RSP | | | | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | ADI | RSP | - | - | | · - | OVRSP | ADRSPRF | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-6 | ADRSP[9:0] | R | AD conversion result Top-priority AD conversion result is stored. | | 5-2 | - | R | Read as "0". | | 1 | OVRSP | R | Overrun flag 0: Not generated 1: Generated If the conversion result is overwritten before reading <adrsp>, "1" is set. This bit is "0" cleared when it is read.</adrsp> | | 0 | ADRSPRF | R | AD conversion result storage flag 0:Conversion result is not stored 1: Conversion result is stored. If a conversion result is stored, "1" is set. This bit is "0" cleared when the conversion result is read. | ## 20.3.19 ADCMP0 (AD Conversion Result Comparison Register 0) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|-----|-----|----|-----|----------|------|------|----| | bit symbol | - | - | - | - | - | - | - / | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - < | -(0) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | ADC | OM0 | | | | | After reset | 0 | 0 | 0 | 0 | 0 | ٦ | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | ADC | OM0 | - | - | | > - | 2-// | - | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0 | (0) | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-6 | ADCOM0[9:0] | R/W | When AD monitor function 0 is enabled, it sets a value to be compared with the value of the conversion result register specified by ADMOD3 <adregs0>.</adregs0> | | 5-0 | - | R | Read as "0". | Note: To write values into this register, the AD monitor function 0 must be disabled (AD-MOD3<ADOBSV0> ="0"). ## 20.3.20 ADCMP1 (AD Conversion Result Comparison Register 1) | | 31 | 30 | <b>2</b> 9 | (28) | 27 | 26 | 25 | 24 | |-------------|------------|------|------------|------------------------------------|-----|----|----|----| | bit symbol | - ( | 1/ | - < | $\langle \langle \rangle \rangle$ | ) - | - | 1 | - | | After reset | 0 | 0 | 0_ | | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | <u>~</u> ^ | , | - | - | 1 | - | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | | | | ADC | OM1 | | | | | After reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | (6 \ | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | ADC | OM1 | | - | - | - | 1 | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | - | R | Read as "0". | | 15-6 | ADCOM1[9:0] | R/W | When AD monitor function 0 is enabled, it sets a value to be compared with the value of the conversion result register specified by ADMOD5 <adregs1>.</adregs1> | | 5-0 | - | R | Read as "0". | Note: To write values into this register, the AD monitor function 1 must be disabled (AD-MOD5<ADOBSV1> ="0"). Page 609 2023/07/21 ## 20.4 Description of Operations ### 20.4.1 Analog Reference Voltage The "High" level of the analog reference voltage shall be applied to the VRFEH pin, and the "Low" shall be applied to the VREFL pin. To start AD conversion, make sure that you first write "1" to the <VREFON> bit, wait for 3 µs during which time the internal reference voltage should stabilize, and then write "1" to the ADMOD0<ADS> bit. By writing "0" to the ADMOD1<VREFON> bit, a switched-on state of VREFH - VREFL can be turned into a switched -off state. To switch to the power-consumption mode, set "0" to the <VREFON> bit after conversion Note: VREFL and AVSS are shared by TMPM362F10FG. ### 20.4.2 AD Conversion Mode Two types of AD conversion are supported: normal AD conversion and top-priority AD conversion. For normal AD conversion, the following four operation modes are supported. #### 20.4.2.1 Normal AD conversion For normal AD conversion, the following four operation modes are supported and the operation mode is selected with the ADMOD0<REPEAT, SCAN>. - Fixed channel single conversion mode - Channel scan single conversion mode - · Fixed channel repeat conversion mode - Channel scan repeat conversion mode #### Fixed channel single conversion mode If ADMOD0<REPEAT, SCAN> is set to "00", "AD conversion is performed in the fixed channel single conversion mode. In this mode, AD conversion is performed once for one channel selected. After AD conversion is completed, ADMOD0<EOCFN> is set to "1", ADMOD0<ADBFN> is cleared to "0", and the AD conversion completion interrupt request (INTAD) is generated. <EOCFN> is cleared to "0" upon read. #### (2) Channel scan single conversion mode If ADMOD0<REPEAT, SCAN> is set to "01", "AD conversion is performed in the channel scan single conversion mode. In this mode, AD conversion is performed once for each scan channel selected. After AD scan conversion is completed, ADMOD0<EOCFN> is set to "1", ADMOD0<ADBFN> is cleared to "0", and the conversion completion interrupt request (INTAD) is generated. <EOCFN> is cleared to "0". #### (3) Fixed channel repeat conversion mode If ADMOD0<REPEAT, SCAN> is set to "10", AD conversion is performed in fixed channel repeat conversation mode. In this mode, AD conversion is performed repeatedly for one channel selected. After AD conversion is completed, ADMOD0<EOCFN> is set to "1". ADMOD0<ADBFN> is not cleared to "0". It remains at "1". The timing with which the conversion completion interrupt request (INTAD) is generated can be selected by setting ADMOD0<ITM> to an appropriate setting. <EOCFN> is set with the same timing as this interrupt INTAD is generated. By reading <EOCFN>, it is cleared to "0". ### (4) Channel scan repeat conversion mode If ADMOD0<REPEAT, SCAN> is set to "11", AD conversion is performed in the channel scan repeat conversion mode. In this mode, AD conversion is performed repeatedly for a scan channel selected. Each time one AD scan conversion is completed, ADMOD0<EOCFN> is set to "1", and the conversion completion interrupt request (INTAD) is generated. ADMOD0<ADBFN> is cleared to "0". It remains at "1". <EOCFN> is cleared to "0" upon read. ### 20.4.2.2 Top-priority AD conversion By interrupting ongoing normal AD conversion, top-priority AD conversion can be performed. The fixed-channel single conversion is automatically selected, irrespective of the ADMOD0<RE-PEAT,SCAN> setting. When conditions to start operation are met, a conversion is performed just once for a channel designated by ADMOD2<HPADCH>. When conversion is completed, the top-priority AD conversion completion interrupt (INTADHP) is generated, and ADMOD2<EOCFHP> showing the completion of AD conversion is set to "1". <ADBFHP> returns to "0". EOCFHP flag is cleared to "0" upon read. Top-priority AD conversion activated while top-priority AD conversion is under way is ignored. Note: Top-priority A/D conversion interrupt cannot generate DMA transfer request. To generate DMA transfer request, please use A/D conversion completion interrupt (INTAD). ### 20.4.3 AD Monitor Function There are two channels of AD monitor function. If ADMOD3<ADOBSV0> and ADMOD5<ADOBSV1> are set to "1", the AD monitor function is enabled. If the value of the conversion result register specified by ADMOD3<ADREGS0> and ADMOD5<ADREGS1> becomes larger or smaller ("Larger" or "Smaller" to be designated by ADMOD3<ADOBIC0> and ADMOD5<ADBIC1>) than the value of a comparison register, the AD monitor function interrupt (INTADM0,INTADM1) is generated. This comparison operation is performed each time a result is stored in a corresponding conversion result register. If the conversion result register assigned to perform the AD monitor function is continuously used without reading the conversion result, the conversion result is overwritten. The conversion result storage flag <ADRxRF> and the overrun flag <OVRx> remain being set. Page 611 2023/07/21 ### 20.4.4 Selecting the Input Channel After a reset, ADMOD0<REPEAT,SCAN> is initialized to "00" and ADMOD1<ADCH[3:0]> is initialized to "0000". The channels to be converted are selected according to the operation mode of the AD converter as shown below. #### 1. Normal AD conversion mode - If the analog input channel is used in a fixed state (ADMODO<SCAN> = "0") One channel is selected from analog input pins AIN0 through AIN15 by setting ADMOD1<ADCH> to an appropriate setting. - If the analog input channel is used in a scan state (ADMOD0<SCAN> = "1") One scan mode is selected from the scan modes by setting ADMOD1 <ADCH> and ADSCN to an appropriate setting. - 2. Top-priority AD conversion mode One channel is selected from analog input pins from AIN0 through AIN15 by setting AD-MOD2<HPADCH> to an appropriate setting. #### 20.4.5 AD Conversion Details #### 20.4.5.1 Starting AD Conversion Normal AD conversion is activated by setting ADMOD0<ADS> to "1". Top-priority AD conversion is activated by setting ADMOD2<HPADCE> to "1". Four operation modes are made available to normal AD conversion. In performing normal AD conversion, one of these operation modes must be selected by setting ADMOD0<REPEAT,SCAN> to an appropriate setting. For top-priority AD conversion, only one operation mode can be used: fixed channel single conversion mode. Normal AD conversion can be activated using the H/W activation source selected by AD-MOD4<ADHS>, and top-priority AD conversion can be activated using the HW activation source selected by ADMOD4<HADHS>. If bits of <ADHS> and <HADHS> are "0", normal and top-priority AD conversions are activated in response to the input of a falling edge through the $\overline{ADTRG}$ pin. If these bits are "1", normal AD conversion is activated in response to TB6RG0 generated by the 16-bit timer 6, and top-priority AD conversion is activated in response to TB5RG0 generated by the 16-bit timer 5. To permit H/W activation, set ADMOD4<ADHTG> to "1" for normal AD conversion and set ADMOD4<HADHTG> to "1" for top-priority AD conversion. Software activation is still valid even after H/W activation has been permitted. - Note 1: When an external trigger is used for the HW activation source of a top-priority AD conversion, an external trigger cannot be set for activating normal AD conversion H/W. - Note 2: TMPM362F10FG disables the external trigger used for H/W activation. Therefore "0" cannot be set to <HADHS> and <ADHS>. #### 20.4.5.2 AD Conversion When normal AD conversion starts, the AD conversion Busy flag (ADMOD0<ADBFN>) showing that AD conversion is under way is set to "1". When top-priority AD conversion starts, the top-priority AD conversion Busy flag (AD-MOD2<ADBFHP>) showing that AD conversion is underway is set to "1". At that time, the value of the Busy flag ADMOD0<ADBFN> for normal AD conversion before the start of top-priority AD conversions are retained. The value of the conversion completion flag ADMOD0<EOCFN> for normal AD conversion before the start of top-priority AD conversion is retained. Note: Normal AD conversion must not be activated when top-priority AD conversion is under way. ### 20.4.5.3 Top-priority AD conversion during normal AD conversion If top-priority AD conversion has been activated during normal AD conversion, ongoing normal AD conversion is suspended, and restarts normal AD conversion after top-priority AD conversion is completed. If ADMOD2<HPADCE> is set to "1" during normal AD conversion, ongoing normal AD conversion is suspended, and the top-priority AD conversion starts; specifically, AD conversion (fixed-channel single conversion) is executed for a channel designated by ADMOD2<HPADCH>. After the result of this top-priority AD conversion is stored in the storage register ADREGSP, normal AD conversion is resumed. If H/W activation of top-priority AD conversion is authorized during normal AD conversion, ongoing AD conversion is discontinued when requirements for activation using a H/W activation resource are met, and top-priority AD conversion (fixed-channel single conversion) starts for a channel designated by ADMOD2<HPADCH>. After the result of this top-priority AD conversion is stored in the storage register ADREGSP, normal AD conversion is resumed. For example, if channel repeat conversion is activated for channels AIN0 through AIN3 and if <HPADCE> is set to "1" during AIN2 conversion, AIN2 conversion is suspended, and conversion is performed for a channel designated by <HPADCH> (AIN7 in the case shown below). After the result of conversion is stored in ADREGSP, channel repeat conversion is resumed, starting from AIN2. ### 20.4.5.4 Stopping Repeat Conversion Mode To stop the AD conversion operation in the repeat conversion mode (fixed-channel repeat conversion mode or channel scan repeat conversion mode), write "0" to ADMOD0<REPEAT>. When ongoing AD conversion is completed, the repeat conversion mode terminates, and ADMOD0<ADBFN> is set to "0". Page 613 2023/07/21 #### 20.4.5.5 Reactivating normal AD conversion To reactivate normal AD conversion while the conversion is underway, a software reset (AD-MOD3<ADRST>) must be performed before starting AD conversion. The H/W activation method must not be used to reactivate normal AD conversion. #### 20.4.5.6 Conversion completion #### (1) Normal AD conversion completion When normal AD conversion is completed, the AD conversion completion interrupt (INTAD) is generated. The result of AD conversion is stored in the storage register is the storage register, and two registers change: the register ADMOD0<EOCFN> which indicates the completion of AD conversion and the register ADMOD0<ADBFN>.Interrupt request, conversion register storage register and <EOCFN><ADBFN> change with a different timing according to a mode selected. In mode other than fixed-channel repeat conversion mode, conversion results are stored in AD conversion result registers (ADREG08 through ADRG7F) corresponding to a channel. In fixed-channel repeat conversion mode, the conversion results are sequentially stored in storage registers ADREG08 through ADREG7F. However, if interrupt setting on <ITM> is set to be generated each time one AD conversion is completed, the conversion result is stored only in ADREG08. If interrupt setting on <ITM> is set to be generated each time four AD conversions are completed, the conversion results are sequentially stored in ADREG08H through ADREG3B.If interrupt setting on <ITM> is set to be generated each time eight AD conversions are completed, the conversion results are sequentially stored in ADREG08H through ADREG7F. Interrupt requests, flag changes and conversion result registers in each mode are as shown below. #### · Fixed-channel single conversion mode After AD conversion completed, ADMOD0<EOCFN> is set to "1", ADMOD0<ADBFN> is cleared to "0", and the interrupt request is generated. Conversion results are stored a conversion result register correspond to a channel. #### Channel scan single conversion mode After the channel scan conversion is completed, ADMOD0<EOCFN> is set to "1", AD-MOD0<ADBFN> is set to "0", and the interrupt request INTAD is generated. Conversion results are stored a conversion result register correspond to a channel. ### · Fixed-channel repeat conversion mode ADMOD0<ADBFN> is not cleared to "0". It remains at "1". The timing with which the interrupt request INTAD is generated can be selected by setting ADMOD0<ITM> to an appropriate setting. ADMOD0<EOCFN> is set with the same timing as this interrupt INTAD is generated. #### a. One conversion With <ITM[1:0]> set to "00", an interrupt request is generated each time one AD conversion is completed. In this case, the conversion results are always stored in the storage register ADREG08. After the conversion result is stored, <EOCFN> changes to "1". #### b. Four conversions With <ITM[1:0]> set to "01", an interrupt request is generated each time four AD conversions are completed. In this case, the conversion results are sequentially stored in the storage register ADREG08 through ADREG3B. After the conversion result is stored in ADREG3B, <EOCFN> is set to "1", and the storage of subsequent conversion results starts from ADREG08. #### c. 8 conversions With <ITM[1:0]> set to "10", an interrupt request is generated each time eight AD conversions are completed. In this case, the conversion results are sequentially stored in the storage register ADREG08 through ADREG7F. After the conversion result is stored in ADREG7F, <EOCFN> is set to "1", and the storage of subsequent conversion results starts from ADREG08. ### Channel scan repeat conversion mode Each time one AD conversion is completed, ADMOD0<EOCF> is set to "1" and interrupt request INTAD is generated. ADMOD0<ADBFN> is not cleared to "0". It remains at "1". AD conversion results are stored in a AD conversion result register corresponding to a channel. ### (2) Top-priority AD conversion completion After the AD conversion is completed, the top-priority AD conversion completion interrupt (IN-TADHP) is generated, and ADMOD2<EOCFHP> which indicates the completion of top-priority AD conversion is set to "1". AD conversion results are stored in the AD conversion result register SP. ### (3) Data polling To confirm the completion of AD conversion without using interrupts, data polling can be used. When AD conversion is completed, ADMOD0<EOCFN> is set to "1". To confirm the completion of AD conversion and to obtain the results, poll this bit. AD conversion result storage register must be read by half word or word access. If <OVRx> = "0" and <ADRxRF> = "1", a correct conversion result has been obtained. Page 615 2023/07/21 ### 20.4 Description of Operations ### 20.4.5.7 Interrupt generation timings and AD conversion result storage register Table 20-1 shows a relation in the following three items: AD conversion modes, interrupt generation timings and flag operations. Table 20-2 shows a relation between analog channel inputs and AD conversion result registers. Table 20-1 Relations in conversion modes, interrupt generation timings and flag operations | | | | epeat mode<br>(ADMOD0) | setting | 4 | <eqcfn>/</eqcfn> | ADMOD0 | ADMOD2 | |-----------------|--------------------------------------|-------------------|-----------------------------------------------------|-----------------------|------------------------------------------|-----------------------------------------|----------------------------------------------------|-------------------| | Conversion mode | | <repeat></repeat> | <scan></scan> | <itm[1:0]></itm[1:0]> | Interrupt generation timing | <eocfhp> set timing (note)</eocfhp> | <adbfn> (After the interrupt is generated)</adbfn> | <adbfhp></adbfhp> | | | Fixed-channel sin-<br>gle conversion | 0 | 0 | - | After generation is completed. | After conversion is completed. | 0 | - | | | | ···· 1 1 | 0 | 00 | Each time one conversion is completed. | After one conversion is completed. | 30 | _ | | Normal | Fixed-channel re-<br>peat conversion | | | 01 | Each time four conversion is completed. | After four conversions are completed. | ) 1 | - | | conversion | | | | 10 | Each time eight conversion is completed. | After eight conversions are completed. | 1 | - | | | Channel scan single conversion | 0 | 1 | | After scan conversion is completed. | After scan conversion is completed. | 0 | - | | | Channel scan repeat conversion | 1 | 1 | <u> </u> | After one scan conversion is completed. | After one scan conversion is completed. | 1 | - | | Top-prio | ority conversion | | $\left( \begin{array}{c} \\ \\ \end{array} \right)$ | - | After completion is completed. | Conversion completion | - | 0 | Note: ADMOD0<EOCFN> and ADMOD2<EOCFHP> are cleared upon read. Table 20-2 Relation between analog channels input and AD conversion result registers | | | Normal AD | conversion | | | |-----------------------|----------------------------------------------------------------|-------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------|---------------------------------| | Analog input channels | Other conversion<br>mode than those<br>shown on the right side | Fixed channel repeat conversion mode (every one conversion) | Fixed channel repeat<br>conversion mode<br>(every four conver-<br>sions) | Fixed channel repeat conversion mode (every eight conversions) | Top-priority AD conver-<br>sion | | AIN0 | ADREG08 | ADREG08 fixed | | (( | ADREGSP | | AIN1 | ADREG19 | | ADREG08 ◀ | ADREG08 | | | AIN2 | ADREG2A | | Ĭ | | | | AIN3 | ADREG3B | | ADREG3B — | ADREG7F | | | AIN4 | ADREG4C | | | ABILLOTT | | | AIN5 | ADREG5D | | | | | | AIN6 | ADREG6E | | $\mathcal{A}($ | | | | AIN7 | ADREG7F | | | | | | AIN8 | ADREG08 | | (775 | | | | AIN9 | ADREG19 | | | | | | AIN10 | ADREG2A | | | | 901 | | AIN11 | ADREG3B | | | | $\supset$ | | AIN12 | ADREG4C | | (()) | | | | AIN13 | ADREG5D | | | | | | AIN14 | ADREG6E | | | | | | AIN15 | ADREG7F | 4( | | | | Note: To access the conversion result register, use a half-word or a word access. #### Cautions The result value of AD conversion may vary depending on the fluctuation of the supply voltage, or may be affected by noise. When using analog input pins and ports alternately, do not read and write ports during conversion because the conversion accuracy may be reduced. Also the conversion accuracy may be reduced if the output ports current fluctuate during AD conversion. Please take counteractive measures with the program such as averaging the AD conversion results. Page 617 2023/07/21 TOSHIBA TMPM362F10FG # 21. Real Time Clock (RTC) ### 21.1 Function Note 1: Western calendar year column:This product uses only the final two digits of the year. The year following 99 is 00 years. Please take into account the first two digits when handling years in the western calendar. Note 2: Leap year: A leap year is divisible by 4 excluding a year divisible by 100; the year divisible by 100 is not considered to be a leap year. Any year divisible by 400 is a leap year. This product is considered the year divisible by 4 to be a leap year and does not take into account the above exceptions. It needs adjustments for the exceptions. Page 619 2023/07/21 ### 21.3 Detailed Description Register # 21.3 Detailed Description Register ### 21.3.1 Register List The registers and the addresses related to RTC are shown as below. RTC has two functions, PAGE0 (clock) and PAGE1 (alarm), which share some parts of registers. The PAGE can be selected by setting RTCPAGER<PAGE >. Base Address = 0x4004\_0100 | | | Dase Addless - 0x4004_0100 | |-----------------------------------------------|-----------|----------------------------| | Register name | | Address(Base+) | | Second column register (only PAGE0) | RTCSECR | 0x0000 | | Minute column register | RTCMINR | 0x0001 | | Hour column register | RTCHOURR | 0x0002 | | - (note 1) | | 0x0003 | | Day of the week column register | RTCDAYR | 0x0004 | | Day column register | RTCDATER | 0x0005 | | Month column register (PAGE0) | DTCMONTUD | 0,0000 | | Selection register of 24-hour,12-hour (PAGE1) | RTCMONTHR | 0x0006 | | Year column register (PAGE0) | RTCYEARR | 0x0007 | | Leap year register (PAGE1) | RICTEARR | OX0007 | | PAGE register | RTCPAGER | 0x0008 | | - (note 1) | | 0x0009 | | - (note 1) | ` | 0x000A | | - (note 1) | - | 0x000B | | Reset register | RTCRESTR | 0x000C | | Reserved | <u> </u> | 0x000D | | - (note 1) | | 0x000E | | - (note 1) | | 0x000F | Note 1: "0" is read by reading the address. Writing is disregarded. Note 2: Access to the "Reserved" areas is prohibited. ## 21.3.2 Control Register Reset operation initializes the following registers. - RTCPAGER<PAGE>, <ADJUST>, <INTENA> - RTCRESTR<RSTALM>, <RSTTMR>, <DIS16HZ>, <DIS1HZ> Other clock-related registers are not initialized by reset operation. Before using the RTC, set the time, month, day, day of the week, year and leap year in the relevant registers. Caution is required in setting clock data, adjusting seconds or resetting the clock. Refer to "21.4.3 Entering the Low Power Consumption Mode" for more information. Table 21-1 PAGE0 (clock function) register | Symbol | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | Function | |-----------|---------------------|-----------------|------------------|---------------------|-----------------|-----------------|--------------|-----------------|---------------------------------| | RTCSECR | - | 40sec. | 20sec. | 10sec. | 8sec. | 4sec. | 2sec. | 1sec. | Second column | | RTCMINR | ı | 40min. | 20min. | 10min. | 8min. | 4min. | 2min. | 1min. | Minute column | | RTCHOURR | ı | ı | 20hours<br>PM/AM | 10hour | 8hour | 4hour | 2hour | 1hours | Hour column | | RTCDAYR | ı | ı | 1 | - | - | Da | ay of the we | ek | Day of the week column | | RTCDATER | ı | ı | Day20 | Day10 | Day8 | Day4 | Day2 | Day1 | Day column | | RTCMONTHR | - | - | ı | Oct. | Aug. | Apr. | Feb. | Jan. | Month column | | RTCYEARR | year 80 | year 40 | year20 | year 10 | year 8 | year 4 | year 2 | year 1 | Year column (lower two columns) | | RTCPAGER | Interrupt<br>enable | ı | ı | Adjustment function | Clock<br>enable | Alarm<br>enable | | PAGE<br>setting | PAGE<br>register | | RTCRESTR | 1 Hz<br>enable | 16 Hz<br>enable | Clock<br>reset | Alarm<br>reset | - | Always write | e "1" | | Reset register | Note: Reading RTCSECR, RTCMINR, RTCHOURR, RTCDAYR, RTCMONTHR, RTCYEARR of PAGE0 captures the current state. Table 21-2 PAGE1 (alarm function) registers | | | | | | | /_ | | | | |-----------|---------------------|-----------------|------------------|---------------------|-----------------|-----------------|--------------|-----------------|------------------------| | Symbol | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | Function | | RTCSECR | 1 | - | ı | | _ | -// | \ | ı | - | | RTCMINR | 1 | 40min. | 20min. | 10min. | 8min. | 4min. | 2min. | 1min. | Minute column | | RTCHOURR | - | - | 20hours<br>PM/AM | 10hour | 8hour | 4hour | 2hour | 1hour | Hour column | | RTCDAYR | - | - / | | _ | <b>Z</b> | D | ay of the we | ek | Day of the week column | | RTCDATER | ı | | Day20 | Day10 | Day8 | Day4 | Day2 | Day1 | Day column | | RTCMONTHR | - / | / -) \ | )' | | ((/-/^ | - | - | 24/12 | 24-hour clock mode | | RTCYEARR | 1 | \ <u>-</u> / | | - | )) | - | Leap-yea | ar setting | Leap-year mode | | RTCPAGER | Interrupt<br>enable | - | _ | Adjustment function | Clock<br>enable | Alarm<br>enable | _ | PAGE<br>setting | PAGE<br>register | | RTCRESTR | 1 Hz<br>Enable | 16 Hz<br>Enable | Clock<br>reset | Alarm<br>reset | > - | Always writ | e "1" | | Reset register | Note 1: Reading RTCMINR, RTCHOURR, RTCDAYR, RTCMONTHR, RTCYEARR of PAGE1 captures the current state. Note 2: RTCSECR, RTCMINR, RTCHOURR, RTCDAYR, RTCDATER, RTCMONTHR, RTCYEARR of PAGE0 and RTCYEARR of PAGE1 (for leap year) must be read twice and compare the data captured. Page 621 2023/07/21 # 21.3.3 Detailed Description of Control Register ## 21.3.3.1 RTCSECR (Second column register (for PAGE0 only)) | | 7 | 6 | 5 | 4 | 3 | 2 | $\bigcup_{i} Y$ | 0 | |-------------|---|-----------|-----------|-----------|-----------|-----------|-----------------|-----------| | bit symbol | - | | | | SE | | | | | After reset | 0 | Undefined | Bit | Bit Symbol | Туре | Functon | |-----|------------|------|-------------------------------------------------------| | 7 | - | R | Read as 0. | | 6-0 | SE | R/W | Setting digit register of second | | | | | 000_0000 : 00sec. | | | | | 000_0001 : 01sec. 001_0001 : 11sec. | | | | | 000_0010 : 02sec. | | | | | 000_0011 : 03sec. 001_0011 : 13sec. | | | | | 000_0100 : 04sec. | | | | | 000_0101 : 05sec. 001_0101 : 15sec. | | | | | 000_0110 : 06sec. | | | | | 000_0111 : 07sec. 001_0111 : 17sec. | | | | | 000_1000 : 08sec. | | | | | 000_1001 : 09sec. 001_1001 : 19sec. 101_1001 : 59sec. | Note: The setting other than listed above is prohibited. ### 21.3.3.2 RTCMINR (Minute column register (PAGE0/1)) | | 7 / | 6 | 5 | (47/4 | 3 | 2 | 1 | 0 | |-------------|-----|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | Bit symbol | - < | | 7 | | МІ | - | - | | | After reset | 0 | Undefined | Bit | Bit Symbol | Туре | Functon | | | | | | | | |-----|------------|------|------------------------------|------------------------------------|-------------------|--|--|--|--|--| | 7 | - 7 | R) | Read as 0. | | | | | | | | | 6-0 | MI | R/W | Setting digit register of Mi | Setting digit register of Minutes. | | | | | | | | ^ | | | 000_0000 : 00min. | 001_0000 : 10min. | 010_0000 : 20min. | | | | | | | | | / | 000_0001 : 01min. | 001_0001 : 11min. | • | | | | | | | | | ( | 000_0010 : 02min. | 001_0010 : 12min. | 011_0000 : 30min. | | | | | | | 1 | | \ | 000_0011 : 03min. | 001_0011 : 13min. | • | | | | | | | | | | 000_0100 : 04min. | 001_0100 : 14min. | 100_0000 : 40min. | | | | | | | | | | 000_0101 : 05min. | 001_0101 : 15min. | • | | | | | | | | * | | 000_0110 : 06min. | 001_0110 : 16min. | 101_0000 : 50min. | | | | | | | | | | 000_0111 : 07min. | 001_0111 : 17min. | • | | | | | | | | | | 000_1000 : 08min. | 001_1000 : 18min. | • | | | | | | | | | | 000_1001 : 09min. | 001_1001 : 19min. | 101_1001 : 59min. | | | | | | Note: The setting other than listed above is prohibited. # 21.3.3.3 RTCHOURR (Hour column register(PAGE0/1)) # (1) 24-hour clock mode (RTCMONTHR<MO0>= "1") | | 7 | 6 | 5 | 4 | 3 | 2 | ( ) P | 0 | |-------------|---|---|-----------|-----------|-------------|-----------|---------------|-----------| | Bit symbol | ı | 1 | | | Н | 0 | $\rightarrow$ | | | After reset | 0 | 0 | Undefined | Undefined | Undefined 🔷 | Undefined | Undefined | Undefined | | Bit | Bit Symbol | Туре | Functon | |-----|------------|------|------------------------------------------------------| | 7-6 | - | R | Read as 0. | | 5-0 | НО | R/W | Setting digit register of Hour. 00_0000 : 0 o'clock | | | | | 00_1000 : 8 o'clock | Note: The setting other than listed above is prohibited. ### (2) 12-hour clock mode (RTCMONTHR<MO0> = "0") | | 7 | 6 | 5 | (47) | 3 | 2 | 1 | 0 | |-------------|-----|---|-----------|-----------|-----------|-----------|-----------|-----------| | Bit symbol | - ( | 1 | 7 | | ) н | 0 | | | | After reset | 0 | 0 | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | | Bit | Bit Symbol | Туре | | Functon | |-----|------------|------|-------------------------------|----------------------| | 7-6 | - | R | Read as 0. | $\vee$ | | 5-0 | но | R/W | Setting digit register of Hor | ur. | | ^ | | \ | (AM) | (PM) | | | | / | 00_0000 : 0 o'clock | 10_0000 : 0 o'clock | | | | ( | 00_0001 : 1 o'clock | 10_0001 : 1 o'clock | | 1 | | \ | 00_0010 : 2 o'clock | 10_0010 : 2 o'clock | | | | | 00_0011 : 3 o'clock | 10_0011 : 3 o'clock | | | | | 00_0100 : 4 o'clock | 10_0100 : 4 o'clock | | | ~ | | 00_0101 : 5 o'clock | 10_0101 : 5 o'clock | | | | | 00_0110 : 6 o'clock | 10_0110 : 6 o'clock | | | | | 00_0111 : 7 o'clock | 10_0111 : 7 o'clock | | | | | 00_1000 : 8 o'clock | 10_1000 : 8 o'clock | | | | | 00_1001 : 9 o'clock | 10_1001 : 9 o'clock | | | | | 01_0000 : 10 o'clock | 11_0000 : 10 o'clock | | | | | 01_0001 : 11 o'clock | 11_0001 : 11 o'clock | Note: The setting other than listed above is prohibited. Page 623 2023/07/21 # 21.3.3.4 RTCDAYR (Day of the week column register(PAGE0/1)) | | 7 | 6 | 5 | 4 | 3 | 2 _ | 1 | 0 | |-------------|---|---|---|---|---|-----------|-----------|-----------| | Bit symbol | - | - | - | - | - | | WE | | | After reset | 0 | 0 | 0 | 0 | 0 | Undefined | Undefined | Undefined | | Bit | Bit Symbol | Туре | | Function | |-----|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------| | 7-3 | - | R | Read as 0. | | | 2-0 | WE | R/W | Setting digit register of day of the week. 000: Sunday 001: Monday 010: Tuesday 011: Wednesday 100: Thursday 101: Friday 110: Saturday | | Note: The setting other than listed above is prohibited. # 21.3.3.5 RTCDATER (Day column register (for PAGE0/1 only)) | | 7 | 6 | 5 | 4 | 3 | // 2 | 1 | 0 | |-------------|---|---|-----------|-----------|-----------|-----------|-----------|-----------| | Bit symbol | - | 1 | | | D | A | - | | | After reset | 0 | 0 | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | | Bit | Bit Symbol | Туре | (0/4) | Fund | cton | | |-----|------------|------|------------------------------|--------------------|--------------------|--------------------| | 7-6 | _ | R | Read as 0. | | | | | 5-0 | DA | R/W | Setting digit register of da | y. (V/)) | | | | | ] | | | 01_0000 : 10th day | 10_0000 : 20th day | 11_0000 : 30th day | | | | | 00_0001 : 1st day | 01_0001 : 11th day | 10_0001 : 21th day | 11_0001 : 31th day | | | | | 00_0010 : 2nd day | 01_0010 : 12th day | 10_0010 : 22th day | | | | | | 00_0011 : 3rd day | 01_0011 : 13th day | 10_0011 : 23th day | | | | 7/ | N | 00_0100 : 4th day | 01_0100 : 14th day | 10_0100 : 24th day | | | | | | 00_0101 : 5th day | 01_0101 : 15th day | 10_0101 : 25th day | | | | | \ | 00_0110 : 6th day | 01_0110 : 16th day | 10_0110 : 26th day | | | < | | ) | 00_0111 : 7th day | 01_0111 : 17th day | 10_0111 : 27th day | | | | | ſ. | 00_1000 : 8th day | 01_1000 : 18th day | 10_1000 : 28th day | | | | | ( | 00_1001 : 9th day | 01_1001 : 19th day | 10_1001 : 29th day | | Note 1: The setting other than listed above is prohibited. Note 2: Do not set for non-existent days (e.g. 30th Feb.). # 21.3.3.6 RTCMONTHR (Month column register (for PAGE0 only)) | | 7 | 6 | 5 | 4 | 3 | 2 _ | 1 | 0 | |-------------|---|---|---|-----------|-----------|-----------|-----------|-----------| | Bit symbol | - | - | - | | | МО | | | | After reset | 0 | 0 | 0 | Undefined | Undefined | Undefined | Undefined | Undefined | | Bit | Bit Symbol | Туре | | | | Functon | |-----|------------|------|--------------|-------------------|----------|-----------| | 7-5 | _ | R | Read as 0. | | | | | 4-0 | МО | R/W | Setting digi | t register of Mon | th. | | | | | | 0_0001 : | January | 0_0111 : | July | | | | | 0_0010 : | February | 0_1000: | August | | | | | 0_0011 : | March | 0_1001: | September | | | | | 0_0100 : | April | 1_0000 : | October | | | | | 0_0101 : | May | 1_0001: | November | | | | | 0_0110 : | June | 1_0010 : | December | Note: The setting other than listed above is prohibited. # 21.3.3.7 RTCMONTHR (Selection of 24-hour clock or 12-hour clock (for PAGE1 only)) | | 7 | 6 | 5 | ) 4 | 3 | // 2 | 1 | 0 | |-------------|---|---|-------|-----|----------|------|---|-----------| | bit symbol | 1 | - | | - | <u> </u> | - | - | MO0 | | After reset | 0 | 0 | ( 0 ) | 0 | 0 | 0 | 0 | Undefined | | Bit | Bit Symbol | Туре | Function | |-----|------------|------|--------------------------| | 7-1 | - | R | Read as 0. | | 0 | MO0 | R/W | 0: 12-hour<br>1: 24-hour | Note: Do not change the RTCMONTHR<MO0> while the RTC is in operation. # 21.3 Detailed Description Register # 21.3.3.8 RTCYEARR (Year column register (for PAGE0 only)) | | 7 | 6 | 5 | 4 | 3 | 2 _ | 1 | 0 | |-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | bit symbol | | | | Y | E | | | | | After reset | Undefined | Bit | Bit Symbol | Туре | Function | | |-----|------------|------|---------------------------------|---------------| | 7-0 | YE | R/W | Setting digit register of Year. | | | | | | 0000_0000 : 00 year | | | | | | 0000_0001 : 01 years | | | | | | 0000_0010 : 02 years | | | | | | 0000_0011 : 03 years | | | | | | 0000_0100 : 04 years | | | | | | 0000_0101 : 05 years | | | | | | 0000_0110 : 06 years | $\rightarrow$ | | | | | 0000_0111 : 07 years · \( \) | $\bigcirc$ | | | | | 0000_1000 : 08 years | | | | | | 0000_1001 : 09 years | | Note: The setting other than listed above is prohibited. # 21.3.3.9 RTCYEARR (Leap year register (for PAGE1 only)) | | 7 | 6 | 5 | 4 / | 3 | 2 | 1 | 0 | |-------------|---|------|---|-----|---|---|-----------|-----------| | bit symbol | - | - 6 | | - < | | - | LE | AP | | After reset | 0 | 0 (/ | 0 | 0 | 0 | 0 | Undefined | Undefined | | | | / / | | | | | |-----|-----------------|------|------------------------------------|--|--|--| | Bit | Bit Symbol | Туре | Functon | | | | | 7-2 | - | R | Read as 0. | | | | | 1-0 | LEAP | R/W | 00 A leap year | | | | | | $\wedge \wedge$ | | 1 : one year after a leap year | | | | | | >,< | | 0 : two years after a leap year | | | | | | | | 11 : three years after a leap year | | | | ### 21.3.3.10 RTCPAGER(PAGE register(PAGE0/1)) | | 7 | 6 | 5 | 4 | 3 | 2 _ | 1 | 0 | |-------------|--------|---|---|--------|-----------|-----------|---|------| | Bit symbol | INTENA | - | - | ADJUST | ENATMR | ENAALM | - | PAGE | | After reset | 0 | 0 | 0 | 0 | Undefined | Undefined | 0 | 0 | | Bit | Bit Symbol | Туре | Function | |-----|------------|------|-------------------------------------------------------------------------------------------------------------| | 7 | INTENA | R/W | INTRTC | | | | | 0:Disable | | | | | 1:Enable | | 6-5 | - | R | Read as 0. | | 4 | ADJUST | R/W | [Write] | | | | | 0: Don't care | | | | | 1: Sets ADJUST request | | | | | Adjusts seconds. The request is sampled when the sec. counter counts up. | | | | | If the time elapsed is between 0 and 29 seconds, the sec. counter is cleared to "0". | | | | | If the time elapsed is between 30 and 59 seconds, the min. counter is carried and sec. counter is cleared | | | | | to "0". | | | | | [Read] | | | | | 0: ADJUST no request | | | | | 1: ADJUST requested | | | | | If "1" is read, it indicates that ADJUST is being executed. If "0" is read, it indicates that the execution | | | | | is finished. | | 3 | ENATMR | R/W | Clock | | | | | 0: Disable | | | | | 1: Enable | | 2 | ENAALM | R/W | ALARM | | | | | 0: Disable | | | | | 1: Enable | | 1 | - | R | Read as 0. | | 0 | PAGE | R/W_ | PAGE selection | | | | | 0:Selects Page0 | | | | X / | 1:Selects Page1 | | | | | | Note 1: A read-modify-write operation cannot be porfored. Note 2: To set interrupt enable bits to <ENATMR>, <ENAALM> and <INTENA>, you must follow the order specified here. Make sure not to set them at the same time (make sure that there is time lag between interrupt enable and clock/ alarm enable). To change the setting of <ENATMR> and <ENAALM>, <INTENA> must be disabled first. Example: Clock setting/Alarm setting 0 Enables Clock and alarm RTCPAGER $\leftarrow$ 1 0 0 0 1 1 0 0 Enables interrupt 21.3.3.11 RTCRESTR (Reset register (for PAGE0/1)) | | 7 | 6 | 5 | 4 | 3 | 2 _ | 1 | 0 | |-------------|--------|---------|--------|--------|---|------|---|---| | Bit symbol | DIS1HZ | DIS16HZ | RSTTMR | RSTALM | - | - \ | - | - | | After reset | 1 | 1 | 0 | 0 | 0 | 1 (( | 7 | 1 | | D:t | Dit Coursely 1 | Tomas | Fire-tier ( | |-----|----------------|-------|---------------------------------------------------------------------------------------------------------------| | Bit | Bit Symbol | Туре | Function (7/ | | 7 | DIS1HZ | R/W | 1 Hz | | | | | 0:Enable | | | | | 1: Disable | | 6 | DIS16HZ | R/W | 16 Hz | | | | | 0: Enable | | | | | 1: Disable | | 5 | RSTTMR | R/W | [Write] | | | | | 0: Don't care | | | | | 1: Sec.counter reset | | | | | Resets the sec counter. The equest is sampled using low-speed clock. | | | | | [Read] | | | | | 0: No reset request | | | | | 1: RESET requested | | | | | If "1" is read, it indicates that RESET is being executed. If "0" is read, it indicates that the execution is | | | | | finished. | | 4 | RSTALM | R/W | 0:Don't care | | | | | 1: Alarm reset | | | | | Initializes alarm registers (Minute column, hour column, day column and day of the week column) as | | | | | follows. | | | | | MInute:00, Hour:00, Day:01, Day of the week:Sunday | | 3 | _ | R | Read as 0. | | 2-0 | - | R/W | Write "1". | Note 1: A read-modify-write operation cannot be performed. The setting of <DIS1HZ> and <DIS16MHZ>, RTCPAGER<ENAALM> used for alarm, 1Hz interrupt and 16Hz interrupt is shown as below. | > | <dis1hz></dis1hz> | <dis16hz></dis16hz> | RTCPAGER<br><enaalm></enaalm> | Interrupt source<br>signal | | | | | | | |---|-------------------|---------------------|-------------------------------|----------------------------|--|--|--|--|--|--| | | 1 | 1 | 1 | Alarm | | | | | | | | | 0 | 1 | 0 | 1 Hz | | | | | | | | ) | 1 | 0 | 0 | 16 Hz | | | | | | | | | | Others | | | | | | | | | TMPM362F10FG # TOSHIBA # 21.4 Operational Description The RTC incorporates a second counter that generates a 1Hz signal from a 32.768 kHz signal. The second counter operation must be taken into account when using the RTC. # 21.4.1 Reading clock data #### 1. Using 1Hz interrupt The 1Hz interrupt is generated being synchronized with counting up of the second counter. Data can be read correctly if reading data after 1Hz interrupt occurred. #### 2. Using pair reading There is a possibility that the clock data may be read incorrectly if the internal counter operates carry during reading. To ensure correct data reading, read the clock data twice as shown below. A pair of data read successively needs to match. Figure 21-2 Flowchart of the clock data reading # 21.4.2 Writing clock data A carry during writing ruins correct data writing. The following procedure ensures the correct data writing. #### 1. Using 1 Hz interrupt The 1Hz interrupt is generated by being synchronized with counting up of the second counter. If data is written in the time between 1Hz interrupt and subsequent one second count, it completes correctly. ### 2. Resetting counter Write data after resetting the second counter. The 1Hz-interrupt is generated one second after enabling the interrupt subsequent to counter reset. Page 629 2023/07/21 The time must be set within one second after the interrupt. Figure 21-3 Flowchart of the clock data writing 3. Disabling the clock Writing "0" to RTCPAGER<ENATMR> disables clock operation including a carry. Stop the clock after the 1Hz-interrupt. The second counter keeps counting. Set the clock again and enable the clock within one second before next 1Hz-interrupt Figure 21-4 Flowchart of the disabling clock # 21.4.3 Entering the Low Power Consumption Mode To enter SLEEP mode, in which the system clock stops, after changing clock data, adjusting seconds or resetting the clock, be sure to observe one of the following procedures - 1. After changing the clock setting registers, setting the RTCPAGER<ADJUST> bit or setting the RTCRESTR<RSTTMR> bit, wait for one second for an interrupt to be generated. - 2. After changing the clock setting registers, setting the RTCPAGER<ADJUST> bit or setting the RTCRESTR<RSTTMR> bit, read the corresponding clock register values, <ADJUST> or <RSTTMR> to make sure that the setting you have made is reflected. Page 631 2023/07/21 21.5 Alarm function TMPM362F10FG ### 21.5 Alarm function By writing "1" to RTCPAGER<PAGE>, the alarm function of the PAGE1 registers is enabled. One of the following three signals is output to the ALARM pin. - 1. "Low" pulse (when the alarm register corresponds with the clock) - 2. 1Hz cycle "Low" pulse - 3. 16Hz cycle "Low" pulse In any cases shown above, the INTRTC outputs one cycle pulse of low-speed clock. It outputs the INTRTC interrupt request simultaneously. The INTRTC interrupt signal is falling edge triggered. Specify the falling edge as the active state in the CG Interrupt Mode Control Register ### 21.5.1 "Low" pulse (when the alarm register corresponds with the clock) "Low" pulse is output to the ALARM pin when the values of the PAGE0 clock register and the PAGE1 alarm register correspond. The INTRTC interrupt is generated and the alarm is triggered. The alarm settings Initialize the alarm with alarm prohibited. Write "1" to RTCRESTR<RSTALM>. It makes the alarm setting to be 00 minute, 00 hour, 01 day and Sunday. Setting alarm for min., hour, date and day is done by writing data to the relevant PAGE1 register. Enable the alarm with the RTCPAGER <ENAALM> bit. Enable the interrupt with the RTCPAGER <INTENA> bit. The following is an example program for outputting an alarm from the ALARM pin at noon (12:00) on Monday 5th. | | $\vee$ | | | | | | | | | | |----------|----------------|----|---|-----|----|---|---|---|---|---------------------------| | Ì | | 7 | 6 | 5 | 4_ | 3 | 2 | 1 | 0 | | | RTCPAGER | ← | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | Disables alarm,sets PAGE1 | | RTCRESTR | $\leftarrow$ | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | Initializes alarm | | RTCDAYR | J <del>)</del> | 0 | 0 | 0 / | 0 | 0 | 0 | 0 | 1 | Monday | | RTCDATER | <b>←</b> | 0 | 0 | 0/ | 0 | 0 | 1 | 0 | 1 | 5th day | | RTCHOURR | ← | 0 | 0 | _0 | 1 | 0 | 0 | 1 | 0 | Sets 12 o'clock | | RTCMINR | ←() | >0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Sets 00 min | | RTCPAGER | -( | 0/ | 0 | 0 | 0 | 1 | 1 | 0 | 0 | Enables alarm | | RTCPAGER | ← ( | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | Enables interrupts | | | | | | | | | | | | | The above alarm works in synchronization with the low-speed clock. When the CPU is operating at high frequency oscillation, a maximum of one clock delay at fs (about 30µs) may occur for the time register setting to become valid. Note: To make the alarm work repeatedly (e.g. every Wednesday at 12:00), next alarm must be set during the INTRTC interrupt routine that is generated when the time set for the alarm matches the RTC count. # 21.5.2 1Hz cycle "Low" pulse The RTC outputs a "Low" pulse cycle of low-speed 1Hz clock to the ALARM pin by setting RTCPAGER<INTENA>="1" after setting RTCPAGER<ENAALM>= "0", RTCRESTR<DIS1HZ>= "0" and <DIS16HZ>= "1". It generates an INTRTC interrupt simultaneously. # 21.5.3 16Hz cycle "Low" pulse The RTC outputs a "Low" pulse cycle of low-speed 16Hz clock to the ALARM pin by setting RTCPAGER<INTENA>="1" after setting RTCPAGER<ENAALM>= "0", RTCRESTR<DIS1HZ>= "1" and <DIS16HZ>= "0". It generates an INTRTC interrupt simultaneously. 21.5 Alarm function TMPM362F10FG # 22. Flash This section describes the hardware configuration and operation of the flash memory. # 22.1 Flash Memory #### 22.1.1 Features #### 1. Memory capacity TMPM362F10FG contains flash memory. The memory sizes and configurations are shown in the table below. Independent write access to each block is available. When the CPU is to access the internal flash memory, 32-bit data bus width is used. #### 2. Write / erase time Writing is executed per page. TMPM362F10FG contains 128 words. Page writing requires 1.25ms (typical) regardless of number of words. A block erase requires 0.1 sec. (typical). The following table shows write and erase time per chip. | Date deset Norma | Managaria | Blo | ck Configurat | tion | Number of | \\/-ittime- | | | |------------------|-------------|--------|---------------|-------|-----------|-------------|------------|--| | Product Name | Memory size | 128 KB | 64 KB | 32 KB | words | Write time | Erase time | | | TMPM362F10FG | 1024 KB | 7/ | 1 | 2 | 128 | 2.56 sec | 1.0 sec | | Note: The above values are theoretical values not including data transfer time. The write time per chip depends on the write method to be used by users. #### 3. Programming method There are two types of the onboard programming mode for users to program (rewrite) the device while it is mounted on the user's board: a. User boot mode The use's original rewriting method can be supported. b. Single boot mode The rewriting method to use serial data transfer (Toshiba's unique method) can be supported. Page 635 2023/07/21 22.1 Flash Memory TMPM362F10FG #### 4. Rewriting method The flash memory included in this device is generally compliant with the applicable JEDEC standards except for some specific functions. Therefore, if a user is currently using an external flash memory device, it is easy to implement the functions into this device. Furthermore, the user is not required to build his/her own programs to realize complicated write and erase functions because such functions are automatically performed using the circuits already built-in the flash memory chip. | JEDEC compliant functions | Modified, added, or deleted functions | |---------------------------|-----------------------------------------------------------------------------| | Automatic programming | $\langle \langle \langle \rangle \rangle \rangle$ | | Automatic chip erase | <modified> Block protect (only software protection is supported)</modified> | | Automatic block erase | <deleted> Erase resume - suspend function</deleted> | | Data polling / toggle bit | | #### 5. Protect/ Security Function This device is also implemented with a read-protect function to inhibit reading flash memory data from any external writer device. On the other hand, rewrite protection is available only through command-based software programming; any hardware setting method to apply +12VDC is not supported. See the chapter "ROM protection" for details of ROM protection and security function. Note: If a password is set to 0xFF (erased data), it is difficult to protect data securely due to an easy-toguess password. Even if Single Boot mode is not used, it is recommended to set a unique value as a password. # 22.1.2 Block Diagram of the Flash Memory Section Figure 22-1 Block Diagram of the Flash Memory Section Page 637 2023/07/21 22.2 Operation Mode TMPM362F10FG # 22.2 Operation Mode This device has three operation modes including the mode not to use the internal flash memory. Table 22-1 Operation modes | Operation mode | | Operation details | | | | |------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Single chip mode | | After reset is cleared, it starts up from the internal flash memory. | | | | | Normal mode | | In this operation mode, two different modes, i.e., the mode to execute user application programs and the mode to rewrite the flash memory onboard the user's set, are defined. The former is referred to as "normal mode" and the latter "user boot mode". | | | | | | User boot mode | A user can uniquely configure the system to switch between these two modes. For example, a user can freely design the system such that the normal mode is selected when the port "A0" is set to "1" and the user boot mode is selected when it is set to "0". A user should prepare a routine as part of the application program to make the decision on the selection of the modes. | | | | | Single boot mode | | After reset is cleared, it starts up from the internal Boot ROM (Mask ROM). In the Boot ROM, an algorithm to enable flash memory rewriting on the user's set through the serial port of this device is programmed. By connecting to an external host computer through the serial port, the internal flash memory can be programmed by transferring data in accordance with predefined protocols. | | | | Among the flash memory operation modes listed in the above table, the User Boot mode and the Single Boot mode are the programmable modes. These two modes, the User Boot mode and the Single Boot mode, are referred to as "Onboard Programming" modes where onboard rewriting of internal flash memory can be made on the user's set. Either the Single Chip or Single Boot operation mode can be selected by externally setting the level of the BOOT (PI0) pin while the device is in reset status. Table 22-2 Operating Mode Setting Figure 22-2 Mode Transition Diagram ### 22.2.1 Reset Operation To reset the device, ensure that the power supply voltage is within the operating voltage range, that the internal oscillator has been stabilized, and that the RESET input is held at "0" for a minimum duration of 12 system clocks (0.19µs with 64MHz operation; the "1/1" clock gear mode is applied after reset). Note 1: It is necessary to apply "0" to the RESET inputs upon power on for a minimum duration of 700 µs regardless of the operating frequency. Note 2: While flash auto programming or erasing is in progress, at least 0.5 µs of reset period is required regardless of the system clock frequency. In this condition, it takes approx. 2 ms to enable reading after reset. ### 22.2.2 User Boot Mode (Single chip mode) User Boot mode is to use flash memory programming routine defined by users. It is used when the data transfer buses for flash memory program code on the old application and for serial I/O are different. It operates at the single chip mode; therefore, a switch from normal mode in which user application is activated at the single chip mode to User Boot Mode for programming flash is required. Specifically, add a mode judgment routine to a reset program in the user application. The condition to switch the modes needs to be set by using the I/O of TMPM362F10FG in conformity with the user's system setup condition. Also, flash memory programming routine that the user uniquely makes up needs to be set in the new application. This routine is used for programming after being switched to User Boot Mode. The execution of the programming routine must take place while it is stored in the area other than the flash memory since the data in the internal flash memory cannot be read out during delete / writing mode. Once re-programming is complete, it is recommended to protect relevant flash blocks from accidental corruption during subsequent Single-Chip (Normal mode) operations. Be sure not to cause any exceptions including a non-maskable while User Boot Mode. (1-A) and (1-B) are the examples of programming with routines in the internal flash memory and in the external memory. For a detailed description of the erase and program sequence, refer to "22.3 On-board Programming of Flash Memory (Rewrite/Erase)". Page 639 2023/07/21 22. Flash 22.2 Operation Mode TMPM362F10FG #### 22.2.2.1 (1-A) Method 1: Storing a Programming Routine in the Flash Memory #### (1) Step-1 Determine the conditions (e.g., pin states) required for the flash memory to enter User Boot mode and the I/O bus to be used to transfer new program code. Create hardware and software accordingly. Before installing the TMPM362F10FG on a printed circuit board, write the following program routines into an arbitrary flash block using programming equipment. (a) Mode judgment routine: Code to determine whether or not to switch to User Boot mode (b) Programming routine: Code to download new program code from a host controller and re-program the flash memory (c) Copy routine: Code to copy the data described in (b) from the TMPM362F10FG flash memory to either the TMPM362F10FG on-chip RAM or external memory device. (TMPM362F10FG) (I/O) Flash memory Old Application Program Code [Reset Procedure] (a) Mode Judgement Routine (b) Programming Routine (c) Copy Routine ### (2) Step-2 The following description is the case that programming routines are installed in the reset processing program. After RESET pin is released, the reset procedure determines whether to put the TMPM362F10FG flash memory in User Boot mode. If mode switching conditions are met, the flash memory enters User Boot mode. (All interrupts including NMI must be not used while in User Boot mode.) #### (3) Step-3 Once transition to User Boot mode is occurred, execute the copy routine (c) to copy the flash programming routine (b) to the TMPM362F10FG on-chip RAM. Page 641 2023/07/21 22. Flash 22.2 Operation Mode TMPM362F10FG #### (4) Step-4 Jump program execution to the flash programming routine in the on-chip RAM to clear write or erase protection and erase a flash block containing the old application program code. #### (5) Step-5 Continue executing the flash programming routine to download new program code from the host controller and program it into the erased flash block. When the programming is completed, the writing or erase protection of that flash block in the user's program area must be set. # (6) Step-6 Set $\overline{RESET}$ to "0" to reset the TMPM362F10FG. Upon reset, the on-chip flash memory is set to Normal mode. After $\overline{RESET}$ is released, the CPU will start executing the new application program code. Page 643 2023/07/21 22.2 Operation Mode TMPM362F10FG #### 22.2.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host #### (1) Step-1 22. Flash Determine the conditions (e.g., pin states) required for the flash memory to enter User Boot mode and the I/O bus to be used to transfer new program code. Create hardware and software accordingly. Before installing the TMPM362F10FG on a printed circuit board, write the following program routines into an arbitrary flash block using programming equipment. (a) Mode judgment routine: Code to determine whether or not to switch to User Boot mode(b) Transfer routine: Code to download new program code from a host controller Also, prepare a programming routine shown below on the host controller: (c) Programming routine: Code to download new program code from an external host controller and re-program the flash memory #### (2) Step-2 The following description is the case that programming routines are installed in the reset processing program. After RESET is released, the reset procedure determines whether to put the TMPM362F10FG flash memory in User Boot mode. If mode switching conditions are met, the flash memory enters User Boot mode. (All interrupts including NMI must be not used while in User Boot mode). #### (3) Step-3 Once User Boot mode is entered, execute the transfer routine (b) to download the flash programming routine (c) from the host controller to the TMPM362F10FG on-chip RAM. Page 645 2023/07/21 22. Flash 22.2 Operation Mode TMPM362F10FG #### (4) Step-4 Jump program execution to the flash programming routine in the on-chip RAM to clear write or erase protection and erase a flash block containing the old application program code. #### (5) Step-5 Continue executing the flash programming routine to download new program code from the host controller and program it into the erased flash block. When the programming is completed, the writing or erase protection of that flash block in the user program area must be set. # (6) Step-6 Set $\overline{RESET}$ to "0" low to reset the TMPM362F10FG. Upon reset, the on-chip flash memory is set to Normal mode. After $\overline{RESET}$ is released, the CPU will start executing the new application program code. Page 647 2023/07/21 22.2 Operation Mode TMPM362F10FG ### 22.2.3 Single Boot Mode In Single Boot mode, the flash memory can be re-programmed by using a program contained in the TMPM362F10FG on-chip boot ROM. This boot ROM is a masked ROM. When Single Boot mode is selected upon reset, the boot ROM is mapped to the address region including the interrupt vector table while the flash memory is mapped to an address region different from it. Single Boot mode allows for serial programming of the flash memory. Channel 4 of the SIO (SIO4) of the TMPM362F10FG is connected to an external host controller. Via this serial link, a programming routine is downloaded from the host controller to the TMPM362F10FG on-chip RAM. Then, the flash memory is re-programmed by executing the programming routine. The host sends out both commands and programming data to re-program the flash memory. Communications between the SIO4 and the host must follow the protocol described later. To secure the contents of the flash memory, the validity of the application's password is verified before a programming routine is downloaded into the on-chip RAM. If password matching fails, the transfer of a programming routine itself is aborted. As in the case of User Boot mode, all interrupts including the non-maskable interrupt (NMI) must be disabled in Single Boot mode while the flash memory is being erased or programmed. In Single Boot mode, the boot-ROM programs 33are executed in Normal mode. Once re-programming is complete, it is recommended to set the write/erase protection to the relevant flash blocks from accidental corruption during subsequent Single-Chip (Normal mode) operations. # 22.2.3.1 (2-A) Using the Program in the On-Chip Boot ROM #### (1) Step-1 The flash block containing the old version of the program code does not need to be erased before executing the programming routine. Since a programming routine and programming data are transferred via the SIO (SIO4), the SIO4 must be connected to a host controller. Prepare a programming routine (a) on the host controller. #### (2) Step-2 Set the RESET pin to "1" to cancel the reset of the TMPM362F10FG when the BOOT pin has already been set to "0". After reset, CPU reboots from the on-chip boot ROM. The 12-byte password transferred from the host controller via SIO4 is firstly compared to the contents of the special flash memory locations. (If the flash block has already been erased, the password is 0xFF). #### (3) Step-3 If the password is correct, the boot program downloads the programming routine (a) from the host controller into the on-chip RAM of the TMPM362F10FG. The programming routine must be stored in the range from 0x2000\_0400 to the end address of RAM. Page 649 2023/07/21 22. Flash 22.2 Operation Mode TMPM362F10FG #### (4) Step-4 The CPU jumps to the programming routine (a) in the on-chip RAM to erase the flash block containing the old application program code. The Block Erase or Chip Erase command may be used. #### (5) Step-5 Next, the programming routine (a) downloads new application program code from the host controller and programs it into the erased flash block. When the programming is completed, the writing or erase protection of that flash block in the user's program area must be set. In the example below, new program code comes from the same host controller via the same SIO4 channel as for the programming routine. However, once the programming routine has begun to execute in the on-chip RAM, it is free to change the transfer path and the source of the transfer. Create board hardware and a programming routine to suit your particular needs. #### (6) Step-6 When programming of the flash memory is complete, power off the board and disconnect the cable between the host and the target board. Turn on the power again so that the TMPM362F10FG reboots in Single-Chip (Normal) mode to execute the new program. # 22.2.4 Configuration for Single Boot Mode To execute the on-board programming, boot the TMPM362F10FG with Single Boot mode following the configuration shown below. $\overline{\text{BOOT}}(\text{PI0}) = 0$ $\overline{\text{RESET}} = 0 \rightarrow 1$ Set the $\overline{RESET}$ input to "0", and set the each $\overline{BOOT}$ (PI0) pins to values shown above, and then release $\overline{RE-SET}$ pin (high). ### 22.2.5 Memory Map Figure 22-3 shows a comparison of the memory maps in Normal and Single Boot modes. In Single Boot mode, the internal flash memory is mapped to 0x3F80\_0000 and later addresses, and the Internal boot ROM (Mask ROM) is mapped to 0x0000 0000 through 0x0000 0FFF. The internal flash memory and RAM addresses of each device are shown below. | Product Name | Flash Size | RAM Size Flash Address (Single Chip / Single Boot Mode) | | RAM Address | |--------------|------------|---------------------------------------------------------|----------------------------------------------------------|----------------------------| | TMPM362F10FG | 1024 KB | 64 KB | 0x0000_0000 to 0x000F_FFFF<br>0x3F80_0000 to 0x3F8F_FFFF | 0x2000_0000 to 0x2000_FFFF | Page 651 2023/07/21 Figure 22-3 Memory Maps for TMPM362F10FG # 22.2.6 Interface specification In Single Boot mode, an SIO channel is used for communications with a programming controller. The same configuration is applied to a communication format on a programming controller to execute the onboard programming. Both UART (asynchronous) and I/O Interface (synchronous) modes are supported. The communication formats are shown below. #### · UART communication Communication channel: SIO channel 4 Serial transfer mode: UART (asynchronous), half-duplex, LSB first Data length: 8 bits Parity bit: None STOP bit: 1 bit Baud rate: Arbitrary baud rate #### I/O Interface mode Communication channel: SIO channel 4 Serial transfer mode: I/O interface mode, full -duplex, LSB first Synchronization clock (SCLK4): Input mode Handshaking signal: PN3 configured as an output mode Baud rate: Arbitrary baud rate Table 22-3 Required Pin Connections | Pir | | Interface | | | |-------------------|-------------|-----------|--------------------|--| | Pir | $\bigcap$ | UART | I/O Interface Mode | | | | RVDD3 | | 0 | | | // )_ | AVDD3 | | 0 | | | Dower aupply pine | DVDD3B | 0 | 0 | | | Power supply pins | DVDD3A | 0 | 0 | | | $\wedge$ | AVSS | 0 | 0 | | | | DVSS | 0 | 0 | | | Mode-setting pin | BOOT (PI0) | 0 | 0 | | | Reset pin | RESET | 0 | 0 | | | | TXD4 (PN0) | 0 | 0 | | | Communication | RXD4 (PN1) | 0 | 0 | | | pin | SCLK4 (PN2) | × | o (Input mode) | | | Ť | PN3 | × | o (Output mode) | | 22. Flash 22.2 Operation Mode TMPM362F10FG #### 22.2.7 Data Transfer Format Table 22-4, Table 22-6 to Table 22-9 illustrate the operation commands and data transfer formats at each operation mode. In conjunction with this section, refer to "22.2.10 Operation of Boot Program". Table 22-4 Single Boot Mode Commands | Code | Command | | | |------|-------------------------------|--|--| | 0x10 | RAM transfer | | | | 0x20 | Show Flash Memory SUM | | | | 0x30 | Show Product Information | | | | 0x40 | Chip and protection bit erase | | | # 22.2.8 Restrictions on internal memories Single Boot Mode places restrictions on the internal RAM and ROM as shown in Table 22-5. Table 22-5 Restrictions in Single Boot Mode | Memory | Details | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Internal RAM | A program contained in the BOOT ROM uses the area, through 0x2000_0000 to 0x2000_03FF, as a work area. Store the RAM transfer program from 0x2000_0400 through the end address of RAM. | | Internal ROM | The following addresses are assigned for storing software ID information and passwords. Storing program in these addresses is not recommendable. 0x3F8F_FFF0 to 0x3F8F_FFFF | # 22.2.9 Transfer Format for Boot Program The following tables shows the transfer format for each Boot program command. Use this section in conjunction with Chapter "22.2.10 Operation of Boot Program". #### 22.2.9.1 RAM Transfer Table 22-6 Transfer Format for the RAM Transfer Command | | Byte | Data Transferred from the Controller to the TMPM362F10FG | Baud rate | Data Transferred from the TMPM362F10FG to the Controller | |-------------|-------------------------|----------------------------------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Boot<br>ROM | 1 byte | Serial operation mode and baud rate<br>For UART mode : 0x86<br>For I/O Interface mode : 0x30 | Desired baud rate (Note 1) | - | | | 2 byte | - | | ACK for the serial operation mode byte For UART mode Normal acknowledge: 0x86 (The boot program aborts if the baud rate can not be set correctly.) For I/O Interface mode Normal acknowledge:0x30 | | | 3 byte | Command code (0x10) | 4() | | | | 4 byte | - | | ACK for the command code byte (Note 2) - Normal acknowledge: 0x10 - Negative acknowledge: 0xX1 - Communication error: 0xX8 | | | 5 byte<br>to<br>16 byte | Password sequence (12 bytes)) 0x3F8F_FFF4 to 0x3F8F_FFFF | | | | | 17 byte | Check SUM value for bytes 5 to 16 | $\searrow$ | (0/6) | | | 18 byte | - | | ACK for the checksum byte (Note 2) Normal acknowledge : 0x10 Negative acknowledge : 0xX1 Communication error : 0xX8 | | | 19 byte | RAM storage start address 31 to 24 | | 7 | | | 20 byte | RAM storage start address 23 to 16 | | - | | | 21 byte | RAM storage start address 15 to 8 | | _ | | | 22 byte | RAM storage start address 7 to 0 | | _ | | | 23 byte | RAM storage start address 15 to 8 | | _ | | | 24 byte | RAM storage start address 7 to 0 | () | - | | | 25 byte | Check SUM value for bytes 19 to 24 | / | - | | | 26 byte | | | ACK for the checksum byte (Note 2) - Normal acknowledge : 0x10 - Negative acknowledge : 0xX1 - Communication error : 0xX8 | | < | 27 byte<br>to<br>mbyte | RAM storage data | | - | | (= | m+ 1 byte | Checksum value for bytes 27 to m | | - | | | m+ 2 byte | - 1 | | ACK for the checksum byte (Note 2) - Normal acknowledge : 0x10 - Negative acknowledge : 0xX1 - Communication error : 0xX8 | | RAM | m+ 3 byte | _ | | Jump to RAM storage start address | Note 1: In I/O Interface mode, the baud rate for the transfers of the first and second bytes must be 1/16 of the desired baud rate. Note 2: In case of any negative acknowledge, the boot program returns to a state in which it waits for a command code (3rd byte). In I/O Interface mode, if a communication error occurs, a negative acknowledge does not occur. Note 3: The 19th to 25th bytes must be within the RAM address range from 0x2000\_0400 through the end address of RAM. Page 655 2023/07/21 22. Flash 22.2 Operation Mode TMPM362F10FG ### 22.2.9.2 Show Flash Memory SUM Table 22-7 Transfer Format for the Show Flash Memory SUM Command | | Byte | Data Transferred from the Controller to the TMPM362F10FG | Baud rate | Data Transferred from the TMPM362F10FG to the Controller | |-------------|--------|----------------------------------------------------------------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Boot<br>ROM | 1 byte | Serial operation mode and baud rate<br>For UART mode : 0x86<br>For I/O Interface mode : 0x30 | Desired baud rate (Note 1) | - | | | 2 byte | - | | ACK for the serial operation mode byte For UART mode Normal acknowledge: 0x86 (The boot program aborts if the baud rate can not be set correctly.) For I/O Interface mode Normal acknowledge: 0x30 | | | 3 byte | Command code (0x20) | 4 | -> // > | | | 4 byte | - | | ACK for the command code byte (Note 2) - Normal acknowledge: 0x10 - Negative acknowledge: 0xX1 - Communication error: 0xX8 | | | 5 byte | - | | SUM (upper byte) | | | 6 byte | - | | SUM (lower byte) | | | 7 byte | - | > | Checksum value for byte 5 and 6 | | | 8 byte | (Wait for the next command code:) | | ((/)) | Note 1: In I/O Interface mode, the baud rate for the transfers of the first and second bytes must be 1/16 of the desired baud rate. Note 2: In case of any negative acknowledge, the boot program returns to a state in which it waits for a command code (3rd byte). In I/O Interface mode, if a communication error occurs, a negative acknowledge does not occur. # 22.2.9.3 Transfer Format for the Show Product Information Table 22-8 Transfer Format for the Show Product Information Command | | Byte | Data Transferred from the Controller to the TMPM362F10FG | Baud rate | Data Transferred from the TMPM362F10FG to the Controller | |-------------|--------------------------|----------------------------------------------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Boot<br>ROM | 1 byte | Serial operation mode and baud rate<br>For UART mode : 0x86<br>For I/O Interface mode : 0x30 | Desired<br>baud rate<br>(Note 1) | - | | | 2 byte | - | | ACK for the serial operation mode byte For UART mode Normal acknowledge: 0x86 (The boot program aborts if the baud rate can not be set correctly.) For I/O Interface mode Normal acknowledge:0x30 | | | 3 byte | Command code (0x30) | 4 | (- ) | | | 4 byte | - | | ACK for the command code byte (Note 2) Normal acknowledge: 0x10 Negative acknowledge: 0xX1 - Communication error: 0xX8 | | | 5 byte | - | | Flash memory data at address 0x3F8F_FFF0 | | | 6 byte | - | | Flash memory data<br>at address 0x3F8F_FFF1 | | | 7 byte | - | | Flash memory data<br>at address 0x3F8F_FFF2î'ín | | | 8 byte | - | | Flash memory data<br>at address 0x3F8F_FFF3 | | | 9 byte<br>to<br>20 byte | | | Product name (12-byte ACCII code) From 9th byte : 'TMPM360F1' | | | 21 byte<br>to<br>24 byte | | | Password comparison start address (4 bytes) From 21st byte : 0xF4, 0xFF, 0x8F, 0x3F | | | 25 byte<br>to<br>28 byte | | | RAM start address (4 bytes) From 25th byte : 0x00, 0x00, 0x00, 0x20 | | | 29 byte<br>to<br>32 byte | - | | Dummy data (4 bytes) From 29th byte : 0x00, 0x00, 0x00, 0x00 | | | 33 byte<br>to<br>36 byte | | | RAM end address (4bytes) From 33th byte: 0xFF, 0xFF, 0x00, 0x20 | | | 37 byte<br>to<br>40 byte | - | | Dummy date (4bytes) From 37th byte : 0x00, 0x00, 0x00, 0x00 | | | 41 byte<br>to | - | | Dummy date (4bytes)<br>From 41st byte | | | 44 byte | | | 0x00, 0x00, 0x00, 0x00 | Page 657 2023/07/21 22. Flash22.2 Operation Mode Operation Mode TMPM362F10FG Table 22-8 Transfer Format for the Show Product Information Command | Byte | Data Transferred from the Controller to the TMPM362F10FG | Baud rate | Data Transferred from the TMPM362F10FG to the Controller | |--------------------------|----------------------------------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 45 byte<br>to<br>46 byte | - | | Dummy data (2 bytes) From 45th byte: 0x00, 0x00 | | 47 byte<br>to<br>50 byte | - | | Flash memory start address (4 bytes) From 47th byte: 0x00, 0x00, 0x80, 0x3F | | 51 byte<br>to<br>54 byte | - | | Flash memory end address (4 bytes) From 51st byte: 0xFF, 0xFF, 0x8F, 0x3F | | 55 byte<br>to<br>56 byte | - | | Flash memory block count (2 bytes) From 55th byte : 0x0A, 0x00 | | 57 byte<br>to<br>60 byte | - | | Start address of a group of the same-size (16K) flash blocks (4 bytes) From 57th byte: 0x00, 0x00, 0x00, 0x00 TMPM362F10FG does not have 16KB block. | | 61 byte<br>to<br>64 byte | - | | Size (in halfwords) of the same-size (16K) flash blocks (4 bytes) From 61st byte: 0x00, 0x00, 0x00, 0x00 TMPM362F10FG does not have 16KB block. | | 65 byte | - | | Number of flash blocks of the same size (16K) (1 byte) 0x00 TMPM362F10FG does not have 16KB block. | | 66 byte<br>to<br>69 byte | - | | Start address of a group of the same-size (32K) flash blocks (4 bytes) From 66th byte: 0x00, 0x00, 0x8F, 0x3F | | 70 byte<br>to<br>73 byte | | | Size (in halfwords) of the same-size (32K) flash blocks (4 bytes) From 70th byte: 0x00, 0x40, 0x00, 0x00 | | 74 byte | - | | Number of flash blocks of the same size (32K) (1 byte) 0x02 | | 75 byte to 78 byte | | | Start address of a group of the same-size (32K) flash blocks (4 bytes) From 75th byte: 0x00, 0x00, 0x81, 0x3F | | 79 byte<br>to<br>82 byte | - (2) | | Size (in halfwords) of the same-size (32K) flash blocks (4 bytes) From 79th byte : | | 82 byte | $\rightarrow$ | | 0x00, 0x80, 0x00, 0x00 | Table 22-8 Transfer Format for the Show Product Information Command | Byte | Data Transferred from the Controller to the TMPM362F10FG | Baud rate | Data Transferred from the TMPM362F10FG to the Controller | |--------------------------|----------------------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------| | 83 byte | - | | Number of flash blocks of the same size (64K) (1 byte) 0x01 | | 84 byte<br>to<br>87 byte | - | | Start address of a group of the same-size (128K) flash blocks (4 bytes) From 84th byte: 0x00, 0x00, 0x82, 0x3F | | 88 byte<br>to<br>91 byte | - | ( | Size (in halfwords) of the same-size (128K) flash blocks (4 bytes) From 88th byte: 0x00, 0x00, 0x01, 0x00 | | 92 byte | - | | Number of flash blocks of the same size (128K) (1 byte) 0x07 | | 93 byte | _ | | Checksum value for bytes from 5 to 92 | | 94 byte | (Wait for the next command code.) | | - | Note 1: In I/O Interface mode, the baud rate for the transfers of the first and second byte must be 1/16 of the desired baud rate. Note 2: In case of any negative acknowledge, the boot program returns to a state in which it waits for a command code (3rd byte). In I/O Interface mode, if a communication error occurs, a negative acknowledge does not occur. Page 659 2023/07/21 22.2 Operation Mode TMPM362F10FG ### 22.2.9.4 Chip Erase and Protect Bit Erase Table 22-9 Transfer Format for the Chip and Protection Bit Erase Command | | Byte | Data Transferred from the Controller to the TMPM362F10FG | Baud rate | Data Transferred from the TMPM362F10FG to the Controller | |-------------|--------|----------------------------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Boot<br>ROM | 1 byte | Serial operation mode and baud rate For UART mode : 0x86 For I/O Interface mode : 0x30 | Desired baud rate (Note 1) | - | | | 2 byte | _ | | ACK for the serial operation mode byte For UART mode Normal acknowledge: 0x86 (The boot program aborts if the baud rate can not be set correctly.) For I/O Interface mode Normal acknowledge:0x30 | | | 3 byte | Command code (0x40) | 4( ) | -> // | | | 4 byte | - | | ACK for the command code byte (Note 2) - Normal acknowledge : 0x10 - Negative acknowledge : 0xX1 - Communication error : 0xX8 | | | 5 byte | Chip erase command code (0x54) | | - | | | 6 byte | - | | ACK for the command code byte (Note 2) - Normal acknowledge : 0x10 - Negative acknowledge : 0xX1 - Communication error : 0xX8 | | | 7 byte | - | | ACK for the chip erase command code byte - Normal acknowledge : 0x4F - Negative acknowledge : 0x4C | | | 8 byte | (Wait for the next command code.) | | <u></u> | Note 1: In I/O Interface mode, the baud rate for the transfers of the first and second byte must be 1/16 of the desired baud rate. Note 2: In case of any negative acknowledge, the boot program returns to a state in which it waits for a command code (3rd byte). In I/O Interface mode, if a communication error occurs, a negative acknowledge does not occur. ### 22.2.10 Operation of Boot Program When Single Boot mode is selected, the boot program is automatically executed on startup. The boot program offers these four commands, of which the details are provided on the following subsections. #### 1. RAM Transfer command The RAM Transfer command stores program code transferred from the host controller to the onchip RAM and executes the program once the transfer is successfully completed. The user program RAM space can be assigned to the range from $0x2000\_0400$ to the end address of RAM, whereas the boot program area $(0x2000\_0000$ to $0x2000\_03FF)$ is unavailable. The user program starts at the assigned RAM address. The RAM Transfer command can be used to download a flash programming routine of your own; this provides the ability to control on-board programming of the flash memory in a unique manner. The programming routine must utilize the flash memory command sequences described in Section 22.3. Before initiating a transfer, the RAM Transfer command verifies a password sequence coming from the controller against that stored in the flash memory. Note: If a password is set to 0xFF (erased data), it is difficult to protect data securely due to an easy-toguess password. Even if Single Boot mode is not used, it is recommended to set a unique value as a password. ### 2. Show Flash Memory SUM command The Show Flash Memory SUM command adds the entire contents of the flash memory together. The boot program does not provide a command to read out the contents of the flash memory. Instead, the Flash Memory SUM command can be used for software revision management. ### 3. Show Product Information command The Show Product Information command provides the product name, on-chip memory configuration and the like. This command also reads out the contents of the flash memory locations at addresses shown below. In addition to the Show Flash Memory Sum command, these locations can be used for software revision management. | / | 7 | | |---|--------------|----------------------------| | | Product name | Area | | / | TMPM362F10FG | 0x3F8F_FFF0 to 0x3F8F_FFF3 | ### 4. Flash Memory Chip Erase and Protection Bit Erase command This command erases the entire area of the flash memory automatically. All the blocks in the memory cell and their protection conditions are erased even when any of the blocks are prohibited from writing and erasing. When the command is completed, the FCSECBIT <SECBIT> bit is set to "1". This command serves to recover boot programming operation when a user forgets the password. Therefore password verification is not executed. Page 661 2023/07/21 22.2 Operation Mode TMPM362F10FG #### 22.2.10.1 RAM Transfer Command See Table 22-6 for the transfer format of this command. 1. The 1st byte specifies which one of the two serial operation modes is used. For a detailed description of how the serial operation mode is determined, see "22.2.10.6 Determination of a Serial Operation Mode" described later. If the mode is determined as UART mode, the boot program checks if the baud rate setting can be performed. During the first-byte processing, receiving operation is prohibited. (SC4MOD0<RXE>=0) · To communicate in UART mode The 1st byte is set to "0x86" and is transmitted from the controller to the target board at the specified baud rate by setting UART. If the serial operation mode is determined as UART, then the boot program checks if the baud rate setting can be performed. If that baud rate cannot be set, the boot program aborts and any subsequent communications cannot be done. Please refer to "Baud rate setting" for the method of judging whether the setting of the baud rate is possible. To communicate in I/O Interface mode. The 1st byte is set to "0x30" and is transmitted from the controller to the target board at 1/16 of the desired baud rate by the synchronous setting. Same as the 1st byte, a 1/16 of the specified baud rate is used in the 2nd transmission. From the 3rd byte (operation command data), users can transmit data at specified baud rate. In I/O interface mode, CPU considers the reception terminal to be an input port and monitors the level of I/O port. If the baud rate is high or operation frequency is high, CPU may not distinguish the level of I/O port. To avoid this situation, the baud rate is set at the 1/16 of desired baud rate in the I/O interface. When the serial operation mode is determined as I/O Interface mode, SCLK Input mode is set. The controller must ensure that its AC timing restrictions are satisfied at the selected baud rate. In the case of I/O Interface mode, the boot program does not check the receive error flag; thus there is no error acknowledge responce (bit 3, 0x08). 2. The 2nd byte, transmitted from the target board to the controller, is an acknowledge response to the 1st byte where the serial operation mode is set. When 1st byte is determined as UART and can be set at the specified band rate, data "0x86" is transmitted. When 1st byte is determined as I/O interface, data "0x30" is transmitted. · UART mode The 2nd byte is used for distinguishing whether the baud rate can be set. If the baud rate can be set, a value of SC4BRCE is renewed and data "0x86" is sent to the controller. If the baud rate cannot be set, transmit operation is stopped and no data is transmitted. After transmission of 1st byte completed, the controller allows for five seconds of time-out. If it does not receive 0x86 within the allowed time-out period, the controller should give up the communication. Receiving operation is permitted by setting SC4MOD0 I/O Interface mode The boot program sets a value of the SC4MOD0 and SC4CR registers to configure the the I/O Interface mode and writes 0x30 to the SC4BUF. Then, the SIO4 waits for the SCLK4 signal to come from the controller. After the transmission of the 1st byte completed, the controller should send the SCLK clock to the target board after a certain idle time (several microseconds). This must be done at 1/16 of the desired baud rate. If the 2nd byte, which is from the target board to the controller, is 0x30, then the controller regards it as communication possible. From the 3rd byte, users can transmit data at specified baud rate. Receiving operation is permitted by setting SC4MOD0<RXE>=1, before loading 0x86 to the SIO. - 3. The 3rd byte transmitted from the controller to the target board is a command. The code for the RAM Transfer command is 0x10. - 4. The 4th byte, transmitted from the target board to the controller, is an acknowledge response to the 3rd byte. Before sending back the acknowledge response, the boot program checks for a receive error. If there is a receive error, the boot program transmits 0xX8 (bit 3) and returns to the state in which it waits for a command (the third byte) again. In this case, the upper four bits of the acknowledge response are undefined they hold the same values as the upper four bits of the previously issued command. When the SIO0 is configured for I/O Interface mode, the boot program does not check for a receive error. If the 3rd byte is equal to any of the command codes listed in Table 22-4, the boot program echoes it back to the controller. When the RAM Transfer command is received, the boot program echoes back a value of 0x10 and then branches to the RAM Transfer routine. Once this branch is taken, password verification is done. Password verification is detailed in the later Section "Password". If the 3rd byte is not a valid command, the boot program sends back 0xX1 (bit 0) to the controller and returns to the state in which it waits for a command (the third byte) again. In this case, the upper four bits of the acknowledge response are undefined - they hold the same values as the upper four bits of the previously issued command. 5. The 5th to 16th bytes transmitted from the controller to the target board, are a 12-byte password. Each byte is compared to the contents of following addresses in the flash memory. The verification is started with the 5th byte. If the password verification fails, the RAM Transfer routine sets the password error flag. | Product name | Area | |--------------|----------------------------| | TMPM362F10FG | 0x3F8F_FFF4 to 0x3F8F_FFFF | - 6. The 17th byte is a checksum value for the password sequence (5th to 16th bytes). To calculate the checksum value for the 12-byte password, add the 12 bytes together, ignore the carries and caluculate the 8-bit two's complement by using lower 8 bits then transmit this checksum value from the controller. The checksum calculation is described in details in the later Section "Checksum Calculation". - 7. The 18th byte, transmitted from the target board to the controller, is an acknowledge response to the 5th to 17th bytes. First, the RAM Transfer routine checks for a receive error in the 5th to 17th byte. If there is a receive error, the boot program sends back 0x18 (bit 3) and returns to the state in which it waits for a command (i.e., the 3rd byte) again. In this case, the upper four bits of the acknowledge response are the same as those of the previously issued command (i.e., 1). When the SIO4 is configured for I/O Interface mode, the RAM Transfer routine does not check for a receive error. Next, the RAM Transfer routine performs the checksum operation to ensure 17th byte data integrity. Adding the series of the 5th to 16th bytes must result in 0x00 (with the carry dropped). In case of a checksum error, the RAM Transfer routine sends back 0x11 to the controller and returns to the state in which it waits for a command (i.e., the 3rd byte) again. Finally, the password verification result is checked. If the following case is generated, the boot program transmits an acknowledge response (bit 0, 0x11) as a password error and waits for next operation command (3rd byte). - Irrespective of the result of the password comparison, all the 12 bytes of a password in the flash memory are the same value other than 0xFF. - Not the entire password bytes transmitted from the controller matched those contained in the flash memory. When all the above verification has been successful, the RAM Transfer routine returns a normal acknowledge response (0x10) to the controller. - 8. The 19th to 22nd bytes, transmitted from the controller the target board, indicate the start address of the RAM region where subsequent data (e.g., a flash programming routine) should be stored. The 19th byte corresponds to bits 31 to 24 of the address and the 22nd byte corresponds to bits 7 to 0 of the address. The start address of the stored RAM must be even address. - 9. The 23rd and 24th bytes, transmitted from the controller to the target board, indicate the number of bytes that will be transferred from the controller to be stored in the RAM. The 23rd byte corresponds to bits 15 to 8 of the number of bytes to be transferred, and the 24th byte corresponds to bits 7 to 0 of the number of bytes. - 10. The 25th byte is a checksum value for the 19th to 24th bytes. To calculate the checksum value, add all these bytes together, ignore the carries and caluculate the 8-bit two's complement by using lower 8 bits then transmit this checksum value from the controller. The checksum calculation is described in detail in the later Section "22.2.10.9 Checksum Calculation". - 11. The 26th byte, transmitted from the target board to the controller, is an acknowledge response to the 19th to 25th bytes of data. First, the RAM Transfer routine checks for a receive error in the 19th to 25th bytes. If there is a receive error, the RAM Transfer routine sends back 0x18 and returns to the command wait state (i.e., the 3rd byte) again. In this case, the upper four bits of the acknowledge response are the same as those of the previously issued command (i.e., 1). When the SIO4 is configured for I/O Interface mode, the RAM Transfer routine does not check for a receive error. Next, the RAM Transfer routine performs the checksum operation to ensure data integrity. Adding the series of the 19th to 24th bytes must result in 0x00 (with the carry dropped). In case of a checksum error, the RAM Transfer routine sends back 0x11 to the controller and returns to the state in which it waits for a command (i.e., the 3rd byte) again. The 19th to 25th bytes data must be within the range of 0x2000\_0400 to the end address of RAM. When the above checks have been successful, the RAM Transfer routine returns a normal acknowledge response (0x10) to the controller. - 12. The 27th to mth bytes from the controller are stored in the on-chip RAM of the TMPM362F10FG. Storage begins at the address specified by the 19th to 22nd bytes and continues for the number of bytes specified by the 23rd to 24th bytes. - 13. The (m+1) th byte is a checksum value. To calculate the checksum value, add the 27th to mth bytes together, ignore the carries and calculate the 8-bit two's complement by using lower 8 bits then transmit this checksum value from the controller. The checksum calculation is described in detail in later Section "22.2.10.9 Checksum Calculation". - 14. The (m+2) th byte is a acknowledge response to the 27th to (m+1) th bytes. First, the RAM Transfer routine checks for a receive error in the 27th to (m+1) th bytes. If there is a receive error, the RAM Transfer routine sends back 0x18 (bit 3) and returns to the state in which it waits for a command (i.e., the 3rd byte) again. In this case, the upper four bits of the acknowledge response are the same as those of the previously issued command (i.e., 1). When the SIO4 is configured for I/O Interface mode, the RAM Transfer routine does not check for a receive error. Next, the RAM Transfer routine performs the checksum operation to ensure data integrity. Adding the series of the 27th to (m+1) th bytes must result in 0x00 (with the carry dropped). In case of a checksum error, the RAM Transfer routine sends back 0x11 (bit 0) to the controller and returns to the command wait state (i.e., the 3rd byte) again. When the above checks have been completed successfully, the RAM Transfer routine returns a normal acknowledge response (0x10) to the controller. 15. If the (m+2) th byte was a normal acknowledge response, a branch is made to the address specified by the 19th to 22nd bytes. ### 22.2.10.2 Show Flash Memory SUM Command See Table 22-7 for the transfer format of this command. - 1. The processing of the 1st and 2nd bytes are the same as for the RAM Transfer command. - 2. The 3rd byte, which the target board receives from the controller, is a command. The code for the Show Flash Memory Sum command is 0x20. - 3. The 4th byte, transmitted from the target board to the controller, is an acknowledge response to the 3rd byte. Before sending back the acknowledge response, the boot program checks for a receive error. If there is a receive error, the boot program transmits 0xX8 (bit 3) and returns to the command wait state again. In this case, the upper four bits of the acknowledge response are undefined- they hold the same values as the upper four bits of the previously issued command. When the SIO4 is configured for I/O Interface mode, the boot program does not check for a receive error. If the 3rd byte is equal to any of the command codes listed in Table 22-4, the boot program echoes it back to the controller. When the Show Flash Memory Sum command is received, the boot program echoes back a value of 0x20 and then branches to the Show Flash Memory Sum routine. If the 3rd byte is not a valid command, the boot program sends back 0xX1 (bit 0) to the controller and returns to the command wait state (the third byte) again. In this case, the upper four bits of the acknowledge response are undefined - they hold the same values as the upper four bits of the previously issued command. - 4. The Show Flash Memory Sum routine adds all the bytes of the flash memory together. The 5th and 6th bytes, transmitted from the target board to the controller, indicate the upper and lower bytes of this total sum, respectively. For details on sum calculation, see Section "22.2.10.8 Calculation of the Show Flash Memory Sum Command". - 5. The 7th byte is a checksum value for the 5th and 6th bytes. To calculate the checksum value, add the 5th and 6th bytes together, ignore the carry and calculate the 8-bit two's complement by using lower 8 bits then transmit this checksum value from the controller. - 6. The 8th byte is the next command code. ### 22.2.10.3 Show Product Information Command See Table 22-8 for the transfer format of this command. - 1. The processing of the 1st and 2nd bytes are the same as for the RAM Transfer command. - 2. The 3rd byte, which the target board receives from the controller, is a command. The code for the Show Product Information command is 0x30. - 3. The 4th byte, transmitted from the target board to the controller, is an acknowledge response to the 3rd byte. Before sending back the acknowledge response, the boot program checks for a receive error. If there is a receive error, the boot program transmits 0xX8 (bit 3) and returns to Page 665 2023/07/21 22.2 Operation Mode TMPM362F10FG the command wait state again. In this case, the upper four bits of the acknowledge response are undefined- they hold the same values as the upper four bits of the previously issued command. When the SIO4 is configured for I/O Interface mode, the boot program does not check for a receive error. If the 3rd byte is equal to any of the command codes listed in Table 22-4, the boot program echoes it back to the controller. When the Show Flash Memory Sum command is received, the boot program echoes back a value of 0x30 and then branches to the Show Flash Memory Sum routine. If the 3rd byte is not a valid command, the boot program sends back 0xX1 (bit 0) to the controller and returns to the state in which it waits for a command (the third byte) again. In this case, the upper four bits of the acknowledge response are undefined - they hold the same values as the upper four bits of the previously issued command. 4. The 5th to 8th bytes, transmitted from the target board to the controller, are the data read from addresses shown below in the flash memory. Software version management is possible by storing a software ID in these locations. | Product name | Area | |--------------|----------------------------| | TMPM362F10FG | 0x3F8F_FFF0 to 0x3F8F_FFF3 | 5. The 9th to 20th bytes, transmitted from the target board to the controller, indicate the product name as shown below (where [] is a space) in ASCII code. | Product name | 4 | Core | |--------------|-------------|--------------------------| | TMPM362F10FG | T, M, P, M, | 3, 6, 0, F, 1, _, [ ], _ | 6. The 21st to 24th bytes, transmitted from the target board to the controller, indicate the start address of the flash memory area contained the password. Each product has own start address shown below. Starting from the 21st byte, the following values are transmitted. | $\perp$ | / / 〈 \ | | |---------|------------|-----------------------| | Pr | oduct name | Address | | TMI | PM362F10FG | 0xF4, 0xFF,0x8F, 0x3F | | | _ | | 7. The 25th to 28th bytes, transmitted from the target board to the controller, indicate the start address of the on-chip RAM. TMPM362F10FG has own start address shown below. Starting from the 25th byte, the following values are transmitted. | Product name | Address | |--------------|-----------------------| | TMPM362F10FG | 0x00, 0x00,0x00, 0x20 | - 8. The 29th to 32nd bytes, transmitted from the target board to the controller, are dummy data. Starting from the 29th byte, 0x00, 0x00, 0x00, 0x00 are transmitted. - The 33rd to 36th bytes, transmitted from the target board to the controller, indicate the end address of the on-chip RAM. TMPM362F10FG has own end address shown below. Starting from the 33th byte, the following values are transmitted. | Product name | Address | |--------------|------------------------| | TMPM362F10FG | 0xFF, 0xFF, 0x00, 0x20 | - 10. The 37th to 40th bytes, transmitted from the target board to the controller, are 0x00, 0x00, 0x00 and 0x00. The 41st to 44th bytes, transmitted from the target board to the controller, are 0x00, 0x00, 0x00 and 0x00. - 11. The 45th and 46th bytes transmitted are 0x00, 0x00. - 12. The 47th to 50th bytes, transmitted from the target board to the controller, indicate the start address of the on-chip flash memory, are 0x00, 0x00, 0x80, and 0x3F. | Product name Address | | LL/ | |------------------------------------|--------------|------------| | | Product name | $\sum_{i}$ | | TMPM362F10FG 0x00, 0x00,0x80, 0x3F | TMPM362F10FG | / | 13. The 51st to 54th bytes, transmitted from the target board to the controller, indicate the end address of the on-chip flash memory. Each product has own end address shown below. Starting from the 51th byte, the following values are transmitted. | Product name | Address | |--------------|------------------------| | TMPM362F10FG | 0xFF, 0xFF, 0x8F, 0x3F | 14. The 55th to 56th bytes, transmitted from the target board to the controller, indicate the number of flash blocks available. Each product transmits own number shown below. Starting from the 55th byte, the following values are transmitted. | Product | Number of flash blocks | |--------------|------------------------| | TMPM362F10FG | 0x0A, 0x00 | - 15. The 57th to 92nd bytes, transmitted from the target board to the controller, contain information about the flash blocks. Flash blocks of the same size are treated as a group. Information about the flash blocks indicate the start address of a group, the size of the blocks in that group (in halfwords) and the number of the blocks in that group. The 57th to 65th bytes are the information about the 16-kbyte blocks. The 66th to 74th bytes are the information about the 32-kbyte blocks. The 75th to 83rd bytes are the information about the 64-kbyte blocks. The 84th to 92nd bytes are the information about the 128-kbyte blocks. See Table 22-8 for the values of bytes transmitted. - 16. The 93rd byte, transmitted from the target board to the controller, is a checksum value for the 5th to 92nd bytes. To calculate the checksum value, add all these bytes together, ignore the carries and calculate the 8-bit two's complement by using lower 8 bits. - 17. The 94th byte is the next command code. 22.2 Operation Mode TMPM362F10FG ### 22.2.10.4 Chip and Protection Bit Erase Command See Table 22-9 for the transfer format of this command. 1. The processing of the 1st and 2nd bytes are the same as for the RAM Transfer command. ### 2. From the Controller to the TMPM362F10FG The 3rd byte, which the target board receives from the controller, is a command. The code for the Show Product Information command is 0x40. ### 3. From TMPM362F10FG to the Controller The 4th byte, transmitted from the target board to the controller, is an acknowledge response to the 3rd byte. Before sending back the acknowledge response, the boot program checks for a receive error. If there was a receive error, the boot program transmits 0xX8 (bit 3) and returns to the command wait state again. In this case, the upper four bits of the acknowledge response are undefined - they hold the same values as the upper four bits of the previously issued command. If the 3rd byte is equal to any of the command codes listed in Table 22-4, the boot program echoes it back to the controller. When the Show Flash Memory Sum command was received, the boot program echoes back a value of 0x40. If the 3rd byte is not a valid command, the boot program sends back 0xX1 (bit 0) to the controller and returns to the state in which it waits for a command (the third byte) again. In this case, the upper four bits of the acknowledge response are undefined - they hold the same values as the upper four bits of the previously issued command. ### 4. From the controller to the TMPM362F10FG The 5th byte, transmitted from the target board to the controller, is the Chip Erase Enable command code (0x54). ### 5. From TMPM362F10FG to the Controller The 6th byte, transmitted from the target board to the controller, is an acknowledge response to the 5th byte. Before sending back the acknowledge response, the boot program checks for a receive error. If there was a receive error, the boot program transmits 0xX8 (bit 3) and returns to the command wait state again. In this case, the upper four bits of the acknowledge response are undefined - they hold the same values as the upper four bits of the previously issued command. If the 5th byte is equal to any of the command codes to enable erasing, the boot program echoes it back to the controller. When the Chip and Protection Erase command was received, the boot program echoes back a value of 0x54 and then branches to the Chip Erase routine. If the 5th byte is not a valid command, the boot program sends back 0xX1 (bit 0) to the controller and returns to the state in which it waits for a command (the third byte) again. In this case, the upper four bits of the acknowledge response are undefined - they hold the same values as the upper four bits of the previously issued command. ### 6. From TMPM362F10FG to the Controller The 7th byte indicates whether the Chip Erase command is normally completed or not. At normal completion, completion code (0x4F) is sent. When an error was detected, error code (0x4C) is sent. 7. The 9th byte is the next command code. Page 669 2023/07/21 22.2 Operation Mode TMPM362F10FG ### 22.2.10.5 Acknowledge Responses The boot program represents processing states with specific codes. Table 22-10 to show the values of possible acknowledge responses to the received data. The upper four bits of the acknowledge response are equal to those of the command being executed. The 3rd bit indicates a receive error. The 0th bit indicates an invalid command error, a checksum error or a password error. The 1st bit and 2nd bit are always "0". Receive error checking is not done in I/O Interface mode. Table 22-10 ACK Response to the Serial Operation Mode Byte | Return Value | Meaning | |--------------|--------------------------------------------------------------| | 0x86 | The SIO can be configured to operate in UART mode (See Note) | | 0x30 | The SIO can be configured to operate in I/O Interface mode. | Note: In the UART mode, if the baud rate setting cannot be set, the communication is stopped without any response. Table 22-11 ACK Response to the Command Byte | Return Value | Meaning | |--------------------|-----------------------------------------------------------------------------| | 0x?8<br>(See note) | A receive error occurred while receiving a command code. | | 0x?1<br>(See note) | An undefined command code was received. (Reception was completed normally.) | | 0x10 | The RAM Transfer command was received. | | 0x20 | The Show Flash Memory Sum command was received. | | 0x30 | The Show Product Information command was received. | | 0x40 | The Chip Erase command was received: | Note: The upper four bits of the ACK response are the same as those of the previous command code. Table 22-12 ACK Response to the Checksum Byte | | Return Value | Meaning | |-----|--------------------|----------------------------------------| | | 0xN8<br>(See note) | A receive error occurred. | | 1// | 0xN1<br>(See note) | A checksum or password error occurred. | | > | 0xN0<br>(See note) | The checksum was correct. | Note: The upper four bits of the ACK response are the same as those of the operation command code. For example, it is 1 (N; RAM transfer command data [7:4]) when password error occurs. Table 22-13 ACK Response to Chip and Protection Bit Erase Byte | Return Value | Meaning | | | | |-------------------------------------------------------|---------------------------------------|--|--|--| | 0x54 The Chip Erase enabling command was received. | | | | | | 0x4F | The Chip Erase command was completed. | | | | | 0x4C The Chip Erase command was abnormally completed. | | | | | ### 22.2.10.6 Determination of a Serial Operation Mode The first byte from the controller determines the serial operation mode. To use UART mode for communications between the controller and the target board, the controller must firstly send a value of 0x86 at a desired baud rate to the target board. To use I/O Interface mode, the controller must send a value of 0x30 at 1/16 of the desired baud rate. Figure 22-4 shows the waveforms for the first byte in each mode. Figure 22-4 Serial Operation Mode Byte After RESET is released, the boot program monitors the first serial byte from the controller, with the SIO reception disabled, and calculates the intervals of tAB, tAC and tAD. Figure 22-5 shows a flowchart describing the steps to determine the intervals of tAB, tAC and tAD. As shown in the flowchart, the boot program captures timer counts when each time the logic transition occurs in the first serial byte. Consequently, the calculated tAB, tAC and tAD intervals tend to have slight errors. If the transfer goes at a high baud rate, the CPU might not be able to keep up with the speed of logic transitions at the serial receive pin. In particular, I/O Interface mode may have this problem since its baud rate is generally much higher than that for UART mode. To avoid such a situation, the controller should send the first serial byte at 1/16 of the desired baud rate. The flowchart in Figure 22-5 shows how the boot program distinguishes between UART and I/O Interface modes. If the length of tAB is equal to or less than the length of tCD, the serial operation mode is determined as UART mode. If the length of tAB is greater than the length of tCD, the serial operation mode is determined as I/O Interface mode. Note that if the baud rate is too high or the timer operating frequency is too low, each timer value becomes small. It causes an unintentional behavior of the controller. To prevent this problem, reset UART mode within the programming routine. For example, the serial operation mode may be determined to be I/O Interface mode when the intended mode is UART mode. To avoid such a situation, when UART mode is utilized, the controller should allow for a time-out period within which it expects to receive an echo-back (0x86) from the target board. The controller should give up the communication if it fails to get that echo-back within the allowed time. When I/O Interface mode is utilized, once the first serial byte has been transmitted, the controller should send the SCLK clock after a certain idle time to get an acknowledge response. If the received acknowledge response is not 0x30, the controller should give up further communications. When the intended mode is I/O interface mode, the first byte does not have to be 0x30 as long as tAB is greater than tCD as shown above. 0x91, 0xA1 or 0xB1 can be sent as the first byte code to determine the falling edges of Point A and Point C and the rising edges of Point B and Point D. If tAB is greater than tCD and SIO is selected by the resolution of the operation mode determination, the second byte code is 0x30 even though the transmitted code on the first byte is not 0x30 (The first byte code to determine I/O interface mode is described as 0x30). Page 671 2023/07/21 Figure 22-5 Serial Operation Mode Byte Reception Flowchart Figure 22-6 Serial Operation Mode Determination Flowchart ### 22.2.10.7 Password The RAM Transfer command (0x10) causes the boot program to perform password verification. Following an echo-back of the command code, the boot program verifies the contents of the 12-byte password area within the flash memory. The following table shows the password area of each product. | Product name | Area | K | |--------------|----------------------------|---| | TMPM362F10FG | 0x3F8F_FFF4 to 0x3F8F_FFFF | | Note: If a password is set to 0xFF (erased data area), it is difficult to protect data securely due to an easy-to-guess password. Even if Single Boot mode is not used, it is recommended to set a unique value as a password. If all these address locations contain the same bytes of data other than 0xFF, a password area error occurs as shown in Figure 22-7. In this case, the boot program returns an error acknowledge (0x11) in response to the checksum byte (the 17th byte), regardless of whether the password sequence sent from the controller is all 0xFFs. Receiving data (5th to 16th bytes) from the controller is compared to the password stored in the flash memory. All of the 12 bytes must match to pass the password verification. Otherwise, a password error occurs, which causes the boot program to reply an error acknowledge in response to the checksum byte (the 17th byte). The password verification is performed even if the security function is enabled. Figure 22-7 Password Area Verification Flowchart Page 673 2023/07/21 22.2 Operation Mode TMPM362F10FG ### 22.2.10.8 Calculation of the Show Flash Memory Sum Command The result of the sum calculation ("byte + byte + byte + $\cdot$ $\cdot$ ") is responded by a half-word quantity. The Show Flash Memory Sum command adds all 512 Kbytes of the flash memory together and provides the total sum as a halfword quantity. The sum is sent to the controller, with the upper eight bits first, followed by the lower eight bits. Example) | 0xA1 | |------| | 0xB2 | | 0xC3 | | 0xD4 | | | For the interest of simplicity, assume the depth of the flash memory is four location. Then the sum of the four bytes is calculated as: 0xA1 + 0xB2 + 0xC3 + 0xD4 = 0x02EA Hence, 0x02 is first sent to the controller, followed by 0xEA. ### 22.2.10.9 Checksum Calculation The checksum byte for a series of bytes of data is calculated by adding the bytes together with ignoring the carries and calculating the 8-bit two's complement by using lower 8 bits. The Show Flash Memory Sum command and the Show Product Information command perform the checksum calculation. The controller must perform the same checksum operation in transmitting checksum bytes. Example) Assume the Show Flash Memory Sum command provides the upper and lower bytes of the sum as 0xE5 and 0xF6. To calculate the checksum for a series of 0xE5 and 0xF6: Add the bytes together 0xE5 + 0xF6 = 0x1DB Calculate the two's complement by using lower 8 bits, and that is the checksum byte. Then send 0x25 to the controller. 0 - 0xDB = 0x25 ## 22.2.11 General Boot Program Flowchart Figure 22-8 shows an overall flowchart of the boot program. Figure 22-8 Overall Boot Program Flowchart Page 675 2023/07/21 #### On-board Programming of Flash Memory (Rewrite/Erase) 22.3 In on-board programming, the CPU is to execute software commands for rewriting or erasing the flash memory. The rewrite/erase control program should be prepared by the user beforehand. Because the flash memory content cannot be read while it is being written or erased, it is necessary to run the rewrite/erase program from the internal RAM after shifting to the user boot mode. #### 22.3.1 Flash Memory Except for some functions, writing and erasing flash memory data are in accordance with the standard JE-DEC commands. In writing or erasing, use 32-bit data transfer command of the CPU to enter commands to the flash memory. Once the command is entered, the actual write or erase operation is automatically performed internally. Table 22-14 Flash Memory Functions | Major functions | Description | |------------------------|----------------------------------------------------------------------------| | Automatic page program | Writes data automatically per page. | | Automatic chip erase | Erase the entire area of the flash memory automatically. | | Automatic block erase | Erases a selected block automatically. | | Protect function | The write or erase operation can be individually inhibited for each block. | ### 22.3.1.1 Block Configuration ### (1) TMPM362F10FG Figure 22-9 Block Configuration of Flash Memory (TMPM362F10FG) Page 677 2023/07/21 #### 22.3.1.2 **Basic Operation** This flash memory device has the following two operation modes: - The mode to read memory data (Read mode) - The mode to automatically erase or rewrite memory data (Automatic operation) Transition to the automatic mode is made by executing a command sequence while it is in the memory read mode. In the automatic operation mode, flash memory data cannot be read and any commands stored in the flash memory cannot be executed. In the automatic operation mode, any interrupt or exception generation cannot set the device to the read mode except when a hardware reset is generated. During automatic operation, be sure not to cause any exception other than reset and debug exceptions while a debug port is connected. Any exception generation cannot set the device to the read mode except when a hardware reset is generated. #### (1) Read When data is to be read, the flash memory must be set to the read mode. The flash memory will be set to the read mode immediately after power is applied, when CPU reset is removed, or when an automatic operation is normally terminated. In order to return to the read mode from other modes or after an automatic operation has been abnormally terminated, either the Read/reset command (a software command to be described later) or a hardware reset is used. The device must also be in the read mode when any command written on the flash memory is to be executed. Read / reset command and Read command (software reset) When ID-Read command is used, the reading operation is terminated instead of automatically returning to the read mode. In this case, the Read/reset command can be used to return the flash memory to the read mode. Also, when a command that has not been completely written has to be canceled, the Read/reset command must be used. The Read command is used to return to the read mode after executing 32-bit data transfer command to write the data "0x0000\_00F0" to an arbitrary address of the flash memory. With the Read/reset command, the device is returned to the read mode after completing the third bus write cycle. #### Command write (2) This flash memory uses the command control method. Commands are executed by executing a command sequence to the flash memory. The flash memory executes automatic operation commands according to the address and data combinations applied (refer to Command Sequence). If it is desired to cancel a command write operation already in progress or when any incorrect command sequence has been entered, the Read/reset command is to be executed. Then, the flash memory will terminate the command execution and return to the read. While commands are generally comprised of several bus cycles and the operation applying to the 32-bit (word) data transmission command to the flash memory is called "bus write cycle". The bus write cycles have a specific sequential order and the flash memory will perform an automatic operation when the sequence of the bus write cycle data and address of command write is operated in accordance with a predefined specific order. If any bus write cycle does not follow a predefined command write sequence, the flash memory will terminate the command execution and return to the read mode. Note 1: Command sequences are executed from outside the flash memory area. Note 2: Each bus write cycle must be sequentially executed by 32-bit data transmit command. While a command sequence is being executed, access to the flash memory is prohibited. Also, do not generate any interrupt (except debug exceptions when a debug port is connected). If such an operation is made, it may result in an unexpected read access to the flash memory, and the command sequencer may not be able to correctly recognize Page 678 2023/07/21 the command. While it may cause an abnormal termination of the command sequence, it also may cause an incorrect recognition of the command. Note 3: For the command sequencer to recognize a command, the device must be in the read mode prior to executing the command. Be sure to check before the first bus write cycle where FCFLCS <RDY / BSY> is set to "1". It is recommended to subsequently execute a Read command. Note 4: Upon issuing a command, if any address or data is incorrectly written, be sure to perform a software reset to return to the read mode again. ### 22.3.1.3 Reset (Hardware reset) A hardware reset is used to cancel the operational mode set by the command write operation when forcibly terminated during auto programming/erasing or abnormal termination in the automatic operation. The flash memory has a reset input as the memory block and it is connected to the CPU reset signal. Therefore, when the $\overline{RESET}$ input pin of this device is set to VIL or when the CPU is reset due to any overflow of the watch dog timer, the flash memory will return to the read mode terminating any automatic operation that may be in progress. It should also be noted that applying a hardware reset during an automatic operation can result in incorrect rewriting of data. In such a case, be sure to perform the rewriting again. Refer to Section "1.2.1 Reset Operation" for CPU reset operations. After a given reset input, the CPU will read the reset vector data from the flash memory and starts operation after the reset is removed. #### 22.3.1.4 Commands ### (1) Automatic Page Program Writing to a flash memory device is to change "1" data cells to "0" data cells. Any "0" data cell cannot be changed to a "1" data cell. For changing "0" data cells to "1" data cells, it is necessary to perform an erase operation. The automatic page programming function of this device writes data of each page. The TMPM362F10FG contains 128 words in a page. A 128 word block is defined by the same [31:9] address. It starts from the address [8:0] = 0x00 and ends at the address [8:0] = 0x1FF. This programming unit is hereafter referred to as a "page" Writing to data cells is automatically performed by an internal sequencer and no external control by the CPU is required. The state of automatic page programming (whether it is in writing operation or not) can be checked by FCFLCS [0] <RDY/BSY>. Also, any new command sequence is not accepted while it is in the automatic page programming mode. If it is desired to interrupt the automatic page programming, use the hardware reset function. If the operation is stopped by a hardware reset operation, it is necessary to once erase the page and then perform the automatic page programming again because writing to the page has not been normally terminated. The automatic page programming operation is allowed only once for a page already erased. No programming can be performed twice or more. Note that rewriting to a page that has been once written requires execution of the automatic block erase or automatic chip erase command before executing the automatic page programming command again. Note that an attempt to rewrite a page two or more times without erasing the content may cause damages to the device. No automatic verify operation is performed internally to the device. So, be sure to read the data programmed to confirm that it has been correctly written. The automatic page programming operation starts when the third bus write cycle of the command cycle is completed. After the fifth bus write cycle, data will be written sequentially starting from the next address of the address specified in the fourth bus write cycle (in the fourth bus write cycle, the page top address will be command written) (32 bits of data is input at one time). Be sure to use the 32-bit data transfer command in writing commands after the fourth bus cycle. At this time, any 32-bit data transfer commands shall not be placed across word boundary. After the fifth bus write cycle, data is command written to the same page area. Even if it is desired to write the page only partially, it is required to perform the automatic page programming for the entire page. In this case, the address input for the fourth bus write cycle shall be set to the top address of the page. Be sure to perform command write operation with the input data set to "1" for the data cells not to be set to "0". For example, if the top address of a page is not to be written, set the input data in the fourth bus write cycle to 0xFFFFFFFF as a command write. Once the third bus cycle is executed, the automatic page programming is in operation. This condition can be checked by monitoring FCFLCS<RDY / BSY>. Any new command sequence is not accepted while it is in automatic page programming mode. If it is desired to stop operation, use the hardware reset function. Be careful in doing so because data cannot be written normally if the operation is interrupted. When a single page has been command written with normally terminating the automatic page writing process, FCFLCS<RDY / BSY> is set to "1" then it returns to the read mode. When multiple pages are to be written, it is necessary to execute the page programming command for each page because the number of pages to be written by a single execution of the automatic page program command is limited to only one page. It is not allowed for automatic page programming to process input data across pages. Data cannot be written to a protected block. When automatic programming is finished, it automatically returns to the read mode. This condition can be checked by monitoring FCFLCS<RDY/ BSY>. If automatic programming has failed, the flash memory is locked in the current mode and will not return to the read mode. For returning to the read mode, it is necessary to execute hardware reset to reset the flash memory or the device. In this case, while writing to the address has failed, it is recommended not to use the device or not to use the block that includes the failed address. Note: Software reset becomes ineffective after the fourth bus write cycle of the automatic page programming command. #### (2)Automatic chip erase The automatic chip erase operation starts when the sixth bus write cycle of the command cycle is completed. This condition can be checked by monitoring FCFLCS<RDY / BSY>. While no automatic verify operation is performed internally to the device, be sure to read the data to confirm that data has been correctly erased. Any new command sequence is not accepted while it is in an automatic chip erase operation. If it is desired to stop operation, use the hardware reset function. If the operation is forced to stop, it is necessary to perform the automatic chip erase operation again because the data erasing operation has not been normally terminated. Also, any protected block cannot be erased. If all the blocks are protected, the automatic chip erase operation will not be performed and it returns to the read mode after completing the sixth bus read cycle of the command sequence. When an automatic chip erase operation is normally terminated, it automatically returns to the read mode. If an automatic chip erase operation has failed, the flash memory is locked in the current mode and will not return to the read mode. For returning to the read mode, it is necessary to execute hardware reset to reset the device. In this case, the failed block cannot be detected. It is recommended not to use the device anymore or to identify the failed block by using the block erase function for not to use the identified block anymore. #### (3) Automatic block erase (for each block) The automatic block erase operation starts when the sixth bus write cycle of the command cycle is completed. This status of the automatic block erase operation can be checked by monitoring FCFLCS <RDY / BSY>. While no automatic verify operation is performed internally to the device, be sure to read the data to confirm that data has been correctly erased. Any new command sequence is not ac- Page 680 2023/07/21 cepted while it is in an automatic block erase operation. If it is desired to stop operation, use the hardware reset function. In this case, it is necessary to perform the automatic block erase operation again because the data erasing operation has not been normally terminated. Also, any protected block cannot be erased. If an automatic block erase operation has failed, the flash memory is locked in the mode and will not return to the read mode. In this case, execute hardware reset to reset the device. ### (4) Automatic programming of protection bits (for each block) This device is implemented with protection bits. This protection can be set for each block. See Table 22-18 for table of protection bit addresses. This device assigns 1 bit to 1 block as a protection bit. The applicable protection bit is specified by PBA in the seventh bus write cycle. By automatically programming the protection bits, write and/or erase functions can be inhibited (for protection) individually for each block. The protection status of each block can be checked by FCFLCS <BLPRO> to be described later. This status of the automatic programming operation to set protection bits can be checked by monitoring FCFLCS <RDY/BSY>. Any new command sequence is not accepted while automatic programming is in progress to program the protection bits. If it is desired to stop the programming operation, use the hardware reset function. In this case, it is necessary to perform the programming operation again because the protection bits may not have been correctly programmed. If all the protection bits have been programmed, all FCFLCS <BLPRO> are set to "1" indicating that it is in the protected state. This disables subsequent writing and erasing of all blocks. Note: Software reset is ineffective in the seventh bus write cycle of the automatic protection bit programming command. FCFLCS <RDY/BSY> turns to "0" after entering the seventh bus write cycle. ### (5) Automatic erasing of protection bits Different results will be obtained when the automatic protection bit erase command is executed depending on the status of the protection bits and the security bits. It depends on whether all <BLPRO> in the FCFLCS register are set to "I" or not, when FCSECBIT<FCSECBIT> is set to "1". Be sure to check the value of FCFLCS <BLPRO> before executing the automatic protection bit erase command. See Chapter "Protect/security function" for details. • When all the FCFLCS BLPRO are set to "1" (all the protection bits are programmed): When the automatic protection bit erase command is command written, the flash memory is automatically initialized within the device. When the seventh bus write cycle is completed, the entire area of the flash memory data cells is erased and then the protection bits are erased. This operation can be checked by monitoring FCFLCS <RDY/BSY>. If the automatic operation to erase protection bits is normally terminated, FCFLCS will be set to "0x00000001". Since no automatic verify operation is performed internally to the device, be sure to read the data to confirm that it has been correctly erased. For returning to the read mode while the automatic operation after the seventh bus cycle is in progress, it is necessary to use the hardware reset to reset the device. If this is done, it is necessary to check the status of protection bits by FCFLCS <BLPRO> after retuning to the read mode and perform either the automatic protection bit erase, automatic chip erase, or automatic block erase operation, as required. • When FCFLCS <BLPRO> include "0" (not all the protection bits are programmed): If the automatic protection bit is cleared to "0", the protection condition is canceled. With this device, protection bits can be programmed to an individual block and performed bit-erase operation in the four bits unit as shown in Table 22-18. The target bits are specified in the seventh bus write cycle. The protection status of each block can be checked by FCFLCS <BLPRO> to be described later. This status of the programming operation for automatic protection bits can be checked by monitoring FCFLCS <RDY/BSY>. When the automatic operation to erase protection bits is normally terminated, the protection bits of FCFLCS <BLPRO> selected for erasure are set to "0". Page 681 2023/07/21 In any case, any new command sequence is not accepted while it is in an automatic operation to erase protection bits. If it is desired to stop the operation, use the hardware reset function. When the automatic operation to erase protection bits is normally terminated, it returns to the read mode. Note: The FCFLCS <RDY / BSY> bit is "0" while in automatic operation and it turns to "1" when the automatic operation is terminated. #### (6) ID-Read Using the ID-Read command, you can obtain the type and other information on the flash memory contained in the device. The data to be loaded will be different depending on the address [15:14] of the fourth and subsequent bus write cycles (recommended input data is 0x00). After the fourth bus write cycle, when an arbitrary flash memory area is read, the ID value will be loaded. Once the fourth bus write cycle of an ID-Read command has passed, the device will not automatically return to the read mode. In this condition, the set of the fourth bus write cycle and ID-Read commands can be repeatedly executed. For returning to the read mode, use the Read/reset command or hardware reset command. Page 682 2023/07/21 ## 22.3.1.5 Flash control / status register Base Address = 0x41FF\_F000 | Register name | | Address (Base+) | |------------------------|----------|-----------------| | Reserved | - | 0x0000 | | Reserved | - | 0x0004 | | Security bit register | FCSECBIT | 0x0010 | | Flash control register | FCFLCS | 0x0020 | | Reserved | - | 0x0024 | | Reserved | - 📏 | 0x0028 | Note: Do not access to the reserved address. ## (1) FCFLCS (Flash control register) | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------------|----------|----------|----------|----------|------------|----------|----------|-----------| | bit symbol | - | - | - | 7// | <b>→</b> . | | BLPRO9 | BLPRO8 | | After reset | 0 | 0 | 0 | 0 | 0 | 0) | (Note 2) | (Note 2) | | | 23 | 22 | 21 | 20 | 19 | (/18)) | 17 | 16 | | bit symbol | BLPR07 | BLPRO6 | BLPRO5 < | BLPRO4 | BLPRO3 | BLPRO2 | BLPRO1 | BLPRO0 | | After reset | (Note 2) | | 15 | 14 | 13 | 12 | 11 | // 10 | 9 | 8 | | bit symbol | - | - | | <u> </u> | | · - | - | - | | After reset | 0 | 0 | (0 \ | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 < | 3 | 2 | 1 | 0 | | bit symbol | - | - ( | 7/^ - | - ( | | - | - | RDY / BSY | | After reset | 0 | 0 | ( ) ) o | 0 | <b>→</b> 0 | 0 | 0 | 1 | | Bit | Bit Symbol | Type | Function | |----------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 26 | - | R | Read as 0. | | 25 to 16 | BLPRO9 to | R | Protection for Block 9 to 0 | | | BLPRO0 | | 0: disabled 1: enabled | | ^ | | | Each of the protection bits represents the protection status of the corresponding block. When a bit is set to "1", it indicates that the block corresponding to the bit is protected. When the block is protected, data cannot be written to it. | | 15 to 1 | | R | Read as 0. | | 0 | RDY/BSY | R ( | Ready / Busy (Note 1) 0:Auto operating 1:Auto operation terminated. Ready/Busy flag bit | | | | | The RDY/BSY output is provided as a means to monitor the status of automatic operation. This bit is a function bit for the CPU to monitor the function. When the flash memory is in automatic operation, it outputs "0" to indicate that it is busy. When the automatic operation is terminated, it returns to the ready state and outputs "1" to accept the next command. If the automatic operation has failed, this bit maintains the "0" output. By applying a hardware reset, it returns to "1". | Page 683 2023/07/21 Note 1: This command must be issued in the ready state. Issuing the command in the busy state may disable both correct command transmission and further command input. To exit from the condition, execute system reset. System reset requires at least 0.5 µs regardless of the system clock frequency. In this condition, it takes approx. 2 ms to enable reading after reset. Note 2: The value varies depending on protection applied. #### (2) FCSECBIT (Security bit register) | | 31 | 30 | 29 | 28 | 27 | 26 // < | 25 | 24 | |-------------|----|----|----|----|-------------------------|----------|-------------|--------| | bit symbol | - | - | - | - | - | | _ | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ( | <u> </u> | -( | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | (11) | 10 | 9 | 8 | | bit symbol | - | - | - | - | $((// \langle \rangle)$ | | $(\bigcirc$ | - | | After reset | 0 | 0 | 0 | 0 | )) | 0 \ | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit symbol | - | - | - | | - | | <u> </u> | SECBIT | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | // 0 | 1 | | | | | | | 7 | (0/0) | | | | Bit | Bit Symbol | Туре | Function | |------|------------|------|------------------------------------| | 31-1 | - | R | Read as 0. | | 0 | SECBIT | R/W | Security bits 0:disabled 1:enabled | Note: This register is initialized by cold reset. ### 22.3.1.6 List of Command Sequences Table 22-15 shows the address and the data of each command of flash memory. Bus cycles are "bus write cycles" except for the second bus cycle of the Read command, the fourth bus-cycle of the Read/reset command, and the fifth bus cycle of the ID-Read command. Bus write cycles are executed by 32-bit (word) data transfer commands. (In the following table, only lower 8 bits data are shown.) See Table 22-16 for the detail of the address bit configuration. Use a value of "Addr." in the Table 22-15 for the address [15:8] of the normal command in the Table 22-16. Note: Always set "0" to the address bits [1:0] in the entire bus cycle. Table 22-15 Flash Memory Access from the Internal CPU | | | | - | _ | | | | |-------------------------------------------------------|----------------------|------------------|----------------------|------------------|----------------------|----------------------|-------------------| | | First bus cy-<br>cle | Second bus cycle | Third bus cy-<br>cle | Fourth bus cycle | Fifth bus cy-<br>cle | Sixth bus cy-<br>cle | Seventh bus cycle | | Command sequence | Addr. | | Data | Book | 0xXX | - | -\( \) | \ <u></u> | - (( | | - | | Read | 0xF0 | - | - | \ <del>-</del> | | (J) | - | | Dood / Doost | 0x54XX | 0xAAXX | 0x54XX | RA | (-7/< | - | - | | Read / Reset | 0xAA | 0x55 | 0xF0 | RD | | / - | - | | ID-Read | 0x54XX | 0xAAXX | 0x54XX | /IA | 0xXX | - | - | | ID-Read | 0xAA | 0x55 | 0x90 | 0x00 | )ID | - | - | | Automatic page pro- | 0x54XX | 0xAAXX | 0x54XX | PA | PA | PA | PA | | gramming | 0xAA | 0x55 | 0xA0 | /PD0 | PD1 | PD2 | PD3 | | A. | 0x54XX | 0xAAXX | 0x54XX | 0x54XX | 0xAAXX | 0x54XX | - | | Automatic chip erase | 0xAA | 0x55 | 0x80 | 0xAA | 0x55 | 0x10 | - | | Auto block erase | 0x54XX// | 0xAAXX | 0x54XX | 0x54XX | 0xAAXX | BA | - | | Auto block erase | 0xAA | 0x55 | 0x80 | OxAA | 0x55 | 0x30 | - | | Protection bit program- | 0x54XX | 0xAAXX | 0x54XX | 0x54XX | 0xAAXX | 0x54XX | PBA | | ming | 0xAA | 0x55 | 0x9A | 0xAA | 0x55 | 0x9A | 0x9A | | Drotaction bit areas | 0x54XX | 0xAAXX | 0x54XX | 0x54XX | 0xAAXX | 0x54XX | PBA | | Protection bit erase | 0xAA | 0x55 | 0x6A | 0xAA | 0x55 | 0x6A | 0x6A | Supplementary explanation RA: Read address RD: Read data IA: ID address ID: ID data PA: Program page address PD: Program data (32 bit data) After fourth bus cycle, enter data in the order of the address for a page. · BA: Block address PBA: Protection bit address #### Address bit configuration for bus write cycles 22.3.2 Table 22-16 is used in conjunction with "Table 22-15 Flash Memory Access from the Internal CPU". Address setting can be performed according to the normal bus write cycle address configuration from the first bus cycle. "0" is recommended" in the Table 22-16 Address Bit Configuration for Bus Write Cycles can be changed as necessary. | Address | Addr |----------------------|--------------------------------|-------------------------------------------------------------------------------------|-----------------|-----------|-----------|-----------|------------|--------------------------|-----------|-----------|-----------|-----------------------| | Address | [31:20] | [19] | [18] | [17] | [16] | [15] | [14] | [13:11] | [10] | [9] | [8] | [7:0] | | | | | | | Norm | al bus w | rite cycl | e address configuration | n ( (// | ( ) | | | | Normal | | | | | | | | | | | | Addr[1:0]="0" (fixed) | | commands | Flash area | "0 | " is reco | mmende | ed. | | | Command | | , | | Others:0 | | | | | | | | | | | <u> </u> | | | (recommended) | | ID-READ | | | IA: ID | addres | s (Set th | e fourth | bus wri | te cycle address for ID | -Read o | peration | ) | | | ID-READ | Flash area "0" is recommended. | | | ed. | ID ac | ldress | Addr[1:0]= | "0" (fixed | d), Other | s:0 (reco | ommended) | | | Diagly areas | | BA: Block address (Set the sixth bus write cycle address for block erase operation) | | | | | | | | | | | | Block erase | Bloo | ck select | ion (Tab | le 22-16 | i) | | | Addr[1:0]="0" ( | fixed), C | thers:0 | (recomm | ended) | | Auto page | ı | PA: Prog | ram pag | e addre | ss (Set t | the fourt | h bus w | rite cycle address for p | age pro | grammir | ig opera | tion) | | program- | | | | | Dogo | selection | . (( | | | | Ad | dr[1:0]="0" (fixed) | | ming | | | | | raye | Selection | | | | | Othe | rs:0 (recommended) | | | F | PBA: Pro | tection b | it addre | ss (Set | the seve | nth bus | write cycle address for | r protect | ion bit p | rogramn | ning) | | Protection bit pro- | | Fixed | | tion bit | | | | > // | 7 -7 - 6 | t bit se- | Ad | dr[1:0]="0" (fixed) | | gramming | Flash area | to<br>"0". | sele | | | 7 | Fixed t | o "0". | // ``` | tion | | rs:0 (recommended) | | | | | (Table | | | () | | | | 22-17) | | , | | | | PBA: F | rotection | n bit add | dress (Se | et the se | venth b | us erase cycle address | for pro | tection b | it erasur | e) | | Protection bit erase | | Fixed | | tion bit | | | | | ) | | Addr[1 | :0]="0" (fixed) | | Dit Clase | Flash area | to<br>"0". | seled<br>(Table | | | )) | Fix | ed to "0". | / | | others:0 | (recommended) | | í | | | , | , | | // | | | | | | | As block address, specify any address in the block to be erased. Table 22-16 Block Address Table | | Block | Address<br>(User boot mode) | Address (Single boot mode) | Size<br>(Kbyte) | |---|-------|-----------------------------|----------------------------|-----------------| | | 8 | 0x0000_0000 to 0x0000_7FFF | 0x3F80_0000 to 0x3F80_7FFF | 32 | | | 9 | 0x0000_8000 to 0x0000_FFFF | 0x3F80_8000 to 0x3F80_FFFF | 32 | | 1 | 7 | 0x0001_0000 to 0x0001_FFFF | 0x3F81_0000 to 0x3F81_FFFF | 64 | | | 6 | 0x0002_0000 to 0x0003_FFFF | 0x3F82_0000 to 0x3F83_FFFF | 128 | | 4 | 5 | 0x0004_0000 to 0x0005_FFFF | 0x3F84_0000 to 0x3F85_FFFF | 128 | | | 4 ( | 0x0006_0000 to 0x0007_FFFF | 0x3F86_0000 to 0x3F87_FFFF | 128 | | | 3 | 0x0008_0000 to 0x0009_FFFF | 0x3F88_0000 to 0x3F89_FFFF | 128 | | | 2 | 0x000A_0000 to 0x000B_FFFF | 0x3F8A_0000 to 0x3F8B_FFFF | 128 | | | 1 | 0x000C_0000 to 0x000D_FFFF | 0x3F8C_0000 to 0x3F8D_FFFF | 128 | | | 0 | 0x000E_0000 to 0x000F_FFFF | 0x3F8E_0000 to 0x3F8F_FFFF | 128 | Note: As for the addresses from the first to the fifth bus cycles, specify the upper addresses of the blocks to be erased. Page 686 2023/07/21 Table 22-17 Protection Bit Programming Address Table | | | | The seventl | h bus write cy | cle address | | |--------|-----------------------|---------|-------------|----------------|-------------|---------| | Block | Protection bit | Address | Address | Address | Address | Address | | | | [18] | [17] | [16:11] | [10] | [9] | | Block0 | <blpro[0]></blpro[0]> | 0 | 0 | | 0 | | | Block1 | <blpro[1]></blpro[1]> | 0 | 0 | | о ( | 1 | | Block2 | <blpro[2]></blpro[2]> | 0 | 0 | | 1 | 9 | | Block3 | <blpro[3]></blpro[3]> | 0 | 0 | ^ | (1(7/ | <u></u> | | Block4 | <blpro[4]></blpro[4]> | 0 | 1 | Fixed to | 6 | 0 | | Block5 | <blpro[5]></blpro[5]> | 0 | 1 | "0". | 0 | 1 | | Block6 | <blpro[6]></blpro[6]> | 0 | 1 | | 7 | 0 | | Block7 | <blpro[7]></blpro[7]> | 0 | 1 | | ) = | 1 ( | | Block9 | <blpro[9]></blpro[9]> | 1 | 0 | | 0 | 1, | | Block8 | <blpro[8]></blpro[8]> | 1 | 0 / | | > o | | Table 22-18 Protection Bit Erase Address Table | Block | Protection bit | | vrite cycle address<br>:17] | |-------------|---------------------------|--------------|-----------------------------| | | | Address [18] | Address [17] | | Block0 to 3 | <blpro[0:3]></blpro[0:3]> | 0 / / | 0 | | Block4 to 7 | <blpro[4:7]></blpro[4:7]> | 0 | ))1 | | Block8 to 9 | <blpro[8:9]></blpro[8:9]> | 1 | 0 | Note: The protection bit erase command cannot erase by individual block. Table 22-19 The ID-Read command's fourth bus write cycle ID address (IA) and the data to be read by the following 32-bit data transfer command (ID) | IA[15:14] | ID[7:0] | Code | |-----------|----------|-------------------| | 0y00 | 0x98 | Manufacturer code | | 0y01 | 0x5A | Device code | | 0y10 | Reserved | - | | 0y11 | 0x10 | Macro code | ### 22.3.2.1 Flowchart Figure 22-10 Automatic Programming Note: Command sequence is executed by 0x54xx or 0x55xx. Figure 22-11 Automatic Erase Note: Command sequence is executed by 0x54xx or 0x55xx. Page 689 2023/07/21 TOSHIRA TMPM362F10FG ## 23. ROM protection ### 23.1 Outline The TMPM362F10FG offers two kinds of ROM protection/ security functions. One is a write/ erase-protection function for the internal flash ROM data. The other is a security function that restricts internal flash ROM data readout and debugging. ### 23.2 Features ### 23.2.1 Write/ erase-protection function The write/ erase-protection function enables the internal flash to prohibit the writing and erasing operation for each block. To activate the function, write "1" to the corresponding bits to a block to protect. Writing "0" to the bits cancels the protection. The protection settings of the bits can be monitored by the FCFLCS <BLPRO[9:0]> bit. See the chapter "Flash" for programming details. ## 23.2.2 Security function The security function restricts flash ROM data readout and debugging. This function is available under the conditions shown below. - 1. The FCSECBIT <SECBIT> bit is set to"I". - 2. All the protection bits (the FCFLCS BLPRO) bits) used for the write/erase-protection function are set to "1". Note: The FCSECBIT <SECBIT> bit is set to "1" at a power-on reset right after power-on. Table 23-1 shows details of the restrictions by the security function. Table 23-1 Restrictions by the security function | (Item) | Details | | | | |-----------------------------|----------------------------------------------------------------------------------------------------------------------|--|--|--| | 1) ROM data readout | Data can be read from CPU. | | | | | 2) Debug port | Communication of SW and trace are prohibited | | | | | | Writing a command to the flash memory is prohibited. | | | | | 3) Command for flash memory | An attempt to erase the contents in the bits used for the write/<br>erase-protection erases all the protection bits. | | | | Page 691 2023/07/21 23.3 Register TMPM362F10FG # 23.3 Register Base Address = 0x41FF\_F000 | Register name | Address(Base+) | | |------------------------|----------------|---------------| | Reserved | - | 0x0000,0x0004 | | Security bit register | FCSECBIT | 0x0010 | | Flash control register | FCFLCS | 0x0020 | | Reserved | - | 0x0024,0x0028 | ## 23.3.1 FCFLCS (Flash control register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|---------|---------|---------|---------|----------|--------------|---------|---------| | bit symbol | - | - | - | - | - | - > | BLPRO9 | BLPRO8 | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | (Note2) | (Note2) | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | BLPRO7 | BLPRO6 | BLPRO5 | BLPRO4 | BLPRO3 | BLPRO2 | BLPRO1 | BLPRO0 | | After reset | (Note2) | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | - | - | - | ( <u>)</u> } | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | RDY/BSY | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | (0) | 1 | | Bit | Bit Symbol | Туре | Function | |-------|---------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-26 | - | R | Read as 0. | | 25-16 | BLPRO9 to<br>BLPRO0 | R | Protection for Block9 to 0 0: disabled 1: enabled Protection status bits Each of the protection bits represents the protection status of the corresponding block. When a bit is set to "1," it indicates that the block corresponding to the bit is protected. When the block is protected, data cannot be written to if. | | 15-1 | - | R | Read as 0. | | 0 | RDY/BSY | R | Ready/Busy (Note 1) 0: Auto operating 1: Auto operation 1: Auto operation terminated Ready/Busy flag bit The RDY/BSY output is provided as a means to monitor the status of automatic operation. This bit is a function bit for the CPU to monitor the function. When the flash memory is in automatic operation, it outputs "0" to indicate that it is busy. When the automatic operation is terminated, it returns to the ready state and outputs "1" to accept the next command. If the automatic operation has failed, this bit maintains the "0" output. By applying a hardware reset, it returns to "1." | Note 1: This command must be issued in the ready state. Issuing the command in the busy state may disable both correct command transmission and further command input. To exit from the condition, execute system reset. System reset requires at least 0.5 ms regardless of the system clock frequency. In this condition, it takes approx. 2 ms to enable reading after reset. Note 2: The value varies depending on protection applied. 23.3 Register TMPM362F10FG # 23.3.2 FCSECBIT(Security bit register) | | 31 | 30 | 29 | 28 | 27 | 26 🔨 | 25 | 24 | |-------------|----|----|----|----|----------|-------|-------|--------| | bit symbol | - | - | - | - | - | - > | | - | | After reset | 0 | 0 | 0 | 0 | 0 | 0 (( | 0 | 0 | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | bit symbol | - | - | - | - | - ^ | (7/4 | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | bit symbol | - | - | 1 | 1 | - | ( ) Y | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | bit symbol | - | - | - | - | | > - | 2-// | SECBIT | | After reset | 0 | 0 | 0 | 0 | ((/o/ \) | 0_ | ( ) 0 | 1 | | Bit | Bit Symbol | Туре | | Function | |------|------------|------|--------------|----------| | 31-1 | _ | R | Read as 0. | | | 0 | SECBIT | R/W | Security bit | | | | | | 0: Disabled | | | | | | 1: Enabled | | TOSHIBA TMPM362F10FG ## 23.4 Writing and erasing Writing and erasing protection bits are available with a single chip mode, single boot mode and writer mode. #### 23.4.1 Protection bits Writing to the protection bits is done on block-by-block basis. When the settings for all the blocks are "1", erasing must be done after setting the FCSECBIT <SECBIT> bit to "0". Setting "1" at that situation erases all the protection bits. To write and erase the protection bits, command sequence is used. See the capter "Flash" for details ### 23.4.2 Security bit The FCSECBIT <SECBIT> bit that activates security function is set to "1" at a power-on reset right after power-on. The bit is rewritten by the following procedure. - 1. Write the code 0xa74a9d23 to FCSECBIT register. - 2. Write data within 16 clocks from the above.1. Note: The above procedure is enabled only when using 32-bit data transfer command. Page 695 2023/07/21 23.4 Writing and erasing TMPM362F10FG # 24. RAM Interface After releasing reset, then wait time of RAM (from 0x2000\_4000 to 0x2000\_BFFF) is set one wait. It is possible to use zero wait. # 24.1 Register List The control register and it's address are shwon as below. Base Address = 0x41FF\_F058 | Register name | | Address(Base+) | |------------------------|--------|----------------| | RAM Interface register | RCWAIT | 0x0000 | # 24.1.1 RCWAIT(RAM Interface Register) | | 31 | 30 | 29 | 28 | 27 | 26 | )) 25 | 24 | |-------------|----|------|---------|-------|---------------|--------------------|-------|----------| | bit symbol | - | - | - | | - | (7) | - | - | | After reset | 0 | 0 | 0 | 0 | 0 | (V <sub>0</sub> )) | 0 | 0 | | | 23 | 22 | 21 < | 20 | /19 | 18 | 17 | 16 | | bit symbol | - | - | -( | | | ) - | - | - | | After reset | 0 | 0 | 0 ( | 0 | 0 | // 0 | 0 | 0 | | | 15 | 14 | 13 | 12 | 11 | <b>1</b> 0 | 9 | 8 | | bit symbol | - | - | | 1 | - | 1 | - | - | | After reset | 0 | 0 | 9 | 0 | | 0 | 0 | 0 | | | 7 | 6 | 5 | 4 ( | 3 | 2 | 1 | 0 | | bit symbol | - | | ( ) ) - | | $\rightarrow$ | 1 | - | RAM1WAIT | | After reset | 0 | / )0 | 0 0 | (0/// | 0 | 0 | 0 | 1 | | Bit | Bit Symbol | Type | ã@îl | |------|------------|------|---------------------------------| | 31-1 | - | R | Read as "0" | | 0 | RAM1WAIT | R/W | Specify RAMWAIT 0:0WAIT 1:1WAIT | Page 697 2023/07/21 24.1 Register List TMPM362F10FG # 25. Port Section Equivalent Circuit Schematic Basically, the gate symbols written are the same as those used for the standard CMOS logic IC [74HCXX] series. The input protection resistance ranges from several tens of $\Omega$ to several hundreds of $\Omega$ . Damping resistors X2 and XT2 are shown with a typical value. # 25.1 PA0 to 7, PB0 to 7, PP1, PP3 to 5 25.2 PC0 to 7, PD0 to 7, PE0 to 7, PF0 to 4, PG0 to 7, PH0 to 7, PI0, PL0 to 7, PM0 to 7, PN0 to 7, PO0 to 7, PP0, PP2, PP6 Page 699 2023/07/21 25.3 PI1 TMPM362F10FG ### 25.3 PI1 TOSHIBA TMPM362F10FG # 25.6 $\overline{\text{RESET}}$ , $\overline{\text{NMI}}$ Page 701 2023/07/21 25.9 X1, X2 TMPM362F10FG 25.9 X1, X2 # 26. Electrical Characteristics # 26.1 Absolute Maximum Ratings | Para | meter | Symbol | Rating | Unit | | | |----------------------|-------------------------|---------------------|---------------------|-----------|-------------|------| | | | DVDD3 (Note2) | -0.3 to 3.9 | | | | | Supply voltage | Supply voltage | | upply voltage | | -0.3 to 3.9 | y) · | | | | RVDD3 | -0.3 to 3.9 | | | | | Input voltage | | V <sub>IN</sub> | -0.3 to DVDD3 + 0.3 | // v | | | | Low-level | Per pin | I <sub>OL</sub> | 5 | | | | | output current | Total | ΣI <sub>OL</sub> | 50 | | | | | High-level | Per pin | I <sub>OH</sub> | -5 | mA | | | | output current | Total | ΣI <sub>OH</sub> | -50 | 1/2 | | | | Power consumption | (Ta = 85 °C) | PD / | 600 | mW | | | | Soldering temperatur | re (10 s) | T <sub>SOLDER</sub> | 260 | (00) | | | | Storage temperature | | T <sub>STG</sub> | -40 to 125 | ,c- | | | | Operating Tempera- | Except during Flash W/E | Tope | -20 to 85 | °C | | | | ture | During Flash W/E | | 0 to 70 | $\sim$ // | | | Note 1: Absolute maximum ratings are limiting values of operating and environmental conditions which should not be exceeded under the worst possible conditions. The equipment manufacturer should design so that no Absolute maximum rating value is exceeded with respect to current, voltage, power consumption, temperature, etc. Exposure to conditions beyond those listed above may cause permanent damage to the device or affect device reliability, which could increase potential risks of personal injury due to IC blowup and/or burning. Page 703 2023/07/21 # DC Electrical Characteristics (1/3) Ta = -20 to 85 °C | | Parameter | Symbol | Co | ndition | Min. | Typ. (Note1) | Max. | Unit | |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------------------------------------------|----------------|------------|---------------------------|--------------|------| | Supply<br>voltage | DVDD3A = AVDD3=DVDD3B= RVDD3 (Note3) DVSS = AVSS = 0V | DVDD3A<br>AVDD3<br>DVDD3B<br>RVDD3 | f <sub>OSC</sub> = 8 to 16<br>fsys = 1to 64<br>fs = 30 to 34 | 6.0 MHz<br>MHz | 2.7 | | 3.6 | V | | | PJ0 to 7, PK0 to 7 (Note2) | V <sub>IL1</sub> | 2.7 V ≤ AVDD | 03 ≤ 3.6 V | | | 0.25 AVDD3 | | | | PA0 to 7, PB0 to 7, PP1,<br>PP3 to 5 | V <sub>IL2</sub> | 2.7 V ≤ DVDD3 ≤ 3.6 V | | | $(\mathbb{Z}/\mathbb{S})$ | 0.3 DVDD3 | | | Low-level<br>Input<br>voltage | PC0 to 7, PD0 to 7, PE0 to 7, PF0 to 4, PG0 to 7, PH0 to 7, PI0 to 3, PL0 to 7, PM0 to 7, PN0 to 7, PN0 to 7, PO0 to 7, PP0/2/6 RESET, NMI, MODE, SWDIO, SWCLK | $V_{\text{IL3}}$ | | | -0,3 | ) <del>}</del> - | 0.25 DVDD3 | V | | | X1 | $V_{IL4}$ | 2.7 V ≤ DVDD | 03A ≤ 3.6 V | | | 0.1 DVDD3A | | | | PJ0 to 7, PK0 to 7 (Note2) | V <sub>IH1</sub> | 2.7 V ≤ AVDD | 03 ≤ 3.6 V | 0.75 AVDD3 | 0 | AVDD3 + 0.3 | | | | PA0 to 7, PB0 to 7, PP1,<br>PP3 to 5 | V <sub>IH2</sub> | | | 0.7 DVDD3 | | | | | High-level<br>Input<br>voltage | PC0 to 7, PD0 to 7, PE0 to 7, PF0 to 4, PG0 to 7, PH0 to 7, PI0 to 3, PL0 to 7, PM0 to 7, PN0 to 7, PN0 to 7, PN0 to 7, PO0 to 7, PP0/2/6 RESET, NMI, MODE, SWDIO, SWCLK | V <sub>IH3</sub> | 2.7 V ≤ DVDE | 33.≤ 3.6 V | 0.75 DVDD3 | | DVDD3 + 0.3 | V | | | X1 | V <sub>IH4</sub> | 2.7 V ≤ DVDD | )3A ≤ 3.6 V | 0.9 DVDD3A | | DVDD3A + 0.3 | | | Low-level | Except below | V <sub>OL1</sub> | I <sub>OL</sub> = 2 mA | | | - | | | | output<br>voltage | PL0/1/4/5, PG0/1/4/5 | V <sub>OL2</sub> | I <sub>OL</sub> = 3 mA | DVDD3 ≥ 2.7 V | - | - | 0.4 | V | | High-level o | utput voltage | V <sub>OH</sub> | I <sub>OH</sub> = -2 mA | DVDD3 ≥ 2.7 V | 2.4 | - | - | V | | Input leakag | e current | | $0.0 \le V_{IN} \le D^{\circ}$<br>$0.0 \le V_{IN} \le A^{\circ}$ | | _ | 0.02 | ±5 | 4 | | Output leaka | Output leakage current | | $0.2 \le V_{IN} \le D^{V}$ $0.2 \le V_{IN} \le A^{V}$ | | - | 0.05 | ±10 | μΑ | | Pull-up resis | ster at RESET | RRST | DVDD3 = 2.7 | V to 3.6 V | - | 50 | 150 | kΩ | | Hysteresis v | Hysteresis voltage | | 2.7 V ≤ DVDE | 03 ≤ 3.6 V | 0.3 | 0.6 | - | V | | Programma | ole pull-up / pull-down resister | PKH | DVDD3 = 2.7 | V to 3.6 V | - | 50 | 150 | kΩ | | Pin capacita pins) | nce (Except power supply | C <sub>IO</sub> | fc = 1 MHz | | - | - | 10 | pF | Note 1: Ta = 25 °C, DVDD3 = RVDD3 = AVDD3 = 3.3 V, unless otherwise noted. Note 2: When PJ and PK port are used for input port. Note 3: The same voltage must be supplied to DVDD3A, DVDD3B, AVDD3, RVDD3. Page 704 2023/07/21 # 26.3 DC Electrical Characteristics (2/3) DVDD3A = DVDD3B = AVDD3 = RVDD3 = 2.7 V to 3.6 V, Ta =-20 to 85 $^{\circ}$ C | Parameter | Symbol | Condition | Min. | Typ.<br>(Note1) | Max. | Unit | |------------------------------|-------------------|-------------------------------|----------|----------------------|--------|------| | | I <sub>OL1</sub> | Except below (per pin) | - | - | 2 | mA | | | I <sub>OL2</sub> | PL0/1/4/5,PG0/1/4/5 (per pin) | - | - 0 | 3 | mA | | | ΣI <sub>OL1</sub> | Per group (PORT L/I) | - | - ( | 20 | mA | | Low-level output<br>current | ΣI <sub>OL2</sub> | Per group (PORT M/N/O/P) | - | | 27 | mA | | | ΣI <sub>OL3</sub> | Per group (PORT A/B/C/D/E) | - < | | 27 | mA | | | ΣI <sub>OL4</sub> | Per group (PORT F/G/H) | - | 1 | 27 | mA | | | ΣI <sub>OL5</sub> | Total (All ports) | - ( | ( ) <del>-</del> > | 35 | mA | | | I <sub>OH</sub> | Per pin | | ) | -2 | mA | | | ΣI <sub>OH1</sub> | Per group (PORT I/L/M/N/O/P) | 4( ) | <b>\rightarrow</b> - | -13 | mA | | High-level output<br>current | ΣI <sub>OH2</sub> | Per group (PORT A/B/C/D/E) | <u>-</u> | - | -13 | mA | | | ΣI <sub>OH3</sub> | Per group (PORT F/G/H) | (//-5) | | -13 | mA | | | ΣI <sub>OH4</sub> | Total (All ports) | | - < | (=35/) | mA | Note 1: Ta = 25 °C, DVDD3 = RVDD3 = AVDD3 = 3.3 V, unless otherwise noted. Note 2: The same voltage must be supplied to DVDD3, DVDD3A, DVDD3B, AVDD3, RVDD3. Note 3: High-level output current ( $\Sigma I_{OH}$ ) is total per power supply pin. Page 705 2023/07/21 #### 26.4 DC Electrical Characteristics (3/3) ## 26.4 DC Electrical Characteristics (3/3) DVDD3A = DVDD3B = AVDD3 = RVDD3 = 2.7 V $\sim$ 3.6 V, Ta =-20 to 85 °C | Parameter | Symbol | Condition | Min. | Typ. (Note1) | Max. | Unit | |-------------------------|-----------------|------------------------------------------------------------------|------|--------------|------|------| | NORMAL (Note2) Gear 1/1 | | fsys = 64 MHz | - | 85 | 95 | | | IDLE2 (Note3) | ] | (f <sub>OSC</sub> = 8 MHz) | - | 40 | 48 | | | IDLE1 (Note4) | | fsys = 1 MHz<br>(f <sub>OSC</sub> = 8 MHz,<br>PLL= OFF,CG = 1/8) | - | 1.3 | 5 | mA | | SLOW | I <sub>DD</sub> | 6. 00.700 111 | - ^ | ((1// \ | 6 | | | SLEEP(Note5) | ] | fs = 32.768 kHz | - | 260 | 2450 | | | STOP | ] | - | - (( | 250 | 2400 | | | BACKUP SLEEP (Note6) | ] | fs=32.768 kHz | - | 35 | 210 | μA | | BACKUP STOP (Note7) | ] | - | A | 25 | 200 | | Note 1: Ta = 25 °C, DVDD3 = RVDD3 = AVDD3 = 3.3 V, unless otherwise noted. Note 2: I<sub>DD</sub> NORMAL: Measured with: Operation program : The dhrystone ver. 2.1 operated in Flash. Operation peripheral : All function operates excluding ADC. Note 3: I<sub>DD</sub> IDLE2: Measured with: Operation peripheral : All peripherals are operated. Note 4: I<sub>DD</sub> IDLE1: Measured with: Operation peripheral: Some peripherals are operated. Note 5: I<sub>DD</sub> SLEEP: Measured with: Operation peripheral: CEC, RMC and RTC operated. Note 6: IDD BACKUP SLEEP: Measured with: Operation peripheral : CEC, RMC and RTC operated, keep contents of BACKUP RAM, other peripherals are shut down power supply. Note 7: IDD BACKUP STOP: Measured with: Operation peripheral: Keep contents of BACKUP RAM, other peripherals are shut down power supply. ## 26.5 10-bit ADC Electrical Characteristics DVDD3A = DVDD3B = AVDD3 = RVDD3 = 2.7 V to 3.6 V $AVSS = DVSS, Ta = -20 \text{ to } 85 \text{ }^{\circ}\text{C}$ | Para | meter | Symbol | Symbol Condition Min Typ. Max. | | Max. | Unit | | |---------------------------------------------|------------------------|--------|-------------------------------------------------------------------------------------|------|------|------------|-----| | Analog reference | e voltage(+) | VREFH | - | 2.7 | 3.3 | 3.6 | ٧ | | Analog input vol | tage | VAIN | - | AVSS | -( | VREFH | V | | Power supply | AD conversion | | | - | 2.5 | 5.5 | mA | | current of ana-<br>log reference<br>voltage | Non-AD con-<br>version | IREF | DVSS = AVSS | - | 0.02 | 5 | μA | | Supply current | AD conversion | - | Except IREF | - ] | | 3 | mA | | INL error | • | | | -(( | ±2 | ±3 | | | DNL error | DNL error | | AIN resistance ≤ 1.3 kΩ | | €1 | ±2 | | | Offset error Full-scale error | | _ | <ul> <li>AIN load capacitance ≥ 0.1 Fµ</li> <li>Conversion time ≥ 1.5 μs</li> </ul> | | ±2 | <u>£</u> 4 | LSB | | | | | - Солтолого или – то ро | | ±2 | ±4 | | Page 707 2023/07/21 TMPM362F10FG ### 26.6 AC Electrical Characteristics ### 26.6.1 AC measurement condition The AC characteristics data of this chapter is measured under the following conditions unless otherwise noted. - Output levels : High = $0.8 \times DVDD3$ - Output levels : Low = $0.2 \times DVDD3$ - Input levels: Refer to low-level input voltage and high-level input voltage in "DC Electrical Characteristics". - Load capacity : CL = 30pF ## 26.6.2 Static memory controller (SMC) "T" is 1/2 cycles of an internal bus frequency (fsys) in the Equation of the table. AC measurement condition • Output levels : High = $0.7 \times DVDD3$ , Low = $0.3 \times DVDD3$ • Input levels : High = $0.7 \times DVDD3$ , Low = $0.3 \times DVDD3$ • Load capacity : CL = 40pF #### 26.6.2.1 Basic Bus cycle (Read) | | | Equati | on | fsys = 64 MHz | $\vee$ | |---------------------------------------------------------------------------------------------|-------------------|-----------------|-----------------|---------------------------------------------------------------|--------| | Parameter | Symbol | Min. | Max. | T=31.25<br>N = 4<br>M = 1<br>K = 5<br>L = 2<br>P = 2<br>Q = 2 | Unit | | SMCCLK | tcyc | 31.25 | 2000 | 31.3 | | | A1 to A23 Valid → D0 to D15 Input (Separate bus mode) | t <sub>ADH</sub> | | (N)T - 35.0 | 90.0 | | | A1 to A23 Valid → D0 to D15 Input (Multiplex bus mode) | t <sub>ADL</sub> | _ | (N)T - 35.0 | 90.0 | | | A1 to A23 Valid → D0 to D15 Input (Page access) | t <sub>AD1</sub> | <u> </u> | (Q)T - 35.0 | 27.5 | | | $\overline{\text{OE}}$ falling edge $\rightarrow$ D0 to D15 Input | t <sub>OED</sub> | - | (N - M)T - 25.0 | 68.8 | | | OE Low-level pulse width | toew | (N - M)T - 13.0 | - | 80.8 | | | A1 ~ A23 Valid → OE falling edge (Separate bus mode) | tаоен | (M)T - 15.0 | <u>-</u> | 16.3 | | | A1 ~ A16 Valid → OE falling edge (Multiplex bus mode) | t <sub>AOEL</sub> | (M)T - 15.0 | - | 16.3 | ns | | $\overline{\text{OE}}$ rising edge $\rightarrow$ D0 to D15 Hold | t <sub>HR</sub> | 0.00 | - | 0.00 | | | A1 to A23 Valid → D0 to D15 Hold | t <sub>HA</sub> | 0.00 | _ | 0.00 | | | OE High-level pulse width | t <sub>OEHW</sub> | (M)T - 13.0 | - | 18.3 | | | ALE Low-level pulse width | tıL | T - 13.0 | - | 18.3 | | | A1 to A16 Valid → ALE rising edge | t <sub>AL</sub> | T - 15.0 | _ | 16.3 | | | ALE rising edge → A1to A16 Hold | t <sub>L</sub> A | T - 10.0 | _ | 21.3 | | | $\overline{\sf QE}$ rising edge $ ightarrow$ $\overline{\sf ALE}$ falling edge $ ightarrow$ | tclr | (P)T - 13.0 | _ | 49.5 | | | OE rising edge → A1to A16 Hold | t <sub>CAR</sub> | (P)T - 13.0 | _ | 49.5 | | | OE rising edge → A1to A16 Output | t <sub>RAE</sub> | (P)T - 13.0 | - | 49.5 | | #### Note: " Equation Measurement condition: Page 709 2023/07/21 #### 26.6 AC Electrical Characteristics ## 26.6.2.2 BASIC Bus Cycle (Write) | | | Equati | on | fsys = 64 MHz | | |---------------------------------------------------------------------------------------|------------------|-------------------------|-------|----------------------------------------------------|---------------| | Parameter | Symbol | Min. | Max. | N = 4<br>M = 1<br>K = 5<br>L = 2<br>P = 2<br>Q = 2 | Unit | | D0 to D15 Valid → WE rising edge (Separate bus mode) | t <sub>DW</sub> | (L + 1)T - 23.0 | | 70.8 | | | D0 to D15 Valid $\rightarrow$ $\overline{\text{WE}}$ rising edge (Multiplex bus mode) | t <sub>DW1</sub> | (L)T - 23.0 | | 39.5 | | | WE Low-level pulse width (Separate bus mode) | t <sub>ww</sub> | (L)T - 13.0 | | 49.5 | $\rightarrow$ | | WE Low-level pulse width (Multiplex bus mode) | t <sub>WW1</sub> | (L + 1)T - 13.0 | (())- | 80.8 | | | A1 to A23 Valid → WE falling edge | t <sub>AW</sub> | T- 15.0 | - | 16.3 | ns | | $\overline{\text{WE}}$ rising edge $ ightarrow$ A1 to A23 Hold | t <sub>WA</sub> | (K - L)T - 13.0 | - ( | 80.8 | | | $\overline{\text{WE}}$ rising edge $\rightarrow$ D0 to D15 Hold (Separate bus mode) | t <sub>WD</sub> | (K - L - 1)T - 10.0 | - ( | 52.5 | | | WE rising edge → D0 to D15 Hold (Multiplex bus mode) | t <sub>WD1</sub> | (K - L - 2)T - 10.0 | | 21.3 | | | WE rising edge → A1to A16 Hold | t <sub>CLW</sub> | (K - L - 2 + P)T - 13.0 | - \ \ | 80.8 | | | $\overline{\text{WE}}$ rising edge $ ightarrow$ $\overline{\text{ALE}}$ falling edge | t <sub>CAW</sub> | (K - L - 2 + P)T - 13.0 | - )) | 80.8 | | #### 26.6.2.3 Example of Read / Write cycle When accessing to read from the external bus, dummy read cycle besides a valid one is occurred. Therefore, the external memory can not be used as FIFO. The bollowing operation chart shows only valid read cycle except the dummy cycle. (1) Memory Read Cycle (Separate Bus) (t<sub>RC</sub>=4, t<sub>CEQE</sub>=1) Page 711 2023/07/21 # (2) Memory Write Cycle (Separate Bus) ( $t_{WC}$ =4, $t_{WP}$ =2) # (3) Memory Read Cycle (Multiplex Bus) ( $t_{RC}$ =7, $t_{CEOE}$ =3) # (4) Memory Write Cycle (Multiplex Bus) ( $t_{WC}$ =7, $t_{WP}$ =4) # 26.6.3 Serial Interface (SIO/UART) #### 26.6.3.1 I/O Interface mode In the table below, the letter x represents the SIO operation clock cycle time which is identical to the fsys cycle time. It varies depending on the programming of the clock gear function. # (1) SCLK Input mode [Data input] Page 715 2023/07/21 | Deservator | Oh al | Equation | fsys = | Unit | | | |---------------------------------------------|------------------|-------------|--------|--------|---------|------| | Parameter | Symbol | Min. | Max. | Min. | Max. | Unit | | SCLK Clock High width (input) | t <sub>SCH</sub> | 4x | - | 62.5 | - | | | SCLK Clock Low width (input) | t <sub>SCL</sub> | 4x | - | 62.5 < | - | | | SCLK cycle | t <sub>SCY</sub> | tsch + tscl | - | 125 | >>/ | | | Valid Data input → SCLK rise / fall (Note1) | t <sub>SRD</sub> | 30 | - | 30.0 | (-) | ns | | SCLK rise / fall (Note1) → Input Data hold | t <sub>HSR</sub> | x + 30 | - | 45.6 | <u></u> | | #### [Data output] | | | | 7 4 1 | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------|-------|-----------------|--------|---------------------| | Parameter | Cumbal | Equation | | fsys = | 64 MHz | : | | Parameter | Symbol | Min. | Max. | Min. | Max. | Unit | | SCLK Clock High width (input) | t <sub>SCH</sub> | 4x | | 91.9 | 7 | | | Land Control of the C | 0011 | | | (Note3) | | $_{1}$ $\bigcirc$ / | | SCLK Clock Low width (input) | t <sub>SCL</sub> | 4X | - | 91.9<br>(Note3) | | | | SCLK cycle | t <sub>SCY</sub> | tsch + tscl | - | 184 | | ns | | Output Data → | + | t <sub>SCY</sub> /2 - 3x- 45 | | (0.00 \ | \ | | | SCLK rise / fall (Note1) | toss | (SCY/2 - 5x- 45 | | (Note2) | _ | | | SCLK rise / fall (Note1) → | tous | t <sub>SCY</sub> /2 | | 91.9 | | | | Output Data hold | tons | ISCY/2 | | 91.9 | _ | | Note 1: SCLK rise/fall : SCLK rise mode uses the rise timing of SCLK. SCLK fall mode uses the fall timing of SCLK. Note 2: Use the frequency of SCLK in a range where the calculation value keeps positive. Note 3: The value indicates a minimum value that enables $t_{\mbox{\scriptsize OSS}}$ to be zero or more. #### (2) SCLK output mode | Parameter | Cimpol | Equation | | fsys = | 64 MHz | Lloit | |------------------------------|------------------|--------------------------|------|--------|--------|-------| | Parameter | Symbol | Min. | Max. | Min. | Max. | Unit | | SCLK cycle (programmable) | tscy | 4x | 1 | 62.5 | - | | | Output Data → SCLK rise | toss | t <sub>SCY</sub> /2 - 20 | ı | 11.3 | - | | | SCLK rise → Output Data hold | tons | t <sub>SCY</sub> /2 - 20 | ı | 11.3 | ı | ns | | Valid Data input → SCLK rise | tsrd | x + 45 | ı | 45 | ı | | | SCLK rise → Input Data hold | t <sub>HSR</sub> | 0 | - | 0 | - | | Page 716 2023/07/21 Page 717 2023/07/21 #### 26.6 AC Electrical Characteristics ### 26.6.4 Serial Bus Interface (I2C/SIO) #### 26.6.4.1 I2C Mode In the table below, the letter x represents the I2C operation clock cycle time which is identical to the fsys cycle time. It varies depending on the programming of the clock gear function. n denotes the value of n programmed into the SCK (SCL output frequency select) field in the SBIxCR. | Description | O. mada ad | Equ | ation | Standa | rd Mode | Fast | Mode | 11-4 | |----------------------------------------------------------|----------------------|---------|-----------|--------|------------|------|----------|------| | Parameter | Symbol | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | SCL clock frequency | t <sub>SCL</sub> | 0 | - | O( | 100 | 0 | 400 | kHz | | Hold time for a START condition | t <sub>HD; STA</sub> | - | - | 4.0 | - | 0.6 | | μs | | SCL Low width (input) (Note1) | $t_{LOW}$ | - | - ( | 4.7 | <b>\</b> | 1.3 | 7-/ | μs | | SCL high width (input) (Note2) | t <sub>HIGH</sub> | - | - \ | 4.0 | - < | 0.6 | <u> </u> | μs | | Setup time for a repeated START condition | t <sub>SU; STA</sub> | (Note5) | (-( | 4.7 | - | 0.6 | | μs | | Data hold time (input) (Note3, 4) | t <sub>HD; DAT</sub> | - | | 0.0 | - ( | 0.0 | > - | μs | | Data setup time | t <sub>SU; DAT</sub> | - | <u> </u> | 250 | - ( | 100 | - | ns | | Setup time for a STOP condition | t <sub>SU; STO</sub> | -( | > | 4.0 | $(\theta)$ | 0.6 | - | μs | | Bus free time between STOP condition and START condition | t <sub>BUF</sub> | (Note5) | \rangle - | 4.7 | 1 | 1.3 | _ | μs | Note 1: SCL clock Low width (output) : $(2^{n-1} + 58)/x$ Note 2: SCL clock High width (output) : $(2^{n-1} + 14)/x$ On I2C-bus specification, Maximum Speed of Standard Mode is 100kHz, Fast mode is 400khz. Internal SCL frequency setting should comply with Note1 & Note2 shown above. Note 3: The output data hold time is equal to 4x of internal SCL. Note 4: The Philips I2C-bus specification states that a device must internally provide a hold time of at least 300 ns for the SDA signal to bridge the undefined region of the falling edge of SCL. However, this SBI does not satisfy this requirement. Also, the output buffer for SCL does not incorporate slope control of the falling edges; therefore, the equipment manufacturer should design so that the input data hold time shown in the table is satisfied, including tr/tf of the SCL and SDA lines. Note 5: Software dependent Note 6: The Philips I2C-bus specification instructs that if the power supply to a Fast-mode device is switched off, the SDA and SCI I/O pins must be floating so that they don't obstruct the bus lines. However, this SBI does not satisfy this requirement. S: START condition Sr: RESTART condition P: STOP condition #### 26.6.4.2 Clock-Synchronous 8-Bit SIO mode In the table below, the letter x represents the SBI operation clock cycle time which is identical to the fsys cycle time. It varies depending on the programming of the clock gear function. (1) SCK Input mode(The electrical specifications below are for an SCK signal with a 50% duty cycle.) [Data input] | Davanatas | Couradh a l | Equation | | fsys = | 11-4 | | |------------------------------|------------------|-------------------------------------|---------------|--------|------|------| | Parameter | Symbol | Min. | Max. | Min. | Max. | Unit | | SCK Clock High width (input) | t <sub>SCH</sub> | 4x | 47 | 62.5 | - < | | | SCK Clock Low width (input) | t <sub>SCL</sub> | 4x | 7) <u>-</u> \ | 62.5 | -35 | | | SCK cycle | t <sub>SCY</sub> | t <sub>SCH</sub> + t <sub>SCL</sub> | $(\ \ )$ | 125 | (-) | ns | | SCK rise→ Valid Data input | t <sub>SRD</sub> | 30 - x | <u></u> | 14.4 | 7 | 10/ | | SCK rise → Input Data hold | t <sub>HSR</sub> | 2x + 30 | | 61.3 | 7 - | ) | [Data output] | Description | O. Calad | Equation | | fsys = | 64 MHz | Unit | |------------------------------|------------------|-------------------------------------|------|-----------------|--------|-------| | Parameter | Symbol | Min. | Max. | Min. | Max. | Uniit | | SCK Clock High width (input) | tsch | // 4x | )/1 | 91.9<br>(Note2) | 1 | | | SCK Clock Low width (input) | tscı | 4x | - | 91.9<br>(Note1) | ı | | | SCK cycle | t <sub>SCY</sub> | t <sub>SCH</sub> + t <sub>SCL</sub> | - | 184 | 1 | ns | | SCK rise → Output Data | toss | t <sub>SCY</sub> /2 - 3x - 45 | - | 0<br>(Note1) | - | | | SCK rise → Output Data hold | tons | t <sub>SCY</sub> /2 + x | - | 107.6 | _ | | Note 1: Use the frequency of SCLK in a range where the calculation value keeps positive. Note 2: The value indicates a minimum value that enables $t_{OSS}$ to be zero or more. (2) SCK Output Mode (The electrical specifications below are for an SCK signal with a 50% duty cycle.) | Downster | O. wash ad | Equation | | fsys = | 64 MHz | Unit | |-----------------------------|------------------|--------------------------|------|--------|-----------|-------| | Parameter | Symbol | Min. | Max. | Min. | 4 MHz Max | Offic | | SCK cycle (programmable) | tscy | 16x | - | 250 | - | | | Output Data → SCK rise | toss | t <sub>SCY</sub> /2 - 20 | - | 105 | - | | | SCK rise → Output Data hold | t <sub>OHS</sub> | t <sub>SCY</sub> /2 - 20 | - | 105 | - | ns | | Valid Data input → SCK rise | t <sub>SRD</sub> | x + 45 | _ | 60.6 | _ | | | SCK rise → Input Data hold | t <sub>HSR</sub> | 0 | _ | 0 | _ | | Note 1: SCK cycle after automatic wait becomes 14x. Note 2: $t_{OSS}$ after automatic wait may be $t_{SCY}/2$ -x-20. Page 719 2023/07/21 ## 26.6.5 SSP Controller (SSP) "T" is 1/2 cycles of an internal bus frequency (fsys) in the Equation of the table. AC measurement condition - Output level: High = $0.8 \times DVDD3$ , Low = $0.2 \times DVDD3$ - Input level: Refer low-level input voltage and high-level input voltage in DC Electrical Characteristics - Load capacitance : CL = 30pF Note: The "Equation" column in the table shows the specifications under the conditions DVDD3 2.7 to 3.6 V. | | | | > | W / | | |-------------------------------------------------------|-------------------|------------------------------------|-------------|-------------------------------------|------| | Parameter | Symbol | Equation Min. | Max. | fsys =<br>64 MHz<br>m = 4<br>n = 12 | Unit | | SPCLK period (Master) | Tm | (m)T<br>However more than<br>50 ns | | 62.5<br>(16MHz) | | | SPCLK period (Slave) | Ts | (n)T | | 187.5<br>(8MHz) | | | SPCLK rise up time | ţ | | 10.0 | 10.0 | | | SPCLK fall down time | t <sub>f</sub> | << - \) | 10.0 | 10.0 | | | Master mode : SPCLK low-level pulse width | t <sub>WLM</sub> | (m)T / 2 - 10.0 | _ | 21.3 | | | Master mode : SPCLK high-level pulse width | t <sub>WHM</sub> | (m)T / 2 - 10.0 | - | 21.3 | | | Slave mode : SPCLK low-level pulse width | t <sub>WLS</sub> | (n)T / 2 - 10.0 | - | 83.8 | | | Slave mode : SPCLK high-level pulse width | twns | (n)T / 2 - 10.0 | - | 83.8 | | | Master mode :<br>SPCLK rise / fall → output valid | t <sub>ODSM</sub> | <del>-</del> | 15.0 | 15.0 | | | Master mode :<br>SPCLK rise / fall → output data/hold | todнм | (m)T / 2 - 10.0 | I | 21.3 | | | Master mode : input data valid → SPCLK rise / fall | t <sub>IDSM</sub> | 15.0 | 1 | 15.0 | ns | | Master mode :<br>SPCLK rise / fall → input data hold | t <sub>IDHM</sub> | 5.00 | 1 | 5.00 | | | Master mode : SPFSS valid → SPCLK rise / fall | t <sub>OFSM</sub> | (m)T - 10.0 | (m)T + 10.0 | 52.5 - 72.5 | | | Slave mode :<br>SPCLK rise / fall → output data valid | t <sub>ODSS</sub> | - | (3T) + 22.0 | 68.9 | | | Slave mode :<br>SPCLK rise / fall → output data hold | t <sub>ODHS</sub> | (n)T / 2 + (2T) | 1 | 125 | | | Slave mode : input data valid → SPCLK rise / fall | t <sub>IDSS</sub> | 0.00 | - | 0.00 | | | Slave mode :<br>SPCLK rise / fall → input data hold | t <sub>IDHS</sub> | (3T) + 10.0 | ı | 56.9 | | | Slave mode :<br>SPFSS valid → SPCLK rise / fall | torss | (n)T - 15.0 | - | 172.5 | | Note: Baud rate clock is set under below condition Page 721 2023/07/21 Master mode : $m = (<\!CPSDVSR\!> \times (1+<\!SCR\!>)) = f_{sys} / f_{SPCLK}$ <CPSDVR> is set only even number and "m" must set within 65024≥ m≥4 Slave mode : $n = (<\!CPSDVSR\!> \times (1+<\!SCR\!>)) = f_{sys} / f_{SPCLK}$ "n" must set within 65024≥ n≥12 #### 26.6.5.1 SSP SPI mode (Master) - fsys / 4 $\geq f_{SPCLK} \geq$ fsys / 65024 (1) Master SSPCR0<SPH> = "0" (Data is latched on the first edge) (2) Master SSPCR0<SPH> = "1" (Data is latched on the second edge) Page 723 2023/07/21 ### 26.6.5.2 SSP SPI mode (Slave) - fsys / $12 \ge f_{SPCLK} \ge$ fsys / 65024 (1) Slave SSPCR0<SPH> = "0" (Data is latched on the first edge) (2) Slave SSPCR0<SPH> = "1" (Data is latched on the second edge) #### 26.6.6 16-bit timer / even counter #### 26.6.6.1 Event counter In the table below, the letter x represents the 16-bit timer / event counter operation clock cycle time which is identical to the fsys cycle time. It varies depending on the programming of the clock gear function. | Parameter | 0 | Equation | | fsys = | 64 MHz | 11.29 | |------------------------------|-------------------|----------|------|--------|--------|-------| | | Symbol | Min. | Max. | Min. | Max. | Unit | | Clock low-level pulse width | t <sub>VCKL</sub> | 2x + 100 | - ( | 131.3 | - | ns | | Clock high-level pulse width | t <sub>VCKH</sub> | 2x + 100 | | 131.3 | - ( | ns | #### 26.6.6.2 Capture In the table below, the letter x represents the 16-bit timer / event counter operation clock cycle time which is identical to the fsys cycle time. It varies depending on the programming of the clock gear function. | Deservator | Equation | | | fsys = 64 MHz | | 11.2 | | |------------------------------|------------------|----------|------|---------------|------|------|--| | Parameter | Symbol | Min. | Max. | Min. | Max. | Unit | | | Clock low-level pulse width | t <sub>CPL</sub> | 2x + 100 | - \ | 131.3 | - | ns | | | Clock high-level pulse width | t <sub>CRH</sub> | 2x + 100 | | 131.3 | - | ns | | # 26.6.7 External Interrupt In the table below, the letter x represents the fsys cycle time. 1. Except STOP release interrupt | Parameter | 0 | Equation | | fsys = | 64 MHz | | | |----------------------------------|--------------------|----------|------|--------|--------|------|--| | | Symbol | Min. | Max. | Min. | Max. | Unit | | | INT0 to F Low-level pulse width | t <sub>INTAL</sub> | x + 100 | - (( | 115.6 | - | ns | | | INT0 to F High-level pulse width | t <sub>INTAH</sub> | x + 100 | _ | 115.6 | - ( | ns | | #### 2. STOP release interrupt | Parameter | Symbol | Min. | Max. | Unit | |----------------------------------|--------------------|------|-------|------| | INT0 to F Low-level pulse width | t <sub>INTBL</sub> | 100 | ( -/> | ns | | INT0 to F High-level pulse width | t <sub>INTBH</sub> | 100 | | ns | ### 26.6.8 NMI | Parameter | Symbol | )) Min. | Max. | Unit | |---------------------------|--------|---------|----------|------| | NMI Low-level pulse width | tINTCL | 100 | $\wedge$ | ns | ## 26.6.9 SCOUT Pin AC Characteristic | Parameter | Cumbal | Equation | | fsys = 64 MHz | | 1.1 | |------------------------|--------|----------|------|---------------|------|------| | | Symbol | Min. | Max. | Min. | Max. | Unit | | High-level pulse width | ∕ tscн | 0.5T - 5 | - | 2.8 | - | ns | | Low-level pulse width | tscL | 0.5T - 5 | ı | 2.8 | - | ns | Note: In the above table, the letter T represents the cycle time of the SCOUT output clock. # 26.6.10 Debug communication | Parameter | Symbol | Min. | Max. | Unit | |------------------------------|------------------|------|------|------| | CLK cycle | T <sub>dck</sub> | 100 | - | ns | | CLK rise → Output data hold | T <sub>d1</sub> | 4 | - | ns | | CLK rise → Output data valid | T <sub>d2</sub> | - | 30 | ns | | Input data valid ← CLK rise | T <sub>ds</sub> | 20 | - | ns | | CLK rise → Input data hold | T <sub>dh</sub> | 15 | - | ns | | | | | | | Page 727 2023/07/21 ## 26.6.11 ETM Trace | Parameter | Symbol | Min. | Max. | Unit | |--------------------------------------------|---------------------|-------|------|--------| | TRACECLK cycle | t <sub>tclk</sub> | 31.25 | - | ns | | TRACEDATA valid ← TRACECLK rise | t <sub>setupr</sub> | 2 | - | ns (( | | TRACECLK rise $\rightarrow$ TRACEDATA hold | t <sub>holdr</sub> | 1 | - | ns | | TRACEDATA valid ← TRACECLK rise | t <sub>setupf</sub> | 2 | | (ns//< | | TRACECLK fall → TRACEDATA hold | t <sub>holdf</sub> | 1 | - | ns | # 26.7 Flash Characteristics # 26.7.1 Erase / Write Characteristics | Parameter | Condition Min. | Тур. | Max. | Unit | |---------------------------|-----------------------------------------------------------|------|------|-------| | The number of E / W cycle | DVDD3 = AVDD3 = RVDD3 = 2.7 V to 3.6 V<br>Ta = 0 to 70 °C | - | 100 | cycle | #### 26.8 Oscillation Circuit Oscillation circuit is shown as below; Figure 26-1 High-frequency oscillation connection Figure 26-2 Low-frequency oscillation connection Note: To obtain a table oscillation, load capacity and the position of the oscillator must be configured properly. Since these factors are strongly affected by substrate pattern, please evaluate oscillation stability using the substrate you use. The TMPM362F10FG has been evaluated by the oscillator vender below. Please refer this information when selecting exter-nal parts. #### 26.8.1 Ceramic oscillator The TMPM362F10FG recommends the high-frequency oscillator by Murata Manufacturing Co., Ltd. Please refer to the Murata Website for details. #### 26.8.2 Crystal oscillator The TMPM362F10FG recommends the high-frequency oscillator by KYOCERA Corporation. Please refer to the KYOCERA Website for details. Page 729 2023/07/21 26.8 Oscillation Circuit TMPM362F10FG ## 26.8.3 Precaution for designing printed circuit boad Be sure to design printed circuit board patterns that connect a crystal unit with other oscillation elements so that the lenghts of such patterns become shortest possible to prevent deterioration of characteristics due to stray capacitances and wiring inductance. For multi-layer circuit boards, it is important not to wire the ground and other signal patterns right beneath the oscillation circuit. ### 26.9 Handling Precaution ### 26.9.1 Notice of Power Supply #### 26.9.1.1 Notice of Power on The power supply must be raised (from 0V to 2.7V) at a speed of 0.1ms/V or slower. The power-on sequence must consider the time for the internal regulator and oscillator to be stable. In the TX03, the internal regulator requires at least 700 µs to be stable. The time required to achieve stable oscillation varies with system. At cold reset, the external reset pin must be kept "Low" for a duration of time sufficiently long enough for the internal regulator and oscillator to be stable. The power-on sequence is shown as below; #### 26.9.1.2 Notice of Power on again When power on again after power off, the voltage of power supply is equal or less than 0.5V and keeps this level until more than 2ms. After this, the power supply must be raised at a speed of 0.1ms/V or slower. Regarding to reset, refer to 26.9.1.1. Page 731 2023/07/21 26.9 Handling Precaution TMPM362F10FG # 27. Package Dimensions LQFP144-P-2020-0.50E Page 733 2023/07/21 #### RESTRICTIONS ON PRODUCT USE Toshiba Corporation and its subsidiaries and affiliates are collectively referred to as "TOSHIBA". Hardware, software and systems described in this document are collectively referred to as "Product". - TOSHIBA reserves the right to make changes to the information in this document and related Product without notice. - This document and any information herein may not be reproduced without prior written permission from TOSHIBA. Even with TOSHIBA's written permission, reproduction is permissible only if reproduction is without alteration/omission. - Though TOSHIBA works continually to improve Product's quality and reliability, Product can malfunction or fail. Customers are responsible for complying with safety standards and for providing adequate designs and safeguards for their hardware, software and systems which minimize risk and avoid situations in which a malfunction or failure of Product could cause loss of human life, bodily injury or damage to property, including data loss or corruption. Before customers use the Product, create designs including the Product, or incorporate the Product into their own applications, customers must also refer to and comply with (a) the latest versions of all relevant TOSHIBA information, including without limitation, this document, the specifications, the data sheets and application notes for Product and the precautions and conditions set forth in the "TOSHIBA Semiconductor Reliability Handbook" and (b) the instructions for the application with which the Product will be used with or for. Customers are solely responsible for all aspects of their own product design or applications, including but not limited to (a) determining the appropriateness of the use of this Product in such design or applications; (b) evaluating and determining the applicability of any information contained in this document, or in charts, diagrams, programs, algorithms, sample application circuits, or any other referenced documents; and (c) validating a operating parameters for such designs and applications. TOSHIBA ASSUMES NO LIABILITY FOR CUSTOMERS' PRODUCT DESIGN OR APPLICATIONS. - PRODUCT IS NEITHER INTENDED NOR WARRANTED FOR USE IN EQUIPMENTS OR SYSTEMS THAT REQUIRE EXTRAORDINARILY HIGH LEVELS OF QUALITY AND/OR RELIABILITY, AND/OR A MALFUNCTION OR FAILURE OF WHICH MAY CAUSE LOSS OF HUMAN LIFE, BODILY INJURY, SERIOUS PROPERTY DAMAGE AND/OR SERIOUS PUBLIC IMPACT ("UNINTENDED USE"). Except for specific applications as expressly stated in this document, Unintended Use includes, without limitation, equipment used in nuclear facilities, equipment used in the aerospace industry, lifesaving and/or life supporting medical equipment, equipment used for automobiles, trains, ships and other transportation, traffic signaling equipment, equipment used to control combustions or explosions, safety devices, elevators and escalators, and devices related to power plant. IF YOU USE PRODUCT FOR UNINTENDED USE, TOSHIBA ASSUMES NO LIABILITY FOR PRODUCT. For details, please contact your TOSHIBA sales representative or contact us via our website. - . Do not disassemble, analyze, reverse-engineer, alter, modify, translate or copy Product, whether in whole or in part. - Product shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable laws or regulations. - The information contained herein is presented only as guidance for Product use. No responsibility is assumed by TOSHIBA for any infringement of patents or any other intellectual property rights of third parties that may result from the use of Product. No license to any intellectual property right is granted by this document, whether express or implied, by estoppel or otherwise. - ABSENT A WRITTEN SIGNED AGREEMENT, EXCEPT AS PROVIDED IN THE RELEVANT TERMS AND CONDITIONS OF SALE FOR PRODUCT, AND TO THE MAXIMUM EXTENT ALLOWABLE BY LAW, TOSHIBA (1) ASSUMES NO LIABILITY WHATSOEVER, INCLUDING WITHOUT LIMITATION, INDIRECT, CONSEQUENTIAL, SPECIAL, OR INCIDENTAL DAMAGES OR LOSS, INCLUDING WITHOUT LIMITATION, LOSS OF PROFITS, LOSS OF OPPORTUNITIES, BUSINESS INTERRUPTION AND LOSS OF DATA, AND (2) DISCLAIMS ANY AND ALL EXPRESS OR IMPLIED WARRANTIES AND CONDITIONS RELATED TO SALE, USE OF PRODUCT, OR INFORMATION, INCLUDING WARRANTIES OR CONDITIONS OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, ACCURACY OF INFORMATION, OR NONINFRINGEMENT. - Do not use or otherwise make available Product or related software or technology for any military purposes, including without limitation, for the design, development, use, stockpiling or manufacturing of nuclear, chemical, or biological weapons or missile technology products (mass destruction weapons). Product and related software and technology may be controlled under the applicable export laws and regulations including, without limitation, the Japanese Foreign Exchange and Foreign Trade Law and the U.S. Export Administration Regulations. Export and re-export of Product or related software or technology are strictly prohibited except in compliance with all applicable export laws and regulations. - Please contact your TOSHIBA sales representative for details as to environmental matters such as the RoHS compatibility of Product. Please use Product in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. TOSHIBA ASSUMES NO LIABILITY FOR DAMAGES OR LOSSES OCCURRING AS A RESULT OF NONCOMPLIANCE WITH APPLICABLE LAWS AND REGULATIONS. https://toshiba.semicon-storage.com/