## TOSHIBA

## 32 Bit RISC Microcontroller TX03 Series

## TMPM341FDXBG/FYXBG

**TOSHIBA CORPORATION** 

© 2011 TOSHIBA CORPORATION All Rights Reserved

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.



Base Address = 0x0000,0000

#### Introduction: Notes on the description of SFR (Special Function Register) under this specification

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"

| 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)).

#### 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.

Note: The register shown above is an example for explanation purpose and not for demonstration purpose. This register does not exist in this microcontroller.

#### 1.2.2 SAMCR(Control register)

TOSHIBA

|             | 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  | 0  |
|             | 15   | 14 | 13 | 12 | 11    | 10 | 9  | 8  |
| bit symbol  | -    | -  | -  | -  | -     | -  | МС | DE |
| After reset | 0    | 0  | 0  | 0  | 0     | 0  | 0  | 0  |
|             | 7    | 6  | 5  | 4  | 3     | 2  | 1  | 0  |
| bit symbol  | MODE |    |    |    | TDATA |    |    |    |
| Sit eyinsei |      |    |    |    |       |    |    |    |

| 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 |
|-------|------------|
| R     | READ       |
| W     | 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       |
|------------|-------------|---------------|
| 2010/10/7  | Tentative 1 | First Release |
| 2011/4/22  | Tentative 2 | First Release |
| 2011/10/15 | 1           | First Release |

# **Table of Contents**

## Introduction: Notes on the description of SFR (Special Function Register) under this specification

#### TMPM341FDXBG/FYXBG

| 1.1   | Features                          |  |
|-------|-----------------------------------|--|
|       | Block Diagram                     |  |
|       | Pin Layout (Top view)             |  |
|       | Pin names and Functions           |  |
| 1.4.  | 1 Sorted by Pin                   |  |
| 1.4.2 | 2 Sorted by Port                  |  |
| 1.5   | Pin Numbers and Power Supply Pins |  |

#### 2. Processor Core

| 2.1 Information on the processor core         |    |
|-----------------------------------------------|----|
| 2.2 Configurable Options                      |    |
| 2.3 Exceptions/ Interruptions                 |    |
| 2.3.1 Number of Interrupt Inputs              |    |
| 2.3.2 Number of Priority Level Interrupt Bits | 24 |
| 2.3.3 SysTick                                 | 24 |
| 2.3.4 SYSRESETREQ                             | 24 |
| 23.5 LOCKUP                                   | 24 |
| 2.3.6 Auxiliary Fault Status register         | 24 |
| 2.4 Events                                    |    |
| 2.5 Power Management                          |    |
| 2.6 Exclusive access                          |    |

#### 3. Endian

| 3.1 E | Indianess of Cortex-M3 core             |    |
|-------|-----------------------------------------|----|
|       | Indianess of TMPM341FDXBG/FYXBG         |    |
| 3.2.1 | Single Mode                             |    |
| 3.2.2 | Single Boot Mode                        |    |
| 3.2.3 | Miscellaneous                           |    |
| 3.2.  |                                         |    |
| 3.2.  | 3.2 Endian in the Debug Tools           |    |
| 3.3 H | Iow to Set Endianess and Endian type    |    |
| 3.3.1 | Operation Setting of TMPM341FDXBG/FYXBG |    |
| 3.3.2 | Operation Mode                          | 29 |
| 3.3.3 | ENDIAN Pin                              |    |
| 3.3.4 | Endian Selection of External Bus Area   |    |
| 3.3.5 | Endian Selection of DMAC                |    |
| 3.4 S | tructure                                |    |
| 3.4.1 | Block Structure of Little-endian        |    |



#### 4. Memory Map

| 4.1 | Memory map                              | 45 |
|-----|-----------------------------------------|----|
|     | .1 Memory map of the TMPM341FDXBG/FYXBG |    |
| 4.2 | SFR area detail                         | 48 |

#### 5. External bus interface (EBIF)

| 5.1 Overview                                                              |    |
|---------------------------------------------------------------------------|----|
| 5.2 Address and Data Pins                                                 |    |
| 5.2.1 Address and Data pin setting                                        |    |
| 5.3 Registers                                                             |    |
| 5.3.1 Registers List                                                      |    |
| 5.3.2 EXBMOD (External Bus Mode Control Register)                         |    |
| 5.3.3 EXBASx (External Bus Area and Start Address Configuration Register) |    |
| 5.3.4 EXBCSx (External Bus Chip Select Control Register)                  |    |
| 5.4 Data Format                                                           |    |
| 5.4.1 Little-endian mode                                                  |    |
| 5.4.1.1 Word access                                                       |    |
| 5.4.1.2 Half word access                                                  |    |
| 5.4.1.3 Byte access<br>5.4.2 Big-endian mode                              | 59 |
| 5.4.2 Big-endian mode                                                     |    |
| 5.4.2.2 Half word access                                                  |    |
| 5.4.2.3 Byte access                                                       |    |
| 5.5 External Bus Operations (Separete Bus Mode)                           |    |
| 5.5.1 Basic bus operation.                                                |    |
| 5.5.2 Wait timing                                                         | 61 |
| 5.5.3 Read and Write Recovery time                                        |    |
| 5.5.4 Chip select recovery time                                           |    |
| 5.5.5 Read and Write setup cycle                                          |    |
| 5.6 External Bus Operations (Multiplexed Bus Mode)                        |    |
| 5.6.1 Basic bus operation.                                                |    |
| 5.6.2 Wait timing                                                         |    |
| 5.6.3 Time that it takes before ALE is asserted                           |    |
| 5.6.4 Read and Write Recovery Time                                        |    |
| 5.6.5 Chip select recovery time                                           |    |
| 5.6.6 Read and Write setup cycle                                          |    |
| 5.7 Connection example for external memory                                | 72 |

#### 6. DMA Controller(DMAC)

| 6.1 | Function Overview | 75 |
|-----|-------------------|----|
| 6.2 | DMA transfer type | 76 |

| 6.3          | Block diagram                                                           | 77 |
|--------------|-------------------------------------------------------------------------|----|
| <b>6.4</b> 1 | Description of Registers                                                |    |
| 6.4.1        | DMAC register list                                                      |    |
| 6.4.2        | DMACxIntStatus (DMAC Interrupt Status Register)                         | 80 |
| 6.4.3        | DMACxIntTCStatus (DMAC Interrupt Terminal Count Status Register)        |    |
| 6.4.4        | DMACxIntTCClear (DMAC Interrupt Terminal Count Clear Register)          |    |
| 6.4.5        | DMACxIntErrorStatus (DMAC Interrupt Error Status Register)              |    |
| 6.4.6        | DMACxIntErrClr (DMAC Interrupt Error Clear Register)                    |    |
| 6.4.7        | DMACxRawIntTCStatus (DMAC Raw Interrupt Terminal Count Status Register) |    |
| 6.4.8        | DMACxRawIntErrorStatus (DMAC Raw Error Interrupt Status Register)       |    |
| 6.4.9        | =                                                                       |    |
| 6.4.10       |                                                                         |    |
| 6.4.1        | DMACxSoftSReq (DMAC Software Single Request Register)                   | 90 |
| 6.4.12       | 2 DMACxConfiguration (DMAC Configuration Register)                      |    |
| 6.4.13       | 3 DMACxCnSrcAddr (DMAC Channeln Source Address Register)                | 93 |
| 6.4.14       | DMACxCnDestAddr (DMAC Channeln Destination Address Register)            | 94 |
| 6.4.1        |                                                                         |    |
| 6.4.10       | 5 DMACxCnControl (DMAC Channeln Control Register)                       |    |
| 6.4.1        | 7 DMACxCnConfiguration (DMAC Channelx Configuration Register)           |    |
| 6.5          | Special Functions                                                       |    |
| 6.5.1        | Scatter/gather function                                                 |    |
| 6.5.2        | Linked list operation                                                   |    |

### 7. Reset

| 7.1   | Initial state  |  |
|-------|----------------|--|
|       | Cold reset     |  |
|       | Warm reset     |  |
| 7.3.1 | 1 Reset period |  |
| 7.3.2 | 2 After reset  |  |
|       |                |  |

### 8. Ocsillation Frequency Detector (OFD)

| 8.1 | Bl              | lock diagram                                                                        |     |
|-----|-----------------|-------------------------------------------------------------------------------------|-----|
| 8.2 |                 | egisters                                                                            |     |
| 8.  | 2.1<br>8.2.1.   | Register List                                                                       |     |
|     | 8.2.1.<br>8.2.1 |                                                                                     |     |
|     | 8.2.1.<br>8.2.1 | 1.4 OFDMX (Higher detection frequency setting register)                             |     |
|     | 8.2.1           | 1.6 OFDSTAT (Status register)                                                       |     |
| 8.3 | O               | perational Description                                                              |     |
| 8.  | 3.1             | Enabling and Disabling the Oscillation Frequency Detection                          | 114 |
| 8.  | 32              | Operation                                                                           | 114 |
| 8.  | 3.3             | Detection Frequency                                                                 |     |
| 8.  | 3.4             | Available Operation Mode                                                            |     |
| 8.  | 3.5             | Detection Frequency<br>Available Operation Mode<br>Example of Operational Procedure | 116 |

## 9. Watchdog Timer(WDT)

| 9.1 | Configuration                            |  |
|-----|------------------------------------------|--|
|     | Register                                 |  |
|     | 1 WDMOD(Watchdog Timer Mode Register)    |  |
|     | 2 WDCR (Watchdog Timer Control Register) |  |
|     | Operations                               |  |
|     | 1 Basic Operation                        |  |



#### **10.** Clock/Mode control

| 10.2       Registers.       126         10.2.1       Register List.       126         10.2.2       CGSYSCR (System control register).       127         10.2.3       CGOSCCR (Oscillation control register).       128         10.2.4       CGSTBYCR (Standby control register).       130         10.2.5       CGPLLSEL (PLL Selection Register).       131         10.2.6       CGCKSEL (System clock selection register).       131         10.2.6       CGCKSEL (System clock selection register).       132         10.2.7       CGPWMGEAR (Timer clock selection register).       133         10.2.8       CGPROTECT (Protect register).       134         10.3       Clock control.       135         10.3.1       Clock System Block Diagram.       135         10.3.2       Initial Values after Reset.       135         10.3.3       Clock system Diagram.       136         10.3.4       Warm-up function.       137         10.3.5       Clock Multiplication Circuit (PLL).       139         10.3.6       System clock.       142         10.3.6.1       Clock setting       136         10.3.6.2       When using external oscillator       146         10.3.7       Prescaler Clock Control. |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10.2.1       Register List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10.2.3       CGOSCCR (Oscillation control register).       128         10.2.4       CGSTBYCR (Standby control register).       130         10.2.5       CGPLLSEL (PLL Selection Register).       131         10.2.6       CGCKSEL (System clock selection register).       132         10.2.7       CGPWMGEAR (Timer clock selection register).       133         10.2.8       CGPROTECT (Protect register).       133         10.2.8       CGPROTECT (Protect register).       134         10.3       Clock control.       135         10.3.1       Clock System Block Diagram.       135         10.3.2       Initial Values after Reset.       135         10.3.3       Clock system Diagram.       136         10.3.4       Warm-up function.       137         10.3.5       Clock Multiplication Circuit (PLL).       139         10.3.6.1       Clock setting       136         10.3.6.2       When using external oscillator       142         10.3.7       Prescaler Clock Control.       146                                                                                                                                                                                                         |
| 10.2.3       CGOSCCR (Oscillation control register)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10.2.5       CGPLLSEL (PLL Selection Register).       131         10.2.6       CGCKSEL (System clock selection register).       132         10.2.7       CGPWMGEAR (Timer clock selection register).       133         10.2.8       CGPROTECT (Protect register).       134         10.3       Clock control.       135         10.3.1       Clock System Block Diagram.       135         10.3.2       Initial Values after Reset.       135         10.3.3       Clock system Diagram.       136         10.3.4       Warm-up function.       137         10.3.5       Clock Multiplication Circuit (PLL).       139         10.3.5.1       How to configure the PLL function       139         10.3.6.2       Stability time       142         10.3.6.1       Clock Scottrol.       146         10.3.7       Prescaler Clock Control.       146                                                                                                                                                                                                                                                                                                                                                            |
| 10.2.6       CGCKSEL (System clock selection register)       132         10.2.7       CGPWMGEAR (Timer clock selection register)       133         10.2.8       CGPROTECT (Protect register)       134         10.3       Clock control       135         10.3.1       Clock System Block Diagram       135         10.3.2       Initial Values after Reset       135         10.3.3       Clock system Diagram       136         10.3.4       Warm-up function       137         10.3.5       Clock Multiplication Circuit (PLL)       139         10.3.5.1       How to configure the PLL function       139         10.3.6.2       Stability time       142         10.3.6.1       Clock Scottrol       146         10.3.7       Prescaler Clock Control       146                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10.2.7       CGPWMGEAR (Timer clock selection register).       133         10.2.8       CGPROTECT (Protect register).       134         10.3       Clock control.       135         10.3.1       Clock System Block Diagram.       135         10.3.2       Initial Values after Reset.       135         10.3.3       Clock system Diagram.       136         10.3.4       Warm-up function.       137         10.3.5       Clock Multiplication Circuit (PLL).       139         10.3.5.1       How to configure the PLL function       139         10.3.6.2       Stability time       142         10.3.6.1       Clock setting       10.3.6.2       When using external oscillator         10.3.7       Prescaler Clock Control.       146       146                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10.2.8       CGPROTECT (Protect register)       134         10.3       Clock control       135         10.3.1       Clock System Block Diagram       135         10.3.2       Initial Values after Reset       135         10.3.3       Clock system Diagram       136         10.3.4       Warm-up function       137         10.3.5       Clock Multiplication Circuit (PLL)       139         10.3.5.1       How to configure the PLL function       139         10.3.5.2       Stability time       142         10.3.6.1       Clock setting       142         10.3.6.2       When using external oscillator       146         10.3.8       System Clock Pin Output Function       146                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10.3       Clock control.       135         10.3.1       Clock System Block Diagram.       135         10.3.2       Initial Values after Reset.       135         10.3.3       Clock system Diagram.       136         10.3.4       Warm-up function.       137         10.3.5       Clock Multiplication Circuit (PLL).       139         10.3.5.1       How to configure the PLL function       139         10.3.5.2       Stability time       142         10.3.6       System clock.       142         10.3.6.1       Clock Setting       146         10.3.7       Prescaler Clock Control.       146                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10.3.1       Clock System Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10.3.2Initial Values after Reset13510.3.3Clock system Diagram13610.3.4Warm-up function13710.3.5Clock Multiplication Circuit (PLL)13910.3.5.1How to configure the PLL function13910.3.5.2Stability time14210.3.6.1Clock setting14210.3.6.2When using external oscillator14610.3.8System Clock Pin Output Function146                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10.3.3Clock system Diagram.13610.3.4Warm-up function.13710.3.5Clock Multiplication Circuit (PLL).13910.3.5.1How to configure the PLL function13910.3.5.2Stability time14210.3.6.1Clock setting14210.3.6.2When using external oscillator14610.3.8System Clock Pin Output Function.146                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10.3.4Warm-up function13710.3.5Clock Multiplication Circuit (PLL)13910.3.5.1How to configure the PLL function13910.3.5.2Stability time14210.3.6System clock14210.3.6.1Clock setting14210.3.6.2When using external oscillator14610.3.7Prescaler Clock Control14610.3.8System Clock Pin Output Function146                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10.3.5       Clock Multiplication Circuit (PLL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10.3.5.1       How to configure the PLL function         10.3.5.2       Stability time         10.3.6       System clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10.3.5.2       Stability time         10.3.6       System clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10.3.6       System clock       142         10.3.6.1       Clock setting       10.3.6.2         10.3.6.2       When using external oscillator       146         10.3.7       Prescaler Clock Control       146         10.3.8       System Clock Pin Output Function       146                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10.3.6.1       Clock setting         10.3.6.2       When using external oscillator         10.3.7       Prescaler Clock Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10.3.6.2       When using external oscillator         10.3.7       Prescaler Clock Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10.3.7Prescaler Clock Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10.3.8 System Clock Pin Output Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>10.4</b> Modes and Mode Transitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10.4.1 Mode Transitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10.5 Operation mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10.5.1 NORMAL mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10.6   Low Power Consumption Modes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10.6.1 IDLE mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 10.6.2 STOP1 mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10.6.3 STOP2 mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10.6.4 Low power Consumption Mode Setting                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10.6.5 Operational Status in Each Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10.6.6 Releasing the Low Power Consumption Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10.6.7 Warm-up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10.6.8 Clock Operations in Mode Transition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10.6.8.1 Transition of operation modes: NORMAL $\rightarrow$ STOP1 $\rightarrow$ NORMAL<br>10.6.8.2 Transition of operation modes: NORMAL $\rightarrow$ STOP2 $\rightarrow$ NORMAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 11. Exceptions

| 11.1 Overview                                                             |              |
|---------------------------------------------------------------------------|--------------|
| 11.1.1 Exception Types                                                    |              |
| 11.1.2 Handling Flowchart                                                 |              |
| 11.1.2.1 Exception Request and Detection                                  |              |
| 11.1.2.2 Exception Handling and Branch to the Interrupt Service Routine ( | Pre-emption) |

|      | 1.1.2.3            | Executing an ISR                                                            |      |
|------|--------------------|-----------------------------------------------------------------------------|------|
| 11.2 | 1.1.2.4<br>Dos     | Exception exit<br>et Exceptions                                             | 164  |
|      |                    |                                                                             |      |
| 11.3 |                    | -Maskable Interrupts (NMI)                                                  |      |
| 11.4 | Sys]               | Fick                                                                        | 165  |
| 11.5 | Inter              | rrupts                                                                      | 166  |
| 11.5 |                    | terrupt Sources                                                             |      |
| 1    | 1.5.1.1            | Interrupt Route                                                             |      |
|      | 1.5.1.2            | Generation                                                                  |      |
|      | 1.5.1.3            | Transmission                                                                |      |
|      | 1.5.1.4<br>1.5.1.5 | Precautions when using external interrupt pins<br>List of Interrupt Sources |      |
|      | 1.5.1.6            | Active level                                                                |      |
| 11.5 |                    | terrupt Handling                                                            | .171 |
| 1    | 1.5.2.1            | Flowchart                                                                   |      |
| 1    | 1.5.2.2            | Preparation                                                                 |      |
|      | 1.5.2.3            | Detection by Clock Generator                                                |      |
|      | 1.5.2.4<br>1.5.2.5 | Detection by CPU                                                            |      |
|      | 1.5.2.5            | CPU processing<br>Interrupt Service Routine (ISR)                           |      |
| 11.6 |                    | eption/Interrupt-Related Registers                                          | 177  |
|      |                    |                                                                             |      |
| 11.6 |                    | gister List                                                                 |      |
| 11.6 | .2 N<br>1.6.2.1    | VIC Registers<br>SysTick Control and Status Register                        | .1/8 |
|      | 1.6.2.1            | SysTick Reload Value Register                                               |      |
|      | 1.6.2.3            | SysTick Current Value Register                                              |      |
| 1    | 1.6.2.4            | SysTick Calibration Value Register                                          |      |
|      | 1.6.2.5            | Interrupt Set-Enable Register 1                                             |      |
|      | 1.6.2.6            | Interrupt Set-Enable Register 2                                             |      |
|      | 1.6.2.7<br>1.6.2.8 | Interrupt Set-Enable Register 3<br>Interrupt Clear-Enable Register 1        |      |
|      | 1.6.2.9            | Interrupt Clear-Enable Register 2                                           |      |
|      | 1.6.2.10           | Interrupt Clear-Enable Register 3                                           |      |
| 1    | 1.6.2.11           | Interrupt Set-Pending Register 1                                            |      |
|      | 1.6.2.12           | Interrupt Set-Pending Register 2                                            |      |
|      | 1.6.2.13           | Interrupt Set-Pending Register 3                                            |      |
|      | 1.6.2.14           | Interrupt Clear-Pending Register 1<br>Interrupt Clear-Pending Register 2    |      |
|      | 1.6.2.16           | Interrupt Clear-Pending Register 3                                          |      |
|      | 1.6.2.17           | Interrupt Priority Register                                                 |      |
| 1    | 1.6.2.18           | Vector Table Offset Register                                                |      |
|      | 1.6.2.19           | Application Interrupt and Reset Control Register                            |      |
|      | 1.6.2.20           | System Handler Priority Register                                            |      |
|      | 1.6.2.21           | System Handler Control and State Register<br>ock generator registers        | 200  |
| 11.6 | .s CI<br>1.6.3.1   | CGIMCGA(CG Interrupt Mode Control Register A)                               | .200 |
|      | 1.6.3.2            | CGIMCGA(CG Interrupt Mode Control Register B)                               |      |
|      | 1.6.3.3            | CGIMCGC(CG Interrupt Mode Control Register C)                               |      |
| 1    | 1.6.3.4            | CGIMCGD(CG Interrupt Mode Control Register D)                               |      |
|      | 1.6.3.5            | CGIMCGE(CG Interrupt Mode Control Register E)                               |      |
|      | 1.6.3.6            | CGIMCGF(CG Interrupt Mode Control Register F)                               |      |
|      | 1.6.3.7<br>1.6.3.8 | CGICRCG(CG Interrupt Request Clear Register)<br>CGNMIFLG(NMI Flag Register) |      |
|      | 1.6.3.9            | CGRSTFLG (Reset Flag Register)                                              |      |
| -    |                    |                                                                             |      |

## **12.** Input/Output Ports

| 12.1 Port Functions                                            |  |
|----------------------------------------------------------------|--|
| 12.1.1 Function Lists                                          |  |
| 12.1.2 Port Registers Outline                                  |  |
| 12.1.3 Port States in STOP Mode                                |  |
| 12.1.4 Precautions for Mode Transition between STOP1 and STOP2 |  |
| 12.2 Port functions                                            |  |
| 12.2.1 Port A (PA0 to PA7)                                     |  |
| 12.2.1.1 Port A register                                       |  |
| 12.2.1.2 PADATA (Port A data register)                         |  |
| 12.2.1.3 PACR (Port A output control register)                 |  |
| 12 2 1 4 PAER1 (Port A function register 1)                    |  |



| 12.2.9           | (                                            |     |
|------------------|----------------------------------------------|-----|
| 12.2.9           |                                              |     |
| 12.2.9<br>12.2.9 | ( , , , , , , , , , , , , , , , , , , ,      |     |
| 12.2.9           |                                              |     |
| 12.2.9           |                                              |     |
| 12.2.9           |                                              |     |
| 12.2.10          | Port J (PJ0 to PJ7)                          |     |
| 12.2.1           |                                              |     |
| 12.2.1           | 10.2 PJDATA (Port J data register)           |     |
| 12.2.1           | 10.3 PJCR (Port J output control register)   |     |
| 12.2.1           |                                              |     |
| 12.2.1           |                                              |     |
| 12.2.1           |                                              |     |
| 12.2.1           |                                              | 287 |
| 12.2.11          | Port K (PK0 to PK6)                          |     |
| 12.2.1<br>12.2.1 |                                              |     |
| 12.2.1           | (                                            |     |
| 12.2.1           |                                              |     |
| 12.2.1           | (                                            |     |
| 12.2.1           | 11.6 PKPUP (Port K pull-up control register) |     |
| 12.2.1           | 11.7 PKIE (Port K input control register)    |     |
| 12.3 B           | Block Diagrams of Ports                      |     |
| 12.3.1           | Port Types                                   |     |
| 12.3.2           | Type FT1                                     |     |
| 12.3.3           | Type FT2                                     |     |
| 12.3.4           | Type FT3                                     |     |
| 12.3.5           | Type FT4                                     |     |
| 12.3.6           | Type FT5                                     |     |
| 12.3.7           | Type FT6                                     |     |
| 12.3.8           | Type FT7                                     |     |
| 12.3.9           | Type FT8                                     |     |
|                  | Appendix (Port setting List)                 |     |
| 12.4.1           | Port A Setting                               |     |
| 12.4.1           | Port B Setting                               |     |
| 12.4.2           | Port C Setting                               |     |
| 12.4.5           | 8                                            |     |
|                  | Port D Setting                               |     |
| 12.4.5           | Port E Setting                               |     |
| 12.4.6           | Port F Setting                               |     |
| 12.4.7           | Port G Setting                               |     |
| 12.4.8           | Port H Setting                               |     |
| 12.4.9           | Port I Setting                               |     |
| 12.4.10          | Port J Setting                               |     |
| 12.4.11          | Port K Setting                               |     |
|                  |                                              |     |

## 13. 16-bit Timer/Event Counters(TMRB)

| 13.1   | Outline                               |     |
|--------|---------------------------------------|-----|
| 13.2   | Differences in the Specifications     |     |
|        | Configuration                         |     |
|        | Registers                             |     |
| 13.4.1 | Register list according to channel    | 318 |
| 13.4.2 |                                       |     |
| 13.4.3 | TBxRUN(RUN register)                  |     |
| 13.4.4 |                                       |     |
| 13.4.5 | 5 TBxMOD (Mode register)              |     |
| 13.4.6 | TBxFFCR (Flip-flop control register)  |     |
| 13.4.7 | TBxST (Status register)               |     |
| 13.4.8 | B TBxIM (Interrupt mask register)     |     |
| 13.4.9 |                                       |     |
| 13.4.1 | 0 TBxRG0 (Timer register 0)           |     |
| 13.4.1 | 1 TBxRG1 (Timer register 1)           |     |
| 13.4.1 | 2 TBxCP0 (Capture register 0)         |     |
| 13.4.1 | 3 TBxCP1 (Capture register 1)         |     |
| 13.4.1 | 4 TBxDMA(DMA request enable register) |     |

| 13.5 I        | Description of Operations for Each Circuit             |  |
|---------------|--------------------------------------------------------|--|
| 13.5.1        | Prescaler                                              |  |
| 13.5.2        | Up-counter (UC)                                        |  |
| 13.5.3        | Timer registers (TBxRG0, TBxRG1)                       |  |
| 13.5.4        | Capture                                                |  |
| 13.5.5        | Capture registers (TBxCP0, TBxCP1)                     |  |
| 13.5.6        | Up-counter capture register (TBxUC)                    |  |
| 13.5.7        | Comparators (CP0, CP1)                                 |  |
| 13.5.8        | Timer Flip-flop (TBxFF0)                               |  |
| 13.5.9        | Capture interrupt (INTCAPx0, INTCAPx1)                 |  |
| 13.6 I        | Description of Operations for Each Mode                |  |
| 13.6.1        | 16-bit Interval Timer Mode                             |  |
| 13.6.2        | 16-bit Event Counter Mode                              |  |
| 13.6.3        | 16-bit PPG (Programmable Pulse Generation) Output Mode |  |
| 13.6.4        | Timer synchronous mode                                 |  |
| 13.6.5        | External trigger count start mode                      |  |
| <b>13.7</b> A | Applications using the Capture Function                |  |
| 13.7.1        | One-shot pulse output triggered by an external pulse   |  |
| 13.7.2        | Frequency measurement.                                 |  |
| 13.7.3        | Pulse width measurement                                |  |
| 13.7.4        | Time Difference Measurement                            |  |

## 14. Two-phase pulse input counter (PHCNT)

| 14.1  | Outline                                    |  |
|-------|--------------------------------------------|--|
| 14.2  | Differences in the Specifications          |  |
| 14.3  | Configuration                              |  |
| 14.4  | Registers                                  |  |
| 14.4. | •                                          |  |
| 14.4. |                                            |  |
| 14.4. | 3 PHCxCR (Timer Control Register)          |  |
| 14.4. | 4 PHCxEN (Timer Enable Register)           |  |
| 14.4. | 5 PHCxFLG (Timer Status Register)          |  |
| 14.4. | 6 PHCxCMP0 (Timer Compare Register 0)      |  |
| 14.4. | 7 PHCxCMP1(Timer Compare Register 1)       |  |
| 14.4. | 8 PHCxCNT (Timer Read Register)            |  |
| 14.4. | 9 PHCxDMA (DMA request permitted register) |  |
| 14.5  | Operation in Each Mode                     |  |
| 14.5. | -                                          |  |
| 14.5. | 2 Interrupt                                |  |
| 14.5. | 3 Up-and-down counter                      |  |

### 15. High Resolution 16-bit Timer/PPG Outputs (TMRD)

| 15.1   | Outline                                |  |
|--------|----------------------------------------|--|
|        | Block Diagram                          |  |
| 15.2.1 | ÷                                      |  |
| 15.2.2 | Timer unit (TMRD0, TMRD1)              |  |
| 15.3   | Registers                              |  |
| 15.3.1 | Register list according to channel     |  |
| 15.3.2 |                                        |  |
| 15.3.3 |                                        |  |
| 15.3.4 | TD0CONF (Timer Configuration register) |  |
| 15.3.5 |                                        |  |
| 15.3.6 | TD1MOD (Timer mode register)           |  |
| 15.3.7 |                                        |  |
| 15.3.8 |                                        |  |
| 15.3.9 | TDxRUN (Timer run register)            |  |
| 15.3.1 |                                        |  |

| 15.3.11  | TD1BCR (Update flag setting register)       |  |
|----------|---------------------------------------------|--|
| 15.3.12  | TDxDMA (DMA request enable register)        |  |
| 15.3.13  | TDxRG0 (Timer register 0)                   |  |
| 15.3.14  | TDxCP0 (Timer compare register 0)           |  |
| 15.3.15  | TDxRG1 (Timer register 1).                  |  |
| 15.3.16  | TDxCP1 (Timer compare register 1)           |  |
| 15.3.17  | TDxRG2 (Timer register 2).                  |  |
| 15.3.18  | TDxCP2 (Timer compare register 2)           |  |
| 15.3.19  | TDxRG3 (Timer register 3).                  |  |
| 15.3.20  | TDxCP3 (Timer compare register 3)           |  |
| 15.3.21  | TDxRG4 (Timer register 4).                  |  |
| 15.3.22  | TDxCP4 (Timer compare register 4)           |  |
| 15.3.23  | TD0RG5 (Timer register 5)                   |  |
| 15.3.24  | TD0CP5 (Timer compare register 5)           |  |
| 154 Or   | peration mode                               |  |
|          | 16-bit interval timer                       |  |
| 15.4.1   |                                             |  |
| 15.4.1.2 |                                             |  |
| 15.4.1.3 |                                             |  |
| 15.4.1.4 |                                             |  |
| 15.4.1.5 |                                             |  |
| 15.4.2   | 16-bit programmable pulse generation output |  |
| 15.4.2.1 |                                             |  |
| 15.4.2.2 | Interlock PPG mode                          |  |
| 15.4.2.3 | The setting range of compare register       |  |
|          |                                             |  |

## 16. Serial Channel (SIO/UART)

| 16.1 Overview                                                                                           |     |
|---------------------------------------------------------------------------------------------------------|-----|
| 16.2 Difference in the Specifications of SIO Modules                                                    |     |
| 16.3 Configuration                                                                                      |     |
| 16.4 Registers Description                                                                              |     |
| 16.4.1 Registers List in Each Channel                                                                   |     |
| 16.4.2 SCxEN (Enable Register)                                                                          |     |
| 16.4.3 SCxBUF (Buffer Register)                                                                         |     |
| 16.4.4 SCxCR (Control Register)                                                                         |     |
| 16.4.5 SCxMOD0 (Mode Control Register 0)                                                                |     |
| 16.4.6 SCxMOD1 (Mode Control Register 1)                                                                |     |
| 16.4.7 SCxMOD2 (Mode Control Register 2)                                                                |     |
| 16.4.8 SCxBRCR (Baud Rate Generator Control Register), SCxBRADD (Baud Rate Generator Control Register 2 |     |
| 16.4.9 SCxFCNF (FIFO Configuration Register)                                                            |     |
| 16.4.10 SCxRFC (RX FIFO Configuration Register)                                                         | 418 |
| 16.4.11 SCxTFC (TX FIFO Configuration Register) (Note2)                                                 | 419 |
| 16.4.12 SCxRST (RX FIFO Status Register)                                                                |     |
| 16.4.13 SCxTST (TX FIFO Status Register)                                                                | 421 |
| 16.4.14 SCxDMA (DMA request enable register)                                                            | 422 |
| 16.5 Operation in Each Mode                                                                             |     |
| 16.6 Data Format                                                                                        | 424 |
| 16.6.1 Data Format List                                                                                 |     |
| 16.6.2 Parity Control                                                                                   |     |
| 16.6.2.1 Transmission                                                                                   |     |
| 16.6.2.2 Receiving Data                                                                                 |     |
| 16.6.3 STOP Bit Length                                                                                  |     |
| 16.7 Clock Control                                                                                      | 426 |
| 16.7.1 Prescaler                                                                                        |     |
| 16.7.2 Serial Clock Generation Circuit                                                                  | 430 |
| 16.7.2.1 Baud Rate Generator                                                                            |     |
| 16.7.2.2 Clock Selection Circuit                                                                        |     |
| 16.8 Transmit/Receive Buffer and FIFO                                                                   | 434 |
| 16.8.1 Configuration                                                                                    | 434 |
| 16.8.2 Transmit/Receive Buffer                                                                          | 434 |
| 16.8.3 FIFO                                                                                             | 434 |
| 16.9 Status Flag                                                                                        |     |

| 16.10 Error Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 435 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 16.10.1 OERR Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 16.10.2 PERR Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 16.10.3 FERR Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 16.11 Receive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| 16.11.1 Receive Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 16.11.2 Receive Control Unit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 16.11.2.1 I/O interface mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 16.11.2.2 UART Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| 16.11.3 Receive Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
| 16.11.3.1 Receive Buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| 16.11.3.2 Receive FIFO Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |
| 16.11.3.3 I/O interface mode with SCLK output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| 16.11.3.4 Read Received Data<br>16.11.3.5 Wake-up Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| 16.11.3.6 Overrun Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 16.12 Transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 441 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
| 16.12.1 Transmission Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 16.12.2 Transmission Control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| 16.12.2.1 I/O Interface Mode<br>16.12.2.2 UART Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| 16.12.3 Transmit Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 441 |
| 16.12.3.1 Operation of Transmission Buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| 16.12.3.2 Transmit FIFO Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 16.12.3.3 I/O interface Mode/Transmission by SCLK Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| 16.12.3.4 Under-run error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
| 16.13 Handshake function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| <ul><li>16.13 Handshake function</li><li>16.14 Interrupt/Error Generation Timing</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| 16.14 Interrupt/Error Generation Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 446 |
| 16.14 Interrupt/Error Generation Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 446 |
| 16.14         Interrupt/Error Generation Timing.           16.14.1         RX Interrupts.           16.14.1.1         Single Buffer / Double Buffer           16.14.1.2         FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |
| 16.14         Interrupt/Error Generation Timing.           16.14.1         RX Interrupts.           16.14.1.1         Single Buffer / Double Buffer           16.14.1.2         FIFO           16.14.2         TX interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.2       FIFO         16.14.2.1       Single Buffer / Double Buffer         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.3       Error Generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| <b>16.14</b> Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.3       Error Generation.         16.14.3       UART Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.3       Error Generation.         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.3       Error Generation         16.14.3       UART Mode         16.14.3.2       IO Interface Mode         16.14.5       Software Reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.2.4       FIFO         16.14.2.5       FIFO         16.14.3       Error Generation.         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.5       Software Reset.         16.16       DMA request.                                                                                                                                                                                                                                                                                                                                                       |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.2.3       FIFO         16.14.3.4       Error Generation.         16.14.3.4       UART Mode         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.5       Software Reset.         16.16       DMA request.         16.17       Operation in Each Mode.                                                                                                                                                                                                                                                                                                                                         |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.2.4       Single Buffer / Double Buffer         16.14.2.5       FIFO         16.14.2       FIFO         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.3.2       IO Interface Mode         16.15       Software Reset         16.16       DMA request         16.17       Operation in Each Mode         16.17.1       Mode 0 (I/O interface mode)                                                                                                                                                                                                        |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.2.3       FIFO         16.14.2.4       FIFO         16.14.2.5       FIFO         16.14.2.6       FIFO         16.14.2.7       FIFO         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.3.2       IO Interface Mode         16.14.3       Boffer Reset         16.16       DMA request         16.17       Operation in Each Mode         16.17.1       Mode 0 (I/O interface mode)         16.17.1.1       Transmitting Data                                                                                                                                                                |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.2.3       FIFO         16.14.2.4       FIFO         16.14.2.5       FIFO         16.14.3       Error Generation.         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.3.2       IO Interface Mode         16.15       Software Reset         16.16       DMA request.         16.17       Operation in Each Mode.         16.17.1       Transmitting Data         16.17.1.2       Receive                                                                                                                                                                                                    |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.3       Error Generation.         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.15       Software Reset.         16.16       DMA request.         16.17       Operation in Each Mode.         16.17.1       Transmiting Data         16.17.1.2       Receive         16.17.1.3       Transmit and Receive (Full-duplex)                                                                                                                                                         |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.3       Error Generation.         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.15       Software Reset.         16.16       DMA request.         16.17       Operation in Each Mode.         16.17.1       Transmiting Data         16.17.1.2       Receive         16.17.1.3       Transmit and Receive (Full-duplex)         16.17.2       Mode 1 (7-bit UART mode).                                                                    |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       TX interrupts.         16.14.2.4       Single Buffer / Double Buffer         16.14.2.5       FIFO         16.14.3       Error Generation.         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.15       Software Reset.         16.16       DMA request.         16.17       Operation in Each Mode.         16.17.1       Transmiting Data         16.17.1.2       Receive         16.17.1.3       Transmit and Receive (Full-duplex)         16.17.2       Mode 1 (7-bit UART mode).         16.17.3       Mode 2 (8-bit UART mode). |     |
| 16.14       Interrupt/Error Generation Timing.         16.14.1       RX Interrupts.         16.14.1.1       Single Buffer / Double Buffer         16.14.1.2       FIFO         16.14.2       TX interrupts.         16.14.2       TX interrupts.         16.14.2.1       Single Buffer / Double Buffer         16.14.2.2       FIFO         16.14.3       Error Generation.         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.14.3.1       UART Mode         16.14.3.2       IO Interface Mode         16.15       Software Reset.         16.16       DMA request.         16.17       Operation in Each Mode.         16.17.1       Transmiting Data         16.17.1.2       Receive         16.17.1.3       Transmit and Receive (Full-duplex)         16.17.2       Mode 1 (7-bit UART mode).                                                                    |     |

## **17.** Synchronous Serial Port (SSP)

| 17.1   | Overview                                      |  |
|--------|-----------------------------------------------|--|
| 17.2   | Block Diagram                                 |  |
|        | Register                                      |  |
| 17.3.1 | Register List                                 |  |
| 17.3.2 | SSPCR0(Control register 0)                    |  |
| 17.3.3 | SSPCR1(Control register1)                     |  |
| 17.3.4 |                                               |  |
| 17.3.5 | SSPSR(Status register)                        |  |
| 17.3.6 | SSPCPSR (Clock prescale register)             |  |
| 17.3.7 |                                               |  |
| 17.3.8 | SSPRIS (Pre-enable interrupt status register) |  |
| 17.3.9 |                                               |  |

| 17.3.10 | SSPICR (Interrupt clear register)                       | 474 |
|---------|---------------------------------------------------------|-----|
| 17.3.11 | SSPDMACR (DMA control register)                         |     |
| 17.4 C  | Dverview of SSP                                         |     |
| 17.4.1  | Clock prescaler                                         |     |
| 17.4.2  | Clock prescaler<br>Transmit FIFO                        |     |
| 17.4.3  | Receive FIFO                                            |     |
| 17.4.4  | Interrupt generation logic                              | 476 |
| 17.4.5  | DMA interface                                           |     |
| 17.5 S  | SP operation                                            |     |
| 17.5.1  | Initial setting for SSP<br>Enabling SSP<br>Clock ratios | 479 |
| 17.5.2  | Enabling SSP                                            |     |
| 17.5.3  | Clock ratios                                            | 479 |
| 17.6 F  | 'rame Format                                            |     |
| 17.6.1  | SSI frame format                                        |     |
| 17.6.2  | SPI frame format                                        |     |
| 17.6.3  | Microwire frame format                                  |     |
|         |                                                         |     |

### 18. Serial Bus Interface (I2C/SIO)

| 18.1 Configuration                                           |         |
|--------------------------------------------------------------|---------|
| 18.2 Register                                                |         |
| 18.2.1 Registers for each channel                            |         |
| 18.3 I2C Bus Mode Data Format.                               |         |
| 18.4 Control Registers in the I2C Bus Mode                   |         |
| 18.4.1 SBIxCR0(Control register 0)                           |         |
| 18.4.2 SBIxCR1(Control register 1)                           |         |
| 18.4.3 SBIxCR2(Control register 2)                           |         |
| 18.4.4 SBIxSR (Status Register)                              |         |
| 18.4.5 SBIxBR0(Serial bus interface baud rate register 0)    |         |
| 18.4.6 SBIxDBR (Serial bus interface data buffer register o) |         |
| 18.4.7 SBIxI2CAR (I2Cbus address register)                   |         |
| 18.5 Control in the I2C Bus Mode                             |         |
| 18.5.1 Serial Clock                                          |         |
| 18.5.1.1 Clock source                                        |         |
| 18.5.1.2 Clock Synchronization                               |         |
| 18.5.2 Setting the Acknowledgement Mode                      |         |
| 18.5.3 Setting the Number of Bits per Transfer               |         |
| 18.5.4 Slave Addressing and Address Recognition Mode         |         |
| 18.5.5 Operating mode                                        |         |
| 18.5.6 Configuring the SBI as a Transmitter or a Receiver    |         |
| 18.5.7 Configuring the SBI as a Master or a Slave            |         |
| 18.5.8 Generating Start and Stop Conditions                  |         |
| 18.5.9 Interrupt Service Request and Release                 |         |
| 18.5.10 Arbitration Lost Detection Monitor                   |         |
| 18.5.11 Slave Address Match Detection Monitor                |         |
| 18.5.12 General-call Detection Monitor                       |         |
| 18.5.13 Last Received Bit Monitor                            |         |
| 18.5.14 Data Buffer Register (SBIxDBR)                       |         |
| 18.5.15 Baud Rate Register (SBIxBR0)                         |         |
| 18.5.16 Software Reset                                       |         |
| 18.6 Data Transfer Procedure in the I2C Bus ModeI2C          |         |
| 18.6.1 Device Initialization                                 |         |
| 18.6.2 Generating the Start Condition and a Slave Address    |         |
| 18.6.2.1 Master mode                                         |         |
| 18.6.2.2 Slave mode                                          |         |
| 18.6.3 Transferring a Data Word                              |         |
| 18.6.3.1 Master mode ( $(MST > = "1")$ )                     |         |
| 18.6.3.2 Slave mode ( $ = "0"$ )                             | _ · · - |
| 18.6.4 Generating the Stop Condition                         |         |
| 18.6.5 Restart Procedure                                     |         |
| 18.7 Control register of SIO mode                            |         |
| 18.7.1 SBIxCR0(control register 0)                           | 514     |

| 18.7.2  | SBIxCR1(Control register 1)    |  |
|---------|--------------------------------|--|
| 18.7.3  | SBIxDBR (Data buffer register) |  |
|         | SBIxCR2(Control register 2)    |  |
| 18.7.5  | SBIxSR (Status Register).      |  |
|         | SBIxBR0 (Baud rate register 0) |  |
|         | ontrol in SIO mode             |  |
|         | Serial Clock                   |  |
| 18.8.1. | 1 Clock source                 |  |
|         | 2 Shift Edge                   |  |
| 18.8.2  | Transfer Modes                 |  |
| 18.8.2. | 1 8-bit transmit mode          |  |
| 18.8.2. | 2 8-bit receive mode           |  |
| 18.8.2. | 3 8-bit transmit/receive mode  |  |

#### 18.8.2.4 Data retention time of the last bit at the end of transmission

### **19.** Analog/Digital Converter (ADC)

| 19.1  | Outline                                                                        |  |
|-------|--------------------------------------------------------------------------------|--|
| 19.2  | Configuration                                                                  |  |
| 19.3  | Registers                                                                      |  |
| 19.3  | 0                                                                              |  |
| 19.3  |                                                                                |  |
| 19.3. |                                                                                |  |
| 19.3  |                                                                                |  |
| 19.3. |                                                                                |  |
| 19.3. |                                                                                |  |
| 19.3. |                                                                                |  |
| 19.3. | 8 ADMOD5 (Mode Control Register 5)                                             |  |
| 19.3. | 9 ADMOD6 (Mode Control Register 6)                                             |  |
| 19.3. | 10 ADMOD7 (Mode Control Register7)                                             |  |
| 19.3. |                                                                                |  |
| 19.3. | 12 ADCMPCR1 (AD Monitor Control Register 1)                                    |  |
| 19.3. | 13 ADCMP0 (AD Conversion Result Comparison Register 0)                         |  |
| 19.3. | 14 ADCMP1 (AD Conversion Result Comparison Register 1)                         |  |
| 19.3. | 15 ADREG00 to ADREG14 (Normal Conversion Result Register 00 to 14)             |  |
| 19.3. |                                                                                |  |
| 19.4  | Description of Operations.                                                     |  |
| 19.4. |                                                                                |  |
| 19.4. |                                                                                |  |
| 19    | 0.4.2.1 Normal AD Conversion                                                   |  |
| 19    | 0.4.2.2 Highest-priority AD conversion                                         |  |
| 19.4. | 3 AD Monitor Function                                                          |  |
| 19.4. | 4 Selecting the Input Channel                                                  |  |
| 19.4. | 5 AD Conversion Details                                                        |  |
| 19    | 0.4.5.1 Starting AD Conversion                                                 |  |
| - /   | 0.4.5.2 AD Conversion                                                          |  |
|       | 0.4.5.3 Highest-priority AD conversion requests during normal AD conversion    |  |
|       | 0.4.5.4 Stopping Repeat Conversion Mode                                        |  |
|       | 0.4.5.5 Reactivating normal AD conversion<br>0.4.5.6 Conversion completion     |  |
|       | 0.4.5.7 Interrupt generation timings and AD conversion result storage register |  |

## **20.** Digital/Analog Converter (DAC)

| 20.1   | Features                   |  |
|--------|----------------------------|--|
| 20.2   | Block Diagram              |  |
|        | Registers                  |  |
|        | Register List              |  |
| 20.3.2 | 2 DAxCTL(Control register) |  |
| 20.3.3 | B DAxREG(Output register)  |  |
|        | Operational Description    |  |
|        | Setting method             |  |

### 21. Flash Memory Operation

| 21.1 Flash Memory                                                                     |     |
|---------------------------------------------------------------------------------------|-----|
| 21.1.1 Features                                                                       |     |
| 21.1.2 Block Diagram of the Flash Memory Section                                      |     |
| 21.2 Operation Mode                                                                   | 565 |
| 21.2.1 Reset Operation                                                                |     |
| 21.2.1 Reset Operation                                                                |     |
| 21.2.2 Oser boot Wide (Single enip inde)                                              |     |
| 21.2.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host     |     |
| 21.2.3 Single Boot Mode                                                               |     |
| 21.2.3.1 (2-A) Using the Program in the On-Chip Boot ROM                              |     |
| 21.2.4 Configuration for Single Boot Mode                                             |     |
| 21.2.5 Memory Map                                                                     |     |
| 21.2.6 Interface specification                                                        |     |
| 21.2.7 Data Transfer Format                                                           |     |
| 21.2.8 Restrictions on internal memories                                              |     |
| 21.2.9 Transfer Format for Single Boot Mode commands                                  |     |
| 21.2.9.1 RAM Transfer                                                                 |     |
| 21.2.9.2 Chip Erase and Protect Bit Erase                                             |     |
| 21.2.10 Operation of Boot Program                                                     |     |
| 21.2.10.1 RAM Transfer Command                                                        |     |
| 21.2.10.2 Chip and Protection Bit Erase Command                                       |     |
| 21.2.10.3 Acknowledge Responses<br>21.2.10.4 Determination of a Serial Operation Mode |     |
| 21.2.10.4 Determination of a Serial Operation Mode<br>21.2.10.5 Password              |     |
| 21.210.6 Checksum Calculation                                                         |     |
| 21.2.11 General Boot Program Flowchart                                                | 597 |
| 21.3 On-board Programming of Flash Memory (Rewrite/Erase)                             |     |
| 21.3.1 Flash Memory.                                                                  |     |
| 21.3.1.1 Block Configuration                                                          |     |
| 21.3.1.2 Basic operation                                                              |     |
| 21.3.1.3 Reset (Hardware reset)                                                       |     |
| 21.3.1.4 Commands                                                                     |     |
| 21.3.1.5 Flash control/ status register                                               |     |
| 21.3.1.6 List of Command Sequences                                                    |     |
| 21.3.1.7 Address bit configuration for bus write cycles<br>21.3.1.8 Flowchart         |     |
| 21.5.1.6 Flowchaft                                                                    |     |

#### 22. ROM protection

| 22.1   | Outline                          |     |
|--------|----------------------------------|-----|
|        | Future                           |     |
| 22.2.1 | Write/ erase-protection function |     |
| 22.2.2 | Security function                |     |
|        | Register                         |     |
| 22.3.1 | FCFLCS (Flash control register)  |     |
| 22.3.2 | FCSECBIT(Security bit register)  | 616 |
| 22.4   | Writing and erasing              |     |
|        | Protection bits                  |     |
| 22.4.2 | Security bit                     | 617 |

#### 23. Debug Interface

| 23.1 | Specification Overview | 619 |
|------|------------------------|-----|
|      | SWJ-DP                 |     |
| 23.3 | ETM                    | 619 |

| 23.4   | Pin Functions                                                                                                    |  |
|--------|------------------------------------------------------------------------------------------------------------------|--|
| 23.5   | Peripheral Functions in Halt Mode                                                                                |  |
|        | Connection with a Debug Tool                                                                                     |  |
| 23.6.1 | About connection with debug tool<br>Important points of using debug interface pins used as general-purpose ports |  |

#### 24. JTAG Interface

| 24.1  | Overview                                            |  |
|-------|-----------------------------------------------------|--|
| 24.2  | Signal Summary and Connection Example               |  |
| 24.3  | What is Boundary Scan ?                             |  |
| 24.4  | JTAG Controller and Registers                       |  |
| 24.5  | Instruction Register                                |  |
| 24.6  | Boundary Scan Register                              |  |
| 24.7  | Test Access Port(TAP)                               |  |
| 24.8  | TAP Controller                                      |  |
| 24.9  | Resetting the TAP Controller                        |  |
| 24.10 | State Transitions of the TAP Controller             |  |
| 24.11 | Boundary Scan Order                                 |  |
| 24.12 | Instructions Supported by the JTAG Controller Cells |  |

## 25. Port Section Equivalent Circuit Schematic

| 25.1  | PA0 to 7,PB0 to 7                                              |     |
|-------|----------------------------------------------------------------|-----|
| 25.2  | PC0 to 7,PD0 to 6,PE0 to 7,PF1 to 7,PG0 to 7,PH0 to 6,PI0 to 7 | 637 |
| 25.3  | PJ0 to 7,PK0 to 7                                              |     |
| 25.4  | PF0                                                            |     |
| 25.5  | DA0,DA1                                                        | 638 |
| 25.6  | X1,X2                                                          | 639 |
|       | RESET,NMI                                                      |     |
| 25.8  | BSC                                                            | 639 |
| 25.9  | MODE,INTLV,ENDIAN                                              |     |
| 25.10 | FTEST3                                                         |     |
| 25.11 | AVREFH,AVREFL                                                  | 640 |

#### 26. Electrical Characteristics

| 26.1 Absolute Maximum Ratings              |  |
|--------------------------------------------|--|
| 26.2 DC Electrical Characteristics (1/3)   |  |
| 26.3 DC Electrical Characteristics (2/3)   |  |
| 26.4 DC Electrical Characteristics (3/3)   |  |
| 26.5 12-bit ADC Electrical Characteristics |  |
| 26.6 10-bit DAC Electrical Characteristics |  |
| 26.7 AC Electrical Characteristics         |  |
| 26.7.1 AC measurement condition            |  |
| 26.7.2 Serial Channel (SIO/UART)           |  |
| 26.7.2.1 I/O Interface mode                |  |
| 26.7.3 Serial Bus Interface (I2C/SIO)      |  |
| 26.7.3.1 I2C Mode                          |  |

| 26.7.3.2 Clock-Synchronous 8-Bit SIO mode                |      |
|----------------------------------------------------------|------|
| 26.7.4 Synchronous serial Interface (SSP)                | 651  |
| 26.7.4.1 AC measurement conditions                       |      |
| 26.7.4.2 SSP SPI mode (Master)                           |      |
| 26.7.4.3 SSP SPI mode (Slave)                            |      |
| 26.7.5 Event Counter                                     |      |
| 26.7.6 Capture                                           |      |
| 26.7.7 External Interrupt                                |      |
| 26.7.8 NMI                                               |      |
| 26.7.9 SCOUT Pin AC Characteristic                       |      |
| 26.7.10 Two-phase pulse input Pin AC Characteristic      |      |
| 26.7.11 High resolution PPG output Pin AC Characteristic |      |
| 26.7.12 ADTRG input Pin AC Characteristic                |      |
| 26.7.13 External bus interface AC Characteristic         |      |
| 26.7.13.1 AC measurement condition                       |      |
| 26.7.13.2 Separate Bus mode                              |      |
| 26.7.13.3 Multiplex Bus mode                             | (70) |
| 26.7.14 Debug Communication                              |      |
| 26.7.14.1 SWD Interface<br>26.7.14.2 JTAG Interface      |      |
| 26.7.14.2 JTAG Interface<br>26.7.15 ETM Trace            | 671  |
|                                                          |      |
| 26.7.16     On chip oscillator                           |      |
|                                                          |      |
|                                                          |      |
| 26.7.19 Flash Characteristics                            |      |
|                                                          | (72) |
| 26.8 Recommended Oscillation Circuit                     |      |
| 26.8.1 Ceramic oscillator                                |      |
| 26.9 Handling Precaution                                 | 674  |
| 26.9.1 Solderability                                     |      |
| 26.9.2 Power-on sequence                                 |      |
| -                                                        |      |

## 27. Package Dimensions



## TMPM341FDXBG/FYXBG

The TMPM341FDXBG/FYXBG is a 32-bit RISC microprocessor series with an ARM Cortex<sup>™</sup>-M3 microprocessor core.

| Product Name           | ROM<br>(FLASH) | RAM      | Package                |  |  |
|------------------------|----------------|----------|------------------------|--|--|
| TMPM341FDXBG 512 Kbyte |                |          |                        |  |  |
| TMPM341FYXBG           | 256 Kbyte      | 32 Kbyte | P-TFBGA113-0606-0.50A4 |  |  |

Features of the TMPM341FDXBG/FYXBG 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]

- A 32-bit multiplication  $(32 \times 32 = 32 \text{ bit})$  can be executed with one clock.
- · 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
  - a. TMPM341FDXBG
    - On chip RAM : 32 Kbyte
    - On chip Flash ROM 512 Kbyte
  - b. TMPM341FYXBG
    - On chip RAM : 32 Kbyte
    - On chip Flash ROM 256 Kbyte
- 3. External bus interface (EBIF)
  - Up to 16Mbytes access area (Program / Data)
  - External data bus (Separate / Multiplex): 8/16bit bus width

- Chip select controller: 2 channels
- 4. DMA controller (DMAC): 4 channels

Transfer can support on chip Memory / Peripheral I/O / External memory

- 5. 16-bit timer (TMRB): 10 channels
  - 16-bit interval timer mode
  - 16-bit event counter mode
  - 16-bit PPG output (can start 4-channels synchronously)
  - Input capture function
- 6. 2-phase pulse input counter functions (PHCNT): 4 channels
- High resolution PPG output functions (TMRD): 2 channels Minimum resolution: 6.25ns
- Watchdog timer (WDT): 1 channel Watchdog timer generates a reset or a non-maskable interrupt (NMI).
- Oscillation Frequency Detector (OFD): 1 channel Monitoring for external high frequency oscillator
- 10. General-purpose serial interface (SIO/UART): 5 channelsEither UART mode or synchronous mode can be selected (4byte FIFO equipped)
- 11. Serial bus interface (I2C/SIO): 2 channels

Either I2C bus mode or synchronous mode can be selected.

- 12. Synchronous Serial Port interface (SSP): 1 channel
  - · Communication protocol that includes SPI: 3 types (SPI/SSI/Microwire)
  - Baud rate: Master mode: 20Mbps (max.), Slave mode: 4.5Mbps (max.)
- 13. 12-bit AD converter (ADC): 15 channels
  - · Start up with 16-bit timer / Start up with an external trigger input
  - Fixed channel / Channel scan mode
  - Single / repeat mode
  - AD monitoring: 2ch
  - Minimum conversion time: 1µsec. (@fsys = 40MHz)
- 14. 10-bit DA converter (DAC): 2 channels
  - Built-in cutoff function of AVREFH (reduce the power consumption)
  - Settling time of input variation / output variation: 100µs
- 15. Interrupt source
  - Internal: 73 factors...The order of precedence can be set over 7 levels (except the watchdog timer interrupt).

## TOSHIBA

- External: 12 factors...The order of precedence can be set over 7 levels.
- 16. Non-maskable interrupt (NMI)

Non-maskable interrupt (NMI) is generated by a watchdog timer or a NMI pin.

17. Input/ output ports (PORT): 86 pins

Includes 5V tolerant input pin: 11 pins

- Standby mode
   Standby modes: IDLE, STOP1, STOP2
- 19. Clock generator (CG)
  - On-chip PLL (8× or 16× selectable)
  - Clock gear function: The high-speed clock can be divided into 1/1, 1/2, 1/4, 1/8 or 1/16.

#### 20. Endian

Little-Endian or Big-Endian can be selectable

#### 21. Debug interface

JTAG / SWD / SWV / TRACE (DATA 4bit)

22. JTAG interface

Boundary scan

23. Maximum operating frequency: 54 MHz

#### 24. Operating voltage range

- DVDD3A = 2.7 V to 3.6 V
- DVDD3B = 1.65 V to 3.6 V
- AVDD3 = 2.7 V to 3.6 V
- 25. Temperature range
  - -40 to 85 degrees (except during Flash writing/ erasing)
  - 0 to 70 degrees (during Flash writing/ erasing)
- 26. Package

P-TFBGA113-0606-0.50A4 (6mm × 6mm, 0.5mm pitch)

## 1.2 Block Diagram



Figure 1-1 TMPM341FDXBG/FYXBGBlock Diagram

## 1.3 Pin Layout (Top view)

Figure 1-2 shows the pin layout of TMPM341FDXBG/FYXBG.

| A1 | A2 | A3 | A4 | A5 | A6 | A7 | A8 | A9 | A10 | A11 |
|----|----|----|----|----|----|----|----|----|-----|-----|
| B1 | B2 | B3 | B4 | B5 | B6 | B7 | B8 | B9 | B10 | B11 |
| C1 | C2 | C3 | C4 | C5 | C6 | C7 | C8 | C9 | C10 | C11 |
| D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | D10 | D11 |
| E1 | E2 | E3 | E4 | E5 |    |    | E8 | E9 | E10 | E11 |
| F1 | F2 | F3 | F4 | -  | _  | _  | F8 | F9 | F10 | F11 |
| G1 | G2 | G3 | G4 |    |    |    | G8 | G9 | G10 | G11 |
| H1 | H2 | H3 | H4 | H5 | H6 | H7 | H8 | H9 | H10 | H11 |
| J1 | J2 | J3 | J4 | J5 | J6 | J7 | J8 | J9 | J10 | J11 |
| K1 | K2 | K3 | K4 | K5 | K6 | K7 | K8 | K9 | K10 | K11 |
| L1 | L2 | L3 | L4 | L5 | L6 | L7 | L8 | L9 | L10 | L11 |

## 1.4 Pin names and Functions

Table 1-1 and Table 1-2 sort the input and output pins of the TMPM341FDXBG/FYXBG by pin or port. Each table includes alternate pin names and functions for multi-function pins.

### 1.4.1 Sorted by Pin

| Туре               | Pin<br>No. | Pin Name                       | Input/<br>Out-<br>put | Function                                                                                    |
|--------------------|------------|--------------------------------|-----------------------|---------------------------------------------------------------------------------------------|
| Control            | A1         | ENDIAN                         | I                     | Little Endian operation: Fixed DVSSA<br>Big Endian operation: Fixed DVDD3A                  |
| Function           | A2         | PK4<br>AIN12                   | I/O<br>I              | I/O port<br>Analog input                                                                    |
| Function           | A3         | PJ7<br>AIN07<br>INT9<br>TB0IN1 | I/O<br>I<br>I<br>I    | I/O port<br>Analog input<br>External interrupt pin<br>Inputting the timer B capture trigger |
| Function           | A4         | PJ3<br>AIN03<br>PHC1IN1        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |
| PS                 | A5         | DVDD3A                         | -                     | Power supply pin                                                                            |
| Function           | A6         | NMI                            | I                     | Non-maskable interrupt<br>(note) With a noise filter (about 30ns (typical value))           |
| Clock              | A7         | X1/EHCLKIN                     | I                     | Connected to a high-speed oscillator/ External clock input pin                              |
| PS                 | A8         | DVSSC                          | -                     | GND pin                                                                                     |
| Clock              | A9         | X2                             | 0                     | Connected to a high-speed oscillator.                                                       |
| Function/<br>Debug | A10        | PI5<br>TCK/SWCLK               | I/O<br>I              | I/O port<br>Debug pin                                                                       |
| Function/<br>Debug | A11        | PH5<br>TRACEDA-<br>TA3         | I/O<br>O              | I/O port<br>Debug pin                                                                       |
| Function           | B1         | PK6<br>AIN14                   | I/O<br>I              | I/O port<br>Analog input                                                                    |
| Function           | B2         | PK5<br>AIN13                   | I/O<br>I              | I/O port<br>Analog input                                                                    |
| Function           | В3         | PK0<br>AIN08<br>TB1IN0         | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the timer B capture trigger                           |
| Function           | B4         | PJ4<br>AIN04<br>PHC2IN0        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |
| Function           | B5         | PJ0<br>AIN00<br>PHC0IN0        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |
| Function           | B6         | RESET                          | I                     | Reset input pin<br>(note) With a pull-up and a noise filter (about 30ns (typical value))    |

Table 1-1 Pin Names and Functions Sorted by Pin (2/8)

| Туре               | Pin<br>No. | Pin Name                       | Input/<br>Out-<br>put | Function                                                                                                                                                            |
|--------------------|------------|--------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function           | В7         | PH3<br>PHC3IN0<br>TB4OUT       | I/O<br>I<br>O         | I/O port<br>Inputting the capture trigger of two-phase pulse count timer<br>Timer B output                                                                          |
| PS                 | B8         | RVSS                           | -                     | GND pin for internal ragulator                                                                                                                                      |
| PS                 | В9         | RVDD3                          | -                     | Power supply pin for internal regulator                                                                                                                             |
| Function/<br>Debug | B10        | PI4<br>TDI                     | I/O<br>I              | I/O port<br>Debug pin                                                                                                                                               |
| Function/<br>Debug | B11        | PH6<br>TRACEDA-<br>TA2         | I/O<br>O              | I/O port<br>Debug pin                                                                                                                                               |
| PS                 | C1         | AVDD3                          | I                     | Supplying the A/D and D/A converters with a power supply.<br>(note) AVDD3 must be connected to power supply even if A/D and D/A converters are not used.            |
| PS                 | C2         | AVREFH                         | I                     | Supplying the A/D and D/A converters with a reference power supply.<br>(note) AVREFH must be connected to power supply even if A/D and D/A converters are not used. |
| Function           | C3         | PK1<br>AIN09<br>INTA<br>TB1IN1 | I/O<br>I<br>I<br>I    | I/O port<br>Analog input<br>External interrupt pin<br>Inputting the timer B capture trigger                                                                         |
| Function           | C4         | PJ5<br>AIN05<br>PHC2IN1        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer                                                                            |
| Function           | C5         | PJ1<br>AIN01<br>PHC0IN1        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer                                                                            |
| Control            | C6         | MODE                           | I                     | Mode pin:<br>(note) MODE pin must be connected to GND.                                                                                                              |
| Function           | C7         | PH4<br>PHC3IN1<br>TB5OUT       | I/O<br>I<br>O         | I/O port<br>Inputting the capture trigger of two-phase pulse count timer<br>Timer B output                                                                          |
| Function           | C8         | PH0<br>TXD4                    | 1/O<br>O              | I/O port with 5V tolerant input<br>Sending serial data                                                                                                              |
| Function/<br>Debug | C9         | PI7<br>TDO/SWV                 | 1/O<br>O              | I/O port<br>Debug pin                                                                                                                                               |
| Function/<br>Debug | C10        | PI6<br>TMS/SWDIO               | I/O<br>I/O            | I/O port<br>Debug pin                                                                                                                                               |
| PS                 | C11        | DVDD3A                         | -                     | Power supply pin                                                                                                                                                    |
| PS                 | D1         | AVSS                           | I                     | Supplying the A/D and D/A converters with a power supply.<br>(note) AVSS must be connected to GND even if A/D and D/A converters are not used.                      |
| PS                 | D2         | AVREFL                         | I                     | Supplying the A/D and D/A converters with a reference GND.<br>(note) AVREFL must be connected to GND even if A/D and D/A converters are not used.                   |

| Туре               | Pin<br>No. | Pin Name                       | Input/<br>Out-<br>put | Function                                                                                                                      |
|--------------------|------------|--------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Function           | D3         | PK2<br>AIN10<br>TB6IN0         | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the timer B capture trigger                                                             |
| Function           | D4         | PJ6<br>AIN06<br>TB0IN0         | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the timer B capture trigger                                                             |
| Function           | D5         | PJ2<br>AIN02<br>PHC1IN0        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer                                      |
| Function           | D6         | PG7<br>INT1<br>TB9IN1          | I/O<br>I<br>I         | I/O port with 5V tolerant input<br>External interrupt pin<br>Inputting the timer B capture trigger                            |
| Function           | D7         | PG6<br>SCLK3<br>TB9IN0<br>CTS3 | I/O<br>I/O<br>I<br>I  | I/O port with 5V tolerant input<br>Serial clock input/ output<br>Inputting the timer B capture trigger<br>Handshake input pin |
| Function           | D8         | PH1<br>RXD4                    | I/O<br>I              | I/O port with 5V tolerant input<br>Receiving serial data                                                                      |
| Function/<br>Debug | D9         | PI2<br>TRACECLK                | 1/O<br>O              | I/O port<br>Debug pin                                                                                                         |
| Function/<br>Debug | D10        | PI3<br>TRST                    | I/O<br>I              | I/O port<br>Debug pin                                                                                                         |
| PS                 | D11        | DVSSA                          | -                     | GND pin                                                                                                                       |
| PS                 | E1         | DVSSB                          | -                     | GND pin                                                                                                                       |
| PS                 | E2         | DVDD3B                         | -                     | Power supply pin                                                                                                              |
| Function           | E3         | PK3<br>AIN11<br>INTB<br>TB6IN1 | I/O<br>I<br>I<br>I    | I/O port<br>Analog input<br>External interrupt pin<br>Inputting the timer B capture trigger                                   |
| Function           | E4         | DA0                            | 0                     | Analog output                                                                                                                 |
| Function           | E5         | DA1                            | 0                     | Analog output                                                                                                                 |
| Function           | E8         | PH2<br>SCLK4<br>CTS4           | I/O<br>I/O<br>I       | I/O port with 5V tolerant input<br>Serial clock input/ output<br>Handshake input pin                                          |
| Function           | E9         | PG5<br>RXD3<br>TB8IN1          | I/O<br>I<br>I         | I/O port with 5V tolerant input<br>Receiving serial data<br>Inputting the timer B capture trigger                             |
| Function/<br>Debug | E10        | PI1<br>TRACEDA-<br>TA0         | I/O<br>O              | I/O port<br>Debug pin                                                                                                         |
| PS                 | E11        | DVSSB                          | -                     | GND pin                                                                                                                       |

#### Table 1-1 Pin Names and Functions Sorted by Pin (4/8)

| Туре                 | Pin<br>No. | Pin Name                     | Input/<br>Out-<br>put | Function                                                                                                                                          |
|----------------------|------------|------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Function             | F1         | PA0<br>D0/AD0                | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                                                                                                             |
| Function/<br>Control | F2         | PF0<br>BOOT<br>TB6OUT        | 0<br>I<br>0           | I/O port<br>Setting a single boot mode:<br>This pin goes into single boot mode by sampling "Low" at the rise of a RESET signal.<br>Timer B output |
| Function             | F3         | PF1<br>RD                    | I/O<br>O              | I/O port<br>Read strobe signal                                                                                                                    |
| Control              | F4         | INTLV                        | 1                     | Interleave control pin (Refer to Clock/Mode control chapter)<br>If fc > 40MHz, connect with pull-up. If fc ≤ 40MHz, connect with pull-down.       |
| Function             | F8         | PG4<br>TXD3<br>TB8IN0        | 1/O<br>O<br>I         | I/O port with 5V tolerant input<br>Sending serial data<br>Inputting the timer B capture trigger                                                   |
| Function             | F9         | PG3<br>INT0                  | I/O<br>I              | I/O port with 5V tolerant input<br>External interrupt pin                                                                                         |
| Function/<br>Debug   | F10        | PI0<br>TRACEDA-<br>TA1       | 1/O<br>O              | I/O port<br>Debug pin                                                                                                                             |
| PS                   | F11        | DVDD3B                       | -                     | Power supply pin                                                                                                                                  |
| Function             | G1         | PA1<br>D1/AD1                | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                                                                                                             |
| Function             | G2         | PA2<br>D2/AD2                | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                                                                                                             |
| Function             | G3         | PF3<br>BELL                  | I/O<br>O              | I/O port<br>Byte enable signal as an external 8-bit memory access                                                                                 |
| Function             | G4         | PF2<br>WR                    | I/O<br>O              | I/O port<br>Write strobe signal                                                                                                                   |
| Function             | G8         | PG2<br>SCK0<br>INT8          | I/O<br>I/O<br>I       | I/O port with 5V tolerant input<br>Inputting and outputting a clock if the serial bus interface operates in SIO mode<br>External interrupt pin    |
| Function             | G9         | PG1<br>SI0/SCL0<br>TB7IN1    | 1/0<br>1/0<br>1       | I/O port with 5V tolerant input<br>Data pin in SIO mode, Clock pin in I2C mode<br>Inputting the timer B capture trigger                           |
| Function             | G10        | PD7<br>A15<br>SPFSS<br>SCOUT | 1/0<br>0<br>1/0<br>0  | I/O port<br>Address bus<br>SPI FSS input/ output<br>System clock output                                                                           |
| Function             | G11        | PD6<br>A14<br>SPCLK          | 1/O<br>O<br>1/O       | I/O port<br>Address bus<br>SPI clock input/ output                                                                                                |
| Function             | H1         | PA3<br>D3/AD3                | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                                                                                                             |

| Table 1-1 | Pin | Names    | and | Functions | Sorted | by P | in (5/8) |
|-----------|-----|----------|-----|-----------|--------|------|----------|
|           | гш  | INAILIES | anu | Functions | Solieu | υуг  | 11 (5/6) |

| Туре     | Pin<br>No. | Pin Name                             | Input/<br>Out-<br>put     | Function                                                                                                                              |
|----------|------------|--------------------------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Function | H2         | PA4<br>D4/AD4                        | I/O<br>I/O                | I/O port<br>Data bus/Address data bus                                                                                                 |
| Function | H3         | PF4<br>BELH<br>INT6<br>TB5IN0        | I/O<br>O<br>I<br>I        | I/O port<br>Byte enable signal as an external 16-bit memory access<br>External interrupt pin<br>Inputting the timer B capture trigger |
| Function | H4         | PF5<br>CS1<br>INT7<br>TB5IN1         | I/O<br>O<br>I<br>I        | I/O port<br>Chip select output<br>External interrupt pin<br>Inputting the timer B capture trigger                                     |
| Function | H5         | PC1<br>A1<br>RXD1<br>TB2IN1          | I/O<br>O<br>I<br>I        | I/O port<br>Address bus<br>Receiving serial data<br>Inputting the timer B capture trigger                                             |
| Function | H6         | PC3<br>A3<br>INT2<br>TB1OUT          | I/O<br>O<br>I<br>O        | I/O port<br>Address bus<br>External interrupt pin<br>Timer B output                                                                   |
| Function | H7         | PC6<br>A6<br>SCLK2<br>TB4IN0<br>CTS2 | I/O<br>O<br>I/O<br>I<br>I | I/O port<br>Address bus<br>Serial clock input/ output<br>Inputting the timer B capture trigger<br>Handshake input pin                 |
| Function | H8         | PC7<br>A7<br>INT3<br>TB4IN1          | I/O<br>O<br>I<br>I        | I/O port<br>Address bus<br>External interrupt pin<br>Inputting the timer B capture trigger                                            |
| Function | H9         | PG0<br>SO0/SDA0<br>TB7IN0            | I/O<br>I/O<br>I           | I/O port with 5V tolerant input<br>Data pin in SIO mode, Data pin in I2C mode<br>Inputting the timer B capture trigger                |
| Function | H10        | PD5<br>A13<br>SPDI                   | I/O<br>O<br>I             | I/O port<br>Address bus<br>SPI DI input                                                                                               |
| Function | H11        | PD4<br>A12<br>SPDO                   | I/O<br>O<br>O             | I/O port<br>Address bus<br>SPI DO output                                                                                              |
| Function | J1         | PA5<br>D5/AD5                        | I/O<br>I/O                | I/O port<br>Data bus/Address data bus                                                                                                 |
| Function | J2         | PA6<br>D6/AD6                        | I/O<br>I/O                | I/O port<br>Data bus/Address data bus                                                                                                 |
| Function | J3         | PF6<br>CS0                           | I/O<br>O                  | I/O port<br>Chip select output                                                                                                        |

| Table 1-1 | Pin Names and | Functions | Sorted by Pin (6/8) |
|-----------|---------------|-----------|---------------------|
|-----------|---------------|-----------|---------------------|

| Туре     | Pin<br>No. | Pin Name                              | Input/<br>Out-<br>put     | Function                                                                                                                       |
|----------|------------|---------------------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Function | J4         | PF7<br>ALE                            | I/O<br>O                  | I/O port<br>Address latch enable (output disable for noise-reduction can be selectable)                                        |
| Function | J5         | PC0<br>A0<br>TXD1<br>TB2IN0           | I/O<br>O<br>O<br>I        | I/O port<br>Address bus<br>Sending serial data<br>Inputting the timer B capture trigger                                        |
| Function | J6         | PC2<br>A2<br>SCLK1<br>TB0OUT<br>CTS1  | I/O<br>O<br>I/O<br>O<br>I | I/O port<br>Address bus<br>Serial clock input/ output<br>Timer B output<br>Handshake input pin                                 |
| Function | J7         | PC5<br>A5<br>RXD2<br>TB3IN1           | I/O<br>O<br>I<br>I        | I/O port<br>Address bus<br>Receiving serial data<br>Inputting the timer B capture trigger                                      |
| Function | J8         | PE0<br>TXD0<br>A16                    | I/O<br>O<br>O             | I/O port<br>Sending serial data<br>Address bus                                                                                 |
| Function | Jð         | PE2<br>SCLK0<br>A18<br>TB2OUT<br>CTS0 | I/O<br>I/O<br>O<br>I      | I/O port<br>Serial clock input/ output<br>Address bus<br>Timer B output<br>Handshake input pin                                 |
| Function | J10        | PD3<br>A11<br>INT4<br>ADTRG           | I/O<br>O<br>I<br>I        | I/O port<br>Address bus<br>External interrupt pin<br>A/D trigger input                                                         |
| Function | J11        | PD2<br>A10<br>SCK1<br>TB9OUT          | 1/O<br>O<br>1/O<br>O      | I/O port<br>Address bus<br>Inputting and outputting a clock if the serial bus interface operates in SIO mode<br>Timer B output |
| Function | K1         | PA7<br>D7/AD7                         | 1/O<br>1/O                | I/O port<br>Data bus/Address data bus                                                                                          |
| Function | К2         | PB1<br>D9/AD9<br>A1                   | I/O<br>I/O<br>O           | I/O port<br>Data bus/Address data bus<br>Address bus                                                                           |
| Function | КЗ         | PB3<br>D11/AD11<br>A3                 | I/O<br>I/O<br>O           | I/O port<br>Data bus/Address data bus<br>Address bus                                                                           |
| Function | K4         | PB5<br>D13/AD13<br>A5                 | I/O<br>I/O<br>O           | I/O port<br>Data bus/Address data bus<br>Address bus                                                                           |

| Туре     | Pin<br>No. | Pin Name                        | Input/<br>Out-<br>put | Function                                                                                                 |
|----------|------------|---------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------|
| Function | К5         | PB7<br>D15/AD15<br>A7           | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus                                                     |
| PS       | K6         | DVDD3B                          | -                     | Power supply pin                                                                                         |
| Function | К7         | PC4<br>A4<br>TXD2<br>TB3IN0     | I/O<br>O<br>O<br>I    | I/O port<br>Address bus<br>Sending serial data<br>Inputting the timer B capture trigger                  |
| Function | K8         | PE1<br>RXD0<br>A17              | I/O<br>I<br>O         | I/O port<br>Receiving serial data<br>Address bus                                                         |
| Function | K9         | PE3<br>INT5<br>A19<br>TB3OUT    | I/O<br>I<br>O<br>O    | I/O port<br>External interrupt pin<br>Address bus<br>Timer B output                                      |
| Function | K10        | PD1<br>A9<br>SI1/SCL1<br>TB8OUT | I/O<br>O<br>I/O<br>O  | I/O port<br>Address bus<br>Data pin in SIO mode, Clock pin in I2C mode<br>Timer B output                 |
| Function | K11        | PD0<br>A8<br>SO1/SDA1<br>TB7OUT | I/O<br>O<br>I/O<br>O  | I/O port<br>Address bus<br>Data pin in SIO mode, Data pin in I2C mode<br>Timer B output                  |
| Control  | L1         | BSC                             | I                     | JTAG Boundary scan control pin<br>(note) BSC must be connected to GND even if boundary scan is not used. |
| Function | L2         | PB0<br>D8/AD8<br>A0             | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus                                                     |
| Function | L3         | PB2<br>D10/AD10<br>A2           | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus                                                     |
| Function | L4         | PB4<br>D12/AD12<br>A4           | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus                                                     |
| Function | L5         | PB6<br>D14/AD14<br>A6           | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus                                                     |
| PS       | L6         | DVSSB                           | -                     | GND pin                                                                                                  |
| Function | L7         | PE4<br>A20<br>TD0OUT0           | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output                                                                |

| Туре     | Pin<br>No. | Pin Name              | Input/<br>Out-<br>put | Function                                        |
|----------|------------|-----------------------|-----------------------|-------------------------------------------------|
| Function | L8         | PE5<br>A21<br>TD0OUT1 | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output       |
| Function | L9         | PE6<br>A22<br>TD1OUT0 | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output       |
| Function | L10        | PE7<br>A23<br>TD1OUT1 | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output       |
| Control  | L11        | FTEST3                | -                     | TEST pin:<br>(note) TEST pin must be left OPEN. |

## Table 1-1 Pin Names and Functions Sorted by Pin (8/8)

# 1.4.2 Sorted by Port

## Table 1-2 Pin Names and Functions Sorted by Port (1/8)

| PORT   | Туре     | Pin<br>No. | Pin Name              | Input/<br>Out-<br>put | Function                                             |
|--------|----------|------------|-----------------------|-----------------------|------------------------------------------------------|
| PORT A | Function | F1         | PA0<br>D0/AD0         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT A | Function | G1         | PA1<br>D1/AD1         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT A | Function | G2         | PA2<br>D2/AD2         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT A | Function | H1         | PA3<br>D3/AD3         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT A | Function | H2         | PA4<br>D4/AD4         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT A | Function | J1         | PA5<br>D5/AD5         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT A | Function | J2         | PA6<br>D6/AD6         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT A | Function | К1         | PA7<br>D7/AD7         | I/O<br>I/O            | I/O port<br>Data bus/Address data bus                |
| PORT B | Function | L2         | PB0<br>D8/AD8<br>A0   | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |
| PORT B | Function | К2         | PB1<br>D9/AD9<br>A1   | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |
| PORT B | Function | L3         | PB2<br>D10/AD10<br>A2 | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |
| PORT B | Function | КЗ         | PB3<br>D11/AD11<br>A3 | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |
| PORT B | Function | L4         | PB4<br>D12/AD12<br>A4 | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |
| PORT B | Function | К4         | PB5<br>D13/AD13<br>A5 | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |
| PORT B | Function | L5         | PB6<br>D14/AD14<br>A6 | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |
| PORT B | Function | К5         | PB7<br>D15/AD15<br>A7 | I/O<br>I/O<br>O       | I/O port<br>Data bus/Address data bus<br>Address bus |

## Table 1-2 Pin Names and Functions Sorted by Port (2/8)

| PORT   | Туре     | Pin<br>No. | Pin Name                             | Input/<br>Out-<br>put     | Function                                                                                                              |  |  |
|--------|----------|------------|--------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|
| PORT C | Function | J5         | PC0<br>A0<br>TXD1<br>TB2IN0          | I/O<br>O<br>O<br>I        | I/O port<br>Address bus<br>Sending serial data<br>Inputting the timer B capture trigger                               |  |  |
| PORT C | Function | H5         | PC1<br>A1<br>RXD1<br>TB2IN1          | I/O<br>O<br>I<br>I        | I/O port<br>Address bus<br>Receiving serial data<br>Inputting the timer B capture trigger                             |  |  |
| PORT C | Function | J6         | PC2<br>A2<br>SCLK1<br>TB0OUT<br>CTS1 | I/O<br>O<br>I/O<br>O<br>I | I/O port<br>Address bus<br>Serial clock input/ output<br>Timer B output<br>Handshake input pin                        |  |  |
| PORT C | Function | H6         | PC3<br>A3<br>INT2<br>TB1OUT          | I/O<br>O<br>I<br>O        | I/O port<br>Address bus<br>External interrupt pin<br>Timer B output                                                   |  |  |
| PORT C | Function | К7         | PC4<br>A4<br>TXD2<br>TB3IN0          | I/O<br>O<br>O<br>I        | I/O port<br>Address bus<br>Sending serial data<br>Inputting the timer B capture trigger                               |  |  |
| PORT C | Function | J7         | PC5<br>A5<br>RXD2<br>TB3IN1          | I/O<br>O<br>I<br>I        | I/O port<br>Address bus<br>Receiving serial data<br>Inputting the timer B capture trigger                             |  |  |
| PORT C | Function | H7         | PC6<br>A6<br>SCLK2<br>TB4IN0<br>CTS2 | I/O<br>O<br>I/O<br>I<br>I | I/O port<br>Address bus<br>Serial clock input/ output<br>Inputting the timer B capture trigger<br>Handshake input pin |  |  |
| PORT C | Function | H8         | PC7<br>A7<br>INT3<br>TB4IN1          | I/O<br>O<br>I<br>I        | I/O port<br>Address bus<br>External interrupt pin<br>Inputting the timer B capture trigger                            |  |  |
| PORT D | Function | K11        | PD0<br>A8<br>SO1/SDA1<br>TB7OUT      | I/O<br>O<br>I/O<br>O      | I/O port<br>Address bus<br>Data pin in SIO mode, Data pin in I2C mode<br>Timer B output                               |  |  |
| PORT D | Function | K10        | PD1<br>A9<br>SI1/SCL1<br>TB8OUT      | I/O<br>O<br>I/O<br>O      | I/O port<br>Address bus<br>Data pin in SIO mode, Clock pin in I2C mode<br>Timer B output                              |  |  |

| Table 1-2 Pin | Names and  | Functions  | Sorted by | / Port ( | (3/8) |  |
|---------------|------------|------------|-----------|----------|-------|--|
|               | runnoo unu | i anotiono |           |          | (0,0) |  |

| PORT   | Туре     | Pin<br>No. | Pin Name                              | Input/<br>Out-<br>put | Function                                                                                                                       |  |
|--------|----------|------------|---------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|--|
| PORT D | Function | J11        | PD2<br>A10<br>SCK1<br>TB9OUT          | I/O<br>O<br>I/O<br>O  | I/O port<br>Address bus<br>Inputting and outputting a clock if the serial bus interface operates in SIO mode<br>Timer B output |  |
| PORT D | Function | J10        | PD3<br>A11<br>INT4<br>ADTRG           | I/O<br>O<br>I<br>I    | I/O port<br>Address bus<br>External interrupt pin<br>A/D trigger input                                                         |  |
| PORT D | Function | H11        | PD4<br>A12<br>SPDO                    | I/O<br>O<br>O         | I/O port<br>Address bus<br>SPI DO output                                                                                       |  |
| PORT D | Function | H10        | PD5<br>A13<br>SPDI                    | I/O<br>O<br>I         | I/O port<br>Address bus<br>SPI DI input                                                                                        |  |
| PORT D | Function | G11        | PD6<br>A14<br>SPCLK                   | I/O<br>O<br>I/O       | I/O port<br>Address bus<br>SPI clock input/ output                                                                             |  |
| PORT D | Function | G10        | PD7<br>A15<br>SPFSS<br>SCOUT          | 1/O<br>O<br>1/O<br>O  | I/O port<br>Address bus<br>SPI FSS input/ output<br>System clock output                                                        |  |
| PORT E | Function | J8         | PE0<br>TXD0<br>A16                    | I/O<br>O<br>O         | I/O port<br>Sending serial data<br>Address bus                                                                                 |  |
| PORT E | Function | К8         | PE1<br>RXD0<br>A17                    | I/O<br>I<br>O         | I/O port<br>Receiving serial data<br>Address bus                                                                               |  |
| PORT E | Function | Jð         | PE2<br>SCLK0<br>A18<br>TB2OUT<br>CTS0 | I/O<br>I/O<br>O<br>I  | I/O port<br>Serial clock input/ output<br>Address bus<br>Timer B output<br>Handshake input pin                                 |  |
| PORT E | Function | К9         | PE3<br>INT5<br>A19<br>TB3OUT          | I/O<br>I<br>O<br>O    | I/O port<br>External interrupt pin<br>Address bus<br>Timer B output                                                            |  |
| PORT E | Function | L7         | PE4<br>A20<br>TD0OUT0                 | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output                                                                                      |  |
| PORT E | Function | L8         | PE5<br>A21<br>TD0OUT1                 | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output                                                                                      |  |

## Table 1-2 Pin Names and Functions Sorted by Port (4/8)

| PORT   | Туре                 | Pin<br>No. | Pin Name                      | Input/<br>Out-<br>put | Function                                                                                                                                          |  |
|--------|----------------------|------------|-------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PORT E | Function             | L9         | PE6<br>A22<br>TD1OUT0         | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output                                                                                                         |  |
| PORT E | Function             | L10        | PE7<br>A23<br>TD1OUT1         | I/O<br>O<br>O         | I/O port<br>Address bus<br>Timer D output                                                                                                         |  |
| PORT F | Function/<br>Control | F2         | PF0<br>BOOT<br>TB6OUT         | 0<br>I<br>O           | I/O port<br>Setting a single boot mode:<br>This pin goes into single boot mode by sampling "Low" at the rise of a RESET signal.<br>Timer B output |  |
| PORT F | Function             | F3         | PF1<br>RD                     | 1/O<br>O              | I/O port<br>Read strobe signal                                                                                                                    |  |
| PORT F | Function             | G4         | PF2<br>WR                     | 1/O<br>O              | I/O port<br>Write strobe signal                                                                                                                   |  |
| PORT F | Function             | G3         | PF3<br>BELL                   | 1/O<br>O              | I/O port<br>Byte enable signal as an external 8-bit memory access                                                                                 |  |
| PORT F | Function             | H3         | PF4<br>BELH<br>INT6<br>TB5IN0 | I/O<br>O<br>I<br>I    | I/O port<br>Byte enable signal as an external 16-bit memory access<br>External interrupt pin<br>Inputting the timer B capture trigger             |  |
| PORT F | Function             | H4         | PF5<br>CS1<br>INT7<br>TB5IN1  | I/O<br>O<br>I<br>I    | I/O port<br>Chip select output<br>External interrupt pin<br>Inputting the timer B capture trigger                                                 |  |
| PORT F | Function             | J3         | PF6<br>CS0                    | 1/O<br>O              | I/O port<br>Chip select output                                                                                                                    |  |
| PORT F | Function             | J4         | PF7<br>ALE                    | 1/O<br>O              | I/O port<br>Address latch enable (output disable for noise-reduction can be selectable)                                                           |  |
| PORT G | Function             | H9         | PG0<br>SO0/SDA0<br>TB7IN0     | I/O<br>I/O<br>I       | I/O port with 5V tolerant input<br>Data pin in SIO mode, Data pin in I2C mode<br>Inputting the timer B capture trigger                            |  |
| PORT G | Function             | G9         | PG1<br>SI0/SCL0<br>TB7IN1     | I/O<br>I/O<br>I       | I/O port with 5V tolerant input<br>Data pin in SIO mode, Clock pin in I2C mode<br>Inputting the timer B capture trigger                           |  |
| PORT G | Function             | G8         | PG2<br>SCK0<br>INT8           | I/O<br>I/O<br>I       | I/O port with 5V tolerant input<br>Inputting and outputting a clock if the serial bus interface operates in SIO mode<br>External interrupt pin    |  |
| PORT G | Function             | F9         | PG3<br>INT0                   | I/O<br>I              | I/O port with 5V tolerant input<br>External interrupt pin                                                                                         |  |
| PORT G | Function             | F8         | PG4<br>TXD3<br>TB8IN0         | I/O<br>O<br>I         | I/O port with 5V tolerant input<br>Sending serial data<br>Inputting the timer B capture trigger                                                   |  |

| PORT   | Туре               | Pin<br>No. | Pin Name                       | Input/<br>Out-<br>put | Function                                                                                                                      |  |
|--------|--------------------|------------|--------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------|--|
| PORT G | Function           | E9         | PG5<br>RXD3<br>TB8IN1          | I/O<br>I<br>I         | I/O port with 5V tolerant input<br>Receiving serial data<br>Inputting the timer B capture trigger                             |  |
| PORT G | Function           | D7         | PG6<br>SCLK3<br>TB9IN0<br>CTS3 | I/O<br>I/O<br>I<br>I  | I/O port with 5V tolerant input<br>Serial clock input/ output<br>Inputting the timer B capture trigger<br>Handshake input pin |  |
| PORT G | Function           | D6         | PG7<br>INT1<br>TB9IN1          | I/O<br>I<br>I         | I/O port with 5V tolerant input<br>External interrupt pin<br>Inputting the timer B capture trigger                            |  |
| PORT H | Function           | C8         | PH0<br>TXD4                    | 1/O<br>O              | I/O port with 5V tolerant input<br>Sending serial data                                                                        |  |
| PORT H | Function           | D8         | PH1<br>RXD4                    | 1/O<br>1              | I/O port with 5V tolerant input<br>Receiving serial data                                                                      |  |
| PORT H | Function           | E8         | PH2<br>SCLK4<br>CTS4           | I/O<br>I/O<br>I       | I/O port with 5V tolerant input<br>Serial clock input/ output<br>Handshake input pin                                          |  |
| PORT H | Function           | В7         | PH3<br>PHC3IN0<br>TB4OUT       | I/O<br>I<br>O         | I/O port<br>Inputting the capture trigger of two-phase pulse count timer<br>Timer B output                                    |  |
| PORT H | Function           | C7         | PH4<br>PHC3IN1<br>TB5OUT       | I/O<br>I<br>O         | I/O port<br>Inputting the capture trigger of two-phase pulse count timer<br>Timer B output                                    |  |
| PORT H | Function/<br>Debug | A11        | PH5<br>TRACEDA-<br>TA3         | I/O<br>O              | I/O port<br>Debug pin                                                                                                         |  |
| PORT H | Function/<br>Debug | B11        | PH6<br>TRACEDA-<br>TA2         | I/O<br>O              | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | F10        | PI0<br>TRACEDA-<br>TA1         | I/O<br>O              | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | E10        | PI1<br>TRACEDA-<br>TA0         | I/O<br>O              | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | D9         | PI2<br>TRACECLK                | 1/O<br>O              | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | D10        | PI3<br>TRST                    | I/O<br>I              | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | B10        | Pl4<br>TDI                     | I/O<br>I              | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | A10        | PI5<br>TCK/SWCLK               | I/O<br>I              | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | C10        | PI6<br>TMS/SWDIO               | 1/O<br>1/O            | I/O port<br>Debug pin                                                                                                         |  |
| PORT I | Function/<br>Debug | C9         | PI7<br>TDO/SWV                 | 1/O<br>O              | I/O port<br>Debug pin                                                                                                         |  |

## Table 1-2 Pin Names and Functions Sorted by Port (6/8)

| PORT   | Туре     | Pin<br>No. | Pin Name                       | Input/<br>Out-<br>put | Function                                                                                    |  |
|--------|----------|------------|--------------------------------|-----------------------|---------------------------------------------------------------------------------------------|--|
| PORT J | Function | B5         | PJ0<br>AIN00<br>PHC0IN0        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |  |
| PORT J | Function | C5         | PJ1<br>AIN01<br>PHC0IN1        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |  |
| PORT J | Function | D5         | PJ2<br>AIN02<br>PHC1IN0        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |  |
| PORT J | Function | A4         | PJ3<br>AIN03<br>PHC1IN1        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |  |
| PORT J | Function | B4         | PJ4<br>AIN04<br>PHC2IN0        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |  |
| PORT J | Function | C4         | PJ5<br>AIN05<br>PHC2IN1        | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the capture trigger of two-phase pulse count timer    |  |
| PORT J | Function | D4         | PJ6<br>AIN06<br>TB0IN0         | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the timer B capture trigger                           |  |
| PORT J | Function | A3         | PJ7<br>AIN07<br>INT9<br>TB0IN1 | I/O<br>I<br>I<br>I    | I/O port<br>Analog input<br>External interrupt pin<br>Inputting the timer B capture trigger |  |
| PORT K | Function | В3         | PK0<br>AIN08<br>TB1IN0         | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the timer B capture trigger                           |  |
| PORT K | Function | C3         | PK1<br>AIN09<br>INTA<br>TB1IN1 | I/O<br>I<br>I<br>I    | I/O port<br>Analog input<br>External interrupt pin<br>Inputting the timer B capture trigger |  |
| PORT K | Function | D3         | PK2<br>AIN10<br>TB6IN0         | I/O<br>I<br>I         | I/O port<br>Analog input<br>Inputting the timer B capture trigger                           |  |
| PORT K | Function | E3         | PK3<br>AIN11<br>INTB<br>TB6IN1 | I/O<br>I<br>I<br>I    | I/O port<br>Analog input<br>External interrupt pin<br>Inputting the timer B capture trigger |  |
| PORT K | Function | A2         | PK4<br>AIN12                   | I/O<br>I              | I/O port<br>Analog input                                                                    |  |
| PORT K | Function | B2         | PK5<br>AIN13                   | I/O<br>I              | I/O port<br>Analog input                                                                    |  |

| PORT   | Туре     | Pin<br>No. | Pin Name     | Input/<br>Out-<br>put | Function                                                                                                                                         |  |
|--------|----------|------------|--------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PORT K | Function | B1         | PK6<br>AIN14 | I/O<br>I              | I/O port<br>Analog input                                                                                                                         |  |
| -      | Control  | A1         | ENDIAN       | I                     | Little Endian operation: Fixed DVSSA<br>Big Endian operation: Fixed DVDD3A                                                                       |  |
| -      | Function | E4         | DA0          | 0                     | Analog output                                                                                                                                    |  |
| -      | Function | E5         | DA1          | 0                     | Analog output                                                                                                                                    |  |
| -      | Function | B6         | RESET        | I                     | Reset input pin<br>(note) With a pull-up and a noise filter (about 30ns (typical value))                                                         |  |
| -      | Function | A6         | NMI          | I                     | Non-maskable interrupt<br>(note) With a noise filter (about 30ns (typical value))                                                                |  |
| -      | Control  | C6         | MODE         | I                     | Mode pin:<br>(note) MODE pin must be connected to GND.                                                                                           |  |
| -      | Control  | L11        | FTEST3       | -                     | TEST pin:<br>(note) TEST pin must be left OPEN.                                                                                                  |  |
| -      | Control  | F4         | INTLV        | I                     | Interleave control pin (Refer to Clock/Mode control chapter)<br>If fc > 40MHz, connect with pull-up. If fc $\leq$ 40MHz, connect with pull-down. |  |
| -      | Control  | L1         | BSC          | I                     | JTAG Boundary scan control pin<br>(note) BSC must be connected to GND even if boundary scan is not used.                                         |  |
| -      | Clock    | A7         | X1/EHCLKIN   | I                     | Connected to a high-speed oscillator/ External clock input pin                                                                                   |  |
| -      | Clock    | A9         | X2           | 0                     | Connected to a high-speed oscillator.                                                                                                            |  |
| -      | PS       | A5         | DVDD3A       | -                     | Power supply pin                                                                                                                                 |  |
| -      | PS       | C11        | DVDD3A       | -                     | Power supply pin                                                                                                                                 |  |
| -      | PS       | E2         | DVDD3B       | -                     | Power supply pin                                                                                                                                 |  |
| -      | PS       | F11        | DVDD3B       | -                     | Power supply pin                                                                                                                                 |  |
| -      | PS       | K6         | DVDD3B       | -                     | Power supply pin                                                                                                                                 |  |
| -      | PS       | D11        | DVSSA        | -                     | GND pin                                                                                                                                          |  |
| -      | PS       | E1         | DVSSB        | -                     | GND pin                                                                                                                                          |  |
| -      | PS       | E11        | DVSSB        | -                     | GND pin                                                                                                                                          |  |
| -      | PS       | L6         | DVSSB        | -                     | GND pin                                                                                                                                          |  |
| -      | PS       | В9         | RVDD3        | -                     | Power supply pin for internal regulator                                                                                                          |  |
| -      | PS       | B8         | RVSS         | -                     | GND pin for internal ragulator                                                                                                                   |  |
| -      | PS       | A8         | DVSSC        | -                     | GND pin                                                                                                                                          |  |

## Table 1-2 Pin Names and Functions Sorted by Port (7/8)

| PORT | Туре | Pin<br>No. | Pin Name | Input/<br>Out-<br>put | Function                                                                                                                                                               |
|------|------|------------|----------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -    | PS   | C2         | AVREFH   | I                     | Supplying the A/D and D/A converters with a reference power supply.<br>(note) AVREFH must be connected to power supply even if A/D and D/A converters<br>are not used. |
| -    | PS   | D2         | AVREFL   | 1                     | Supplying the A/D and D/A converters with a reference GND.<br>(note) AVREFL must be connected to GND even if A/D and D/A converters are not used.                      |
| -    | PS   | C1         | AVDD3    | I                     | Supplying the A/D and D/A converters with a power supply.<br>(note) AVDD3 must be connected to power supply even if A/D and D/A converters are<br>not used.            |
| -    | PS   | D1         | AVSS     | I                     | Supplying the A/D and D/A converters with a power supply.<br>(note) AVSS must be connected to GND even if A/D and D/A converters are not used.                         |

## Table 1-2 Pin Names and Functions Sorted by Port (8/8)

# 1.5 Pin Numbers and Power Supply Pins

## Table 1-3 Pin Numbers and Power Supplies

| Power supply | Voltage range | Pin No.     | Pin name                                               |
|--------------|---------------|-------------|--------------------------------------------------------|
| DVDD3B       | 1.65 to 3.6V  | K6, E2, F11 | PA, PB, PC, PD, PE, PF, BSC                            |
| DVDD3A       |               | A5, C11     | PG, PH, PI, X1, X2, FTEST3, RESET,<br>NMI, MODE, INTLV |
| AVDD3        | 2.7 to 3.6V   | C1          | PJ, PK, DA0, DA1, ENDIAN                               |
| RVDD3        |               | B9          | -                                                      |

# 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 TMPM341FDXBG/FYXBG.

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 |
|------------------------|---------------|
| TMPM341FDXBG/<br>FYXBG | r2p0          |

# 2.2 Configurable Options

The Cortex-M3 core has optional blocks. The optional blocks of the revision r2p0 are ETM<sup>™</sup> and MPU. The following tables shows the configurable options in the TMPM341FDXBG/FYXBG.

| Configurable Options               | Implementation                                         |
|------------------------------------|--------------------------------------------------------|
| FPB                                | Two literal comparators<br>Six instruction comparators |
| DWT                                | Four comparators                                       |
| ITM                                | Implementable                                          |
| MPU                                | Not implementable                                      |
| ETM                                | Implementable                                          |
| AHB-AP                             | Implementable                                          |
| AHB Trace Macrocell In-<br>terface | Implementable                                          |
| TPIU                               | Implementable                                          |
| WIC                                | Not implementable                                      |

# 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.

TMPM341FDXBG/FYXBG has 84 interrupt inputs. The number of interrupt inputs is reflected in <INTLI-NESNUM[4:0]> bit of NVIC register. In this product, if read <INTLINESNUM[4:0]> bit, 0x00 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.

TMPM341FDXBG/FYXBG 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.

TMPM341FDXBG/FYXBG provides the same operation when SYSRESETREQ signal are output.

### 2.3.5 LOCKUP

When irreparable exception generates, the Cortex-M3 core outputs LOCKUP signal to show a serious error included in software.

TMPM341FDXBG/FYXBG does not use this signal. To return from LOCKUP status, it is necessary to use non-maskable 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, TMPM341FDXBG/FYXBG is not defined this function. If auxiliary fault status register is read, always "0x0000\_0000" is read out.

## 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.

TMPM341FDXBG/FYXBG 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.

TMPM341FDXBG/FYXBG 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 TMPM341FDXBG/FYXBG does not use this function.

- 2. Processor Core
- 2.6 Exclusive access

# TOSHIBA

# 3. Endian

## 3.1 Endianess of Cortex-M3 core

The Cortex-M3 core has a bi-endian CPU core allowing to support both little-endian and big-endian. The features are as follows:

1. Employed ARM endianess for Big-endian (BE8)

Big-endian (BE8) specified by ARM is partly different in the format and operation from big-endian specified by MIPS which is used in Toshiba TX19 series.

The difference between two is referred to Section"3.5.1 Differences in the big-endian format".

2. Space aligned in little-endian always exists

Even when big-endian is used, CPU core operates and accesses the following area using little-endian.

- Instruction fetch
- Internal peripheral bus (0xE0000000 to 0xE003FFFF)
- External peripheral bus (0xE0040000 to 0xE00FFFF)

For details, see "Cortex-M series processors" of ARM in below URL.

http://infocenter.arm.com/help/index.jsp

# 3.2 Endianess of TMPM341FDXBG/FYXBG

This product has a bi-endian CPU core (Cortex-M3) and supports bi-endian operation.

If big-endian is used, users needs some consideration in operation modes, endian-types (BE8 format or MIPS format), operations and access areas (instructions or operands).

The following sections describes specifications and operations in each operation mode.

### 3.2.1 Single Mode

The Cortex-M3 instructions always use little-endian format, so that a result of compiling using big-endian (BE8) is mixed with little-endian. However a memory, where compiler data is assigned, must use big-endian of Cortex-M3. The internal memory and the memory, which is connected to the external memory, are applied.

To enable data transfer between external devices and the MCU, the MCU allows to use MIPS format data using big-endian in the external bus area. Cortex-M3 format and MIPS format are selectable in each CS space.

Control registers of built-in peripheral function unit uses MIPS format.

Transfer data of DMAC uses MIPS format as well.

### 3.2.2 Single Boot Mode

Boot programs in the built-in BOOT ROM use little-endian. When single boot mode is used, little-endian operation is used regardless of ENDIAN pin setting. Note that programs and data running on RAM with RAM transfer command must be little-endian format.

#### 3.2.3 Miscellaneous

#### 3.2.3.1 Endian in the DMAC

The DMAC can independently choose endianess with the endian selection bit (DMACxConfiguration<M>). However a user always must set the same endianess as product's endianess.

#### 3.2.3.2 Endian in the Debug Tools

When debug tools are connected, data must use big-endian of Cortex-M3 since data is observed via internal bus matrix in the CPU. Thus, instructions is observed in little-endian and operands observed in big-endian (BE8).

## 3.3 How to Set Endianess and Endian type

### 3.3.1 Operation Setting of TMPM341FDXBG/FYXBG

Endianess of this product is set with operation modes (determined by BOOT pin) and the ENDIAN pin. Additionally, endianess in the external bus area is set with EXBCSx<ENDTYPE>in EBIF. Endianess of DMAC is set with DMACxConfiguration<M>.

Table 3-1 and Table 3-2 show a list of bus masters and endian types in each setting and access area. This product has two bus masters (CPU and DMAC). Access by DMAC is the same as the access of CPU operand.

| Table 3-1 Endian types | (access by CPU) |
|------------------------|-----------------|
|                        |                 |

|                 |                                | Endianess of product |                |                                |                   |                                    |         |  |
|-----------------|--------------------------------|----------------------|----------------|--------------------------------|-------------------|------------------------------------|---------|--|
|                 |                                |                      | Single<br>BOOT | Single boot mode<br>BOOT="Low" |                   |                                    |         |  |
|                 |                                | Little-e<br>ENDIAN   |                | Big-e<br>ENDIAN                | ndian<br>I="High" | Little-endian<br>ENDIAN=don't care |         |  |
|                 | Access area                    | Instruction Operand  |                | Instruction                    | Operand           | Instruction                        | Operand |  |
|                 | nternal FLASH                  | LE                   |                | LE                             | BE8               | -<br>(Disabled)                    | LE      |  |
|                 | Internal RAM                   | L                    | E              | LE BE8                         |                   | LE                                 |         |  |
| Inte            | ernal BOOT ROM                 | -                    |                | -                              |                   | LE                                 |         |  |
| Control registe | er of peripheral function unit | LE                   |                | - MIPS                         |                   | LE                                 |         |  |
|                 | EXBCSx <endtype>="0"</endtype> | LE                   |                | LE                             | BE8               | LE                                 |         |  |
| External memory | EXBCSx <endtype>="1"</endtype> | -<br>(Disabled)      | MIPS           | -<br>(Disabled)                | MIPS              | -<br>(Disabled)                    | MIPS    |  |

LE: Little-endian

BE8: Big-endian of BE8

MIPS: Big-endianof MIPS

#### Table 3-2 Endian types (access by DMAC)

|                                              |                                | Endianess of product/DMAC                                          |                                                                  |                                                                         |  |  |  |
|----------------------------------------------|--------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------|--|--|--|
|                                              |                                | Single<br>BOOT:                                                    | Single boot mode<br>BOOT="Low"                                   |                                                                         |  |  |  |
|                                              | Access area                    | Little-endian<br>ENDIAN="Low"<br>DMACxConfiguration<br><m>="0"</m> | Big-endian<br>ENDIAN="High"<br>DMACxConfiguration<br><m>="1"</m> | Little-endian<br>ENDIAN=don't care<br>DMACxConfiguration<br><m>="0"</m> |  |  |  |
|                                              | Internal FLASH                 | LE                                                                 | BE8                                                              | LE                                                                      |  |  |  |
|                                              | Internal RAM                   | LE                                                                 | BE8                                                              | LE                                                                      |  |  |  |
| Inte                                         | ernal BOOT ROM                 | -                                                                  | -                                                                | LE                                                                      |  |  |  |
| Control register of peripheral function unit |                                | LE                                                                 | MIPS                                                             | LE                                                                      |  |  |  |
| External                                     | EXBCSx <endtype>="0"</endtype> | LE                                                                 | BE8                                                              | LE                                                                      |  |  |  |
| memory                                       | EXBCSx <endtype>="1"</endtype> | MIPS                                                               | MIPS                                                             | MIPS                                                                    |  |  |  |

LE: Little-endian

BE8: Big-endian of BE8

MIPS: Big-endian of MIPS

#### 3.3.2 Operation Mode

Operation mode is determined by  $\overline{\text{BOOT}}$  pin. This pin is booted in the single boot mode when the external reset pin is booted while AVSS is "Low" level. When AVDD3 is "High" level, the pin is booted in the single mode.

In the single boot mode, endianess of the product is little-endian regardless of ENDIAN pin setting.

### 3.3.3 ENDIAN Pin

This product has an ENDIAN pin to determine endianess. This ENDIAN pin is input-only. When this pin is set to "Low" (AVSS level), if the external reset pin is booted, the pin is booted as little-endian. When the pin is set to "High" (AVDD3 level), the pin is booted as big-endian. As mentioned before, in the single boot mode, little-endian is used regardless of ENDIAN pin setting.

### 3.3.4 Endian Selection of External Bus Area

Endianess is set with EXBCSx<ENDTYPE> of the external bus interface (EBIF) in each CS space. Endianess of external bus area setting with ENDIAN pin and <ENDTYPE> are as follows:

|               | EXBCSx <endtype></endtype> |                      |  |  |  |
|---------------|----------------------------|----------------------|--|--|--|
| Endianess     | "0"                        | "1"                  |  |  |  |
|               | (same as CPU)              | (different from CPU) |  |  |  |
| Little-endian | Little-endian              | MIPS type            |  |  |  |
| Big-endian    | BE8 type                   | MIPS type            |  |  |  |

## 3.3.5 Endian Selection of DMAC

Endianess is set with DMACxConfiguration<M>. Endianess of DMAC must be the same as those of ENDI-AN pin. When <M>="0" is set, little-endian is used. When <M>="1" is set, big-endian is used.

## 3.4 Structure

This section shows a structure of TMPM341FDXBG/FYXBG. Data conversion circuit exists between AHB bus and bus-bridge, and AHB bus and DMAC respectively to deal with the difference of endianess.



Figure 3-1 TMPM341FDXBG/FYXBG Block diagram

Next chapter describes the operation of little-endian and big-endian in detail.

## 3.4.1 Block Structure of Little-endian

When little-endian is used, CPU, internal memory and control registers of built-in peripheral function unit use little-endian. Only in the external bus area, either little-endian or big-endian of MIPS can be chosen in each memory (in each chip select signal).

DMAC uses little-endian.

The conversion circuit operates when external bus accesses using MIPS memory access.



Figure 3-2 Little-endian Block diagram

## 3.4.2 Block Structure of Big-endian

When big-endian is used, instruction fetches uses little-endian and operand access uses BE8 among accesses from CPU to the internal memory. These operations are basics of Cortex-M3, so that the conversion is not required.

The memory connecting to the external bus can select endianess either BE8 or big-endian of MIPS.

The access to the control register of peripheral function unit is big-endian of MIPS.

DMAC uses big-endian. Transfer data is big-endian of MIPS.

The conversion circuit operates at the following conditions; when big-endian MIPS format data on the external bus accesses memory; when control registers of peripheral function unit access memory; when DMAC performs data transfer.



Figure 3-3 Big-endian Block diagram

# 3.5 Operational Description

## 3.5.1 Differences in the big-endian format

Data alignment is different between BE8 format and MIPS format.

Data in the general-purpose register of CPU is aligned on the bus connecting to CPU according to data size and address as follows:

< 4-byte data > 0 31 General-purpose register DD CC BΒ AA <Little Endian> <BE8> <MIPS> 31 0 31 0 31 0 Data on the bus DD BΒ BΒ СС DD DD СС ΒB СС AA AA AA < 2-byte data > 31 General-purpose register BΒ AA <Little Endian> <BE8> <MIPS> [Address: 0x00] 31 31 31 0 0 0 Data on the bus BΒ AA AA BΒ BΒ AA [Address: 0x02] 31 31 31 0 0 Data on the bus BΒ BΒ BΒ AA AA AA < 1-byte data > 31 0 General-purpose register AA [Address: 0x00] <Little Endian> <BE8> <MIPS> 31 0 31 31 0 0 Data on the bus AA AA AA [Address: 0x01] 31 Λ 31 n 31 0 Data on the bus AA AA AA [Address: 0x02]



## 3.5.2 Access of Control Register

When the control registers of peripheral function unit is accessed using big-endian, i.e. operand access (BE8) by CPU, data alignment output to the bus is set as described in Section"3.5.1 Differences in the big-endian format". The data is converted in the conversion circuit which is located between AHB bus and the bus connecting to peripheral function unit. Data alignment is MIPS type when data is written to the control register.

Usually, when big-endian is used in the Cortex-M3, write data to the control register is prepared on having some considerations to data alignment for BE8. In the MIPS format, data alignment is the same as generalpurpose registers, so that write data can be used as it is in this product.

< 4-byte data >



Data output position when the 2-byte data access and the 1-byte data access using big-endian is as follows. Note that little-endian address and big-endian address seem to be different.

< 2-byte data >



< 1-byte data >



The following table shows address differences depending on endianess taking example of EXBCS0 register in the external bus interface (EBIF).

|          | Address     | Bit           | 31 | 30 | 29 | 28  | 27 | 26   | 25  | 24   |
|----------|-------------|---------------|----|----|----|-----|----|------|-----|------|
| Little : | 0x4005_C003 | Symbol        | CS | SR |    | WRR |    |      | RDR |      |
| Big :    | 0x4005_C000 | Initial value | 0  | 1  | 0  | 0   | 1  | 0    | 0   | 1    |
|          |             | Bit           | 23 | 22 | 21 | 20  | 19 | 18   | 17  | 16   |
| Little : | 0x4005_C002 | Symbol        | -  | -  | AL | EW  | W  | RS   | RI  | DS   |
| Big :    | 0x4005_C001 | Initial value | 0  | 0  | 0  | 1   | 0  | 1    | 0   | 1    |
|          |             | Bit           | 15 | 14 | 13 | 12  | 11 | 10   | 9   | 8    |
| Little : | 0x4005_C001 | Symbol        | -  | -  | -  |     |    | CSIW |     |      |
| Big :    | 0x4005_C002 | Initial value | 0  | 0  | 0  | 0   | 0  | 0    | 1   | 0    |
|          |             | Bit           | 7  | 6  | 5  | 4   | 3  | 2    | 1   | 0    |
| Little : | 0x4005_C000 | Symbol        | -  | -  | -  | -   | -  | CS   | SW  | CSW0 |
| Big :    | 0x4005_C003 | Initial value | 0  | 0  | 0  | 0   | 0  | 0    | 1   | 0    |

#### 3.5.3 External Bus Operation

Data format of external bus access is determined by ENDIAN pin and EXBCSx<ENDTYPE> setting. (See Section"3.3.4 Endian Selection of External Bus Area")

Data formats of little-endian, BE8 and MIPS on the external bus are shown in below.

#### 3.5.3.1 Data Size: 32-bit

(1) External bus width: 16-bit



#### 3.5.3.2 Data Size (16-bit)

#### (1) External bus width (16-bit)



## (2) External bus width (8-bit)

| General-purposo<br>register | D31                             | D00<br>AA                |                          |
|-----------------------------|---------------------------------|--------------------------|--------------------------|
|                             | Address 0x00 0x01               | 0x00 0x01<br>X BB X AA X | 0x00 0x01<br>X BB X AA X |
| External bus                | Address 0x02 0x03<br>AA BB      | 0x02 0x03<br>X BB X AA X | 0x02 0x03<br>X BB X AA X |
|                             | <little-endian></little-endian> | <be8></be8>              | <mips></mips>            |

#### 3.5.3.3 Data Size (8-bit)

#### (1) External bus width (16-bit)



#### (2) External bus width (8-bit)



## 3.5.4 Image of Compile Result

This section describes the data alignment in the memory, e.g. Motorola S record or Intel HEX.

If the following memory image of 32-bit data is assumed, the data alignment will be shown in the table below by setting endianess when compiling.



| Endian                    |                             |      | Address |      |      |  |  |
|---------------------------|-----------------------------|------|---------|------|------|--|--|
|                           |                             |      | 0x01    | 0x02 | 0x03 |  |  |
| Little-endian             | Little-endian               |      |         | 0xCC | 0xDD |  |  |
| Big-endian                | Instruction (Little-endian) | 0xAA | 0xBB    | 0xCC | 0xDD |  |  |
| (Cortex-M3) Operand (BE8) |                             | 0xDD | 0xCC    | 0xBB | 0xAA |  |  |
| Big-endian (MIPS)         |                             | 0xDD | 0xCC    | 0xBB | 0xAA |  |  |

When using big-endian in the Cortex-M3, instructions use little-endian and operands use BE8 type. When CPU accesses operands using big-endian, CPU switches data alignment when read as shown below. This causes that an addressing of instructions (little-endian) and operands (BE8) seems to be same. Memory image is generated based on the above consideration, so that all data addressing can be treated as little-endian.



### 3.5.5 Operation in the Single Boot Mode

An operations in the single boot mode is a little-endian operation regardless of ENDIAN pin setting, since boot programs in the internal BOOT ROM are little-endian. In the boot program, a RAM transfer command is prepared. The data transfer program is developed on the RAM using this command and the data is transfer-red to the internal memory or external memory.

Note: Programs or data developed on the RAM using RAM transfer command must be prepared with little-endian format since CPU uses little-endian.

This section describes specific operation that a compile result (memory image), which is caused by different data format from little-endian, is transferred to the internal memory or external memory.

A memory image is the same as the example in Section"3.5.4 Image of Compile Result". The following example is Motorola S format.

| Little-endian             |                             | S1xx0000 | AA | BB | СС | DD | • |
|---------------------------|-----------------------------|----------|----|----|----|----|---|
| Big-endian                | Instruction (Little-endian) | S1xx0000 | AA | BB | СС | DD | : |
| (Cortex-M3) Operand (BE8) |                             | S1xx0000 | DD | СС | BB | AA | : |
| Big-endian (MIPS)         |                             | S1xx0000 | DD | СС | BB | AA | • |

#### 3.5.5.1 Data Transfer to the Internal Memory

This section describes an example that 32-bit data is transferred with 1 byte at a time from the external device to the internal memory.

#### (1) Data Transfer using Little-endian Format

When little-endian is used, desired data is prepared by writing an address to the memory incrementing from 0x00.



#### (2) Cortex-M3 Big-endian Transfer

When data, which is mixed instructions (little-endian) with operands (BE8), is written to memory using little-endian, addressing is considered on becoming the same operation as little-endian operation as shown in Section"3.5.4 Image of Compile Result".

When CPU reads data, instructions are taken as it is; however operands is switched bytes around.

Operand



#### 3.5.5.2 Data Transfer to External Memory

This section describes an example that 32-bit data is transferred to the 16-bit width external memory with 1 byte at a time.

#### (1) Data Transfer using Little-endian Format

When little-endian is used, a desired data is prepared by writing an address to the memory incrementing from 0x00.

When the CPU reads 32-bit data, each 16-bit read data is assigned from lower bit in the external bus interface to generate 32-bit data and outputs the data to the bus.

# TOSHIBA



#### (2) Data Transfer using BE8 Format

When data, which is mixed instructions (little-endian) with operands (BE8), is written to memory using little-endian, addressing is considered on becoming the same operation as little-endian operation as shown in Section"3.5.4 Image of Compile Result".

When CPU reads 32-bit data, each 16-bit read data is assigned from upper bit in the external bus interface to generate 32-bit data and outputs the data to the bus. When CPU reads data, instructions are taken as it is; however operands is switched bytes around.

- Write address 0x01 0x02 0x03 0x00 ΒB Transfer data ) DD СС AA Write data in the Single boot mode (Little-endian) BΒ 0x02 AA External memory СС DD 0x00 0 31 AHB bus Access by CPU in the AA BΒ СС DD Single mode (Big-endian) General-purpose СС BΒ DD AA register
  - Instruction

#### • Operand



#### (3) Data Transfer using MIPS Format

To write MIPS format data to memory using little-endian, use EXBCSx<ENDTYPE> function of the external bus interface (EBIF). If <ENDTYPE> is set to "1", a corresponding CS area becomes MIPS format and EBIF automatically controls memory access.

When CPU reads 32-bit data, each 16-bit read data is assigned from upper bit in the external bus interface to generate 32-bit data and outputs the data to the bus.



# 4. Memory Map

## 4.1 Memory map

The memory maps for theTMPM341FDXBG/FYXBG 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 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.

# 4.1.1 Memory map of the TMPM341FDXBG/FYXBG

Figure 4-1 and Figure 4-2 show the memory map of the TMPM341FDXBG/FYXBG.



Figure 4-1 Memory Map (TMPM341FDXBG)



Figure 4-2 Memory Map (TMPM341FYXBG)

# 4.2 SFR area detail

This section contains the list of addresses in the SFR area (0x4000\_0000 through 0x41FF\_FFFF) assigned to peripheral function.

Access to the Reserved areas in the Table 4-1, the address not specified and the Reserved area in each chapter are prohibited. As for the SFR area, the areas not specified in each chapter is read an undefined value. Writing this area is ignored.

| Start Address | End Address | Peripheral     |
|---------------|-------------|----------------|
| 0x4000_0000   | 0x4000_3FFF | DMAC (4ch)     |
| 0x4000_4000   | 0x4003_FFFF | Reserved       |
| 0x4004_0000   | 0x4004_7FFF | SSP (1ch)      |
| 0x4004_8000   | 0x4004_FFFF | Reserved       |
| 0x4005_0000   | 0x4005_3FFF | ADC (15ch)     |
| 0x4005_4000   | 0x4005_7FFF | DAC (2ch)      |
| 0x4005_8000   | 0x4005_BFFF | TMRD (2ch)     |
| 0x4005_C000   | 0x4005_CFFF | EBIF           |
| 0x4006_D000   | 0x400B_FFFF | Reserved       |
| 0x400C_0000   | 0x400C_3FFF | PORT (A to K)  |
| 0x400C_4000   | 0x400C_6FFF | TMRB (10ch)    |
| 0x400C_7000   | 0x400C_9FFF | Reserved       |
| 0x400C_A000   | 0x400C_BFFF | PHCNT (4ch)    |
| 0x400C_C000   | 0x400D_FFFF | Reserved       |
| 0x400E_0000   | 0x400E_0FFF | SBI (2ch)      |
| 0x400E_1000   | 0x400E_5FFF | SIO/UART (5ch) |
| 0x400E_6000   | 0x400F_0FFF | Reserved       |
| 0x400F_1000   | 0x400F_1FFF | OFD            |
| 0x400F_2000   | 0x400F_2FFF | WDT            |
| 0x400F_3000   | 0x400F_3FFF | CG             |
| 0x400F_4000   | 0x41FF_FFFF | Reserved       |

Table 4-1 SFR area detail

# 5. External bus interface (EBIF)

# 5.1 Overview

The TMPM341FDXBG/FYXBG has a built-in external bus interface function to connect to external memory, I/ Os, etc. This interface consists of an external bus interface circuit (EBIF), a chip selector (CS) and a wait controller.

The chip selector and wait controller designate mapping addresses in a 2-block address space and also control wait states and data bus widths (8- or 16-bit) in these and other external address spaces.

The external bus interface circuit (EBIF) controls the timing of external buses based on the chip selector and wait controller settings.

This product is a bi-endian capable product that supports both little and big endian byte ordering used for the CPU core Cortex-M3. This chapter mainly describes the CS/Wait controller. For information about bi-endian, see the chapter Endian. For detailed information, refer to the manual "Cortex-M series processors" at the below URL.

http://infocenter.arm.com/help/index.jsp

| features                                      |                                                                                                                                                                              |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory supports                               | Asynchronous memory (NOR Flash memory, SRAM, Peripheral I/O and e.t.c.)<br>Selectable separate bus mode or multiplex bus mode.                                               |
| Data bus width                                | Either an 8- or 16-bit width can be set for each channel.                                                                                                                    |
| Chip select                                   | 2 channels (CS0, CS1)                                                                                                                                                        |
| Endian                                        | Bi-Endian is supported.                                                                                                                                                      |
| Address access spaces                         | Supports up to 16MB memory spaces<br>CS0: 0x6000_0000 to 0x61FF_FFFF (Max. 16MB space)<br>CS1: 0x6000_0000 to 0x61FF_FFFF (Max. 16MB space)                                  |
| Internal wait function                        | This function can be enabled for each channel.<br>A wait of up to 15 cycles can be automatically inserted.                                                                   |
| ALE wait function                             | This function can be enabled for each channel.<br>An ALE high pulse of up to 4 cycles can be automatically inserted.                                                         |
| Setup cycle insertion function                | This function can be enabled for each channel.<br>A $\overline{\text{RD}}$ or $\overline{\text{WR}}$ setup cycle can be automatically inserted.<br>(tAC cycle expanded)      |
| Recovery (Hold) cycle in-<br>sertion function | When an external bus is selected, a dummy cycle of up to 8 clocks can be inserted<br>and this dummy cycle can be specified for each channel.<br>(tCAR, tRAE cycles expanded) |
| Bus expansion function                        | The internal wait, the ALE wait, the Setup wait and the Recovery cycle can be expan-<br>ded double or quadruple.                                                             |
|                                               | Separate bus mode: D[15:0], A[23:0], RD, WR, BELL, BELH, CS0, CS1, ENDIAN                                                                                                    |
| Control pins                                  | Multiplex bus mode: AD[15:0], A[23:16], RD, WR, BELL, BELH, CS0, CS1, ALE, ENDIAN                                                                                            |

#### Table 5-1 Features of External bus interface

# 5.2 Address and Data Pins

## 5.2.1 Address and Data pin setting

The TMPM341FDXBG/FYXBG can be set to either separate bus or multiplexed bus mode. Setting the bit <EXBSEL> of EXBMOD register to "1" as the separate bus mode, and setting to "0" as the multiplexed bus mode. Port pins A to E which are to be connected to external devices (memory), are used as address buses, data buses and address/data buses. Table 5-2 shows these.

| PORT                | Separate<br>EXBMOD <exbsel> = "1"</exbsel> | Multiplex<br>EXBMOD <exbsel> = "0"</exbsel> |
|---------------------|--------------------------------------------|---------------------------------------------|
| Port A (PA0 to PA7) | D0 to D7                                   | AD0 to AD7                                  |
| Port B (PB0 to PB7) | D8 to D15<br>A0 to A7                      | AD8 to AD15                                 |
| Port C (PC0 to PC7) | A0 to A7                                   | -                                           |
| Port D (PD0 to PD7) | A8 to A15                                  | -                                           |
| Port E (PE0 to PE7) | A16 to A23                                 | A16 to A23                                  |

Each port is put into input mode after a reset. To access an external device, set the address and data bus functions by using the port control register (PxCR) and the port function register (PxFC), and set the input enable register (PxIE).

When the access changing from the external area to internal area, the address buses are kept the previously external area address output and the data buses will be high impedance.

# 5.3 Registers

## 5.3.1 Registers List

Address and names of EBIF control registers are shown below.

|                                                              |                 | Base Address = 0x4005_C000 |
|--------------------------------------------------------------|-----------------|----------------------------|
| Register name                                                | Address (Base+) |                            |
| External Bus Mode Control Register                           | EXBMOD          | 0x0000                     |
| Reserved                                                     | -               | 0x0004 to 0x000C           |
| External Bus Area and Start Address Configuration Register 0 | EXBAS0          | 0x0010                     |
| External Bus Area and Start Address Configuration Register 1 | EXBAS1          | 0x0014                     |
| Reserved                                                     | -               | 0x0018 to 0x003C           |
| External Bus Chip Select Control Regiser 0                   | EXBCS0          | 0x0040                     |
| External Bus Chip Select Control Regiser 1                   | EXBCS1          | 0x0044                     |
| Reserved                                                     | -               | 0x0048 to 0x0FFC           |

Note 1: Access the registers by using word reads and word writes.

Note 2: Access to the "Reserved" area is prohibited.

5.3 Registers

|              | 31 | 30 | 29 | 28 | 27 | 26      | 25 | 24     |
|--------------|----|----|----|----|----|---------|----|--------|
| hit overskol |    |    |    |    |    |         |    |        |
| 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  | 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   | -  | -  | -  | -  | -  | EXBWAIT |    | EXBSEL |
| After reset  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0      |

# 5.3.2 EXBMOD (External Bus Mode Control Register)

| Bit  | Bit Symbol   | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3 | -            | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2-1  | EXBWAIT[1:0] | R/W  | Bus cycle extension<br>00: None<br>01: Double<br>10: Quadruple<br>11: Prohibited<br>These bits are used to set the setup, wait and recovery of the bus cycle to be double or quadruple. For ex-<br>ample, if a Read setup cycle is set as two cycles by setting <exbwait>="00" (no extension), the two cy-<br/>cles can be<br/>quadruplicated by changing the bit setting to <exbwait>="01" (double). It also can be octuplicated by set-</exbwait></exbwait> |
|      |              |      | ting the bits to <exbwait>="10" (quadruple). The extended cycle is configured by setting Read/Write set-<br/>up, chip select/Read/Write recovery, ALE/internal wait cycle and <exbwait> (double or quadruple).</exbwait></exbwait>                                                                                                                                                                                                                            |
| 0    | EXBSEL       | R/W  | Select external bus mode (Note)<br>0: Multiplex bus<br>1: Separate bus                                                                                                                                                                                                                                                                                                                                                                                        |

Note:Do not change the setting of external bus mode in operating the external bus access.

# 5.3.3 EXBASx (External Bus Area and Start Address 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  | SA23 | SA22 | SA21 | SA20 | SA19 | SA18 | SA17 | SA16 |
| 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    | 0    |
|             | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| bit symbol  |      |      |      | EX   | (AR  |      |      |      |
| After reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | -          | R/W  | Always write to 0y01100000                                                                                                                                                                                                                                                                                                                                                 |
| 23-16 | SA23-SA16  | R/W  | Chip select Start address (Note)<br>The A[23:16] is specified as start address.                                                                                                                                                                                                                                                                                            |
| 15-8  | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                 |
| 7-0   | EXAR[7:0]  | R/W  | Chip select Address space size<br>The size of address space can be specified nine kind of setting from 64Kbyte up to 16Mbyte.<br>0y0000_0000: 16 Mbyte, 0y0000_0011: 2 Mbyte, 0y0000_0110: 256 Kbyte,<br>0y0000_0001: 8 Mbyte, 0y0000_0100: 1 Mbyte, 0y0000_0111: 128 Kbyte,<br>0y0000_0010: 4 Mbyte, 0y0000_0101: 512 Kbyte, 0y0000_1000: 64 Kbyte,<br>Others: Prohibited |

Note: If same address space is specified between CS0 and CS1, the chip selector will be given priority to CS0.

Note: If the access address is exceeded space in 0x6000\_0000 to 0x61FF\_FFFF, a hard fault error will be generated.

5.3 Registers

|             | 31      | 30 | 29 | 28  | 27 | 26      | 25  | 24   |
|-------------|---------|----|----|-----|----|---------|-----|------|
| bit symbol  | C       | SR |    | WRR |    |         | RDR |      |
| After reset | 0       | 1  | 0  | 0   | 1  | 0       | 0   | 1    |
|             | 23      | 22 | 21 | 20  | 19 | 18      | 17  | 16   |
| bit symbol  | -       | -  | AL | EW  | W  | WRS RDS |     | DS   |
| After reset | 0       | 0  | 0  | 1   | 0  | 1       | 0   | 1    |
|             | 15      | 14 | 13 | 12  | 11 | 10      | 9   | 8    |
| bit symbol  | -       | -  | -  |     | -  | CSIW    |     |      |
| After reset | 0       | 0  | 0  | 0   | 0  | 0       | 1   | 0    |
|             | 7       | 6  | 5  | 4   | 3  | 2       | 1   | 0    |
| bit symbol  | ENDTYPE | -  | -  | -   | -  | CSW     |     | CSW0 |
| After reset | 0       | 0  | 0  | 0   | 0  | 0       | 1   | 0    |

# 5.3.4 EXBCSx (External Bus Chip Select Control Register)

| Bit   | Bit Symbol | Туре |                               | Function                                                  |                       |         |           |  |  |
|-------|------------|------|-------------------------------|-----------------------------------------------------------|-----------------------|---------|-----------|--|--|
| 31-30 | CSR[1:0]   | R/W  | Chip select (CSx) Recovery    | Chip select (CSx) Recovery cycle                          |                       |         |           |  |  |
|       |            |      | 0y00: None, 0y01: 1 cycle,    | Dy00: None, 0y01: 1 cycle, 0y10: 2 cycles, 0y11: 4 cycles |                       |         |           |  |  |
| 29-27 | WRR[2:0]   | R/W  | Write (WR) Recovery cycle     |                                                           |                       |         |           |  |  |
|       |            |      | 0y000: None, 0y001: 1 cyc     | le, 0y010: 2 cycles, 0y011: 3 c                           | cycles,               |         |           |  |  |
|       |            |      | 0y100: 4 cycles, 0y101: 5 c   | cycles, 0y110: 6 cycles, 0y111:                           | 8 cycles              |         |           |  |  |
| 26-24 | RDR[2:0]   | R/W  | Read (RD) Recovery cycle      |                                                           |                       |         |           |  |  |
|       |            |      |                               | le, 0y010: 2 cycles, 0y011: 3 c                           |                       |         |           |  |  |
|       |            |      | 0y100: 4 cycles, 0y101: 5 c   | cycles, 0y110: 6 cycles, 0y111:                           | 8 cycles              |         |           |  |  |
| 23-22 | -          | R    | Read as 0.                    |                                                           |                       |         |           |  |  |
| 21-20 | ALEW[1:0]  | R/W  | ALE wait cycle for multiple>  | ( bus                                                     |                       |         |           |  |  |
|       |            |      | 0y000: None, 0y001: 1 cyc     | le, 0y010: 2 cycles, 0y011: 4 c                           | cycles                |         |           |  |  |
| 19-18 | WRS[1:0]   | R/W  | Write (WR) Setup cycle        |                                                           |                       |         |           |  |  |
|       |            |      |                               | le, 0y010: 2 cycles, 0y011: 4 c                           | cycles                |         |           |  |  |
| 17-16 | RDS[1:0]   | R/W  | Read (RD) Setup cycle         |                                                           |                       |         |           |  |  |
|       |            |      |                               | le, 0y010: 2 cycles, 0y011: 4 c                           | cycles                |         |           |  |  |
| 15-13 | -          | R    | Read as 0.                    |                                                           |                       |         |           |  |  |
| 12-8  | CSIW[4:0]  | R/W  | Internal Wait (Automatically  | r insertion)                                              |                       |         |           |  |  |
|       |            |      | 0y0000: 0 wait,               | 0y0001: 1 waits, 0                                        | y0010: 2 waits,       | 0y0011: | 3 waits,  |  |  |
|       |            |      | 0y0100: 4 waits,              | 0y0101: 5 waits, 0                                        | y0110: 6 waits,       | 0y0111: | 7 waits,  |  |  |
|       |            |      | 0y1000: 8 waits,              | 0y1001: 9 waits, 0                                        | y1010: 10 waits,      | 0y1011: | 11 waits, |  |  |
|       |            |      | 0y1100: 12 waits,             | 0y1101: 13 waits, 0                                       | y1110: 14 waits,      | 0y1111: | 15 waits, |  |  |
| 7     | ENDTYPE    | R/W  | Classifies an endian type for | or external memory or perophe                             | eral I/O (ASIC, etc.) |         | _         |  |  |
|       |            |      |                               | <en< td=""><td>IDTYPE&gt;</td><td></td><td></td></en<>    | IDTYPE>               |         |           |  |  |
|       |            |      | Endian setting                | "0"                                                       | "1"                   |         |           |  |  |
|       |            |      |                               | (Same endian as CPU)                                      | (Not same endian      | as CPU) |           |  |  |
|       |            |      | Little Endian                 | Little Endian                                             | MIPS type             | e       |           |  |  |
|       |            |      | Big Endian                    | BE8                                                       | MIPS type             | е       |           |  |  |
| 6-4   | -          | R    | Read as 0.                    |                                                           |                       |         | -         |  |  |
| 3     | -          | R/W  | Always write to "0"           |                                                           |                       |         |           |  |  |
| 2-1   | CSW[2:1]   | R/W  | Data bus width                |                                                           |                       |         |           |  |  |
|       |            |      | 0y00: 8-bit, 0y01: 16-bit, Of | thers: Prohibited                                         |                       |         |           |  |  |
| 0     | CSW0       | R/W  | CS Enable                     |                                                           |                       |         |           |  |  |
|       |            |      | 0y0: Disable, 0y1: Enable     |                                                           |                       |         |           |  |  |

# TOSHIBA

## 5.4 Data Format

Internal registers and external bus interfaces of the TMPM341FDXBG/FYXBG are configured as described below.

### 5.4.1 Little-endian mode

- 5.4.1.1 Word access
  - 16-bit bus width

| Internal | Registers | External Buses |      |      |
|----------|-----------|----------------|------|------|
| _        | address   | 0x             | 00   | 0x02 |
| D31 DD   | 2         | BB             | аа Х | DDCC |
| cc       |           | MSB            | LSB  |      |
| D00 AA   |           |                |      |      |
|          | <u> </u>  |                |      |      |

• 8-bit bus width

| Inter | Internal Registers |         |     | External Buses |  |      |  |
|-------|--------------------|---------|-----|----------------|--|------|--|
|       |                    | address | 0x  | 00             |  | 0x02 |  |
| D31   | DD                 |         | BB  | вваа 🗙         |  | DDCC |  |
|       | CC<br>BB           |         | MSB | LSB            |  |      |  |
| D00   | AA                 |         |     |                |  |      |  |

- 5.4.1.2 Half word access
  - 16-bit bus width



• 8-bit bus width

5.4 Data Format



# TOSHIBA

#### 5.4.1.3 Byte access

• 16-bit bus width



• 8-bit bus width



## 5.4.2 Big-endian mode

5.4.2.1 Word access

• 16-bit bus width



• 8-bit bus width



#### 5.4.2.2 Half word access

• 16-bit bus width

Internal Registers External Buses <BE8> External Buses <MIPS>

| D31    | address | Ox00<br>AABB X | Ox00<br>BBAA X |
|--------|---------|----------------|----------------|
|        |         | MSB LSB        | MSB LSB        |
| вв     |         | 0x02           | 0x02           |
| D00 AA |         | аавв Х         | вваа Х         |
|        |         | MSB LSB        | MSB LSB        |

• 8-bit bus width

Internal Registers External Buses <BE8> External Bases <MIPS>

| D31   | Address | 0x00 0x01<br>BB X AA X | 0x00 0x01<br>BB X AA X |
|-------|---------|------------------------|------------------------|
| B     | BB      | 0x02 0x03              | 0x02 0x03              |
| D00 A |         | BB X AA X              | BB X AA X              |

#### 5.4.2.3 Byte access

• 16-bit bus width



• 8-bit bus width

| Internal Regist | ters Exter | mal Bases <be8></be8> | External Bases <mips></mips> |
|-----------------|------------|-----------------------|------------------------------|
| D31             | Address    | 0x00<br>AA            | 0x00<br>AA X                 |
|                 | Address    | 0x01<br>AA X          | 0x01<br>AA X                 |
| D00 AA          | Address    | AA X                  | 0x02<br>AA X                 |
|                 | Address    | 0x03<br>AA X          | 0x03<br>AA X                 |
|                 |            |                       |                              |

Page 59

# 5.5 External Bus Operations (Separete Bus Mode)

This section describes various bus timing values. The timing diagram shown below assumes that the address buses are A23 through A0 and that the data buses are D15 through D0.

### 5.5.1 Basic bus operation

The external bus cycle of the TMPM341FDXBG/FYXBG basically consists of three clock pulses. The basic clock of an external bus cycle is the same as the internal system clock. Figure 5-1 shows read bus timing and Figure 5-2 shows write bus timing. If internal areas are accessed, address buses remain unchanged as shown in these figures. Additionally, data buses are in a state of high impedance and control signals such as  $\overline{\text{RD}}$  and  $\overline{\text{WR}}$  do not become active.



Figure 5-1 Read Operation Timing



Figure 5-2 Write Operation Timing

### 5.5.2 Wait timing

A wait cycle can be inserted for each channel by using the chip selector (CS) and wait controller.

The following wait can be inserted.

• A wait of up to 15 clocks can be automatically inserted.

The setting of the number of waits to be automatically inserted and the setting can be made using the chip select control registers, EXBCSx<CSIW[4:0]>.

Figure 5-3 through Figure 5-4 show the timing diagrams in which waits have been inserted.



Figure 5-3 Read Operation Timing (0 Wait and 1 Wait Automatically Inserted)



Figure 5-4 Read Operation Timing (5 Waits Automatically Inserted)



Figure 5-5 through Figure 5-6 shows the read and write operation timing when 0 wait and 2 waits automatically inserted in the separate bus mode.





Figure 5-6 Write Operation Timing

## 5.5.3 Read and Write Recovery time

If access to external areas occurs consecutively, a dummy cycle can be inserted for recovery time.

A dummy cycle can be inserted in both a read and a write cycle. The dummy cycle insertion setting can be made in the chip select control registers, EXBCSx<WRR[2:0]> (write recovery cycle) and <RDR[2:0]> (read recovery cycle). As for dummy cycle, none, one to six or eight system clocks (internal) can be specified for each channel. Figure 5-7 shows the timing of recovery time insertion.



Figure 5-7 Timing of Recovery Time insertion

### 5.5.4 Chip select recovery time

If access to external areas occurs consecutively, a dummy cycle can be inserted for recovery time.

The dummy cycle insertion setting can be made in the chip select control registers, EXBCSx<CSR[1:0]>. As for the number of dummy cycles, none, one, two and four system clocks (internal) can be specified for each channel. Figure 5-8 shows the timing of recovery time insertion.



Figure 5-8 Timing of Chip Select Recovery Time Insertion

## 5.5.5 Read and Write setup cycle

A read and a write setup cycle can be inserted for each channel by using the chip selector (CS) and wait controller.

The following can be inserted.

• A read and a write setup cycle of up to 4 clocks can be automatically inserted.

The setting of the number of setup cycles to be automatically inserted and the setting can be made using the chip select control registers, EXBCSx < WRS[1:0] > and < RDS[1:0] >.

Figure 5-9 show the timing diagrams in which setup cycle have been inserted.



Figure 5-9 Timing of Read and Write Setup Time Insertion

# 5.6 External Bus Operations (Multiplexed Bus Mode)

This section describes various bus timing values. The timing diagram shown below assumes that the address buses are A23 through A16 and that the data buses are AD15 through AD0.

## 5.6.1 Basic bus operation

The external bus cycle of the TMPM341FDXBG/FYXBG basically consists of four clock pulses. The basic clock of an external bus cycle is the same as the internal system clock. Figure 5-10 shows read bus timing and Figure 5-11 shows write bus timing. If internal areas are accessed, address buses remain unchanged and the ALE does not output latch pulse as shown in these figures.

Additionally, address/data buses are in a state of high impedance and control signals such as  $\overline{RD}$  and  $\overline{WR}$  do not become active.



Figure 5-10 Read Operation Timing





### 5.6.2 Wait timing

A wait cycle can be inserted for each channel by using the chip selector (CS) and wait controller.

The following wait can be inserted.

• A wait of up to 15 clocks can be automatically inserted.

The setting of the number of waits to be automatically inserted and the setting can be made using the chip select control registers, EXBCSx<CSIW[4:0]>.

Figure 5-12 through Figure 5-13 show the timing diagrams in which waits have been inserted.



Figure 5-12 Read Operation Timing

5.6 External Bus Operations (Multiplexed Bus Mode)



Figure 5-13 Write Operation Timing

## 5.6.3 Time that it takes before ALE is asserted

One of system clocks of 1, 2 or 4 can be selected as the time that it takes before ALE is asserted. The setting can be made using the chip select control registers, EXBCSx < ALEW[1:0]>. The default is asserted the RD or WR signal from the address is generated after 2 clocks.



Figure 5-14 Time that it takes before ALE is asserted

Figure 5-15 shows the timing when the ALE is 1 clock or 2 clocks.



Figure 5-15 Read Operation Timing (When the ALE is 1 Clock or 2 Clocks)

## 5.6.4 Read and Write Recovery Time

If access to external areas occurs consecutively, a dummy cycle can be inserted for recovery time.

A dummy cycle can be inserted in both a read and a write cycle. The dummy cycle insertion setting can be made in the chip select control registers, EXBCSx<WRR[2:0]> (write recovery cycle) and <RDR[2:0]> (read recovery cycle). As for the number of dummy cycles, none, one to six or eight system clocks (internal) can be specified for each channel. Figure 5-16 shows the timing of recovery time insertion.



Figure 5-16 Timing of Recovery Time Insertion

## 5.6.5 Chip select recovery time

If access to external areas occurs consecutively, a dummy cycle can be inserted for recovery time.

The dummy cycle insertion setting can be made in the chip select control registers, EXBCSx<CSR[1:0]>. As for the number of dummy cycles, none, one, two and four system clocks (internal) can be specified for each channel. Figure 5-17 shows the timing of recovery time insertion.



Figure 5-17 Timing of CS Recovery Time Insertion (ALE width: 1 clock)

### 5.6.6 Read and Write setup cycle

A read and a write setup cycle can be inserted for each channel by using the chip selector (CS) and wait controller.

The following can be inserted.

• A read and a write setup cycle of up to 4 clocks can be automatically inserted.

The setting of the number of setup cycles to be automatically inserted and the setting can be made using the chip select control registers, EXBCSx < WRS[1:0] > and < RDS[1:0] >.

Figure 5-18 shows the timing diagrams in which the read or write setup cycle have been inserted.



Figure 5-18 Timing of Read or Write Setup Time Insertion

# TOSHIBA

# 5.7 Connection example for external memory

Below Figure 5-19 shows connection example for external 16-bit NORF and 16-bit SRAM.



Figure 5-19 Connection Example for external 16-bit SRAM and NOR-Flash

5.7 Connection example for external memory

# TOSHIBA

# 6. DMA Controller(DMAC)

# 6.1 Function Overview

The table below lists its major functions.

#### Table 6-1 DMA controller functions

| Item                | Fun                                                                                                                | ction                                               | Overview                                                                                                                                                   |
|---------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Number of channels  | 4ch(2 unit)                                                                                                        |                                                     | DMACA × 2ch , DMACB × 2ch                                                                                                                                  |
|                     | Hardware start                                                                                                     |                                                     | Supports DMA requests for peripheral IPs.                                                                                                                  |
| Start trigger       | Software start                                                                                                     | Started with a write to the DMACxSoftBReq register. |                                                                                                                                                            |
| Bus master          | 32bit × 1 (AHB)                                                                                                    |                                                     |                                                                                                                                                            |
| Priority            | (High)DMACA ch0 > DI<br>ch0 > DMACB ch1(low)                                                                       |                                                     | Fixed by hardware                                                                                                                                          |
| FIFO                | DMACA:4word × 2ch<br>DMACB:4word × 2ch                                                                             |                                                     |                                                                                                                                                            |
| 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                                                                                                         |                                                     |                                                                                                                                                            |
| Address             | Transfer source ad-<br>dress                                                                                       | incr / no-incr                                      | It is possible to specify whether Source and<br>Destination addresses should increment or                                                                  |
|                     | Transfer destination address                                                                                       | incr / no-incr                                      | should not increment (should be fixed).<br>(Address wrapping is not supported.)                                                                            |
| Endian              | Little endian / Big endia                                                                                          | an                                                  |                                                                                                                                                            |
| Transfer type       | Peripheral circuit (regist<br>Memory → peripheral c<br>Memory → memory<br>Peripheral circuit (regist<br>(register) | , ,                                                 | When "memory → memory" is selected, hard-<br>ware start for DMA startup is not supported.<br>See the DMACCxConfiguration register for<br>more information. |
| Interrupt function  | Transfer end interrupt<br>Error interrupt                                                                          |                                                     |                                                                                                                                                            |
| Special Function    | Scatter/gather function                                                                                            |                                                     |                                                                                                                                                            |

Note 1: 1 word = 32bit

# 6.2 DMA transfer type

Table 6-2 DMA transfer type

|   | DMA direction                  | DMA request<br>circuit                 | Support<br>DMA request<br>(Note3)            | Other condtion                                                                                                                                                                                                                                                                                           |  |  |  |  |
|---|--------------------------------|----------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1 | Memory → peripheral<br>circuit | peripheral cir-<br>cuit                | Burst request                                | <ol> <li>Uses all burst requests</li> <li>In case of 1word transmission, set to the "1" for burst size of DMA controller.</li> </ol>                                                                                                                                                                     |  |  |  |  |
| 2 | Peripheral circuit →<br>memory | peripheral cir-<br>cuit                | Burst request /<br>single request<br>(Note1) | If the amount of data transfer is not an integral multiple of the burst size, both<br>burst and single transfers are used.<br>• Amount of remaining transfer data≥Burst size: Uses burst transfer.<br>• Amount of remaining transfer data <burst single="" size:="" td="" transfer.<="" uses=""></burst> |  |  |  |  |
| 3 | Memory → memory                | DMAC                                   | None                                         | <ul> <li>Start condition : Enabling the DMAC starts data transfer with no DMAC request required.</li> <li>Stop condition :</li> <li>Transfer of all transfer data is complete.</li> <li>The DMAC channel is disabled. (Note2)</li> </ul>                                                                 |  |  |  |  |
|   | Peripheral circuit →           | Source<br>peripheral cir-<br>cuit      | Burst request /<br>single request<br>(Note1) | Transfer size     Source     Destination       (1)an integral multiple of<br>the burst size     Burst request                                                                                                                                                                                            |  |  |  |  |
| 4 | peripheral circuit             | Destination<br>peripheral cir-<br>cuit | Burst request                                | (2)single transferSingle requestBurst request(3)Not an integral multiple of the burst sizeBurst request /<br>single requestSingle request                                                                                                                                                                |  |  |  |  |

Note 1: Single request circuit in the peripheral circuit: SSP

- Note 2: Recommended: When transfers (big amounts of) data using memory → memory, Another AHB master can get bus rights even while transferring by using low priority channel (DMAC1). When using channel except DMAC1, wait until transfer is finished.
- Note 3: Available DMA request: Refer to Table 6-3.

The DMA direction of "Peripheral circuit  $\rightarrow$  Peripheral circuit" can be used as following conditions.

| Source Addr. | urce Addr. Destination Addr. |                | Source Addr.   |    | Destination Addr. |              |
|--------------|------------------------------|----------------|----------------|----|-------------------|--------------|
| IO           | to                           | IO             |                |    |                   |              |
| IO           | to                           | SCxBUF         | SCxBUF         | to | IO                |              |
| Ю            | to                           | ADREGx         | ADREGx         | to | IO                | (x=00 to 15) |
| Ю            | to                           | ADREGSP        | ADREGSP        | to | IO                |              |
| Ю            | to                           | ADCMP0/1       | ADCMP0/1       | to | IO                |              |
| IO           | to                           | TBxREG0/1      | TBxREG0/1      | to | IO                | (x=0 to 9)   |
| Ю            | to                           | TBxCP0/1       | TBxCP0/1       | to | IO                | (x=0 to 9)   |
| IO           | to                           | TDxRG0/1/2/3/4 | TDxRG0/1/2/3/4 | to | IO                | (x=0,1)      |
| IO           | to                           | TD0RG5         | TD0RG5         | to | IO                |              |

# 6.3 Block diagram



Figure 6-1 DMAC Block diagram

|                    | Corresponding peripheral                |         |                                         |                  |  |  |  |  |  |
|--------------------|-----------------------------------------|---------|-----------------------------------------|------------------|--|--|--|--|--|
| DMA<br>request No. | UNIT A ( DMACA cl                       | h0,ch1) | UNIT B ( DMACB ch0,ch1)                 |                  |  |  |  |  |  |
|                    | Burst                                   | Single  | Burst                                   | Single           |  |  |  |  |  |
| 0                  | SIO0/UART0 Reception                    | -       | TMRD00 compare match                    | -                |  |  |  |  |  |
| 1                  | SIO0/UART0 Transmission                 | -       | TMRD10 compare match                    | -                |  |  |  |  |  |
| 2                  | SIO2/UART2 Reception                    | -       | Two-phase pulse counter0<br>every count | -                |  |  |  |  |  |
| 3                  | SIO2/UART2 Transmission                 | -       | Two-phase pulse counter1<br>every count | -                |  |  |  |  |  |
| 4                  | SIO4/UART4 Reception                    | -       | TMRB6 compare match                     | -                |  |  |  |  |  |
| 5                  | SIO4/UART4 Transmission                 | -       | TMRB7 compare match                     | -                |  |  |  |  |  |
| 6                  | Two-phase pulse counter2<br>every count | -       | TMRB0<br>input capture 1                | -                |  |  |  |  |  |
| 7                  | Two-phase pulse counter3<br>every count | -       | TMRB2<br>input capture 0                | -                |  |  |  |  |  |
| 8                  | TMRB8 compare match                     | -       | TMRB2<br>input capture 1                | -                |  |  |  |  |  |
| 9                  | TMRB9 compare match                     | -       | TMRB3<br>input capture 0                | -                |  |  |  |  |  |
| 10                 | TMRB0<br>input capture 0                | -       | TMRB3<br>input capture 1                | -                |  |  |  |  |  |
| 11                 | TMRB4<br>input capture 0                | -       | TMRB6<br>input capture 0                | -                |  |  |  |  |  |
| 12                 | TMRB4<br>input capture 1                | -       | TMRB6<br>input capture 1                | -                |  |  |  |  |  |
| 13                 | TMRB5<br>input capture 0                | -       | Normal AD Conversion End                | -                |  |  |  |  |  |
| 14                 | TMRB5<br>input capture 1                | -       | SSP Transmission                        | SSP Transmission |  |  |  |  |  |
| 15                 | Highest priority AD Conver-<br>sion End | -       | SSP Reception                           | SSP Reception    |  |  |  |  |  |

## Table 6-3 DMA request number chart

# 6.4 Description of Registers

## 6.4.1 DMAC register list

The following lists the each unit and adress:

| Unit x | Base Address |  |  |
|--------|--------------|--|--|
| UnitA  | 0x4000_0000  |  |  |
| UnitB  | 0x4000_1000  |  |  |

| 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         |

Note: Access the registers by using word (32bit) reads and word writes.

Note: Access to the "Reserved" area is prohibited.

Note: For the registers prepared for every channel, if the channel structure is the same, unit and channel number are expressed as "x" and "n" in detail description of registers.

#### 6.4 Description of Registers

|             | 31        | 30        | 29        | 28        | 27        | 26        | 25         | 24         |
|-------------|-----------|-----------|-----------|-----------|-----------|-----------|------------|------------|
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 23        | 22        | 21        | 20        | 19        | 18        | 17         | 16         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9          | 8          |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             |           | •         |           | 4         | 3         | 2         | 1          | 0          |
|             | 7         | 6         | 5         | 4         | 3         | 2         |            | 0          |
| bit symbol  | 7         | -         | 5         | -         | -         | -         | IntStatus1 | IntStatus0 |

# 6.4.2 DMACxIntStatus (DMAC Interrupt Status Register)

| Bit  | Bit Symbol | Туре | Description                                                                                                                                                                                                                                                                                                                                                          |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | W    | Write as zero.                                                                                                                                                                                                                                                                                                                                                       |
| 1    | IntStatus1 | R    | Status of DMAC channel 1 transfer end interrupt.<br>0 : Interrupt not requested<br>1 : Interrupt requested<br>Status of the DMAC interrupt generation after passing through the transfer end interrupt enable register<br>and error interrupt enable register. An interrupt is requested when there is a transfer error or when the coun-<br>ter completes counting. |
| 0    | IntStatus0 | R    | Status of DMAC channel 0 interrupt generation.<br>0 : Interrupt not requested<br>1 : Interrupt requested<br>Status of the DMAC interrupt generation after passing through the transfer end interrupt enable register<br>and error interrupt enable register. An interrupt is requested when there is a transfer error or when the coun-<br>ter completes counting.   |





17

-

Undefined

9

-

Undefined

1

IntTCStatus1

0

16

-

Undefined

8

-

Undefined

0

IntTCStatus0

0

bit symbol

After reset

bit symbol

After reset

bit symbol

After reset

23

-

Undefined

15

-

Undefined

7

Undefined

22

-

Undefined

14

-

Undefined

6

Undefined

|             |           |           |           |           |           |           | -         |           |
|-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
|             |           |           |           |           |           |           | -         |           |
|             | 31        | 30        | 29        | 28        | 27        | 26        | 25        | 24        |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After reset | Undefined |

20

-

Undefined

12

\_

Undefined

4

Undefined

19

-

Undefined

11

-

Undefined

3

Undefined

18

-

Undefined

10

\_

Undefined

2

Undefined

# 6.4.3 DMACxIntTCStatus (DMAC Interrupt Terminal Count Status Register)

21

-

Undefined

13

-

Undefined

5

Undefined

| Bit  | Bit Symbol   | Туре | Description                                                                                                                                                                               |
|------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -            | W    | Write as zero.                                                                                                                                                                            |
| 1    | IntTCStatus1 | R    | Status of DMAC channel 1 transfer end interrupt.<br>0 : Interrupt not requested<br>1 : Interrupt requested<br>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. |

#### 6.4 Description of Registers

# 6.4.4 DMACxIntTCClear (DMAC Interrupt Terminal Count Clear Register)

|             | 31        | 30        | 29        | 28        | 27        | 26        | 25          | 24          |
|-------------|-----------|-----------|-----------|-----------|-----------|-----------|-------------|-------------|
| bit symbol  | -         | -         | -         | -         | -         | -         |             |             |
| After reset | Undefined   | Undefined   |
|             | 23        | 22        | 21        | 20        | 19        | 18        | 17          | 16          |
| bit symbol  | -         | -         | -         | -         | -         | -         | -           | -           |
| After reset | Undefined   | Undefined   |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9           | 8           |
| bit symbol  | -         | -         | -         | -         | -         | -         | -           | -           |
| After reset | Undefined   | Undefined   |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1           | 0           |
| bit symbol  | -         | -         | -         | -         | -         | -         | IntTCClear1 | IntTCClear0 |
| After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0           | 0           |

| Bit  | Bit Symbol  | Туре | Description                                                                                                                                                            |
|------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -           | W    | Write as zero.                                                                                                                                                         |
| 1    | IntTCClear1 | W    | Clear DMAC channel 1 transfer end interrupt.<br>0 : Do nothing<br>1 : Clear<br>The DMACxIntTCStatus <inttcstatus1> will be cleared when "1" is written.</inttcstatus1> |
| 0    | IntTCClear0 | w    | Clear DMAC channel 0 transfer end interrupt.<br>0 : Do nothing<br>1 : Clear<br>The DMACxIntTCStatus <inttcstatus0> will be cleared when "1" is written.</inttcstatus0> |

|             | 31        | 30        | 29        | 28        | 27        | 26        | 25            | 24             |
|-------------|-----------|-----------|-----------|-----------|-----------|-----------|---------------|----------------|
| bit symbol  | -         | -         | -         | -         | -         | -         | -             | -              |
| After reset | Undefined     | Undefined      |
|             | 23        | 22        | 21        | 20        | 19        | 18        | 17            | 16             |
| bit symbol  | -         | -         | -         | -         | -         | -         | -             | -              |
| After reset | Undefined     | Undefined      |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9             | 8              |
| bit symbol  | -         | -         | -         | -         | -         | -         | -             | -              |
| After reset | Undefined     | Undefined      |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1             | 0              |
| bit symbol  | -         | -         | -         | -         | -         | -         | IntErrStatus1 | IIntErrStatus0 |
| After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0             | 0              |

| Bit  | Bit Symbol    | Туре | Description                                                                                                                                                   |
|------|---------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -             | W    | Write as zero.                                                                                                                                                |
| 1    | IntErrStatus1 | R    | Status of DMAC channel 1 error interrupt generation.<br>0 : Interrupt not requested<br>1 : Interrupt requested<br>Shows error interrupt status after enabled. |
| 0    | IntErrStatus0 | R    | Status of DMAC channel 0 error interrupt generation.<br>0 : Interrupt not requested<br>1 : Interrupt requested<br>Shows error interrupt status after enabled. |

#### 6.4 Description of Registers

| 6.4.6 | DMACxIntErrClr (DMAC Interrupt Error Clear Register) |  |
|-------|------------------------------------------------------|--|
|-------|------------------------------------------------------|--|

|             | 31        | 30        | 29        | 28        | 27        | 26        | 25         | 24         |
|-------------|-----------|-----------|-----------|-----------|-----------|-----------|------------|------------|
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 23        | 22        | 21        | 20        | 19        | 18        | 17         | 16         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9          | 8          |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1          | 0          |
| bit symbol  | -         | -         | -         | -         | -         | -         | IntErrClr1 | IntErrClr0 |
| After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0          | 0          |

| Bit  | Bit Symbol | Туре | Description                                                                                                                                                                 |
|------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | W    | Write as zero.                                                                                                                                                              |
| 1    | IntErrClr1 | w    | Clear DMAC channel 1 transfer end interrupt.<br>0 : Do nothing<br>1 : Clear<br>The DMACxIntErrorStatus <interrstatus1> will be cleared when "1" is written.</interrstatus1> |
| 0    | IntErrClr0 | w    | Clear DMAC channel 0 transfer end interrupt.<br>0 : Do nothing<br>1 : Clear<br>The DMACxIntErrorStatus <interrstatus0> will be cleared when "1" is written.</interrstatus0> |

After reset

Undefined

Undefined

Undefined

|             | 31        | 30        | 29        | 28        | 27        | 26        | 25         | 24         |
|-------------|-----------|-----------|-----------|-----------|-----------|-----------|------------|------------|
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 23        | 22        | 21        | 20        | 19        | 18        | 17         | 16         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9          | 8          |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1          | 0          |
| bit symbol  | -         | -         | -         | -         | -         | -         | RawIntTCS1 | RawIntTCS0 |

Undefined

Undefined

Undefined

0

0

## 6.4.7 DMACxRawIntTCStatus (DMAC Raw Interrupt Terminal Count Status Register)

| Bit  | Bit Symbol | Туре | Description                                                                                                                     |
|------|------------|------|---------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | W    | Read undefined. Write as zero.                                                                                                  |
| 1    | RawIntTCS1 | R    | Status of DMAC channel 1 pre-enable transfer end interrupt generation<br>0 : Interrupt not requested<br>1 : Interrupt requested |
| 0    | RawIntTCS0 | R    | Status of DMAC channel 0 pre-enable transfer end interrupt generation<br>0 : Interrupt not requested<br>1 : Interrupt requested |

| 6.4.8 | DMACxRawIntErrorStatus | (DMAC Raw Erro | or Interrupt Status Register) |
|-------|------------------------|----------------|-------------------------------|
|-------|------------------------|----------------|-------------------------------|

|             | 31                 | 30        | 29        | 28        | 27        | 26        | 25          | 24          |
|-------------|--------------------|-----------|-----------|-----------|-----------|-----------|-------------|-------------|
| bit symbol  | -                  | -         | -         | -         | -         | -         | -           | -           |
| After reset | Undefined Undefine |           | Undefined | Undefined | Undefined | Undefined | Undefined   | Undefined   |
|             | 23                 | 22        | 21        | 20        | 19        | 18        | 17          | 16          |
| bit symbol  | -                  | -         | -         | -         | -         | -         | -           | -           |
| After reset | Undefined          | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined   | Undefined   |
|             | 15                 | 14        | 13        | 12        | 11        | 10        | 9           | 8           |
| bit symbol  | -                  | -         | -         | -         | -         | -         | -           | -           |
| After reset | Undefined          | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined   | Undefined   |
|             | 7                  | 6         | 5         | 4         | 3         | 2         | 1           | 0           |
| bit symbol  | -                  | -         | -         | -         | -         | -         | RawIntErrS1 | RawIntErrS0 |
| After reset | Undefined          | Undefined | Undefined | Undefined | Undefined | Undefined | 0           | 0           |

| Bit  | Bit Symbol  | Туре | Description                                                                                                    |
|------|-------------|------|----------------------------------------------------------------------------------------------------------------|
| 31-2 | -           | W    | Read undefined. Write as zero.                                                                                 |
| 1    | RawIntErrS1 | R    | Status of DMAC channel 1 pre-enable error interrupt.<br>0 : Interrupt not requested<br>1 : Interrupt requested |
| 0    | RawIntErrS0 | R    | Status of DMAC channel 0 pre-enable error interrupt.<br>0 : Interrupt not requested<br>1 : Interrupt requested |

# 6.4.9 DMACxEnbldChns (DMAC Enabled Channel Register)

|             | 31        | 30        | 29        | 28        | 27        | 26        | 25         | 24         |
|-------------|-----------|-----------|-----------|-----------|-----------|-----------|------------|------------|
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 23        | 22        | 21        | 20        | 19        | 18        | 17         | 16         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9          | 8          |
| bit symbol  | -         | -         | -         | -         | -         | -         | -          | -          |
| After reset | Undefined  | Undefined  |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1          | 0          |
| bit symbol  | -         | -         | -         | -         | -         | -         | EnabledCH1 | EnabledCH0 |
| After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0          | 0          |

| Bit  | Bit Symbol | Туре | Description                                               |
|------|------------|------|-----------------------------------------------------------|
| 31-2 | -          | W    | Read undefined. Write as zero.                            |
| 1    | EnabledCH1 | R    | DMA channel 1 enable status.<br>0 : Disable<br>1 : Enable |
| 0    | EnabledCH0 | R    | DMA channel 0 enable status.<br>0 : Disable<br>1 : Enable |

# 6.4.10 DMACxSoftBReq (DMAC Software Burst Request Register)

|             | 31         | 30         | 29         | 28         | 27         | 26         | 25        | 24        |
|-------------|------------|------------|------------|------------|------------|------------|-----------|-----------|
| bit symbol  | -          | -          | -          | -          | -          | -          | -         | -         |
| After reset | Undefined  | Undefined  | Undefined  | Undefined  | Undefined  | Undefined  | Undefined | Undefined |
|             | 23         | 22         | 21         | 20         | 19         | 18         | 17        | 16        |
| bit symbol  | -          | -          | -          | -          | -          | -          | -         | -         |
| After reset | Undefined  | Undefined  | Undefined  | Undefined  | Undefined  | Undefined  | Undefined | 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         | 0         |
|             | 7          | 6          | 5          | 4          | 3          | 2          | 1         | 0         |
| bit symbol  | SoftBReq7  | SoftBReq6  | SoftBReq5  | SoftBReq4  | SoftBReq3  | SoftBReq2  | SoftBReq1 | SoftBReq0 |
| After reset | 0          | 0          | 0          | 0          | 0          | 0          | 0         | 0         |

| Bit   | Bit Symbol             | Туре | Description                                                                                                                                                                                                                                             |
|-------|------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -                      | W    | Write as zero.                                                                                                                                                                                                                                          |
| 15    | SoftBReq15             | R/W  | DMA burst request by software (Request No. [15])<br>Read: 0 : DMA Burst under suspension<br>1 : DMA Burst running<br>Write: 0 : Invalid<br>1 : DMA Burst request                                                                                        |
| 14    | SoftBReq14             | R/W  | DMA burst request by software (Request No. [14])<br>Read: 0 : DMA Burst under suspension<br>1 : DMA Burst running<br>Write: 0 : Invalid<br>1 : DMA Burst request                                                                                        |
| 13    | SoftBReq13             | R/W  | DMA burst request by software (Request No. [13])         Read:       0 : DMA Burst under suspension         1 : DMA Burst running         Write:       0 : Invalid         1 : DMA Burst request                                                        |
| 12    | SoftBReq12             | R/W  | DMA burst request by software (Request No. [12])<br>Read: 0 : DMA Burst under suspension<br>1 : DMA Burst running<br>Write: 0 : Invalid<br>1 : DMA Burst request                                                                                        |
| 11    | SoftBReq11             | R/W  | DMA burst request by software (Request No. [11])         Read:       0 : DMA Burst under suspension         1 : DMA Burst running         Write:       0 : Invalid         1 : DMA Burst request                                                        |
| 10    | SoftBReq10             | R/W  | DMA burst request by software (Request No. [10])         Read:       0 : DMA Burst under suspension         1 : DMA Burst running         Write:       0 : Invalid         1 : DMA Burst request                                                        |
| 9     | SoftBReq9<br>SoftBReq8 | R/W  | DMA burst request by software (Request No. [9])         Read:       0 : DMA Burst under suspension         1 : DMA Burst running         Write:       0 : Invalid         1 : DMA Burst request         DMA burst request by software (Request No. [8]) |

| Bit | Bit Symbol | Туре         | Description                                                   |
|-----|------------|--------------|---------------------------------------------------------------|
|     |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid                                            |
|     |            |              | 1 : DMA Burst request                                         |
| 7   | SoftBReq7  | R/W          | DMA burst request by software (Request No. [7])               |
|     |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid                                            |
|     |            |              | 1 : DMA Burst request                                         |
| 6   | SoftBReq6  | R/W          | DMA burst request by software (Request No. [6])               |
|     |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid                                            |
|     |            |              | 1 : DMA Burst request                                         |
| 5   | SoftBReq5  | R/W          | DMA burst request by software (Request No. [5])               |
|     |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid<br>1 : DMA Burst request                   |
|     | 0.000      | <b>D</b> 444 |                                                               |
| 4   | SoftBReq4  | R/W          | DMA burst request by software (Request No. [4])               |
|     |            |              | Read: 0 : DMA Burst under suspension<br>1 : DMA Burst running |
|     |            |              | Write: 0 : Invalid                                            |
|     |            |              | 1 : DMA Burst request                                         |
| 3   | SoftBReg3  | R/W          | DMA burst request by software (Request No. [3])               |
| Ű   |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid                                            |
|     |            |              | 1 : DMA Burst request                                         |
| 2   | SoftBReq2  | R/W          | DMA burst request by software (Request No. [2])               |
|     |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid                                            |
|     |            |              | 1 : DMA Burst request                                         |
| 1   | SoftBReq1  | R/W          | DMA burst request by software (Request No. [1])               |
|     |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid                                            |
|     | ļ          |              | 1 : DMA Burst request                                         |
| 0   | SoftBReq0  | R/W          | DMA burst request by software (Request No. [0])               |
|     |            |              | Read: 0 : DMA Burst under suspension                          |
|     |            |              | 1 : DMA Burst running                                         |
|     |            |              | Write: 0 : Invalid                                            |
|     |            |              | 1 : DMA Burst request                                         |

Sets a DMA burst transfer request by software. When the DMA burst transfer by software is complete, the appropriate bits in SoftBReq are cleared.

Note 1: Do not execute DMA requests by software and hardware peripheral at the same time. Note 2: Refer to "Table 6-3 DMA request number chart" for DMA request number.

# 6.4.11 DMACxSoftSReq (DMAC Software Single Request Register)

| Case of $x = A$ |
|-----------------|
|-----------------|

|             | 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        | 10        | 9         | 8         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After reset | Undefined |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After reset | Undefined |

| Bit  | Bit Symbol | Туре | Description    |
|------|------------|------|----------------|
| 31-0 | -          | W    | Write as zero. |

|             |            |            |           |           |           | _         |           |           |
|-------------|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|
|             | 31         | 30         | 29        | 28        | 27        | 26        | 25        | 24        |
| bit symbol  | -          | -          | -         | -         | -         | -         | -         | -         |
| After reset | Undefined  | Undefined  | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined |
|             | 23         | 22         | 21        | 20        | 19        | 18        | 17        | 16        |
| bit symbol  | -          | -          | -         | -         | -         | -         | -         | -         |
| After reset | Undefined  | Undefined  | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined |
|             | 15         | 14         | 13        | 12        | 11        | 10        | 9         | 8         |
| bit symbol  | SoftSReq13 | SoftSReq13 | -         | -         | -         | -         | -         | -         |
| After reset | 0          | 0          | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined |
|             | 7          | 6          | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | -          | -          | -         | -         | -         | -         | -         | -         |
| After reset | Undefined  | Undefined  | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined |

| Bit   | Bit Symbol | Туре | Description                                        |  |  |  |
|-------|------------|------|----------------------------------------------------|--|--|--|
| 31-16 | -          | W    | Write as zero.                                     |  |  |  |
| 15    | SoftSReq15 | R/W  | /A single request by software (Request No. [15]).  |  |  |  |
|       |            |      | Read: 0 : DMA Single under suspesion               |  |  |  |
|       |            |      | 1 : DMA Single running                             |  |  |  |
|       |            |      | Write: 0 : Invalid                                 |  |  |  |
|       |            |      | 1 : DMA Single request                             |  |  |  |
| 14    | SoftSReq14 | R/W  | DMA single request by software (Request No. [14]). |  |  |  |
|       |            |      | Read: 0 : DMA Single under suspesion               |  |  |  |
|       |            |      | 1 : DMA Single running                             |  |  |  |
|       |            |      | Write: 0 : Invalid                                 |  |  |  |
|       |            |      | 1 : DMA Single request                             |  |  |  |
| 13-0  | -          | W    | Write as zero.                                     |  |  |  |

Sets a DMA single transfer request by software. When the DMA single transfer by software is complete, the appropriate bits in SoftSReq are cleared.

Note 1: Do not execute a DMA request by software when a DMA request by hardware peripheral is generated. Note 2: Refer to "Table 6-3 DMA request number chart" for DMA request number.

|             | 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        | 10        | 9         | 8         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After reset | Undefined |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | -         | -         | -         | -         | -         | -         | М         | E         |
| After reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0         | 0         |

# 6.4.12 DMACxConfiguration (DMAC Configuration Register)

| Bit  | Bit Symbol | Туре | Description                                                                                                                           |
|------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | -    | Read undefined. Write as zero.                                                                                                        |
| 1    | М          | R/W  | DMA endian configuration:                                                                                                             |
|      |            |      | 0 : Little endian                                                                                                                     |
|      |            |      | 1 : Big endian                                                                                                                        |
| 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, al-<br>ways set <e>="1".</e> |

|             | 31 | 30      | 29 | 28   | 27   | 26 | 25 | 24 |  |  |  |
|-------------|----|---------|----|------|------|----|----|----|--|--|--|
| bit symbol  |    | SrcAddr |    |      |      |    |    |    |  |  |  |
| After reset | 0  | 0       | 0  | 0    | 0    | 0  | 0  | 0  |  |  |  |
|             | 23 | 22      | 21 | 20   | 19   | 18 | 17 | 16 |  |  |  |
| bit symbol  |    |         |    | Src/ | Addr |    |    |    |  |  |  |
| After reset | 0  | 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  | 0  |  |  |  |
|             | 7  | 6       | 5  | 4    | 3    | 2  | 1  | 0  |  |  |  |
| bit symbol  |    |         |    | Src/ | Addr |    |    |    |  |  |  |
| After reset | 0  | 0       | 0  | 0    | 0    | 0  | 0  | 0  |  |  |  |

### 6.4.13 DMACxCnSrcAddr (DMAC Channeln Source Address Register)

| Bit  | Bit Symbol    | Туре |                                                                                                                          | ã@ì\                                                       |  |  |  |  |
|------|---------------|------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--|--|--|--|
| 31-0 | SrcAddr[31:0] | R/W  | Sets a DMA transfer source address.<br>Make sure to confirm the source addre<br>The below are the restrictions in settin | C C                                                        |  |  |  |  |
|      |               |      | Source address bit width<br>DMACxCnControl <swidth[2:0]></swidth[2:0]>                                                   | Setting of least significant address                       |  |  |  |  |
|      |               |      | 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.

|             | 31 | 30       | 29 | 28   | 27   | 26 | 25 | 24 |  |  |  |
|-------------|----|----------|----|------|------|----|----|----|--|--|--|
| bit symbol  |    | DestAddr |    |      |      |    |    |    |  |  |  |
| 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  | 0  |  |  |  |
|             | 15 | 14       | 13 | 12   | 11   | 10 | 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  |    |          |    | Dest | Addr |    |    |    |  |  |  |
| After reset | 0  | 0        | 0  | 0    | 0    | 0  | 0  | 0  |  |  |  |

### 6.4.14 DMACxCnDestAddr (DMAC Channeln Destination Address Register)

| Bit  | Bit Symbol     | Туре |                                                                                                                             | Description                                                |  |  |  |  |  |
|------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--|--|--|--|--|
| 31-0 | DestAddr[31:0] | R/W  | Sets a DMA transfer destination addre<br>Make sure to confirm the destination a<br>The below are the restrictions in settir | address and the bit width before setting.                  |  |  |  |  |  |
|      |                |      | Destination address bit width<br>DMACxCControl <dwidth[2:0]></dwidth[2:0]>                                                  | Setting of least significant address                       |  |  |  |  |  |
|      |                |      | 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 $\leq E \geq ="0"$ ) before change.

|             | 31 | 30  | 29 | 28 | 27 | 26 | 25   | 24   |  |  |  |
|-------------|----|-----|----|----|----|----|------|------|--|--|--|
| bit symbol  |    | LLI |    |    |    |    |      |      |  |  |  |
| After reset | 0  | 0   | 0  | 0  | 0  | 0  | 0    | 0    |  |  |  |
|             | 23 | 22  | 21 | 20 | 19 | 18 | 17   | 16   |  |  |  |
| bit symbol  |    |     |    | L  | LI |    |      |      |  |  |  |
| After reset | 0  | 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    | 0    |  |  |  |
|             | 7  | 6   | 5  | 4  | 3  | 2  | 1    | 0    |  |  |  |
| bit symbol  |    |     | L  | LI |    |    | -    | -    |  |  |  |
| After reset | 0  | 0   | 0  | 0  | 0  | 0  | ïsíË | ïsíË |  |  |  |

# 6.4.15 DMACxCnLLI (DMAC Channelx Linked List Item Register)

| Bit  | Bit Symbol | Туре | Description                                                                                                                                     |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | LLI[29:0]  | R/W  | Sets the first address of the next transfer information.                                                                                        |
|      |            |      | Set a value smaller than 0xFFFF_FFF0.<br>When <lli> = 0, LLI is the last chain. After DMA transfer finishes, the DMA channel is disabled.</lli> |
| 1-0  | -          | R/W  | Read undefined. Write as zero.                                                                                                                  |

For <LLI> detailed operation, see "6.5 Special Functions".

# 6.4.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  |        |           | DBSize    |  |
| After reset | 0      | 0         | 0         | 0         | 0       | 0      | 0         | 0         |  |
|             | 15     | 14        | 13        | 12        | 11      | 10     | 9         | 8         |  |
| bit symbol  | DBSize |           | SBSize    |           |         | Transf | ferSize   |           |  |
| After reset | 0      | 0         | 0         | 0         | 0       | 0      | 0         | 0         |  |
|             | 7      | 6         | 5         | 4         | 3       | 2      | 1         | 0         |  |
| bit symbol  |        |           |           | Transf    | ferSize |        |           |           |  |
| After reset | 0      | 0         | 0         | 0         | 0       | 0      | 0         | 0         |  |

| 31       Image: Second Se                                                                                                                                                                                                                                | Bit   | Bit Symbol  | Туре | Description                                                                                                                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1: Enable     1: Enable       The transfer end interrupt is generated by setting<br>to generate the transfer end interrupt is anable only at the last transfer. To generate interrupt during nor-<br>national transfer. To generate interrupt is anable only at the last transfer. To generate interrupt during nor-<br>interrupt is anable only at the last transfer. To generate interrupt during nor-<br>is bit to "1" and change to enable mode.       30-28     -     W     Wite as zero.       27     DI     RW     Increment the transfer destination address<br>0: Do not increment<br>1: increment       28-24     -     W     Wite as zero.       28-24     -     W     Wite as zero.       29-21     Dudith[2:0]     RW     Increment the transfer source address<br>0: Do not increment<br>1: increment       29-24     -     W     Wite as zero.       29-27     Dudith[2:0]     RW     Transfer destination bit width.<br>000: Byte (8 bits)<br>010: Word (32 bits)<br>o10: 1 beat     101: 64 beats<br>o111: 64 beats       17-15     DSIZE[2:0]     RW     Transfer destination bit width words width width word<br>Word (16 bi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 31    | 1           | R/W  | Register for enabling a transfer interrupt.                                                                                                                                                                                 |
| 1     Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |             |      | 0 : Disable                                                                                                                                                                                                                 |
| 14.10     BSI26[2:0]     RVW     Wite as zero.       27     D1     RVM     Increment the transfer destination address<br>0: Do not increment<br>1: increment       26     S1     RVM     Increment the transfer destination address<br>0: Do not increment<br>1: increment       25:24     -     W     Write as zero.       23:21     Didth[2:0]     RVM     Increment the transfer source address<br>0: Do not increment<br>1: increment       25:24     -     W     Write as zero.       25:24     -     W     Write as zero.       23:21     Dudth[2:0]     RVM     Increment to transfer source address<br>0: Do not increment<br>1: increment       00: Byte (8 bits)<br>001: Haf-word (16 bits)<br>001: Word (32 bits)<br>001: Word (32 bits)<br>001: Haf-word (16 bits)<br>001: Haf-w                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |             |      | 1 : Enable                                                                                                                                                                                                                  |
| 27       DI       R/W       Increment the transfer destination address<br>0 : Do not increment<br>1 : Increment         26       SI       R/W       Increment the transfer source address<br>0 : Do not increment<br>1 : Increment         25-24       -       W       Write as zero.         23-21       Dwidth[2:0]       R/W       Transfer destination bit width.<br>000 : Byte (8 bits)<br>010 : Word (32 bits)<br>011 : Half-word (16 bits)<br>012 : Word (32 bits)<br>013 : Word (32 bits)<br>014 : Half-word (16 bits)<br>015 : Word (32 bits)<br>016 : Word (32 bits)<br>017 : Half-word (16 bits)<br>018 : Half-word (16 bits)<br>019 : Word (32 bits)<br>010 : 1 beat         17-15       DBSize[2:0]       R/W       Transfer destination burst size: (Note 1)<br>000 : 1 beat       100 : 32 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)<br>000 : 1 beat       100 : 32 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)<br>000 : 1 beat       100 : 32 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |             |      | 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 nor- |
| 26       SI       R/W       Increment         26.       SI       R/W       Increment the transfer source address<br>0: Do not increment<br>1: Increment         25.24       -       W       Write as zero.         23-21       Dwidth[2:0]       R/W       Transfer destination bit width.<br>000: Byte (8 bits)<br>001: Half-word (16 bits)<br>010: Word (32 bits)<br>010: Half-word (16 bits)<br>010: Word (32 bits)<br>010: Half-word (16 bits)<br>010: Word (32 bits                                                                                                                                                                    | 30-28 | -           | W    | Write as zero.                                                                                                                                                                                                              |
| 1: Increment         26       SI       RW       Increment the transfer source address<br>0: Do not increment<br>1: Increment         25-24       -       W       Wite as zero.         23-21       Dwidth[2:0]       R/W       Transfer destination bit width.<br>000: Byte (8 bits)<br>01: Half-word (16 bits)<br>010: Word (32 bits)<br>010: Word (32 bits)<br>010: Half-word (16 bits)<br>010: Word (32 bits)<br>010: Word (32 bits)<br>010: Word (32 bits)<br>010: Half-word (16 bits)<br>010: Half-word                                                                                                                                                                          | 27    | DI          | R/W  | Increment the transfer destination address                                                                                                                                                                                  |
| 26       SI       R/W       Increment the transfer source address<br>0 : Do not increment<br>1 : increment         25-24       -       W       Write as zero.         23-21       Dwidth[2:0]       R/W       Transfer destination bit width.<br>000 : Byte (8 bits)<br>01 : Haff-word (16 bits)<br>010 : Word (32 bits)<br>011 : 4 beats         17-15       DBSize[2:0]       R/W       Transfer destination burst size: (Note 1)<br>000 : 1 beat       100: 32 beats<br>001: 4 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)       000: 1 beat       100: 32 beats<br>011: 16 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)       000: 1 beat       100: 32 beats<br>011: 4 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)       000: 1 beat       100: 32 beats<br>011: 64 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |             |      | 0 : Do not increment                                                                                                                                                                                                        |
| 25-24       -       W       Write as zero.         23-21       Dwidth[2:0]       R/W       Transfer destination bit width.<br>000: Byte (8 bits)<br>011: Haff-word (16 bits)<br>010: Word (32 bits)<br>010: Word (32 bits)<br>010: Word (32 bits)<br>010: Word (32 bits)<br>010: Byte (8 bits)<br>010: Byte (8 bits)<br>010: Word (32 bits)<br>011: 16 beats<br>011: 16 beats<br>011: 16 beats<br>011: 12 8beats<br>011: 16 beats<br>011: 16 beats |       |             |      | 1 : Increment                                                                                                                                                                                                               |
| 1Increment25-24-WWrite as zero.23-21Dwidth[2:0]R/WTransfer destination bit width.<br>000 : Byte (8 bits)<br>01 : Half-word (16 bits)<br>010 : Word (32 bits)<br>010 : Word (32 bits)<br>010 : Word (32 bits)<br>010 : Word (32 bits)<br>010 : Half-word (16 bits)<br>010 : Word (32 bits)<br>010 : Half-word (16 bits)<br>010 : Word (32 bits)<br>010 : Half-word (16 bits)<br>010 : Word (32 bits)<br>other: Reserved20-18Swidth[2:0]R/WTransfer source bit width<br>000: Byte (8 bits)<br>010 : Word (32 bits)<br>other: Reserved20-18Dissize[2:0]R/WTransfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)17-14SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-14SBSize[2:0]R/WTransfer source burst size: (Note 1)14-15SBSize[2:0]R/WTransfer source burst size: (Note 1)14-16SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 26    | SI          | R/W  | Increment the transfer source address                                                                                                                                                                                       |
| 25-24       -       W       Write as zero.         23-21       Dwidth[2:0]       R/W       Transfer destination bit width.<br>000: Byte (8 bits)<br>011 : Half-word (16 bits)<br>010 : Word (32 bits)<br>other: Reserved       Normalian         20-18       Swidth[2:0]       R/W       Transfer source bit width<br>000: Byte (8 bits)<br>001: Half-word (16 bits)<br>001: Half-word (16 bits)<br>010 : Word (32 bits)<br>010 : Half-word (16 bits)<br>010 : Word (32 bits)<br>010 : Half-word (16 bits)<br>010 : Word (32 bits)<br>011 : Half-word (16 bits)<br>011 : Half-word (16 bits)<br>011 : Half-word (16 bits)<br>011 : Half-word (16 bits)         17-15       DBSize[2:0]       R/W       Transfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.         17-15       DBSize[2:0]       R/W       Transfer destination burst size: (Note 1)<br>000: 1 beat 100: 32 beats<br>011: 16 beats 111: 256 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)<br>000: 1 beat 100: 32 beats<br>001: 4 beats 101: 64 beats<br>001: 4 beats 101: 64 beats<br>001: 4 beats 101: 64 beats         010: 1 beat 100: 32 beats       001: 4 beats 101: 64 beats<br>001: 4 beats 101: 64 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |             |      | 0 : Do not increment                                                                                                                                                                                                        |
| 23-21       Dwidth[2:0]       R/W       Transfer destination bit width.<br>000 : Byte (8 bits)<br>011 : Half-word (16 bits)<br>010 : Word (32 bits)<br>other: Reserved         20-18       Swidth[2:0]       R/W       Transfer source bit width<br>000: Byte (8 bits)<br>010 : Word (16 bits)<br>001: Half-word (16 bits)<br>010 : Word (32 bits)<br>010 : Half-word (16 bits)<br>010 : Word (32 bits)<br>010 : Half-word (16 bits)         17-15       DBSize[2:0]       R/W       Transfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.         17-15       DBSize[2:0]       R/W       Transfer destination burst size: (Note 1)<br>000: 1 beat 100: 32 beats<br>011: 4 beats 101: 64 beats<br>010: 8 beats 111: 256 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)<br>000: 1 beat 100: 32 beats<br>011: 16 beats 111: 256 beats         14-12       SBSize[2:0]       R/W       Transfer source burst size: (Note 1)<br>000: 1 beat 100: 32 beats<br>011: 4 beats 101: 64 beats<br>010: 8 beats 110: 128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |             |      | 1 : Increment                                                                                                                                                                                                               |
| 11-12SBSize[2:0]RWTransfer source but width.14-12SBSize[2:0]RWTransfer source but width so that the transfer size becames an integral multiple of the transfer destination bit width.14-12SBSize[2:0]RWTransfer destination but size: (Note 1)10:116 beats111:16 beats111:126 beats16 beats011:16 beats17:15RWTransfer destination but size: (Note 1)14:12RWTransfer destination but size: (Note 1)14:12SBSize[2:0]RWTransfer source burst size: (Note 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 25-24 | -           | W    | Write as zero.                                                                                                                                                                                                              |
| 20-18Swidth[2:0]R/WTransfer source bit width<br>000: Byte (8 bits)<br>001: Half-word (16 bits)<br>000: Byte (8 bits)<br>001: Half-word (16 bits)<br>001: Half-word (16 bits)<br>001: Half-word (16 bits)<br>010: Word (32 bits)<br>other: Reserved20-18Swidth[2:0]R/WTransfer source bit width<br>000: Byte (8 bits)<br>001: Half-word (16 bits)<br>010: Word (32 bits)<br>other: Reserved17-15DBSize[2:0]R/WTransfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)100:1 beat100:32 beats<br>101:14-12SBSize[2:0]R/WTransfer size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer sour                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 23-21 | Dwidth[2:0] | R/W  | Transfer destination bit width.                                                                                                                                                                                             |
| 1010: Word (32 bits)<br>other: Reserved20-18Swidth[2:0]R/WTransfer source bit width<br>000: Byte (8 bits)<br>011: Half-word (16 bits)<br>010: Word (32 bits)<br>other: Reserved101: Word (32 bits)<br>other: ReservedNover (16 bits)<br>010: Word (32 bits)<br>other: Reserved17-15DBSize[2:0]R/WTransfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.17-15DBSize[2:0]R/WTransfer destination buts size: (Note 1)17-16DBSize[2:0]R/WTransfer destination buts size: (Note 1)17-17DBSize[2:0]R/WTransfer destination buts size: (Note 1)17-18DBSize[2:0]R/WTransfer destination buts size: (Note 1)17-19DBSize[2:0]R/WTransfer destination buts size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |             |      | 000 : Byte (8 bits)                                                                                                                                                                                                         |
| Image: constraint of the constra                                                                                                                                                                                                        |       |             |      |                                                                                                                                                                                                                             |
| 20-18Swidth[2:0]R/WTransfer source bit width<br>000: Byte (8 bits)<br>001: Half-word (16 bits)<br>010 : Word (32 bits)<br>other: Reserved17-15DBSize[2:0]R/WTransfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)<br>000: 1 beat100: 32 beats<br>011: 64 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)<br>000: 1 beat100: 32 beats<br>011: 16 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)<br>000: 1 beat100: 32 beats<br>011: 64 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)<br>000: 1 beat100: 32 beats<br>011: 64 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)<br>000: 1 beat100: 32 beats<br>101: 64 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)<br>000: 1 beat100: 32 beats<br>101: 64 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |             |      |                                                                                                                                                                                                                             |
| NumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumberNumbe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |             |      |                                                                                                                                                                                                                             |
| 17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)100:1 beat100:32 beats101:4 beats101:64 beats101:4 beats101:64 beats101:4 beats101:32 beats101:1 beat101:32 beats101:4 beats101:64 beats101:8 beats101:64 beats101:8 beats101:128 beats11:128 beats101:128 beats11:128 beats110:128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 20-18 | Swidth[2:0] | R/W  |                                                                                                                                                                                                                             |
| Image: height served010 : Word (32 bits)<br>other: Reserved17-15DBSize[2:0]R/WSet a transfer destination bit width.17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)17-16DBSize[2:0]R/WTransfer destination burst size: (Note 1)17-17DBSize[2:0]R/WTransfer destination burst size: (Note 1)17-18BSize[2:0]R/WTransfer destination burst size: (Note 1)17-19BBSize[2:0]R/WTransfer destination burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |             |      |                                                                                                                                                                                                                             |
| Image: height of the servedother: ReservedSet a transfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)100:1 beat100:32 beats000:1 beat101:64 beats010:8 beats111:256 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)100:1 beat100:32 beats101:1 beat100:32 beats101:1 beat100:32 beats101:1 beat101:4 beats11:1 beat101:128 beats11:1 beat101:128 beats11:1 beats101:128 beats11:1 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |      |                                                                                                                                                                                                                             |
| Instant of the transfer destination bit width so that the transfer size becomes an integral multiple of the transfer destination bit width.17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)000: 1 beat100: 32 beats001: 4 beats101: 64 beats010: 8 beats110: 128 beats011: 16 beats111: 256 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)000: 1 beat100: 32 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)000: 1 beat100: 32 beats001: 4 beats101: 64 beats001: 4 beats101: 64 beats001: 4 beats101: 64 beats001: 8 beats101: 128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |      |                                                                                                                                                                                                                             |
| IndexInitiation bit width.17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)17-15DBSize[2:0]R/WTransfer destination burst size: (Note 1)14-12SBSize[2:0]R/W100: 8 beats14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)14-12SBSize[2:0]R/WTransfer source burst size: (Note 1)100: 1 beat100: 32 beats101: 8 beats101: 64 beats101: 8 beats101: 64 beats101: 8 beats101: 64 beats101: 8 beats101: 128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |      |                                                                                                                                                                                                                             |
| 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         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         001:       4 beats       101:       64 beats         001:       8 beats       101:       128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |      | 5 I                                                                                                                                                                                                                         |
| 14-12         SBSize[2:0]         R/W         Transfer source burst size: (Note 1)         100: 32 beats           001: 4 beats         101: 64 beats         101: 16 beats         111: 256 beats           100: 1 beat         100: 32 beats         100: 32 beats           001: 4 beats         101: 64 beats         101: 128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 17-15 | DBSize[2:0] | R/W  | Transfer destination burst size: (Note 1)                                                                                                                                                                                   |
| Image: Mark Series         Mark Series <td></td> <td></td> <td></td> <td>000: 1 beat 100: 32 beats</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |      | 000: 1 beat 100: 32 beats                                                                                                                                                                                                   |
| 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         101: 64 beats         101: 128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |             |      | 001: 4 beats 101: 64 beats                                                                                                                                                                                                  |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |             |      | 010: 8 beats 110: 128 beats                                                                                                                                                                                                 |
| 000:         1 beat         100:         32 beats           001:         4 beats         101:         64 beats           010:         8 beats         110:         128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |      | 011: 16 beats 111: 256 beats                                                                                                                                                                                                |
| 001:       4 beats       101:       64 beats         010:       8 beats       110:       128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 14-12 | SBSize[2:0] | R/W  | Transfer source burst size: (Note 1)                                                                                                                                                                                        |
| 010: 8 beats 110: 128 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |      | 000: 1 beat 100: 32 beats                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |             |      | 001: 4 beats 101: 64 beats                                                                                                                                                                                                  |
| 011: 16 beats 111: 256 beats                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |      | 010: 8 beats 110: 128 beats                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |             |      | 011: 16 beats 111: 256 beats                                                                                                                                                                                                |

# TOSHIBA

| Bit  | Bit Symbol             | Туре | Description                                                                                                                                      |
|------|------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 11-0 | TransferSize<br>[11:0] | R/W  | Set the total number of transfers.<br>Set the total number of transfers. This value decrements to "0" as DMAC transfer is executed. The read op- |
|      |                        |      | eration reads the number of transfers that have been executed or transfer size is read as "0" when trans-<br>fer have not been executed.         |
|      |                        |      | The total number of transfers is used as the unit for the transfer source bit width.<br>For examples:                                            |
|      |                        |      | When <swidth>="000" (8bit), the number of transfers is expressed in the units of byte.</swidth>                                                  |
|      |                        |      | When <swidth>="001" (16bit), the number of transfers is expressed in the units of half word.</swidth>                                            |
|      |                        |      | When <swidth>="010" (32bit), the number of transfers is expressed in the units of word.</swidth>                                                 |

| <dwidth[2:0]> /<br/><swidth[2:0]></swidth[2:0]></dwidth[2:0]> | Set the number so that the following expression is satisfied:<br>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 \div 16 = 26 half_word$                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                                               | Since 26 is an integer number, the above setting is valid.                                                                                                                                                                                                                                                   |  |  |  |  |  |
| <dbsize[2:0]> /<br/><sbsize[2:0]></sbsize[2:0]></dbsize[2:0]> | When peripheral to memory transfer or memory to peripheral transfer is performed, peripheral circuits gen-<br>erates DMA request signal to indicate the preparation is ready. This signal triggers to execute data trans-<br>fers. (In the case of memory to memory transfers, 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.                                                                                                                             |  |  |  |  |  |

Note 1: The burst size to be set with DBsize and SBsize has nothing to do with the HBURST for the AHB bus.

# 6.4.17 DMACxCnConfiguration (DMAC Channelx 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         | 0         |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
| bit symbol  | ITC       | IE        | FlowCntrl |           | -         | DestPe    | ripheral  |           |
| After reset | 0         | 0         | 0         | 0         | 0         | Undefined | 0         | 0         |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | DestPe    | ripheral  | -         |           | SrcPer    | ripheral  |           | E         |
| After reset | 0         | 0         | Undefined | 0         | 0         | 0         | 0         | 0         |

| Bit   | Bit Symbol              | Туре |                                                                                                                                                                                                 | Descripti                                                                            | on |  |  |
|-------|-------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----|--|--|
| 31-19 | -                       | W    | Write as zero.                                                                                                                                                                                  |                                                                                      |    |  |  |
| 18    | Halt                    | R/W  | Controls accepting a DMA request<br>0 : Accept a DMA request<br>1 : Ignore a DMA request                                                                                                        |                                                                                      |    |  |  |
| 17    | Active                  | R    | Indicates whether data is present in the channel FIFO.<br>0 : No data exists in the FIFO<br>1 : Data exists in the FIFO                                                                         |                                                                                      |    |  |  |
| 16    | Lock                    | R/W  | <ul><li>0 : Disable locked transfer</li><li>1: Enable locked transfer</li><li>When locked transfer is enable</li></ul>                                                                          |                                                                                      |    |  |  |
| 15    | ITC                     | R/W  | Transfer end interrupt enable register.<br>0 : Disable interrupt<br>1 : Enable interrupt                                                                                                        |                                                                                      |    |  |  |
| 14    | IE                      | R/W  | Error interrupt enable regis<br>0 :Disable interrupt<br>1: Enable interrupt                                                                                                                     |                                                                                      |    |  |  |
| 13-11 | FlowCntrl[2:0]          | R/W  | Sets transfer method (Note                                                                                                                                                                      | e 1)                                                                                 |    |  |  |
|       |                         |      | <flowcntrl[2:0]><br/>setting value</flowcntrl[2:0]>                                                                                                                                             | Transfer method                                                                      |    |  |  |
|       |                         |      | 000:                                                                                                                                                                                            | Memory to Memory                                                                     |    |  |  |
|       |                         |      | 001:                                                                                                                                                                                            | Memory to Peripheral                                                                 |    |  |  |
|       |                         |      | 010:                                                                                                                                                                                            | Peripheral to Memory                                                                 |    |  |  |
|       |                         |      | 011:                                                                                                                                                                                            | Peripheral to Peripheral                                                             |    |  |  |
|       |                         |      | 100~111:                                                                                                                                                                                        | Reserved                                                                             |    |  |  |
| 10    | -                       | W    | Write as zero.                                                                                                                                                                                  |                                                                                      |    |  |  |
| 9-6   | DestPeripheral<br>[3:0] | R/W  | Sets transfer destination peripheral (Note 2)<br>000 to 111<br>The DMA request peripheral number is expressed by binary.<br>When a memory is the transfer destination, this setting is ignored. |                                                                                      |    |  |  |
| 5     | -                       | W    | Write as zero.                                                                                                                                                                                  |                                                                                      |    |  |  |
| 4-1   | SrcPeripheral<br>[3:0]  | R/W  |                                                                                                                                                                                                 | neral (Note 2)<br>al number is expressed by bin<br>nsfer source, this setting is ign |    |  |  |

| Bit | Bit Symbol | Туре | Description                                                                                                                                                                                  |
|-----|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | E          | R/W  | Channel enable                                                                                                                                                                               |
|     |            |      | 0 : Disable                                                                                                                                                                                  |
|     |            |      | 1 : Enable                                                                                                                                                                                   |
|     |            |      | This bit can be used to enable/disable the channels. 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> bit, and poll the data until the <active> bit 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. Writing to <E>= 1 starts transfer.

Note 2: Refer to Table 6-3 for DMA request peripheral number.

# 6.5 Special Functions

### 6.5.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.

### 6.5.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 0x00000000.



When transferring data in the area enclosed by the square



| Setting register | Setting parameter |
|------------------|-------------------|
|                  |                   |

| +0 | DMACxCnSrcAddr | :0x0A200 |  |
|----|----------------|----------|--|
|    |                |          |  |

- +4 DMACxCnDestAddr :Destination address 1
- +8 DMACxCnLL :0x200000
- +C DMACxCnControl :Set the number of burst transfers and the number of transfers, etc.

#### Linked List



# 7. Reset

The TMPM341FDXBG/FYXBG has four reset sources: an external reset pin ( $\overline{\text{RESET}}$ ), a watchdog timer (WDT), an oscillation frequency detection (OFD) and the setting  $\langle \text{SYSRESETREQ} \rangle$  in the Application Interrupt and Reset Control Register.

For reset from the WDT, refer to the chapter on the WDT.

For reset from the OFD, refer to the chapter on the OFD.

For reset from <SYSRESETREQ>, refer to "Cortex-M3 Technical Reference Manual".

### 7.1 Initial state

The internal circuits, register settings and pin status of the TMPM341FDXBG/FYXBG are undefined right after the power-on. The state continues until the RESET pin receives low level input after all the power supply voltage (DVDD3A, RVDD3, AVDD3 and DVDD3B) is applied.

### 7.2 Cold reset

The power-on sequence must include the time for the internal regulator to be stable and the reset time. In the TMPM341FDXBG/FYXBG, the internal regulator requires at least 1ms to be stable.

At cold reset, the external reset pin must be kept "Low" for a duration of time sufficiently long enough for the internal regulator to be stable. If you use one of four power sources (DVDD3A, DVDD3B, RVDD3, AVDD3) with a different voltage, or you use only DVDD3B with a different voltage (1.65V), set the power supply to satisfy the following condition: DVDD3A=RVDD3=AVDD3 rising time (time to guaranteed operating voltage)  $\leq$  DVDD3B rising time (time to guaranteed operating voltage).

After the external reset (RESET) signal is released, the internal reset signal remains asserted for a further 400  $\mu$ s.

Figure 7-1 shows the power-on sequence.



Figure 7-1 Cold Reset Sequence

- Note 1: Turn on the power while the RESET pin is fixed to "Low". Release the RESET pin while all the power supplies are stabilized within operating voltage (DVDD3A/DVDD3B/RVDD3/AVDD3) and after an elapse of 1ms or more from while all the power supplies are stabilized within operating voltage.
- Note 2: The above sequence is applied as well when restoring power.

## 7.3 Warm reset

### 7.3.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 #!Undefined!#, assert the  $\overline{\text{RESET}}$  signal (active low) for a minimum duration of 12 systemclocks (1.2µs at internal oscillator). And When the  $\overline{\text{RESET}}$  signal input at "Low" level while in STOP2 mode, the  $\overline{\text{RESET}}$  signal is fixed to "Low" more than 500µs as internal regulator stability time.

After the external reset ( $\overline{\text{RESET}}$ ) signal is released, the internal reset signal remains asserted for a further 400 µs.

### 7.3.2 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 following factors. And FCSECBIT register is initialized by STOP2 mode released.

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.

The factor of register initialization

| Register      | Factors    |                           |  |  |  |  |
|---------------|------------|---------------------------|--|--|--|--|
| CGRSTFLG      | Cold reset | External Reset            |  |  |  |  |
| FCSECBIT      | Cold reset | STOP2 mode released       |  |  |  |  |
| FPB, DWT, ITM | Cold reset | STOP2 mode released (Note |  |  |  |  |

Note: When a debug tool is connecting, these registers are not initialized.

7. Reset

#### 7.3 Warm reset

# 8. Ocsillation Frequency Detector (OFD)

The oscillation frequency detector circuit (OFD) detects abnormal clock frequency. To use the OFD, abnormal states of clock such as a harmonic, a subharmonic or stopped state can be detected.

The OFD monitors the target clock frequency using reference frequency and generates a reset signal if abnormal state is detected. TMPM341FDXBG/FYXBG uses internal high-speed oscillator clock as a reference and the target clock is an external high-speed oscillator clock.

Note: It is not guaranteed that OFD can detect all defects at any time, and it is not a circuit to measure error frequency.

# 8.1 Block diagram



Figure 8-1 Ocsillation Frequency Detector Block diagram

# 8.2 Registers

### 8.2.1 Register List

|                                             |         | Base Address = 0x400F_1000 |
|---------------------------------------------|---------|----------------------------|
| Register name                               |         | Address(Base+)             |
| Control register 1                          | OFDCR1  | 0x0000                     |
| Control register 2                          | OFDCR2  | 0x0004                     |
| Lower detection frequency setting register  | OFDMN   | 0x0008                     |
| Reserved                                    | -       | 0x000C                     |
| Higher detection frequency setting register | OFDMX   | 0x0010                     |
| Reserved                                    | -       | 0x0014                     |
| Reset control register                      | OFDRST  | 0x0018                     |
| Status register                             | OFDSTAT | 0x001C                     |

Note: Access to the "Reserved" area is prohibited.

### 8.2.1.1 OFDCR1 (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  | -  | -      | -  | -  | -  | -  | -  | -  |  |
| 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  | 0  |  |
|             | 7  | 6      | 5  | 4  | 3  | 2  | 1  | 0  |  |
| bit symbol  |    | OFDWEN |    |    |    |    |    |    |  |
| After reset | 0  | 0      | 0  | 0  | 0  | 1  | 1  | 0  |  |

| Bit  | Bit Symbol  | Туре | Description                                                                                                                                                                      |
|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -           | R    | Read as 0.                                                                                                                                                                       |
| 7-0  | OFDWEN[7:0] | R/W  | Controls register write<br>0x06: Disable<br>0xF9: Enable<br>Setting 0xF9 enables to write registers except OFDCR1.<br>When writing a value except 0x06 or 0xF9, 0x06 is written. |
|      |             |      | If writing register is disabled, reading from each register is enabled.                                                                                                          |

#### 8.2 Registers

|             | 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  | 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  |    |    |    | OFI | DEN |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

### 8.2.1.2 OFDCR2 (Control register 2)

| Bit  | Bit Symbol | Туре | Description                                                                                                                                       |
|------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                        |
| 7-0  | OFDEN[7:0] | R/W  | Controls frequency detecting.<br>0x00: Disable<br>0xE4: Enable<br>Writing a value except 0x00 or 0xE4 is invalid and a value will not be changed. |

|             | 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  | 0     |
|             | 15 | 14 | 13 | 12 | 11  | 10 | 9  | 8     |
| bit symbol  | -  | -  | -  | -  | -   | -  | -  | OFDMN |
| After reset | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0     |
|             | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0     |
| bit symbol  |    |    |    | OF | OMN |    |    |       |
| After reset | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0     |

### 8.2.1.3 OFDMN (Lower detection frequency setting register)

| Bit  | Bit Symbol | Туре | Description                     |
|------|------------|------|---------------------------------|
| 31-9 | -          | R    | Read as 0.                      |
| 8-0  | OFDMN[8:0] | R/W  | Sets lower detection frequency. |

Note: Writing to the register of OFDMN is protected while OFD circuit is operating.

#### 8.2.1.4 OFDMX (Higher detection frequency 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  | -  | -  | -  | -   | -   | -  | -  | -     |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0     |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8     |
| bit symbol  | -  | -  | -  | -   | -   | -  | -  | OFDMX |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0     |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0     |
| bit symbol  |    |    |    | OFI | ОМХ |    |    |       |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0     |

| Bit  | Bit Symbol | Туре | Description                      |
|------|------------|------|----------------------------------|
| 31-9 | -          | R    | Read as 0.                       |
| 8-0  | OFDMX[8:0] | R/W  | Sets higher detection frequency. |

Note: Writing to the register of OFDMX is protected while OFD circuit is operating.

|             | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | OFDRSTEN |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1        |

## 8.2.1.5 OFDRST (Reset control register)

| Bit  | Bit Symbol | Туре | Description                  |
|------|------------|------|------------------------------|
| 31-1 | -          | R    | Read as 0.                   |
| 0    | OFDRSTEN   | R/W  | Controls generating a reset. |
|      |            |      | 0: Disable                   |
|      |            |      | 1: Enable                    |

Note: Writing to the register of OFDRST is protected while OFD circuit is operating.

### 8.2.1.6 OFDSTAT (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  | -  | -  | -  | -  | -  | -  | -       | -      |
| 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       | 0      |
|             | 7  | 6  | 5  | 4  | 3  | 2  | 1       | 0      |
| bit symbol  | -  | -  | -  | -  | -  | -  | OFDBUSY | FRQERR |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0      |

| Bit  | Bit Symbol | Туре | Description                                     |
|------|------------|------|-------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                      |
| 1    | OFDBUSY    | R    | OFD operation<br>0: Run<br>1: Stop              |
| 0    | FRQERR     | R    | Error detecting flag<br>0: No Error<br>1: Error |

# 8.3 Operational Description

### 8.3.1 Enabling and Disabling the Oscillation Frequency Detection

Writing "0xE4" to OFDCR2 with OFDCR1="0xF9" enables the oscillation frequency detection, and writing "0x00" to OFDCR2 with OFDCR1="0xF9" disables the oscillation frequency detection.

Setting "0xF9" to OFDCR1 enables writing to OFDCR2 and setting "0x06" to OFDCR1 disables writing to OFDCR2. Reading from OFDCR2 is always enabled without setting of OFDCR1. OFDCR1 is initialized to "0x06" by external reset and OFDCR2 is initialized to "0x00" by external reset.

After writing data to OFDCR2, set "0x06" to OFDCR1 to protect OFDCR2 register.

### 8.3.2 Operation

From the operation start-up to detection start-up, time length as two cycle of detecting clock is needed.

OFDSTAT<OFDBSY> can confirm whether it is operating. Detecting cycle is (reference clock frequency) /  $2^{8}$ MHz.

When generating reset is enabled, OFD generates reset if the target clock frequency exceeds the frequency limit set by OFDMN and OFDMX. OFD reset operates same as the warm reset and OFD itself is also reset.

When generating reset is disabled, OFDSTAT<FRQERR> can be confirmed the condition

Note: There are several factors of reset. Clock generator register CGRSTFLG can confirm the factors. For details of CGRSTFLG see chapter "exception."

### 8.3.3 Detection Frequency

The detection frequency have a detection frequency range and an undetectable frequency range because of oscillation accuracy. Therefore, it is undefined whether to be detected between detection frequency range and undetectable it.

Figure 8-2 shows the detection or undetectable frequency range when the target clock error is  $\pm 10\%$  and the reference clock error is  $\pm 5\%$ .



Figure 8-2 Example of detection frequency range (in case of 10MHz)

The higher and lower limit of the detection frequency is calculated from the maximum error of the target clock and the reference.

How to calculate the setup value of OFDMN/OFDMX is shown below when the target clock error is  $\pm 10\%$  and the reference clock error is  $\pm 5\%$ .

| target clock          | 10MHz ± 10% | Max.11MHz   | <br>а |
|-----------------------|-------------|-------------|-------|
| (f <sub>EHOSC</sub> ) |             | Min. 9MHz   | <br>b |
| reference clock       |             | Max.10.5MHz | <br>с |
| (f <sub>IHOSC</sub> ) | 10MHz ± 5%  | Min. 9.5MHz | <br>d |

```
higher limit of the detection frequency= 1 ÷ {(d + 2<sup>8</sup>) ÷ (a ÷ 4)}lower limit of the detection frequency= 1 ÷ {(c + 28) ÷ (b ÷ 4)}higher limit of the detection frequency= 1 ÷ {( 0.5 × 10<sup>6</sup> + 2<sup>8</sup> ) ÷ ( 11 × 10<sup>6</sup> ÷ 4 )}lower limit of the detection frequency= 1 ÷ {( 10.5 × 10<sup>6</sup> ÷ 2<sup>8</sup> ) ÷ ( 9 × 10<sup>6</sup> ÷ 4 )}= 1 ÷ {( 10.5 × 10<sup>6</sup> ÷ 2<sup>8</sup> ) ÷ ( 9 × 10<sup>6</sup> ÷ 4 )}= 54.85 = 55 (round up after the decimal places)
```

Setting "0x74" to the register OFDMX and "0x55" to the register OFDMN, when the external oscillation of higher than 11MHz or lower than 9MHz is detected, the oscillation frequency detector outputs a reset signal.

#### 8.3.4 Available Operation Mode

The oscillation frequency detection is available only in NORMAL and IDLE mode. Before shifting to another mode, disable the oscillation frequency detection.

### 8.3.5 Example of Operational Procedure

The example of operational procedure is shown below.

After reset, confirms various reset factor by CGRSTFLG. If the reset factor is not by the oscillation frequency detect, enable external oscillation, set register to use OFD and enable operation. Reset output must be disabled at this time.

After waiting the OFD operation is started, confirms abnormal status flag, and if there is not abnormal status, change to external oscillation clock.



Figure 8-3 Example of operational procedure

# 9. 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".

Note: This product does not have the watchdog timer out pin ( $\overline{\text{WDTOUT}}$ ).

### 9.1 Configuration

Figure 9-1shows the block diagram of the watchdog timer.



Figure 9-1 Block Diagram of the Watchdog Timer

# 9.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                     |

# 9.2.1 WDMOD(Watchdog Timer 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  | -    | -  | -    | -  | -  | -     | -     | -  |
| 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     | 0  |
|             | 7    | 6  | 5    | 4  | 3  | 2     | 1     | 0  |
| bit symbol  | WDTE |    | WDTP |    | -  | I2WDT | RESCR | -  |
| After reset | 1    | 0  | 0    | 0  | 0  | 0     | 1     | 0  |

| Bit  | Bit Symbol | Туре |                                               | Function                   |  |  |
|------|------------|------|-----------------------------------------------|----------------------------|--|--|
| 31-8 | -          | R    | Read as 0.                                    |                            |  |  |
| 7    | WDTE       | R/W  | Enable/Disable control                        | Enable/Disable control     |  |  |
|      |            |      | 0:Disable                                     |                            |  |  |
|      |            |      | 1:Enable                                      |                            |  |  |
| 6-4  | WDTP[2:0]  | R/W  | Selects WDT detection time(Ref                | er toTable 9-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    | 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.                                      | Write 0.                   |  |  |

Note: INTWDT interrupt is a factor of the non-maskable interrupts (NMI).

| 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.82 ms                       | 3.28 ms  | 13.11 ms  | 52.43 ms  | 209.72 ms | 838.86 ms |  |
| 100 (fc/2)                      | 1.63 ms                       | 6.55 ms  | 26.21 ms  | 104.86 ms | 419.43 ms | 1.68 s    |  |
| 101 (fc/4)                      | 3.28 ms                       | 13.11 ms | 52.43 ms  | 209.72 ms | 838.86 ms | 3.36 s    |  |
| 110 (fc/8)                      | 6.55 ms                       | 26.21 ms | 104.86 ms | 419.43 ms | 1.68 s    | 6.71 s    |  |
| 111 (fc/16)                     | 13.12 ms                      | 52.43 ms | 209.72 ms | 838.86 ms | 3.36 s    | 13.42 s   |  |

### Table 9-1 Detection time of watchdog timer (fc = 40 MHz)

## 9.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  | -    | -  | -  | -  | -  | -  | -  | -  |
| 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  | 0  |
|             | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| bit symbol  | WDCR |    |    |    |    |    |    |    |
| After reset | -    | -  | -  | -  | -  | -  | -  | -  |

| Bit  | Bit Symbol | Туре | Function           |
|------|------------|------|--------------------|
| 31-8 | -          | R    | Read as 0.         |
| 7-0  | WDCR       | W    | Disable/Clear code |
|      |            |      | 0xB1:Disable code  |
|      |            |      | 0x4E: Clear code   |
|      |            |      | Others:Reserved    |

# 9.3 Operations

### 9.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^{15}$ ,  $2^{17}$ ,  $2^{19}$ ,  $2^{21}$ ,  $2^{23}$  and  $2^{25}$  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.

Note: This product does not include a watchdog timer out pin (WDTOUT).

### 9.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.

- STOP1 mode
- STOP2 mode

In IDLE mode, its operation depends on the WDMOD <I2WDT> setting.

Also, the binary counter is automatically stopped during debug mode.

# TOSHIBA

# 9.4 Operation when malfunction (runaway) is detected

## 9.4.1 INTWDT interrupt generation

In the Figure 9-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.

Note: This product does not have the watchdog timer output pin(WDTOUT).



Figure 9-2 INTWDT interrupt generation

#### 9.4.2 Internal reset generation

Figure 9-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 9-3 Internal reset generation

## 9.5 Control register

The watchdog timer (WDT) is controlled by two control registers WDMOD and WDCR.

## 9.5.1 Watchdog Timer Mode Register (WDMOD)

1. 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 "1".

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.

## 9.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.

#### 9.5.3 Setting example

#### 9.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.

7 6 5 4 3 2 1 0 WDMOD 0 Set <WDTE> to "0". \_ WDCR 0 0 0 1 Writes the disable code (0xB1). 0 1 1 1

#### 9.5.3.2 Enabling control

Set WDMOD <WDTE> to "1".

 7
 6
 5
 4
 3
 2
 1
 0

 WDMOD
 ←
 1
 Set <WDTE> to "1".

#### 9.5.3.3 Watchdog timer clearing control

Writing the clear code (0x4E) to the WDCR register clears the binary counter and it restarts counting.

7 6 5 4 3 2 1 0 WDCR 0 Writes the clear code (0x4E). 0 1 0 0 1 1 1

#### 9.5.3.4 Detection time of watchdog timer

In the case that  $2^{21}$ /fsys is used, set "011" to WDMOD<WDTP[2:0]>.

# 10. Clock/Mode control

## 10.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 TMPM341FDXBG/FYXBG can operate in three types of low power mode to reduce power consumption according to its usage conditions.

# 10.2 Registers

## 10.2.1 Register List

The following table shows the CG-related registers and addresses.

|                                 |           | Base Address = 0x400F_3000 |
|---------------------------------|-----------|----------------------------|
| Register name                   |           | Address(Base+)             |
| System control register         | CGSYSCR   | 0x0000                     |
| Oscillation control register    | CGOSCCR   | 0x0004                     |
| Standby control register        | CGSTBYCR  | 0x0008                     |
| PLL selection register          | CGPLLSEL  | 0x000C                     |
| System clock selection register | CGCKSEL   | 0x0010                     |
| Timer clock setup register      | CGPWMGEAR | 0x0014                     |
| Reserved                        | -         | 0x0038                     |
| Protect register                | CGPROTECT | 0x003C                     |

Note: Access to the "Reserved" area is prohibited.

|             | 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 | -  | -  | SCC  | SEL |
| After reset | 0  | 0  | 0  | 0      | 0  | 0  | 0    | 1   |
|             | 15 | 14 | 13 | 12     | 11 | 10 | 9    | 8   |
| bit symbol  | -  | -  | -  | FPSEL  | -  |    | PRCK |     |
| After reset | 0  | 0  | 0  | 0      | 0  | 0  | 0    | 0   |
|             | 7  | 6  | 5  | 4      | 3  | 2  | 1    | 0   |
| bit symbol  | -  | -  | -  | -      | -  |    | GEAR |     |
| After reset | 0  | 0  | 0  | 0      | 0  | 0  | 0    | 0   |

# 10.2.2 CGSYSCR (System control register)

| Bit   | Bit Symbol  | Туре | Function                                                                                  |
|-------|-------------|------|-------------------------------------------------------------------------------------------|
| 31-21 | -           | R    | Read as 0.                                                                                |
| 20    | FCSTOP      | R/W  | ADC clock                                                                                 |
|       |             |      | 0: Active                                                                                 |
|       |             |      | 1: Stop                                                                                   |
|       |             |      | Enables to stop providing ADC clock.                                                      |
|       |             |      | ADC clock is provided after reset.                                                        |
|       |             |      | Confirming that ADC is stopped or finished in advance is required when setting "1"(stop). |
| 19-18 | -           | R    | Read as 0.                                                                                |
| 17-16 | SCOSEL[1:0] | R/W  | SCOUT out                                                                                 |
|       |             |      | 00: Reserved                                                                              |
|       |             |      | 01: fsys/2                                                                                |
|       |             |      | 10: fsys                                                                                  |
|       |             |      | 11: φΤΟ                                                                                   |
|       |             |      | Enables to output the specified clock from SCOUT pin.                                     |
| 15-13 | -           | R    | Read as 0.                                                                                |
| 12    | FPSEL       | R/W  | fperiph                                                                                   |
|       |             |      | 0: fgear                                                                                  |
|       |             |      | 1: fc                                                                                     |
|       |             |      | Specifies the source clock to fperiph.                                                    |
|       |             |      | Selecting fc fixes fperiph regardless of the clock gear mode.                             |
| 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 110: Reserved                                                              |
|       |             |      | 011: fperiph/8 111: Reserved                                                              |
|       |             |      | Specifies the prescaler clock to peripheral I/O.                                          |
| 7-3   | -           | R    | Read as 0.                                                                                |
| 2-0   | GEAR[2:0]   | R/W  | High-speed clock gear (fc) gear                                                           |
|       |             |      | 000: fc 100: fc/2                                                                         |
|       |             |      | 001: Reserved 101: fc/4                                                                   |
|       |             |      | 010: Reserved 110: fc/8                                                                   |
|       |             |      | 011: Reserved 111: fc/16                                                                  |

# 10.2.3 CGOSCCR (Oscillation control register)

|             | 31 | 30 | 29  | 28 | 27      | 26       | 25     | 24    |
|-------------|----|----|-----|----|---------|----------|--------|-------|
| bit symbol  |    |    |     | WU | ODR     |          |        |       |
| After reset | 1  | 0  | 0   | 0  | 0       | 0        | 0      | 0     |
|             | 23 | 22 | 21  | 20 | 19      | 18       | 17     | 16    |
| bit symbol  |    | WU | ODR |    | HWUPSEL | EHOSCSEL | OSCSEL | XEN2  |
| After reset | 0  | 0  | 0   | 0  | 0       | 0        | 0      | 1     |
|             | 15 | 14 | 13  | 12 | 11      | 10       | 9      | 8     |
| bit symbol  | -  | -  | -   | -  | -       | -        | -      | XEN1  |
| After reset | 0  | 0  | 0   | 0  | 0       | 0        | 0      | 0     |
|             | 7  | 6  | 5   | 4  | 3       | 2        | 1      | 0     |
| bit symbol  | -  | -  | -   | -  | -       | PLLON    | WUEF   | WUEON |
| After reset | 0  | 0  | 1   | 1  | 0       | 0        | 0      | 0     |

| Bit   | Bit Symbol  | Туре | Function                                                                 |
|-------|-------------|------|--------------------------------------------------------------------------|
| 31-20 | WUODR[11:0] | R/W  | Warm-up counter setup value.                                             |
|       |             |      | Setup the 16-bit timer for warm-up timer of upper 12-bits counter value. |
| 19    | HWUPSEL     | R/W  | High-speed warm-up clock.                                                |
|       |             |      | 0: internal (f <sub>IHOSC</sub> )                                        |
|       |             |      | 1: external (f <sub>EHOSC</sub> )                                        |
|       |             |      | Selects warm-up counter by high-speed oscillator.                        |
| 18    | EHOSCSEL    | R/W  | External oscillator.                                                     |
|       |             |      | 0: input external clock                                                  |
|       |             |      | 1: external crystal oscillator                                           |
| 17    | OSCSEL      | R/W  | High-speed oscillator                                                    |
|       |             |      | 0: internal high-speed oscillator                                        |
|       |             |      | 1: external high-speed oscillator                                        |
|       |             |      | Selects warm-up counter by high-speed oscillator.                        |
| 16    | XEN2        | R/W  | Internal high-speed oscillator operation                                 |
|       |             |      | 0: Stop                                                                  |
|       |             |      | 1: Oscillation                                                           |
| 15-12 | -           | R/W  | Write "0" after reset.                                                   |
| 11-10 | -           | R    | Read as 0.                                                               |
| 9     | -           | R/W  | Write "0".                                                               |
| 8     | XEN1        | R/W  | External high-speed oscillator mode                                      |
|       |             |      | 0: Stop                                                                  |
|       |             |      | 1: Oscillation                                                           |
| 7-3   | -           | R/W  | Write "00110"                                                            |
| 2     | PLLON       | R/W  | PLL (multiplying circuit) operation                                      |
|       |             |      | 0: Stop                                                                  |
|       |             |      | 1: Oscillation                                                           |
|       |             |      | As the status is "Stop" after reset, resetting is required.              |
| 1     | WUEF        | R    | Operation of warm-up timer (WUP) for oscillator                          |
|       |             |      | 0: WUP finish                                                            |
|       |             |      | 1: WUP active                                                            |
|       |             |      | Enables to monitor the status of the warm-up timer.                      |
| 0     | WUEON       | W    | Operation of warm-up timer (WUP) for oscillator                          |
|       |             |      | 0: don't care                                                            |
|       |             |      | 1: WUP start                                                             |
|       |             |      | Enables to start the warm-up timer.                                      |
|       |             |      | Read as 0.                                                               |

Note 1: Refer to Section "3.4.6.7 Warm-up" about the Warm-up setup.

Note 2: When selecting external oscillator ( input external clock), select <OSCSEL> after setting <EHOSCSEL>. (Do not select simultaneously)

# TOSHIBA

- Note 3: After setting PLL multiplying value, to keep CGOSCCR<PLLON>="0"(PLL stop) over 100µs is needed as the PLL initializing stable time.
- Note 4: After setting CGOSCCR<PLLON>=1, operate Warm-up operation and then set CGPLLSEL<PLLSEL>=1.
- Note 5: Returning from the STOP1/STOP2 mode, related bits <HWUPSEL>, <OSCSEL>, <XEN2>, <XEN1>, <PLLON> of the register CGOSCCR and CGPLLSEL<PLLSEL> are initialized because of internal high-speed oscillator starts up.
- Note 6: When using internal high-speed oscillator (IHOSC) as system clock, do not use PLL multiplying.
- Note 7: When using internal high-speed oscillator (IHOSC), do not use it as system clock which high accuracy assurance is required.

# 10.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      | 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  | -  | -  | -  | -  | -  |    | STBY   |      |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 1      | 1    |

| Bit   | Bit Symbol | Туре | Function                              |
|-------|------------|------|---------------------------------------|
| 31-20 | -          | R    | Read as 0.                            |
| 19-18 | -          | R/W  | Write "0" after reset.                |
| 17    | PTKEEP     | R/W  | Keeps IO control signal in STOP2 mode |
|       |            |      | 0: Control by port                    |
|       |            |      | 1: Keep status when setting 0->1      |
| 16    | DRVE       | R/W  | Pin status in STOP1 mode.             |
|       |            |      | 0: Inactive in STOP1 mode             |
|       |            |      | 1: Active in STOP1 mode               |
| 15-3  | -          | R    | Read as 0.                            |
| 2-0   | STBY[2:0]  | R/W  | Low power consumption mode            |
|       |            |      | 000: Reserved                         |
|       |            |      | 001: STOP1                            |
|       |            |      | 010: Reserved                         |
|       |            |      | 011: IDLE                             |
|       |            |      | 100: Reserved                         |
|       |            |      | 101: STOP2                            |
|       |            |      | 110: Reserved                         |
|       |            |      | 111: Reserved                         |

|             | 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  | 0      |
|             | 15 | 14 | 13 | 12     | 11  | 10 | 9  | 8      |
| bit symbol  |    | -  | -  | PLL    | SET |    |    |        |
| After reset | 0  | 0  | 0  | 0      | 0   | 0  | 0  | 0      |
|             | 7  | 6  | 5  | 4      | 3   | 2  | 1  | 0      |
| bit symbol  |    |    |    | PLLSET |     |    |    | PLLSEL |
| After reset | 0  | 0  | 0  | 0      | 0   | 0  | 0  | 0      |

## 10.2.5 CGPLLSEL (PLL Selection Register)

| Bit   | Bit Symbol   | Туре | Function                                                                                                                                                                                                                                                       |
|-------|--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -            | R    | Read as 0.                                                                                                                                                                                                                                                     |
| 15-1  | PLLSET[14:0] | R/W  | PLL multiplying value (Do not use except below)<br>0x303D: 16 multiplying<br>0x281D: 8 multiplying                                                                                                                                                             |
| 0     | PLLSEL       | R/W  | Use of PLL<br>0: f <sub>osc</sub><br>1: f <sub>pll</sub> / 4 (PLL use)<br>Specifies use or disuse of the clock multiplied by the PLL.<br>"fosc (internal high-speed oscillator)" is automatically set after reset.Resetting is required when using the<br>PLL. |

Note 1: Select PLL multiplying value which is shown in Table 10-2 and Table 10-3.

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µs is needed as the PLL initializing stable time.

Note 4: Returning from the STOP1/STOP2 mode, related bits <PLLSEL>, CGOSCCR<HWUPSEL>, <OSCSEL>, <XEN2>, <XEN1>, and <PLLON> are initialized because of internal high-speed oscillator starts up.

Note 5: When using internal high-speed oscillator (IHOSC) as system clock, do not use PLL multiplying.

|                           | 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  | 0  |
|                           | 15  | 14 | 13     | 12 | 11 | 10 | 9  | 8  |
| bit symbol                | -   | -  | -      | -  | -  | -  | -  | -  |
|                           |     |    |        |    |    |    |    |    |
| After reset               | 0   | 0  | 0      | 0  | 0  | 0  | 0  | 0  |
| After reset               | 0 7 | 0  | 0<br>5 | 0  | 0  | 0  | 0  | 0  |
| After reset<br>bit symbol |     | -  | -      | -  |    |    |    | -  |

# 10.2.6 CGCKSEL (System clock selection register)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-2 | -          | R    | Read as 0. |
| 1    | -          | R/W  | Write "0". |
| 0    | -          | R    | Read as 0. |

# 10.2.7 CGPWMGEAR (Timer 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  | 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  | -  | -  | PWM | GEAR | -  | -  | -  | TMRDCLKEN |
| After reset | 0  | 0  | 1   | 1    | 0  | 0  | 0  | 0         |

| Bit  | Bit Symbol       | Туре | Function                                                                                                            |
|------|------------------|------|---------------------------------------------------------------------------------------------------------------------|
| 31-6 | -                | R    | Read as 0.                                                                                                          |
| 5-4  | PWMGEAR<br>[1:0] | R/W  | Source clock<br>00 : fpll<br>01 : fpll / 2<br>10 : fpll / 4<br>11 : Reserved<br>Selects source clock to TMRD block. |
| 3-1  | -                | R    | Read as 0.                                                                                                          |
| 0    | TMRDCLKEN        | R/W  | Provides TMRDCLK to TMRD<br>0 : Stop (OFF)<br>1 : Setup (ON)                                                        |

Note 1: Do not set <PWMGEAR> and <TMRDCLKEN> simultaneously. When selecting TMRD, first stop providing clock <TMRDCLKEN>="0" then select source clock <PWMGEAR[1:0]>. After that provide clock by setting <TMRDCLKEN>="1".

Note 2: When changing source clock by <PWMGEAR>, set TMRD stop (<TMRDCLKEN>="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  | -  | -  | -  | -    | -     | -  | -  | -  |
| 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  | 0  |
|             | 7  | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
| bit symbol  |    |    |    | CGPR | OTECT |    |    |    |
| After reset | 1  | 1  | 0  | 0    | 0     | 0  | 0  | 1  |

# 10.2.8 CGPROTECT (Protect register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                            |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                          |
| 7-0  | CGPROTECT  | R/W  | Register protection control, 0x400F_3000 to 0x400F_303B: write configuration to each register<br>0xC1 : Register write enable<br>Except 0xC1 : Register write disable<br>Initial value is "0xC1" as writing enable to each register and when writing except "0xC1", each register ex-<br>cept CGPROTECT regiser can not be written. |

# TOSHIBA

## 10.3 Clock control

## 10.3.1 Clock System Block Diagram

Each clock is defined as follows:

| fosc    | : Clock generated by internal oscillator. Clock input from the X1 and X2 pins. |
|---------|--------------------------------------------------------------------------------|
| fpll    | : Clock multiplied by 8 or 16 by PLL.                                          |
| fc      | : Clock specified by CGPLLSEL <pllsel> (high-speed clock)</pllsel>             |
| fgear   | : Clock specified by CGSYSCR <gear[2:0]></gear[2:0]>                           |
| fsys    | : Clock specified by same as fgear clock (system clock)                        |
| fperiph | : Clock specified by CGSYSCR <fpsel></fpsel>                                   |
| φT0     | : Clock specified by CGSYSCR <prck[2:0]> (prescaler clock)</prck[2:0]>         |

The high-speed clock fc, the prescaler clock  $\phi$ T0, and high-resolution PPG clock fpll are dividable as follows.

| High-speed clock          | : fc, fc/2, fc/4, fc/8, fc/16                                      |
|---------------------------|--------------------------------------------------------------------|
| Prescaler clock           | : fperiph, fperiph/2, fperiph/4, fperiph/8, fperiph/16, fperiph/32 |
| high-resolution PPG clock | : fpll/2, fpll/4                                                   |

## 10.3.2 Initial Values after Reset

Reset operation initializes the clock configuration as follows.

| internal high-speed oscillator  | : oscillating                |
|---------------------------------|------------------------------|
| external high-speed oscillator  | : stop                       |
| PLL (phase locked loop circuit) | : stop                       |
| High-speed clock gear           | : fc (no frequency dividing) |

Reset operation causes all the clock configurations to be the same as fosc.

 $\begin{aligned} & \text{fc} = \text{fosc} \\ & \text{fsys} = \text{fosc} \\ & \phi\text{T0} = \text{fosc} \end{aligned}$ 

For example, reset operation configures fsys as 10MHz, An internal 10MHz oscillator starts after releasing reset signal.

## 10.3.3 Clock system Diagram

Figure 10-1 shows the clock system diagram.

The input clocks to selector shown with an arrow are set as default after reset.



Figure 10-1 Clock Block Diagram

#### 10.3.4 Warm-up function

The warm-up function secures the stability time for the oscillator and the PLL with the warm-up timer. When using external clock inputting, Warm-up function is not necessary when using stable external clock.

How to configure the warm-up function.

1. Specify the count up clock

Specify the count up clock for the warm-up counter in the CGOSCCR<HWUPSEL> bit.

2. Specify the warm-up counter value

The warm-up time can be selected by setting the CGOSCCR<WUODR[11:0]>. The value can be calculated by following formula with round lower 4 bit off, set to the bit of <WUODR[11:0]>.

Note: Setting warm-up count value to CGOSCCR<WUDOR[11:0]>, wait until this value is reflected, then transit to standby mode by executing a command "WFI"

Warm-up time equation and setup example are shown below.

number of warm-up cycle =  $\frac{\text{warm-up time to set}}{\text{input frequency cycle (s)}}$ 

Note: 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.

<example 1> When using high-speed oscillator 8MHz, and set warm-up time 5ms.

 $\frac{\text{warm-up time to set}}{\text{input frequency cycle (s)}} = \frac{5\text{ms}}{1/8\text{MHz}} = 4000 \text{ cycle} = 0x9C40$ 

Round lower 4 bit off, set 0x9C4 to CGOSCCR<WUODR[11:0]>

3. confirm the start and completion of warm-up

The CGOSCCR<WUEON><WUEF> is used to confirm the start and completion of warm-up through software (instruction). When CGOSCCR<WUEON> is set to "1", the warm-up start a count up. The completion of warm-up can be confirmed with CGOSCCR<WUEF>.

The example of warm-up function setup.

# Table 10-1 <example> from STOP mode to NORMAL mode transition (internal high-speed oscillator is selected)

| CGOSCCR <wuodr[11:0]> = "0x9C4"</wuodr[11:0]> | : Specify the warm-up time                                                  |
|-----------------------------------------------|-----------------------------------------------------------------------------|
| CGOSCCR <wuodr[11:0]> read</wuodr[11:0]>      | : Confirm warm-up time reflecting<br>Repaet until the read data is "0x9C4". |
| CGOSCCR <xen2> = "1"</xen2>                   | : high-speed oscillator (fosc) enable                                       |
| CGOSCCR <wueon> = "1"</wueon>                 | : Start the warm-up timer (WUP)                                             |
| CGOSCCR <wuef> read</wuef>                    | : Wait until the state becomes "0" (warm-up is finished)                    |
|                                               |                                                                             |

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.
- Note 3: After setting warm-up count value to OSCCR<WUDOR>, wait until confirming of the value to be reflected, then change to the standby mode by WFI instruction.
- Note 4: When returning from STOP1/STOP2 mode, related bits CGPLLSEL<PLLSEL>, CGOSCCR<HWUPSEL>, <OS-CSEL>, <XEN2>, <XEN1> and <PLLON> are initialized because of internal high-speed oscillator starting, and CGOSCCR<WUDOR[11:0]> is not initialized.

### 10.3.5 Clock Multiplication Circuit (PLL)

This circuit outputs the fpll clock that is multiplied by 8 or 16 of the high-speed oscillator output clock (fosc). As a result, the input frequency to oscillator can be low frequency, and the internal clock be made high-speed.

#### 10.3.5.1 How to configure the PLL function

The PLL is disabled after reset. To enable the PLL, set CGPLLSEL register's PLL multiplying value after CGOSCCR<PLLON> bit is set to "0", and then set CGOSCCR<PLLON> bit set to "1". As CGPLLSEL<PLLSEL> bit is set to "1", the fpll clock which is multiplied by 8 or 16 from fosc is output.

The PLL requires a certain amount of time to be stabilized, which should be secured using the warmup function or other methods.

Note 1: It takes approximately 100µs for the PLL to be stabilized.

Note 2: When using internal high-speed oscillator (IHOSC) as system clock, do not use PLL multiplying.

As for the 8 or 16 multiplying value, only the following setting are permitted.

| Multiplying | <pllsel></pllsel> |
|-------------|-------------------|
| 8           | 0x281D            |
| 16          | 0x303D            |

When the operation starting PLL and the multiplying value are changed, it is necessary to secure the stability time. For a detail, refer to next section.

#### 10.3.5.2 Stability time

The PLL requires a certain amount of time to be stabilized, which should be secured using the warmup function or other methods.

When the  $\langle PLLON \rangle$  is set to "1" and operation starts, it is necessary to take approximately 100µs as the Lock-up time.

The <PLLON> is first made "0" when the multiplying value is changed and PLL is stopped. When the multipling <PLLSEL> value is changed, the <PLLON> is set to "1" after approximately 100µs elapses as initialization time of PLL, and the state of PLL starts. Afterwards, please secure the Lock-up time.

PLL setup sequence and multiplying value change sequence are shown as follows.

#### (1) PLL setup secuence



#### (2) Multiplying value change sequence



Possible to use the multiplied system clock

#### 10.3.6 System clock

The internal high-speed oscillation clock and the external high-speed oscillation clocks which are an oscillator connecting or an inputting clock can be used as a source clock of the system clock.

When using internal high-speed oscillation clock, do not use it as system clock which high accuracy assurance is required.

When using external high-speed oscilltion clock, the PLL function can be used by multiplying.

| Sou                 | rce clock                            | Frequency  | Using PLL             |  |
|---------------------|--------------------------------------|------------|-----------------------|--|
| Internal high-spe   | ed oscillation (f <sub>IHOSC</sub> ) | 10MHz      | can not use           |  |
| External high-speed | Oscillator (f <sub>EHOSC</sub> )     | 8 to 16MHz | 0 og 40 gruttigt ig g |  |
| oscillation         | Input clock (f <sub>EHCLKIN</sub> )  | 8 to 27MHz | 8 or 16 multiplying   |  |

The clock generated with PLL by multiplying is used by high resolution PPG output function. Moreover, the clock four dividing can be used as a system clock and an ADC clock. The frequency that can be used respectively is as follows.

|                              | System clock | ADC clock | High-resolution<br>PPG clock |
|------------------------------|--------------|-----------|------------------------------|
| Operation frequency<br>(MHz) | 1 to 54      | 40 (Max.) | 160 (Max.)                   |

The system clock can be divided by CGSYSCR<GEAR>. Although the setting can be changed while operating, the actual switching takes place after a slight delay.

Table 10-2 shows the example of the operation frequency by the setting of PLL and the clock gear.

| External oscillator | External<br>clock input | PLL         | Max. oper-<br>ation freq. PLL = ON |             |             | Clock gear (CG)<br>PLL = OFF |                           |      |      |      |      |      |      |     |     |     |      |
|---------------------|-------------------------|-------------|------------------------------------|-------------|-------------|------------------------------|---------------------------|------|------|------|------|------|------|-----|-----|-----|------|
| (MHz)               | (MHz)                   | multiplying | multiplying                        | multiplying | multiplying | multiplying                  | multiplying (fc)<br>(MHz) | 1/1  | 1/2  | 1/4  | 1/8  | 1/16 | 1/1  | 1/2 | 1/4 | 1/8 | 1/16 |
| 8                   | 8                       |             | 32                                 | 32          | 16          | 8                            | 4                         | 2    | 8    | 4    | 2    | 1    | -    |     |     |     |      |
| 10                  | 10                      | 16          | 40                                 | 40          | 20          | 10                           | 5                         | 2.5  | 10   | 5    | 2.5  | 1.25 | -    |     |     |     |      |
| 13.5                | 13.5                    |             | 54                                 | 54          | 27          | 13.5                         | 6.75                      | 3.38 | 13.5 | 6.75 | 3.38 | 1.69 | -    |     |     |     |      |
| 16                  | 16                      | 0           | 32                                 | 32          | 16          | 8                            | 4                         | 2    | 16   | 8    | 4    | 2    | 1    |     |     |     |      |
| -                   | 27                      | 8           | 54                                 | 54          | 27          | 13.5                         | 6.75                      | 3.38 | 27   | 13.5 | 6.75 | 3.38 | 1.69 |     |     |     |      |

Table 10-2 System clock frequency when PLL is 8 times or 16 times

↑ Initial value after reset

Table 10-3 shows when the high resolution PPG output function (TMRD), the AD converter function or the flash memory is used, the frequency that can be used respectively.

| External<br>oscillator<br>(MHz) | External<br>clock input<br>(MHz) | PLL<br>multiplying | Max. oper-<br>ation freq.<br>(fc)<br>(MHz) | TMRD<br>Max. oper-<br>ation freq.<br>(MHz) | ADC<br>Max. oper-<br>ation freq.<br>(MHz) | INTLV pin<br>setting<br>(Note3 |
|---------------------------------|----------------------------------|--------------------|--------------------------------------------|--------------------------------------------|-------------------------------------------|--------------------------------|
| 8                               | 8                                |                    | 32                                         | 128                                        | 32                                        | Pull-down                      |
| 10                              | 10                               | 16                 | 40                                         | 160                                        | 40                                        | Pull-down                      |
| 13.5                            | 13.5                             |                    | 54                                         | 108 <sub>(Note1</sub>                      | 27 <sub>(Note2</sub>                      | Pull-up                        |
| 16                              | 16                               |                    | 32                                         | 128                                        | 32                                        | Pull-down                      |
| -                               | 27                               | 8                  | 54                                         | 108 (Note1                                 | 27 <sub>(Note2</sub>                      | Pull-up                        |

Table 10-3 Peripheral system clock setting example when PLL is 8 times or 16 times

Note 2: Maximum Operating Frequency of ADC(AD convertor) is 40MHz, which is 2 dividing fc/2 frequency specified by ADCLK<ADCLK.> register.

Note 3: The INTLV pin setting for the flash interleave access is defined by the maximum operation frequency (fc) that the INTLV pin must be set to Pull-down setting when the value of fc is less than 40MHz, mean-while, the INTLV pin must be set to Pull-up setting when the value of fc is over 40MHz.

Note 1: Maximum Operating Frequency of TMRD (high resolution PPG) is 160MHz, which is 2 dividing fpll/2 frequency specified by CGPWMGEAR<PWMGEAR[1:0]> register.

#### 10.3.6.1 Clock setting

The system clock can be selected by setting the CGOSCCR register. After the clock is selected, the PLL setting is done if necessary with CGPLLSEL and CGOSCCR registers. And, the clock gear is set with CGSYSCR register.

The clock setup sequence is shown as follow.



#### 10.3.6.2 When using external oscillator

This product activates from an internal high-speed oscillator after releasing reset. When an external high-speed oscillator and Clock multiplication circuit (PLL) are used, it sets it according to the procedure of "10.3.5 Clock Multiplication Circuit (PLL)" and "10.3.6.1 Clock setting".

The following figures show the transition when external high-speed oscillator and clock multiplication circuit are used.



Figure 10-2 Transition when high-speed oscillator is set with PLL

## 10.3.7 Prescaler Clock Control

Peripheral IO (TMRB,SIO,SBI) has a prescaler for dividing a clock. As the clock  $\varphi$ T0 to be input to each prescaler, the "fperiph" clock specified in the CGSYSCR<FPSEL> can be divided according to the setting in the CGSYSCR<PRCK[2:0]>. After the controller is reset, fperiph/1 is selected as  $\varphi$ T0.

Note: To use the clock gear, ensure that you make the time setting such that prescaler output  $\phi$ Tn from each peripheral function is slower than fsys ( $\phi$ Tn < fsys). Do not switch the clock gear while the timer counter or other peripheral function is operating.

## 10.3.8 System Clock Pin Output Function

The TX03 enables to output the system clock from a pin. The SCOUT pin can output the system clock fsys and fsys/2, and the prescaler input clock for peripheral I/O  $\phi$ T0.

Note: The phase difference (AC timing) between the system clock output by the SCOUT and the internal clock is not guaranteed.

By setting the port D registers, the PDCR<PD7C> and PDFR3<PD7F3> to "1", the PD7 pin becomes the SCOUT output pin. The output clock is selected by setting the CGSYSCR<SCOSEL[1:0]>.

Table 10-4 shows the pin status in each mode when the SCOUT pin is set to the SCOUT output.

| Table 10-4 SCOUT Output Status in Each Mod | de |
|--------------------------------------------|----|
|--------------------------------------------|----|

| Mode                               |                            | Low power con                    | sumption mode      |
|------------------------------------|----------------------------|----------------------------------|--------------------|
| SCOUT selection<br>CGSYSCR         | NORMAL                     | IDLE                             | STOP1/STOP2 (Note) |
| <scosel[1:0]> = "00"</scosel[1:0]> | Reserved                   |                                  |                    |
| <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 $\phi$ T0 clock | e φT0 clock Fixed to "0" or "1". |                    |

Note: To transit mode to STOP2, set port keep by CGSTBYCR<PTKEEP>="1" at first.

## 10.4 Modes and Mode Transitions

### 10.4.1 Mode Transitions

The IDLE and STOP1 modes can be used as the low power consumption mode that enables to reduce power consumption by halting processor core operation.

And TMPM341FDXBG/FYXBG has STOP2 mode that enables to reduce power consumption significantly by halting main voltage supply, retaining some functional operations.

Figure 10-3 shows a mode transition diagram.

For a detail of sleep-on-exit, refer to "Cortex-M3 Technical Reference Manual."



Figure 10-3 Mode Transition Diagram

- Note 1: Returning from the STOP1/STOP2 mode, related bits <HWUPSEL>, <OSCSEL>, <XEN2>, <XEN1>, <PLLON> of the register CGOSCCR and CGPLLSEL<PLLSEL> are initialized because of internal high-speed oscillator starts up.
- Note 2: It branches to ISR of reset when returning from the STOP2 mode and it branches to ISR of interrupt factor when returning from the STOP1 mode.

# 10.5 Operation mode

### 10.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.

# 10.6 Low Power Consumption Modes

The TMPM341FDXBG/FYXBG has three low power consumption modes: IDLE, STOP1 and STOP2. 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 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 TX03 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 TX03 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.

The features of IDLE, STOP1, STOP2 mode are described as follows.

#### 10.6.1 IDLE mode

Only the 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. (Clock is provided to Synchronous Serial Interface and DA converter at any time) When the IDLE mode is entered, 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)
- Two-phase pulse counter (PHCNT)
- High resolution PPG output (TMRD)
- Serial channel (SIO/UART)
- Serial bus interface (I2C/SIO)
- Analog Digital converter (ADC)
- Watch dog timer (WDT)
- Note:Pay attention that the counter of watch dog timer function can not be cleared by CPU while in IDLE mode.

#### 10.6.2 STOP1 mode

All the internal circuits including the internal oscillator are brought to a stop in STOP1 mode. And the internal oscillator activates the clock after releasing the STOP1 mode then transit to the Normal mode.

The STOP1 mode enables to select the pin status by setting the CGSTBYCR<DRVE>. Table 10-5 shows the pin status in the STOP1 mode.

#### 10.6.3 STOP2 mode

This mode halts main voltage supply, retaining some function operation. This enables to reduce power consumption significantly compares to STOP1 mode. After releasing the STOP2 mode, voltage is supplied to the halted blocks, an internal high-speed oscillator starts, branches to ISR of reset and then returns to NOR-MAL mode. Before entering STOP2 mode, set CGSTBYCR<PTKEEP>="0" $\rightarrow$ "1" and keeps each port conditions. If internal voltage is halted, it can be held interface to the external IC, and STOP2 release source interrupt is available.

- Note 1: Returning from the STOP1/STOP2 mode, it is required to set the warm-up time in normal mode before entering STOP1 and STOP2 mode. The warm-up time setting is referred to "10.3.4 Warm-up function".
- Note 2: Returning from the STOP1/STOP2 mode, related bits <HWUPSEL>, <OSCSEL>, <XEN2>, <XEN1>, <PLLON> of the register CGOSCCR and CGPLLSEL<PLLSEL> are initialized because of internal highspeed oscillator starts up.
- Note 3: Because STOP2 mode halts internal voltage supply, more than 45µs time is required from transition to release. If the STOP2 mode is released during this time, internal voltage cannot operate normally.

| Function    | Pin Name                                                                                                                                                                  | I/O    | STOP1                                                         |                           | STOP2                 |                                                   |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------|---------------------------|-----------------------|---------------------------------------------------|
| FUNCTION    |                                                                                                                                                                           |        | <drve> = 0</drve>                                             | <drve> = 1</drve>         | <ptkeep> = 0</ptkeep> | <ptkeep> = 1</ptkeep>                             |
| Control Pin | RESET, NMI, MODE, INTLV,<br>BSC, ENDIAN                                                                                                                                   | Input  | o                                                             | o                         | o                     | o                                                 |
|             | X1/EHCLKIN                                                                                                                                                                | Input  | ×                                                             | ×                         | ×                     | ×                                                 |
| Oscillator  | X2                                                                                                                                                                        | Output | "High" level out-<br>put.                                     | "High" level out-<br>put. | ×                     | ×                                                 |
| Special pin | DA0, DA1                                                                                                                                                                  | Output | ×                                                             | ×                         | ×                     | ×                                                 |
|             | PJ0 to PJ5<br>(PHC0IN0, PHC0IN1, PHC1IN0,<br>PHC1IN1, PHC2IN0, PHC2IN1)<br>(Functional setting,<br>case of PxFRn <pxmfn>="1")</pxmfn>                                     | Input  | O                                                             | O                         | 0                     | 0                                                 |
|             | PI3 to PI5<br>(TRST, TDI, SWCLK/TCK)<br>(Debug I/F setting,<br>case of PxFRn <pxmfn>="1")</pxmfn>                                                                         | Input  | Depends on (PxIE[m]) o                                        |                           | 0                     | Input holding,<br>but<br>Depends on<br>(PxIE[m])  |
|             | PI6<br>(SWDIO/TMS)<br>(Debug I/F setting,<br>case of PxFRn <pxmfn>="1")</pxmfn>                                                                                           |        |                                                               |                           | 0                     | Input holding,<br>but<br>Depends on<br>(PxIE[m])  |
|             |                                                                                                                                                                           |        | Enabled when data is valid.<br>Disabled when data is invalid. |                           | 0                     | Output holding,<br>but<br>Depends on<br>(PxCR[m]) |
| Port        | PI7, PI2, PI1, PI0, PH6, PH5<br>(TDO/SWV, TRACECLK, TRACE-<br>DATA0 to 3)<br>(Debug I/F setting,<br>case of PxFRn <pxmfn>="1")</pxmfn>                                    | Output | Depends on (PxCR[m])                                          |                           | 0                     | Output holding,<br>but<br>Depends on<br>(PxCR[m]) |
|             | PG3, PG7, PC3, PC7, PD3, PE3,<br>PF4, PF5, PG2, PJ7, PK1, PK3<br>(INT0 to B)<br>(Interrupt setting,<br>case of PxFRn <pxmfn>="1"<br/>and PxIE<pxmie>="1")</pxmie></pxmfn> | Input  | O                                                             | O                         | 0                     | O                                                 |
|             | If using other than listed above                                                                                                                                          |        | x                                                             | Depends on<br>(PxIE[m])   | x                     | Input holding,<br>but<br>Depends on<br>(PxIE[m])  |
|             |                                                                                                                                                                           |        | ×                                                             | Depends on<br>(PxCR[m])   | x                     | Output holding,<br>but<br>Depends on<br>(PxCR[m]) |

#### Table 10-5 Pin States in the STOP1/STOP2 mode

o : Valid input or output.

× : Invalid input or output.

Note:x: port number / m: corresponding bit / n: function register number

## 10.6.4 Low power Consumption Mode Setting

The low power consumption mode is specified by the setting of the standby control register CGSTBYCR<STBY[2:0]>.

Table 10-6 shows the mode setting in the <STBY[2:0]>.

| Mode  | CGSTBYCR<br><stby[2:0]></stby[2:0]> |
|-------|-------------------------------------|
| STOP1 | 001                                 |
| IDLE  | 011                                 |
| STOP2 | 101                                 |

| Table 10-6 Low | power con | sumption | mode setting |
|----------------|-----------|----------|--------------|
|----------------|-----------|----------|--------------|

Note:Do not set any value other than those shown above in <STBY[2:0]>.

## 10.6.5 Operational Status in Each Mode

Table 10-7 show the operational status in each mode.

| Table 10-7 | Operational | Status in | n Each Mode |
|------------|-------------|-----------|-------------|
|------------|-------------|-----------|-------------|

| Block                                       | NORMAL<br>Internal high-<br>speed oscillator<br>use<br>(IHOSC) | NORMAL<br>External high-<br>speed oscillator<br>use<br>(EHOSC) | IDLE<br>Internal high-<br>speed oscillator<br>use<br>(IHOSC) | IDLE<br>External high-<br>speed oscillator<br>use<br>(EHOSC) | STOP1<br>(Note 1) | STOP2<br>(Note 1) |
|---------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|-------------------|-------------------|
| Processor core                              | 0                                                              | 0                                                              | -                                                            | -                                                            | -                 | ×                 |
| DMAC                                        | 0                                                              | 0                                                              | 0                                                            | 0                                                            | -                 | ×                 |
| INTC                                        | 0                                                              | 0                                                              | 0                                                            | 0                                                            | 0                 | ×                 |
| EBIF                                        | 0                                                              | 0                                                              | o                                                            | o                                                            | -                 | ×                 |
| IO port                                     | 0                                                              | 0                                                              | o                                                            | o                                                            | o(Note 2)         | Δ(Note 3)         |
| SIO/UART                                    | 0                                                              | 0                                                              | Δ                                                            | Δ                                                            | -                 | ×                 |
| I2C/SIO                                     | 0                                                              | 0                                                              | Δ                                                            | Δ                                                            | -                 | ×                 |
| TMRB                                        | 0                                                              | 0                                                              | Δ                                                            | Δ                                                            | -                 | ×                 |
| PHCNT                                       | 0                                                              | 0                                                              | Δ                                                            | Δ                                                            | 0                 | ×                 |
| TMRD                                        | 0                                                              | o                                                              | Δ                                                            | Δ                                                            | -                 | ×                 |
| WDT                                         | 0                                                              | 0                                                              | Δ(Note 6)                                                    | Δ(Note 6)                                                    | -                 | ×                 |
| SSP                                         | o                                                              | o                                                              | o                                                            | 0                                                            | -                 | ×                 |
| 12-bit ADC                                  | o                                                              | 0                                                              | Δ                                                            | Δ                                                            | -                 | ×                 |
| 10-bit DAC                                  | 0                                                              | 0                                                              | 0                                                            | 0                                                            | -                 | -                 |
| CG                                          | 0                                                              | 0                                                              | o                                                            | 0                                                            | 0                 | 0                 |
| PLL                                         | 0                                                              | 0                                                              | Δ                                                            | Δ                                                            | -                 | ×                 |
| External high-speed oscilla-<br>tor (EHOSC) | Δ                                                              | o                                                              | Δ                                                            | 0                                                            | -                 | ×                 |
| OFD                                         | Δ(Note 4)                                                      | 0                                                              | Δ(Note 4)                                                    | 0                                                            | -                 | ×                 |
| Internal high-speed oscilla-<br>tor (IHOSC) | o                                                              | o(Note 5)                                                      | o                                                            | o(Note 5)                                                    | -                 | ×                 |
| Main RAM                                    | 0                                                              | 0                                                              | 0                                                            | 0                                                            | 0                 | ×                 |
| Backup RAM                                  | 0                                                              | o                                                              | o                                                            | 0                                                            | o                 | o                 |

o : Operation is available when in the target mode.

- : The clock to module stops automatically when transiting to the target mode.

 $\Delta$  : Enables to select enabling or disabling module operation by software when in the target mode.

× :Voltage supply to module turns off automatically when transiting to the target mode.

Note 2: The status depends on the CGSTBYCR<DRVE> bit.

- Note 3: The status depends on the CGSTBYCR<PTKEEP> bit.
- Note 4: When using internal high-speed oscillator, OFD can not be used.
- Note 5: After reset or STOP1/STOP2 mode released, clock is provided from internal high-speed oscillator.
- Note 6: Pay attention that the counter of watch dog timer function can not be cleared by CPU while in IDLE mode.

Note 1: Before transit to STOP1/STOP2 mode, stop peripheral functions of "-"and "×". It is available to reduce leakage current by stopping reference voltage for AD converter or DA converter.

### 10.6.6 Releasing the Low Power Consumption Mode

The low power consumption 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 10-8.

| Table 10-8 Release | Source in | Each Mode |
|--------------------|-----------|-----------|
|--------------------|-----------|-----------|

| Low power consumption mode |                                 | IDLE                                                | STOP1 | STOP2 |           |
|----------------------------|---------------------------------|-----------------------------------------------------|-------|-------|-----------|
|                            |                                 | INT0 to B (Note2)                                   | 0     | 0     | • (Note1) |
|                            |                                 | INTTB0 to 9                                         | 0     | ×     | ×         |
|                            |                                 | INTTD0CMP0 to 4, INTTD1CMP0 to 4                    | о     | ×     | ×         |
|                            |                                 | INTPHT00 to 31, INTPHEVRY0 to 3                     | о     | о     | ×         |
|                            |                                 | INTCAP00 to 91                                      | о     | ×     | ×         |
|                            | Interrupt                       | INTRX0 to 4, INTTX0 to 4                            | о     | ×     | ×         |
| Release                    |                                 | INTSBI0 to 1                                        | 0     | ×     | ×         |
| source                     |                                 | INTAD/INTADHP/INTADM0 to 1                          | 0     | ×     | ×         |
|                            |                                 | INTDMAC0TC, INTDMAC1TC,<br>INTDMAC0ERR, INTDMAC1ERR | 0     | ×     | ×         |
|                            |                                 | INTSSP                                              | 0     | ×     | ×         |
|                            | Non-Maskable Interrupt (INTWDT) |                                                     | 0     | ×     | ×         |
|                            | Non-Maska                       | ble Interrupt (NMI pin)                             | 0     | 0     |           |
|                            | RESET (RE                       | ESET pin)                                           | 0     | 0     | 0         |

o: Starts the interrupt handling after the mode is released. (The reset initializes the LSI)

• : Starts the reset handling after the mode is released. (The reset initializes the LSI)

× : Unavailable

- Note:After STOP2 mode is released, reset operation initializes the internal supply voltage cut off block. But back-up module is not initialized.
- Note: 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 interrupt.
- Note 1: When STOP2 mode is released set the active request of corresponding interrupt control register CGIMCGA,B,F to "rising edge". When "High" pulse width over than 500µs is detected, STOP2 mode is released by the timing at faling edge of the corresponding interrupt. And releasing by NMI pin, input pulse which "Low" width is over than 500µs.
- Note 2: When releasing from IDLE,STOP mode by interrupting level mode, hold the level until the interrupt handling starts. If the level is changed before that, the correct interrupt handling cannot be started.

• <u>Release by interrupt request</u>

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 STOP1 and STOP2 modes.

• <u>Release by Non-Maskable Interrupt (NMI)</u>

There are two kinds of NMI sources: WDT interrupt (INTWDT) and  $\overline{\text{NMI}}$  pin. INTWDT can only be used in the IDLE mode. The  $\overline{\text{NMI}}$  pin can be used to release all the lower power consumption modes.

<u>Release by reset</u>

Any low power consumption mode can be released by reset from the  $\overline{\text{RESET}}$  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 returning to the STOP1 mode by reset does not induce the automatic warm-up. Keep the reset signal valid until the oscillator operation becomes stable.

When returning to the STOP2 mode by reset, it is required the time at least 1ms as the internal regurator to be stable. The external reset pin must be kept "Low" for a duration of time sufficiently long enough for the internal regulator

Refer to "Interrupts" for details.

#### 10.6.7 Warm-up

Mode transition may require the warm-up so that the internal oscillator provides stable oscillation.

In the mode transition from STOP1/STOP2 to the NORMAL, the warm-up counter and the internal oscillator are activated automatically. And then the system clock output is started after the elapse of warm-up time. It is necessary to set a warm-up time in the CGOSCCR<WUODR[11:0]> before executing the instruction to enter the STOP1/STOP2 mode.

Table 10-9 shows whether the warm-up setting of each mode transition is required or not.

| Mode transition    | Warm-up setting     |
|--------------------|---------------------|
| $NORMAL \to IDLE$  | Not required        |
| $NORMAL \to STOP1$ | Not required        |
| $NORMAL \to STOP2$ | Not required        |
| $IDLE \to NORMAL$  | Not required        |
| $STOP1 \to NORMAL$ | Auto-warm-up (Note) |
| $STOP2 \to NORMAL$ | Auto-warm-up (Note) |

Table 10-9 Warm-up setting in mode transition

Note 1: Returning to NORMAL mode by reset does not induce the automatic warm-up. Keep the reset signal valid until the oscillator operation becomes stable.

Note:Returning from the STOP1/STOP2 mode, related bits <HWUPSEL>, <OSCSEL>, <XEN2>, <XEN1>, <PLLON> of the register CGOSCCR and CGPLLSEL<PLLSEL> are initialized because of internal high-speed oscillator starts up.

### 10.6.8 Clock Operations in Mode Transition

The clock operations in mode transition are described as follows.

#### 10.6.8.1 Transition of operation modes: NORMAL $\rightarrow$ STOP1 $\rightarrow$ NORMAL

When returning to the NORMAL mode from the STOP1 mode, the warm-up is activated automatically. It is necessary for the warm-up to be set CGOSCCR<WUODR>=0x119 in this case as a stability time (450µs) of on chip Flash ROM before entering the STOP1 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.



#### 10.6.8.2 Transition of operation modes: NORMAL $\rightarrow$ STOP2 $\rightarrow$ NORMAL

When returning to the NORMAL mode from the STOP2 mode, the warm-up is activated automatically. It is necessary for the warm-up to be set CGOSCCR<WUODR>=0x1D4 in this case as a stability time (750µs) of on chip Flash ROM before entering the STOP2 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.

Even returning to the NORMAL mode by without reset, it would be branched to ISR of reset. After STOP2 mode is released, reset operation initializes the internal supply voltage cut off block. But back-up module is not initialized.



# 11. 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.

## 11.1 Overview

An exception causes the CPU to stop the currently executing process and handle another process.

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.

## 11.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

## 11.1.2 Handling Flowchart

```
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.



#### 11.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 "11.5 Interrupts".

#### (2) Exception detection

If multiple exceptions occur simultaneously, the CPU takes the exception with the highest priority.

Table 11-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.

| 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             | -1           | Fault that cannot activate because a higher-priority fault is being han-<br>dled or it is disabled               |
| 4    | Memory Management      | Configurable | Exception from the Memory Protection Unit (MPU) (Note 1)<br>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 (Note 2)                                                           |

Table 11-1 Exception Types and Priority

Note 1: This product does not contain the MPU.

Note 2: External interrupts have different sources and numbers in each product. For details, see "11.5.1.5 List of Interrupt Sources".

#### (3) Priority setting

Priority levels

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  $\langle PRI_n \rangle$  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 11-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.

|                                             | <pri_< th=""><th>n[7:0]&gt;</th><th>Number of</th><th>Number of</th></pri_<> | n[7:0]>              | Number of                 | Number of                  |
|---------------------------------------------|------------------------------------------------------------------------------|----------------------|---------------------------|----------------------------|
| <prigroup[2:0]><br/>setting</prigroup[2:0]> | Pre-emption<br>field                                                         | Subpriority<br>field | pre-emption<br>priorities | Number of<br>subpriorities |
| 000                                         | [7:1]                                                                        | [0]                  | 128                       | 2                          |
| 001                                         | [7:2]                                                                        | [1:0]                | 64                        | 4                          |
| 010                                         | [7:3]                                                                        | [2:0]                | 32                        | 8                          |
| 011                                         | [7:4]                                                                        | [3:0]                | 16                        | 16                         |
| 100                                         | [7:5]                                                                        | [4:0]                | 8                         | 32                         |
| 101                                         | [7:6]                                                                        | [5:0]                | 4                         | 64                         |
| 110                                         | [7]                                                                          | [6:0]                | 2                         | 128                        |
| 111                                         | None                                                                         | [7:0]                | 1                         | 256                        |

### Table 11-2 Priority grouping setting

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".

### 11.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 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.

| Old SP $\rightarrow$ | <previous></previous> |
|----------------------|-----------------------|
|                      | xPSR                  |
|                      | PC                    |
|                      | LR                    |
|                      | r12                   |
|                      | r3                    |
|                      | r2                    |
|                      | r1                    |
| $SP \to$             | r0                    |
|                      |                       |

#### (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.

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 ~ 0x28 | Reserved               |                                 |          |
| 0x2C        | SVCall                 | ISR address                     | Optional |
| 0x30        | Debug Monitor          | ISR address                     | Optional |
| 0x34        | Reserved               |                                 |          |
| 0x38        | PendSV                 | ISR address                     | Optional |
| 0x3C        | SysTick                | ISR address                     | Optional |
| 0x40        | External Interrupt     | ISR address                     | Optional |

#### 11.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 "11.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.

#### 11.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.

# 11.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.

# 11.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  $\overline{\text{NMI}}$  pin

A non-maskable interrupt is generated when an external MMI 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.

# 11.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, the systick timer counts based on an external reference clock obtained by 32 dividing the fosc which is selected by the bits <OSCSEL>,<EHOSCSEL> of the register CGOSCCR.

## 11.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.

## 11.5.1 Interrupt Sources

#### 11.5.1.1 Interrupt Route

Figure 11-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 11-1 Interrupt Route

#### 11.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.

• 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.

#### 11.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.

#### 11.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 11-1 Interrupt Route"), 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.

## 11.5.1.5 List of Interrupt Sources

Table 11-3 shows the list of interrupt sources.

## Table 11-3 List of Interrupt Sources

| No. |            | Interrupt Source                                  | active level<br>(Clearing standby) | CG interrupt mode<br>control register |  |
|-----|------------|---------------------------------------------------|------------------------------------|---------------------------------------|--|
| 0   | INT0       | Interrupt pin 0                                   |                                    |                                       |  |
| 1   | INT1       | Interrupt pin 1                                   |                                    | 0011000                               |  |
| 2   | INT2       | Interrupt pin 2                                   |                                    | CGIMCGA                               |  |
| 3   | INT3       | Interrupt pin 3                                   |                                    |                                       |  |
| 4   | INT4       | Interrupt pin 4                                   | Selectable                         |                                       |  |
| 5   | INT5       | Interrupt pin 5                                   |                                    | 0014000                               |  |
| 6   | INT6       | Interrupt pin 6                                   |                                    | CGIMCGB                               |  |
| 7   | INT7       | Interrupt pin 7                                   |                                    |                                       |  |
| 8   | INTRX0     | Serial reception (channel.0)                      |                                    |                                       |  |
| 9   | INTTX0     | Serial transmission (channel.0)                   |                                    |                                       |  |
| 10  | INTRX1     | Serial reception (channel.1)                      |                                    |                                       |  |
| 11  | INTTX1     | Serial transmission (channel.1)                   |                                    |                                       |  |
| 12  | INTRX2     | Serial reception (channel.2)                      |                                    |                                       |  |
| 13  | INTTX2     | Serial transmission (channel.2)                   |                                    |                                       |  |
| 14  | INTSBI0    | Serial bus interface 0                            |                                    |                                       |  |
| 15  | INTSBI1    | Serial bus interface 1                            |                                    |                                       |  |
| 16  | INTADHP    | Highest priority AD conversion complete interrupt | -                                  |                                       |  |
| 17  | INTAD      | A/D conversion completion interrupt               | •                                  |                                       |  |
| 18  | INTADM0    | AD conversion monitoring function interrupt 0     |                                    |                                       |  |
| 19  | INTADM1    | AD conversion monitoring function interrupt 1     |                                    |                                       |  |
| 20  | INTTB0     | 16-bit TMRB match detection 0                     |                                    |                                       |  |
| 21  | INTTB1     | 16-bit TMRB match detection 1                     | •                                  |                                       |  |
| 22  | INTTB2     | TB2 16-bit TMRB match detection 2                 |                                    |                                       |  |
| 23  | INTTB3     | 16-bit TMRB match detection 3                     |                                    |                                       |  |
| 24  | INTTB4     | 16-bit TMRB match detection 4                     |                                    |                                       |  |
| 25  | INTTB5     | 16-bit TMRB match detection 5                     |                                    |                                       |  |
| 26  | INTTB6     | 16-bit TMRB match detection 6                     | •                                  |                                       |  |
| 27  | INTTB7     | 16-bit TMRB match detection 7                     |                                    |                                       |  |
| 28  | INTTB8     | 16-bit TMRB match detection 8                     |                                    |                                       |  |
| 29  | INTTB9     | 16-bit TMRB match detection 9                     |                                    |                                       |  |
| 30  | INTTD0CMP0 | 16-bit TMRD0 compare interrupt 0                  |                                    |                                       |  |
| 31  | INTTD0CMP1 | 16-bit TMRD0 compare interrupt 1                  |                                    |                                       |  |
| 32  | INTTD0CMP2 | ITTD0CMP2 16-bit TMRD0 compare interrupt 2        |                                    |                                       |  |
| 33  | INTTD0CMP3 | OCMP3 16-bit TMRD0 compare interrupt 3            |                                    |                                       |  |
| 34  | INTTD0CMP4 | 16-bit TMRD0 compare interrupt 4                  |                                    |                                       |  |
| 35  | INTTD1CMP0 | CMP0 16-bit TMRD1 compare interrupt 0             |                                    |                                       |  |
| 36  | INTTD1CMP1 | 16-bit TMRD1 compare interrupt 1                  |                                    |                                       |  |
| 37  | INTTD1CMP2 | 16-bit TMRD1 compare interrupt 2                  |                                    |                                       |  |
| 38  | INTTD1CMP3 | 16-bit TMRD1 compare interrupt 3                  |                                    |                                       |  |
| 39  | INTTD1CMP4 | 16-bit TMRD1 compare interrupt 4                  |                                    |                                       |  |

| No.      |                                       | Interrupt Source                            | active level<br>(Clearing standby) | CG interrupt mode<br>control register |  |
|----------|---------------------------------------|---------------------------------------------|------------------------------------|---------------------------------------|--|
| 40       | INTPHT00                              | 16-bit PHC compare interrupt 00             |                                    |                                       |  |
| 41       | INTPHT01                              | 16-bit PHC compare interrupt 01             |                                    |                                       |  |
| 42       | INTPHT10                              | 16-bit PHC compare interrupt 10             | _                                  | CGIMCGC                               |  |
| 43       | INTPHT11                              | 16-bit PHC compare interrupt 11             |                                    |                                       |  |
| 44       | INTPHT20                              | 16-bit PHC compare interrupt 20             |                                    |                                       |  |
| 45       | INTPHT21                              | 16-bit PHC compare interrupt 21             | _                                  |                                       |  |
| 46       | INTPHT30                              | 16-bit PHC compare interrupt 30             | Rising edge                        | CGIMCGD                               |  |
| 47       | INTPHT31                              | 16-bit PHC compare interrupt 31             |                                    |                                       |  |
| 48       | INTPHEVRY0                            | 16-bit PHC every count interrupt 0          | _                                  |                                       |  |
| 49       | INTPHEVRY1                            | 16-bit PHC every count interrupt 1          | _                                  |                                       |  |
| 50       | INTPHEVRY2                            | 16-bit PHC every count interrupt 2          | _                                  | CGIMCGE                               |  |
| 51       | INTPHEVRY3                            | 16-bit PHC every count interrupt 3          | -                                  |                                       |  |
| 52       | INTRX3                                | Serial reception (channel.3)                |                                    |                                       |  |
| 53       | INTTX3                                | Serial transmission (channel.3)             | -                                  |                                       |  |
| 54       | INTRX4                                | Serial reception (channel.4)                | -                                  |                                       |  |
| 55       | INTTX4                                | Serial transmission (channel.4)             | -                                  |                                       |  |
| 56       | INTCAP00                              | 16-bit TMRB0 input capture 0                | -                                  |                                       |  |
| 57       | INTCAP01                              | 16-bit TMRB0 input capture 1                | -                                  |                                       |  |
| 58       | INTCAP10                              | 16-bit TMRB1 input capture 0                | -                                  |                                       |  |
| 59       | INTCAP11                              | 16-bit TMRB1 input capture 1                | -                                  |                                       |  |
| 60       | INTCAP20                              | 16-bit TMRB2 input capture 0                | -                                  |                                       |  |
| 61       | INTCAP21                              | 16-bit TMRB2 input capture 1                | -                                  |                                       |  |
| 62       | INTCAP30 16-bit TMRB3 input capture 0 |                                             | -                                  |                                       |  |
| 63       | INTCAP31 16-bit TMRB3 input capture 1 |                                             | -                                  |                                       |  |
| 64       | INTCAP40                              | 16-bit TMRB4 input capture 0                | -                                  |                                       |  |
| 65       | INTCAP41                              | 16-bit TMRB4 input capture 1                |                                    |                                       |  |
| 66       | INTCAP50                              | 16-bit TMRB5 input capture 0                | -                                  |                                       |  |
| 67       | INTCAP51                              | 16-bit TMRB5 input capture 1                | -                                  |                                       |  |
| 68       | INTCAP60                              | 16-bit TMRB6 input capture 0                | -                                  |                                       |  |
| 69       | INTCAP61                              | 16-bit TMRB6 input capture 1                | -                                  |                                       |  |
| 70       | INTCAP70                              | 16-bit TMRB7 input capture 0                | -                                  |                                       |  |
| 70       | INTCAP70                              | 16-bit TMRB7 input capture 1                |                                    |                                       |  |
| 72       | INTCAP80                              | 16-bit TMRB8 input capture 0                |                                    |                                       |  |
| 72       | INTCAP80                              | 16-bit TMRB8 input capture 1                |                                    |                                       |  |
| 73       | INTCAP90                              | 16-bit TMRB9 input capture 0                |                                    |                                       |  |
| 74       | INTCAP90                              | 16-bit TMRB9 input capture 1                |                                    |                                       |  |
| 75       | INTCAP91                              |                                             |                                    |                                       |  |
| 76       | INT9                                  | Interrupt pin 8                             | -                                  |                                       |  |
|          |                                       | Interrupt pin 9                             | Selectable                         | CGIMCGF                               |  |
| 78       |                                       | Interrupt pin A                             | -                                  |                                       |  |
| 79<br>•0 |                                       | Interrupt pin B                             |                                    |                                       |  |
| 80       |                                       | DMAC unit A terminal count status interrupt |                                    |                                       |  |
| 81       |                                       | DMAC unit B terminal count status interrupt |                                    |                                       |  |
| 82       |                                       | DMAC unit A error status interrupt          |                                    |                                       |  |
| 83       |                                       | DMAC unit B error status interrupt          |                                    |                                       |  |
| 84       | INTSSP                                | SPI serial interface                        |                                    |                                       |  |

## Table 11-3 List of Interrupt Sources

#### 11.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 11-3.

An interrupt request detected by the clock generator is notified to the CPU with a signal in "High" level.

# TOSHIBA

## 11.5.2 Interrupt Handling

11.5.2.1 Flowchart

The following shows how an interrupt is handled.





| Processing                  | Details                                                       | See                                              |
|-----------------------------|---------------------------------------------------------------|--------------------------------------------------|
| ISR execution               | Program for the ISR.<br>Clear the interrupt source if needed. |                                                  |
|                             |                                                               | "11.5.2.6 Interrupt<br>Service Routine<br>(ISR)" |
| Return to preceding program | Configure to return to the preceding program of the ISR.      |                                                  |

#### 11.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) |

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.

You can assign grouping priority by using the PRIGROUP field in the Application Interrupt and Reset Control Register.

| NVIC register                    |   |                                                     |  |  |
|----------------------------------|---|-----------------------------------------------------|--|--|
| <pri_n> ←</pri_n>                |   | "priority"                                          |  |  |
| <pre><prigroup></prigroup></pre> | ← | "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         |   |     |  |  |
|-----------------------|---|-----|--|--|
| PxFRn <pxmfn></pxmfn> | Ļ | "1" |  |  |
| PxIE <pxmie></pxmie>  | ↓ | "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 "11.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             |  |     |  |  |
|---------------------------|--|-----|--|--|
| Interrupt Set-Pending [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 "11.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 "11.5.1.4 Precautions when using external interrupt pins".

| Clock generator register  |   |                                                 |  |  |
|---------------------------|---|-------------------------------------------------|--|--|
| CGIMCGn <emcgm></emcgm>   | Ļ | active level                                    |  |  |
| CGICRCG <icrcg></icrcg>   | Ļ | Value corresponding to the interrupt to be used |  |  |
| CGIMCGn <intmen></intmen> | ÷ | "1" (interrupt enabled)                         |  |  |

| Note: n: register number / m: number assigned to interrupt sour | се |
|-----------------------------------------------------------------|----|
|-----------------------------------------------------------------|----|

#### (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-Enable [m]    | 4 | "1" |  |  |  |  |
| Interrupt mask register     |   |     |  |  |  |  |
| PRIMASK                     | ← | "0" |  |  |  |  |

Note 1: m : corresponding bit

Note 2: PRIMASK register cannot be modified by the user access level.

#### 11.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.

#### 11.5.2.4 Detection by CPU

The CPU detects an interrupt request with the highest priority.

#### 11.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.

#### 11.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.

# 11.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.

# 11.6.1 Register List

| 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 Clear-Enable Register 1                | 0x0180                     |
| Interrupt Clear-Enable Register 2                | 0x0184                     |
| Interrupt Clear-Enable Register 3                | 0x0188                     |
| Interrupt Set-Pending Register 1                 | 0x0200                     |
| Interrupt Set-Pending Register 2                 | 0x0204                     |
| Interrupt Set-Pending Register 3                 | 0x0208                     |
| Interrupt Clear-Pending Register 1               | 0x0280                     |
| Interrupt Clear-Pending Register 2               | 0x0284                     |
| Interrupt Clear-Pending Register 3               | 0x0288                     |
| Interrupt Priority Register                      | 0x0400 ~ 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 registers            |          | Base Address = 0x400F_3000 |
|--------------------------------------|----------|----------------------------|
| Register name                        |          | Address                    |
| CG Interrupt Mode Control Register A | CGIMCGA  | 0x0040                     |
| CG Interrupt Mode Control Register B | CGIMCGB  | 0x0044                     |
| CG Interrupt Mode Control Register C | CGIMCGC  | 0x0048                     |
| CG Interrupt Mode Control Register D | CGIMCGD  | 0x004C                     |
| CG Interrupt Mode Control Register E | CGIMCGE  | 0x0050                     |
| CG Interrupt Mode Control Register F | CGIMCGF  | 0x0054                     |
| CG Interrupt Request Clear Register  | CGICRCG  | 0x0060                     |
| Reset Flag Register                  | CGRSTFLG | 0x0064                     |
| NMI Flag Register                    | CGNMIFLG | 0x0068                     |

# 11.6.2 NVIC Registers

## 11.6.2.1 SysTick Control and 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  | -  | -  | -  | -  | -  | -         | -       | COUNTFLAG |
| 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       | 0         |
|             | 7  | 6  | 5  | 4  | 3  | 2         | 1       | 0         |
| bit symbol  | -  | -  | -  | -  | -  | CLKSOURCE | TICKINT | ENABLE    |
| After reset | 0  | 0  | 0  | 0  | 0  | 0         | 0       | 0         |

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                           |
|-------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17 | -          | R    | Read as 0.                                                                                                                                                                                         |
| 16    | COUNTFLAG  | R/W  | 0: Timer not counted to 0<br>1: Timer counted to 0<br>Returns "1" if timer counted to "0" since last time this was read.<br>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)<br>1: CPU clock (fsys)                                                                                                                                       |
| 1     | TICKINT    | R/W  | 0: Do not pend SysTick<br>1: Pend SysTick                                                                                                                                                          |
| 0     | ENABLE     | R/W  | 0: Disable<br>1: Enable<br>If "1" is set, it reloads with the value of the Reload Value Register and starts operation.                                                                             |

Note: In this product, the systick timer counts based on an external reference clock obtained by 32 dividing the fosc which is selected by the bits <OSCSEL>,<EHOSCSEL> of the register CGOSCCR.

## 11.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  | 0  | 0  |  |
|             | 23              | 22        | 21 | 20   | 19    | 18 | 17 | 16 |  |
| bit symbol  |                 | RELOAD    |    |      |       |    |    |    |  |
| After reset |                 | Undefined |    |      |       |    |    |    |  |
|             | 15              | 14        | 13 | 12   | 11    | 10 | 9  | 8  |  |
| bit symbol  |                 |           |    | REL  | OAD   | -  |    |    |  |
| After reset |                 |           |    | Unde | fined |    |    |    |  |
|             | 7 6 5 4 3 2 1 0 |           |    |      |       |    | 0  |    |  |
| bit symbol  |                 | RELOAD    |    |      |       |    |    |    |  |
| After reset |                 |           |    | Unde | fined |    |    |    |  |

| Bit   | Bit Symbol | Туре | Function                                                                                                  |
|-------|------------|------|-----------------------------------------------------------------------------------------------------------|
| 31-24 | -          | R    | Read as 0.                                                                                                |
| 23-0  | RELOAD     | R/W  | Reload value<br>Set the value to load into the SysTick Current Value Register when the timer reaches "0". |

## 11.6.2.3 SysTick Current Value 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  |    | CURRENT   |    |      |        |    |    |    |  |
| After reset |    | Undefined |    |      |        |    |    |    |  |
|             | 15 | 14        | 13 | 12   | 11     | 10 | 9  | 8  |  |
| bit symbol  |    |           |    | CUR  | RENT   |    |    |    |  |
| After reset |    |           |    | Unde | efined |    |    |    |  |
|             | 7  | 6         | 5  | 4    | 3      | 2  | 1  | 0  |  |
| bit symbol  |    | CURRENT   |    |      |        |    |    |    |  |
| After reset |    |           |    | Unde | efined |    |    |    |  |

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                                                         |
|-------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24 | -          | R    | Read as 0.                                                                                                                                                                                                                       |
| 23-0  | CURRENT    | R/W  | [Read] Current SysTick timer value<br>[Write] Clear<br>Writing to this register with any value clears it to 0.<br>Clearing this register also clears the <countflag> bit of the SysTick Control and Status Register.</countflag> |

|             | 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 | 17 | 16 |  |
| bit symbol  |       |       |    | TEI | NMS |    |    |    |  |
| After reset | 0     | 0     | 0  | 0   | 0   | 0  | 0  | 0  |  |
|             | 15    | 14    | 13 | 12  | 11  | 10 | 9  | 8  |  |
| bit symbol  |       |       |    | TEN | NMS |    |    |    |  |
| After reset | 0     | 0     | 0  | 0   | 1   | 0  | 0  | 1  |  |
|             | 7     | 6     | 5  | 4   | 3   | 2  | 1  | 0  |  |
| bit symbol  |       | TENMS |    |     |     |    |    |    |  |
| After reset | 1     | 1     | 0  | 0   | 0   | 1  | 0  | 0  |  |

## 11.6.2.4 SysTick Calibration Value Register

| 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 10 ms.                   |  |  |  |
| 29-24 | -          | R    | Read as 0.                                           |  |  |  |
| 23-0  | TENMS      | R    | Calibration value                                    |  |  |  |
|       |            |      | Reload value to use for 10 ms timing (0xC35). (Note) |  |  |  |

Note: When using a multi-shot timer, the calibration value is subtracted 1 from this value and use it.

|                           | 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                            | 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<br>(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                            |
| bit symbol                | 15<br>SETENA<br>(Interrupt 15) | 14<br>SETENA<br>(Interrupt 14) | 13<br>SETENA<br>(Interrupt 13) | 12<br>SETENA<br>(Interrupt 12) | 11<br>SETENA<br>(Interrupt 11) | 10<br>SETENA<br>(Interrupt 10) | 9<br>SETENA<br>(Interrupt 9) | 8<br>SETENA<br>(Interrupt 8) |
| bit symbol<br>After reset | SETENA                         | SETENA                         | SETENA                         | SETENA                         | SETENA                         | SETENA                         | SETENA                       | SETENA                       |
|                           | 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)      |
|                           | SETENA<br>(Interrupt 15)<br>0  | SETENA<br>(Interrupt 14)<br>0  | SETENA<br>(Interrupt 13)<br>0  | SETENA<br>(Interrupt 12)<br>0  | SETENA<br>(Interrupt 11)<br>0  | SETENA<br>(Interrupt 10)<br>0  | SETENA<br>(Interrupt 9)      | SETENA<br>(Interrupt 8)<br>0 |

## 11.6.2.5 Interrupt Set-Enable Register 1

| 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.                |

|                           | 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)       | SETENA<br>(Interrupt 57)      | SETENA<br>(Interrupt 56)      |
| After reset               | 0                              | 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<br>(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) | 11<br>SETENA<br>(Interrupt 43) | 10<br>SETENA<br>(Interrupt 42) | 9<br>SETENA<br>(Interrupt 41) | 8<br>SETENA<br>(Interrupt 40) |
| bit symbol<br>After reset | SETENA                         | SETENA                         | SETENA                         | SETENA                         | SETENA                         | SETENA                         | SETENA                        | 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)<br>0  | SETENA<br>(Interrupt 46)<br>0  | SETENA<br>(Interrupt 45)<br>0  | SETENA<br>(Interrupt 44)<br>0  | SETENA<br>(Interrupt 43)<br>0  | SETENA<br>(Interrupt 42)<br>0  | SETENA<br>(Interrupt 41)      | SETENA<br>(Interrupt 40)<br>0 |

## 11.6.2.6 Interrupt Set-Enable Register 2

| Bit  | Bit Symbol | Туре | Function                                                                                              |
|------|------------|------|-------------------------------------------------------------------------------------------------------|
| 31-0 | SETENA     | R/W  | Interrupt number [63:32]                                                                              |
|      |            |      | [Write]                                                                                               |
|      |            |      | 1: Enable                                                                                             |
|      |            |      | [Read]                                                                                                |
|      |            |      | 0: Disabled                                                                                           |
|      |            |      | 1: Enable                                                                                             |
|      |            |      | 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.                |

|             | 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  | -                        | -                        | -                        | SETENA<br>(Interrupt 84) | SETENA<br>(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 79) | SETENA<br>(Interrupt 78) | SETENA<br>(Interrupt 77) | SETENA<br>(Interrupt 76) | SETENA<br>(Interrupt 75) | SETENA<br>(Interrupt 74) | SETENA<br>(Interrupt 73) | SETENA<br>(Interrupt 72) |
| After reset | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        |
|             | 7                        | 6                        | 5                        | 4                        | 3                        | 2                        | 1                        | 0                        |
| bit symbol  | SETENA<br>(Interrupt 71) | SETENA<br>(Interrupt 70) | SETENA<br>(Interrupt 69) | SETENA<br>(Interrupt 68) | SETENA<br>(Interrupt 67) | SETENA<br>(Interrupt 66) | SETENA<br>(Interrupt 65) | SETENA<br>(Interrupt 64) |
| After reset | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        |

## 11.6.2.7 Interrupt Set-Enable Register 3

| Bit   | Bit Symbol | Туре | Function                                                                                              |
|-------|------------|------|-------------------------------------------------------------------------------------------------------|
| 31-21 | -          | R    | Read as 0.                                                                                            |
| 20-0  | SETENA     | R/W  | Interrupt number [84:64]                                                                              |
|       |            |      | [Write]                                                                                               |
|       |            |      | 1: Enable                                                                                             |
|       |            |      | [Read]                                                                                                |
|       |            |      | 0: Disabled                                                                                           |
|       |            |      | 1: Enable                                                                                             |
|       |            |      | 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.                |

|                           | 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                            | 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<br>(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<br>After reset | CLRENA                         | CLRENA                         | CLRENA                         | CLRENA                         | CLRENA                         | CLRENA                         | CLRENA                       | 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)<br>0  | CLRENA<br>(Interrupt 14)<br>0  | CLRENA<br>(Interrupt 13)<br>0  | CLRENA<br>(Interrupt 12)<br>0  | CLRENA<br>(Interrupt 11)<br>0  | CLRENA<br>(Interrupt 10)<br>0  | CLRENA<br>(Interrupt 9)      | CLRENA<br>(Interrupt 8)<br>0 |

## 11.6.2.8 Interrupt Clear-Enable Register 1

| 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.                                                        |

|                           | 31                                 | 30                                 | 29                                 | 28                                 | 27                                 | 26                                 | 25                                 | 24                                 |
|---------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| hit overshol              | CLRENA                             |
| bit symbol                | (Interrupt 63)                     | (Interrupt 62)                     | (Interrupt 61)                     | (Interrupt 60)                     | (Interrupt 59)                     | (Interrupt 58)                     | (Interrupt 57)                     | (Interrupt 56)                     |
| After reset               | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  |
|                           | 23                                 | 22                                 | 21                                 | 20                                 | 19                                 | 18                                 | 17                                 | 16                                 |
| hit overshol              | CLRENA                             |
| bit symbol                | (Interrupt 55)                     | (Interrupt 54)                     | (Interrupt 53)                     | (Interrupt 52)                     | (Interrupt 51)                     | (Interrupt 50)                     | (Interrupt 49)                     | (Interrupt 48)                     |
| After reset               | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  |
|                           |                                    |                                    |                                    |                                    |                                    |                                    |                                    |                                    |
|                           | 15                                 | 14                                 | 13                                 | 12                                 | 11                                 | 10                                 | 9                                  | 8                                  |
| bit oumbol                | 15<br>CLRENA                       | 14<br>CLRENA                       | 13<br>CLRENA                       | 12<br>CLRENA                       | 11<br>CLRENA                       | 10<br>CLRENA                       | 9<br>CLRENA                        | 8<br>CLRENA                        |
| bit symbol                | -                                  |                                    | -                                  |                                    |                                    | -                                  | -                                  | -                                  |
| bit symbol<br>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)           |
| After reset               | CLRENA<br>(Interrupt 47)<br>0      | CLRENA<br>(Interrupt 46)<br>0      | CLRENA<br>(Interrupt 45)<br>0      | CLRENA<br>(Interrupt 44)<br>0      | CLRENA<br>(Interrupt 43)<br>0      | CLRENA<br>(Interrupt 42)<br>0      | CLRENA<br>(Interrupt 41)           | CLRENA<br>(Interrupt 40)<br>0      |
|                           | CLRENA<br>(Interrupt 47)<br>0<br>7 | CLRENA<br>(Interrupt 46)<br>0<br>6 | CLRENA<br>(Interrupt 45)<br>0<br>5 | CLRENA<br>(Interrupt 44)<br>0<br>4 | CLRENA<br>(Interrupt 43)<br>0<br>3 | CLRENA<br>(Interrupt 42)<br>0<br>2 | CLRENA<br>(Interrupt 41)<br>0<br>1 | CLRENA<br>(Interrupt 40)<br>0<br>0 |

## 11.6.2.9 Interrupt Clear-Enable Register 2

| Bit  | Bit Symbol | Туре | Function                                                                                                                                      |
|------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | CLRENA     | R/W  | Interrupt number [63:32]                                                                                                                      |
|      |            |      | [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.                                                        |

|             | 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  | -                        | -                        | -                        | CLRENA<br>(Interrupt 84) | CLRENA<br>(Interrupt 83) | CLRENA<br>(Interrupt 82) | CLRENA<br>(Interrupt 81) | CLRENA<br>(Interrupt 80) |
| After reset | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        |
|             | 15                       | 14                       | 13                       | 12                       | 11                       | 10                       | 9                        | 8                        |
| bit symbol  | CLRENA<br>(Interrupt 79) | CLRENA<br>(Interrupt 78) | CLRENA<br>(Interrupt 77) | CLRENA<br>(Interrupt 76) | CLRENA<br>(Interrupt 75) | CLRENA<br>(Interrupt 74) | CLRENA<br>(Interrupt 73) | CLRENA<br>(Interrupt 72) |
| After reset | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        |
|             | 7                        | 6                        | 5                        | 4                        | 3                        | 2                        | 1                        | 0                        |
| bit symbol  | CLRENA<br>(Interrupt 71) | CLRENA<br>(Interrupt 70) | CLRENA<br>(Interrupt 69) | CLRENA<br>(Interrupt 68) | CLRENA<br>(Interrupt 67) | CLRENA<br>(Interrupt 66) | CLRENA<br>(Interrupt 65) | CLRENA<br>(Interrupt 64) |
| After reset | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        |

## 11.6.2.10 Interrupt Clear-Enable Register 3

| Bit     | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-21 · | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 20-0    | CLRENA     | R/W  | Interrupt number [84:64]<br>[Write]<br>1: Disabled<br>[Read]<br>0: Disabled<br>1: Enable<br>Each bit corresponds to the specified number of interrupts. It can be performed to enable interrupts and to<br>check if interrupts are disabled.<br>Writing "1" to a bit in this register disables the corresponding interrupt. Writing "0" has no effect.<br>Reading the bits can see the enable/disable condition of the corresponding interrupts. |

|                           | 31                                     | 30                                     | 29                                     | 28                                     | 27                                     | 26                                     | 25                            | 24                                    |
|---------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|-------------------------------|---------------------------------------|
| bit symbol                | SETPEND<br>(Interrupt 31)              | SETPEND<br>(Interrupt 30)              | SETPEND<br>(Interrupt 29)              | SETPEND<br>(Interrupt 28)              | SETPEND<br>(Interrupt 27)              | SETPEND<br>(Interrupt 26)              | SETPEND<br>(Interrupt 25)     | SETPEND<br>(Interrupt 24)             |
| After reset               | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                     | Undefined                             |
|                           | 23                                     | 22                                     | 21                                     | 20                                     | 19                                     | 18                                     | 17                            | 16                                    |
| bit symbol                | SETPEND<br>(Interrupt 23)              | SETPEND<br>(Interrupt 22)              | SETPEND<br>(Interrupt 21)              | SETPEND<br>(Interrupt 20)              | SETPEND<br>(Interrupt 19)              | SETPEND<br>(Interrupt 18)              | SETPEND<br>(Interrupt 17)     | SETPEND<br>(Interrupt 16)             |
| After reset               | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                     | Undefined                             |
|                           |                                        |                                        |                                        |                                        |                                        |                                        |                               |                                       |
|                           | 15                                     | 14                                     | 13                                     | 12                                     | 11                                     | 10                                     | 9                             | 8                                     |
| bit symbol                | 15<br>SETPEND<br>(Interrupt 15)        | 14<br>SETPEND<br>(Interrupt 14)        | 13<br>SETPEND<br>(Interrupt 13)        | 12<br>SETPEND<br>(Interrupt 12)        | 11<br>SETPEND<br>(Interrupt 11)        | 10<br>SETPEND<br>(Interrupt 10)        | 9<br>SETPEND<br>(Interrupt 9) | 8<br>SETPEND<br>(Interrupt 8)         |
| bit symbol<br>After reset | SETPEND                                | SETPEND                                | SETPEND                                | SETPEND                                | SETPEND                                | SETPEND                                | SETPEND                       | SETPEND                               |
|                           | SETPEND<br>(Interrupt 15)              | SETPEND<br>(Interrupt 14)              | SETPEND<br>(Interrupt 13)              | SETPEND<br>(Interrupt 12)              | SETPEND<br>(Interrupt 11)              | SETPEND<br>(Interrupt 10)              | SETPEND<br>(Interrupt 9)      | SETPEND<br>(Interrupt 8)              |
|                           | SETPEND<br>(Interrupt 15)<br>Undefined | SETPEND<br>(Interrupt 14)<br>Undefined | SETPEND<br>(Interrupt 13)<br>Undefined | SETPEND<br>(Interrupt 12)<br>Undefined | SETPEND<br>(Interrupt 11)<br>Undefined | SETPEND<br>(Interrupt 10)<br>Undefined | SETPEND<br>(Interrupt 9)      | SETPEND<br>(Interrupt 8)<br>Undefined |

## 11.6.2.11 Interrupt Set-Pending Register 1

| 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.                                                                 |
|      |            |      | 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.                                     |

|             | 31                          | 30                               | 29                               | 28                               | 27                               | 26                          | 25                          | 24                          |
|-------------|-----------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|-----------------------------|-----------------------------|-----------------------------|
| bit symbol  | SETPEND                     | SETPEND                          | SETPEND                          | SETPEND                          | SETPEND                          | SETPEND                     | SETPEND                     | SETPEND                     |
| bit oynibol | (Interrupt 63)              | (Interrupt 62)                   | (Interrupt 61)                   | (Interrupt 60)                   | (Interrupt 59)                   | (Interrupt 58)              | (Interrupt 57)              | (Interrupt 56)              |
| After reset | Undefined                   | Undefined                        | Undefined                        | Undefined                        | Undefined                        | Undefined                   | Undefined                   | Undefined                   |
|             | 23                          | 22                               | 21                               | 20                               | 19                               | 18                          | 17                          | 16                          |
| bit symbol  | SETPEND                     | SETPEND                          | SETPEND                          | SETPEND                          | SETPEND                          | SETPEND                     | SETPEND                     | SETPEND                     |
| bit symbol  | (Interrupt 55)              | (Interrupt 54)                   | (Interrupt 53)                   | (Interrupt 52)                   | (Interrupt 51)                   | (Interrupt 50)              | (Interrupt 49)              | (Interrupt 48)              |
| After reset | Undefined                   | Undefined                        | Undefined                        | Undefined                        | Undefined                        | Undefined                   | Undefined                   | Undefined                   |
|             | 15                          | 14                               | 13                               | 12                               | 11                               | 10                          | 9                           | 8                           |
| bit symbol  | SETPEND                     | SETPEND                          | SETPEND                          | SETPEND                          | SETPEND                          | SETPEND                     | SETPEND                     | SETPEND                     |
|             |                             | OE II EIIB                       | 02.1.2.10                        | -                                |                                  |                             |                             | -                           |
|             | (Interrupt 47)              | (Interrupt 46)                   | (Interrupt 45)                   | (Interrupt 44)                   | (Interrupt 43)                   | (Interrupt 42)              | (Interrupt 41)              | (Interrupt 40)              |
| After reset | (Interrupt 47)<br>Undefined | -                                |                                  |                                  |                                  | (Interrupt 42)<br>Undefined | (Interrupt 41)<br>Undefined | (Interrupt 40)<br>Undefined |
|             |                             | (Interrupt 46)                   | (Interrupt 45)                   | (Interrupt 44)                   | (Interrupt 43)                   |                             |                             |                             |
| After reset | Undefined                   | (Interrupt 46)<br>Undefined      | (Interrupt 45)<br>Undefined      | (Interrupt 44)<br>Undefined      | (Interrupt 43)<br>Undefined      | Undefined                   |                             | Undefined                   |
|             | Undefined<br>7              | (Interrupt 46)<br>Undefined<br>6 | (Interrupt 45)<br>Undefined<br>5 | (Interrupt 44)<br>Undefined<br>4 | (Interrupt 43)<br>Undefined<br>3 | Undefined<br>2              | Undefined<br>1              | Undefined<br>0              |

## 11.6.2.12 Interrupt Set-Pending Register 2

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                       |
|------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | SETPEND    | R/W  | Interrupt number [63: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.                                                                                                                     |
|      |            |      | Clear and Interrupt Set-Pending Register bit by writing "1" to the corresponding bit in the Interrupt Clear-Pend-<br>ing 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  | -                         | -                         | -                         | SETPEND<br>(Interrupt 84) | SETPEND<br>(Interrupt 83) | SETPEND<br>(Interrupt 82) | SETPEND<br>(Interrupt 81) | SETPEND<br>(Interrupt 80) |
| After reset | 0                         | 0                         | 0                         | Undefined                 | Undefined                 | Undefined                 | Undefined                 | Undefined                 |
|             | 15                        | 14                        | 13                        | 12                        | 11                        | 10                        | 9                         | 8                         |
| bit symbol  | SETPEND<br>(Interrupt 79) | SETPEND<br>(Interrupt 78) | SETPEND<br>(Interrupt 77) | SETPEND<br>(Interrupt 76) | SETPEND<br>(Interrupt 75) | SETPEND<br>(Interrupt 74) | SETPEND<br>(Interrupt 73) | SETPEND<br>(Interrupt 72) |
| After reset | Undefined                 |
|             | 7                         | 6                         | 5                         | 4                         | 3                         | 2                         | 1                         | 0                         |
| bit symbol  | SETPEND<br>(Interrupt 71) | SETPEND<br>(Interrupt 70) | SETPEND<br>(Interrupt 69) | SETPEND<br>(Interrupt 68) | SETPEND<br>(Interrupt 67) | SETPEND<br>(Interrupt 66) | SETPEND<br>(Interrupt 65) | SETPEND<br>(Interrupt 64) |
| After reset | Undefined                 |

## 11.6.2.13 Interrupt Set-Pending Register 3

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-21 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 20-0  | SETPEND    | RW   | Interrupt number [84:64]<br>[Write]<br>1: Pend<br>[Read]<br>0: Not pending<br>1: Pending<br>Each bit corresponds to the specified number can force interrupts into the pending state and determines<br>which interrupts are currently pending.<br>Writing "1" to a bit in this register pends the corresponding interrupt. However, writing "1" has no effect on<br>an interrupt that is already pending or is disabled. Writing "0" has no effect.<br>Reading the bit returns the current state of the corresponding interrupts.<br>Clear and Interrupt Set-Pending Register bit by writing "1" to the corresponding bit in the Interrupt Clear-Pend-<br>ing Register. |

|                           | 31                                     | 30                                     | 29                                     | 28                                     | 27                                     | 26                                     | 25                            | 24                                    |
|---------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|-------------------------------|---------------------------------------|
| bit symbol                | CLRPEND<br>(Interrupt 31)              | CLRPEND<br>(Interrupt 30)              | CLRPEND<br>(Interrupt 29)              | CLRPEND<br>(Interrupt 28)              | CLRPEND<br>(Interrupt 27)              | CLRPEND<br>(Interrupt 26)              | CLRPEND<br>(Interrupt 25)     | CLRPEND<br>(Interrupt 24)             |
| After reset               | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                     | Undefined                             |
|                           | 23                                     | 22                                     | 21                                     | 20                                     | 19                                     | 18                                     | 17                            | 16                                    |
| bit symbol                | CLRPEND<br>(Interrupt 23)              | CLRPEND<br>(Interrupt 22)              | CLRPEND<br>(Interrupt 21)              | CLRPEND<br>(Interrupt 20)              | CLRPEND<br>(Interrupt 19)              | CLRPEND<br>(Interrupt 18)              | CLRPEND<br>(Interrupt 17)     | CLRPEND<br>(Interrupt 16)             |
| After reset               | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                     | Undefined                             |
|                           |                                        |                                        |                                        |                                        |                                        |                                        |                               |                                       |
|                           | 15                                     | 14                                     | 13                                     | 12                                     | 11                                     | 10                                     | 9                             | 8                                     |
| bit symbol                | 15<br>CLRPEND<br>(Interrupt 15)        | 14<br>CLRPEND<br>(Interrupt 14)        | 13<br>CLRPEND<br>(Interrupt 13)        | 12<br>CLRPEND<br>(Interrupt 12)        | 11<br>CLRPEND<br>(Interrupt 11)        | 10<br>CLRPEND<br>(Interrupt 10)        | 9<br>CLRPEND<br>(Interrupt 9) | 8<br>CLRPEND<br>(Interrupt 8)         |
| bit symbol<br>After reset | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                       | 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)              |
|                           | 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 |

## 11.6.2.14 Interrupt Clear-Pending Register 1

| 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.                                                                                                                      |

|                           | 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)              | CLRPEND<br>(Interrupt 57)      | CLRPEND<br>(Interrupt 56)              |
| After reset               | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                      | 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                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                              | Undefined                      | 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)        | 11<br>CLRPEND<br>(Interrupt 43)        | 10<br>CLRPEND<br>(Interrupt 42)        | 9<br>CLRPEND<br>(Interrupt 41) | 8<br>CLRPEND<br>(Interrupt 40)         |
| bit symbol<br>After reset | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                                | CLRPEND                        | 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 |

## 11.6.2.15 Interrupt Clear-Pending Register 2

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                        |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | CLRPEND    | R/W  | Interrupt number [63:32]                                                                                                                                                                        |
|      |            |      | [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.                                                                                                                      |

|             | 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  | -                         | -                         | -                         | CLRPEND<br>(Interrupt 84) | CLRPEND<br>(Interrupt 83) | CLRPEND<br>(Interrupt 82) | CLRPEND<br>(Interrupt 81) | CLRPEND<br>(Interrupt 80) |
| After reset | 0                         | 0                         | 0                         | Undefined                 | Undefined                 | Undefined                 | Undefined                 | Undefined                 |
|             | 15                        | 14                        | 13                        | 12                        | 11                        | 10                        | 9                         | 8                         |
| bit symbol  | CLRPEND<br>(Interrupt 79) | CLRPEND<br>(Interrupt 78) | 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 | Undefined                 |
|             | 7                         | 6                         | 5                         | 4                         | 3                         | 2                         | 1                         | 0                         |
| bit symbol  | CLRPEND<br>(Interrupt 71) | CLRPEND<br>(Interrupt 70) | CLRPEND<br>(Interrupt 69) | CLRPEND<br>(Interrupt 68) | CLRPEND<br>(Interrupt 67) | CLRPEND<br>(Interrupt 66) | CLRPEND<br>(Interrupt 65) | CLRPEND<br>(Interrupt 64) |
| After reset | Undefined                 |

## 11.6.2.16 Interrupt Clear-Pending Register 3

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-21 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 20-0  | CLRPEND    | R/W  | Interrupt number [84:64]<br>[Write]<br>1: Clear pending interrupt<br>[Read]<br>0: Not pending<br>1: Pending<br>Each bit corresponds to the specified number can force interrupts into the pending state and determines<br>which interrupts are currently pending.<br>Writing "1" to a bit in this register clears the corresponding pending interrupt. However, writing "1" has no ef-<br>fect on an interrupt that is already being serviced. Writing "0" has no effect.<br>Description the bit surgestime these of the corresponding interrupt. |
|       |            |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### 11.6.2.17 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 0    |
|-------------|----------|----------|----------|--------|
| 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   | PRI_57   | PRI_56 |
| 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_79   | PRI_78   | PRI_77   | PRI_76 |
| 0xE000_E450 | PRI_83   | PRI_82   | PRI_81   | PRI_80 |
| 0xE000_E454 | Reserved | Reserved | Reserved | PRI_84 |

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.

|             | 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 | 9  | 8  |
| bit symbol  |       | PRI_1 |    | -  | -  | -  | -  | -  |
| After reset | 0     | 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.                     |

|             | 31     | 30 | 29      | 28  | 27  | 26     | 25 | 24 |
|-------------|--------|----|---------|-----|-----|--------|----|----|
| bit symbol  | -      | -  | TBLBASE |     |     | TBLOFF |    |    |
| After reset | 0      | 0  | 0       | 0   | 0   | 0      | 0  | 0  |
|             | 23     | 22 | 21      | 20  | 19  | 18     | 17 | 16 |
| bit symbol  |        |    |         | TBL | OFF |        |    |    |
| 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  | 0  |
|             | 7      | 6  | 5       | 4   | 3   | 2      | 1  | 0  |
| bit symbol  | TBLOFF | -  | -       | -   | -   | -      | -  | -  |
| After reset | 0      | 0  | 0       | 0   | 0   | 0      | 0  | 0  |

#### 11.6.2.18 Vector Table Offset Register

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                           |
|-------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                         |
| 29    | TBLBASE    | R/W  | Table base<br>The vector table is in:<br>0: Code space<br>1: SRAM space                                                                                                                                                                                                                                                                                            |
| 28-7  | TBLOFF     | R/W  | Offset value<br>Set the offset value from the top of the space specified in TBLBASE.<br>The offset must be aligned based on the number of exceptions in the table. This means that the minimum<br>alignment is 32 words that you can use for up to 16 interrupts. For more interrupts, you must adjust the align-<br>ment by rounding up to the next power of two. |
| 6-0   | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                         |

|             | 31        | 30 | 29 | 28         | 27        | 26              | 25                | 24        |
|-------------|-----------|----|----|------------|-----------|-----------------|-------------------|-----------|
| bit symbol  |           |    | -  | VECTKEY/VE | CTKEYSTAT |                 |                   |           |
| After reset | 0         | 0  | 0  | 0          | 0         | 0               | 0                 | 0         |
|             | 23        | 22 | 21 | 20         | 19        | 18              | 17                | 16        |
| bit symbol  |           |    |    | VECTKEY/VE | CTKEYSTAT |                 |                   |           |
| 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                 | 0         |
|             | 7         | 6  | 5  | 4          | 3         | 2               | 1                 | 0         |
| bit symbol  | -         | -  | -  | -          | -         | SYSRESET<br>REQ | VECTCLR<br>ACTIVE | VECTRESET |
| After reset | 0         | 0  | 0  | 0          | 0         | 0               | 0                 | 0         |

#### 11.6.2.19 Application Interrupt and Reset Control Register

| Bit   | Bit Symbol                                    | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | VECTKEY<br>(Write)/<br>VECTKEY-<br>STAT(Read) | R/W  | Register key<br>[Write] Writing to this register requires 0x5FA in the <vectkey> field.<br/>[Read] Read as 0xFA05.</vectkey>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15    | ENDIANESS                                     | R/W  | Endianness bit:(Note1)<br>1: big endian<br>0: little endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14-11 | -                                             | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10-8  | PRIGROUP                                      | R/W  | Interrupt priority grouping<br>000: seven bits of pre-emption priority, one bit of subpriority<br>001: six bits of pre-emption priority, two bits of subpriority<br>010: five bits of pre-emption priority, three bits of subpriority<br>011: four bits of pre-emption priority, four bits of subpriority<br>100: three bits of pre-emption priority, five bits of subpriority<br>101: two bits of pre-emption priority, six bits of subpriority<br>101: one bit of pre-emption priority, seven bits of subpriority<br>110: one bit of pre-emption priority, seven bits of subpriority<br>111: no pre-emption priority, eight bits of subpriority<br>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.<br>1=CPU outputs a SYSRESETREQ signal. (note2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1     | VECTCLR<br>ACTIVE                             | R/W  | Clear active vector bit<br>1: clear all state information for active NMI, fault, and interrupts<br>0: do not clear.<br>This bit self-clears.<br>It is the responsibility of the application to reinitialize the stack.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0     | VECTRESET                                     | R/W  | System Reset bit<br>1: reset system<br>0: do not reset system<br>Resets the system, with the exception of debug components (FPB, DWT and ITM) by setting "1" and this<br>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.

#### 11.6.2.20 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                 |
|-------------|-----------|---------------|-------------|---------------------|
| 0.000 5018  | PRI_7     | PRI_6         | PRI_5       | PRI_4               |
| 0xE000_ED18 |           | (Usage Fault) | (Bus Fault) | (Memory Management) |
|             | PRI_11    | PRI_10        | PRI_9       | PRI_8               |
| 0xE000_ED1C | (SVCall)  |               |             |                     |
| 075000 5000 | 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 |    | -  | -  | -  | -  | -  |
| After reset | 0     | 0     | 0  | 0  | 0  | 0  | 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     | 0  | 0  | 0  | 0  | 0  | 0  |
|             | 7     | 6     | 5  | 4  | 3  | 2  | 1  | 0  |
| bit symbol  | PRI_4 |       |    | -  | -  | -  | -  | -  |
| After reset | 0     | 0     | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit   | Bit Symbol | Туре | 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   | -          | R    | Read as 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  | -                | -                  | -                  | -                  | -               | USGFAULT<br>ENA | BUSFAULT<br>ENA | MEMFAULT<br>ENA |
| After reset | 0                | 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               | 1               | 0               |
| bit symbol  | SVCALLACT        | -                  | -                  | -                  | USGFAULT<br>ACT | -               | BUSFAULT<br>ACT | MEMFAULT<br>ACT |
| After reset | 0                | 0                  | 0                  | 0                  | 0               | 0               | 0               | 0               |

#### 11.6.2.21 System Handler Control and State Register

| Bit   | Bit Symbol         | Туре | Function                                        |
|-------|--------------------|------|-------------------------------------------------|
| 31-19 | -                  | R    | Read as 0.                                      |
| 18    | USGFAULT<br>ENA    | R/W  | Usage Fault<br>0: Disabled<br>1: Enable         |
| 17    | BUSFAUL<br>TENA    | R/W  | Bus Fault<br>0: Disabled<br>1: Enable           |
| 16    | MEMFAULT<br>ENA    | R/W  | Memory Management<br>0: Disabled<br>1: Enable   |
| 15    | SVCALL<br>PENDED   | R/W  | SVCall<br>0: Not pended<br>1: Pended            |
| 14    | BUSFAULT<br>PENDED | R/W  | Bus Fault<br>0: Not pended<br>1: Pended         |
| 13    | MEMFAULT<br>PENDED | R/W  | Memory Management<br>0: Not pended<br>1: Pended |
| 12    | USGFAULT<br>PENDED | R/W  | Usage Fault<br>0: Not pended<br>1: Pended       |
| 11    | SYSTICKACT         | R/W  | SysTick<br>0: Inactive<br>1: Active             |
| 10    | PENDSVACT          | R/W  | PendSV<br>0: Inactive<br>1: Active              |
| 9     | -                  | R    | Read as 0.                                      |
| 8     | MONITORACT         | R/W  | Debug Monitor<br>0: Inactive<br>1: Active       |
| 7     | SVCALLACT          | R/W  | SVCall<br>0: Inactive<br>1: Active              |
| 6-4   | -                  | R    | Read as 0.                                      |

| 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         |

Note: You must clear or set the active bits with extreme caution because clearing and setting these bits does not repair stack contents.

## 11.6.3 Clock generator registers

### 11.6.3.1 CGIMCGA(CG Interrupt Mode Control Register A)

|             | 31 | 30    | 29    | 28 | 27 | 26  | 25 | 24     |
|-------------|----|-------|-------|----|----|-----|----|--------|
| bit symbol  | -  |       | EMCG3 |    | EM | ST3 | -  | INT3EN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 23 | 22    | 21    | 20 | 19 | 18  | 17 | 16     |
| bit symbol  | -  |       | EMCG2 |    | EM | ST2 | -  | INT2EN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 15 | 14    | 13    | 12 | 11 | 10  | 9  | 8      |
| bit symbol  | -  |       | EMCG1 |    | EM | ST1 | -  | INT1EN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 7  | 6     | 5     | 4  | 3  | 2   | 1  | 0      |
| bit symbol  | -  | EMCG0 |       |    | EM | ST0 | -  | INT0EN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 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~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |
| 27-26 | EMST3[1:0] | R    | active level of INT3 standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 25    | -          | R    | Reads as undefined.                                                                                                                                                                    |
| 24    | INT3EN     | R/W  | INT3 clear input<br>0:Disable<br>1: Enable                                                                                                                                             |
| 23    | -          | R    | Read as 0.                                                                                                                                                                             |
| 22-20 | EMCG2[2:0] | R/W  | active level setting of INT2 standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |
| 19-18 | EMST2[1:0] | R    | active level of INT2 standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 17    | -          | R    | Reads as undefined.                                                                                                                                                                    |
| 16    | INT2EN     | R/W  | INT2 clear input<br>0:Disable<br>1: Enable                                                                                                                                             |
| 15    | -          | R    | Read as 0.                                                                                                                                                                             |

# TOSHIBA

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                               |
|-------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14-12 | EMCG1[2:0] | R/W  | active level setting of INT1 standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |
| 11-10 | EMST1[1:0] | R    | active level of INT1 standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 9     | -          | R    | Reads as undefined.                                                                                                                                                                    |
| 8     | INT1EN     | R/W  | INT1 clear input<br>0:Disable<br>1: Enable                                                                                                                                             |
| 7     | -          | R    | Read as 0.                                                                                                                                                                             |
| 6-4   | EMCG0[2:0] | R/W  | active level setting of INT0 standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |
| 3-2   | EMST0[1:0] | R    | active level of INT0 standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 1     | -          | R    | Reads as undefined.                                                                                                                                                                    |
| 0     | INTOEN     | R/W  | INT0 clear input<br>0:Disable<br>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 prohibited.

| 11.6.3.2 | CGIMCGB(CG Interrupt Mode Control Register B) |
|----------|-----------------------------------------------|
|----------|-----------------------------------------------|

|             | 31 | 30    | 29    | 28 | 27    | 26  | 25 | 24     |
|-------------|----|-------|-------|----|-------|-----|----|--------|
| bit symbol  | -  |       | EMCG7 |    | EM    | ST7 | -  | INT7EN |
| After reset | 0  | 0     | 1     | 0  | 0     | 0   | 0  | 0      |
|             | 23 | 22    | 21    | 20 | 19    | 18  | 17 | 16     |
| bit symbol  | -  |       | EMCG6 |    | EM    | ST6 | -  | INT6EN |
| After reset | 0  | 0     | 1     | 0  | 0     | 0   | 0  | 0      |
|             | 15 | 14    | 13    | 12 | 11    | 10  | 9  | 8      |
| bit symbol  | -  |       | EMCG5 |    | EM    | ST5 | -  | INT5EN |
| After reset | 0  | 0     | 1     | 0  | 0     | 0   | 0  | 0      |
|             | 7  | 6     | 5     | 4  | 3     | 2   | 1  | 0      |
| bit symbol  | -  | EMCG4 |       |    | EMST4 |     | -  | INT4EN |
| After reset | 0  | 0     | 1     | 0  | 0     | 0   | 0  | 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~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |
| 27-26 | EMST7[1:0] | R    | active level of INT7 standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 25    | -          | R    | Reads as undefined.                                                                                                                                                                    |
| 24    | INT7EN     | R/W  | INT7 clear input<br>0:Disable<br>1: Enable                                                                                                                                             |
| 23    | -          | R    | Read as 0.                                                                                                                                                                             |
| 22-20 | EMCG6[2:0] | R/W  | active level setting of INT6 standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |
| 19-18 | EMST6[1:0] | R    | active level of INT6 standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 17    | -          | R    | Reads as undefined.                                                                                                                                                                    |
| 16    | INT6EN     | R/W  | INT6 clear input<br>0:Disable<br>1: Enable                                                                                                                                             |
| 15    | -          | R    | Read as 0.                                                                                                                                                                             |
| 14-12 | EMCG5[2:0] | R/W  | active level setting of INT5 standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |

# TOSHIBA

| 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 edges                                                                    |
| 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~111: setting prohibited) |
|       |            |      | 000: "Low" level                                                                  |
|       |            |      | 001: "High" level                                                                 |
|       |            |      | 010: Falling edge                                                                 |
|       |            |      | 011: Rising edge                                                                  |
|       |            |      | 100: Both edges                                                                   |
| 3-2   | EMST4[1:0] | R    | active level of INT4 standby clear request                                        |
|       |            |      | 00: -                                                                             |
|       |            |      | 01: Rising edge                                                                   |
|       |            |      | 10: Falling edge                                                                  |
|       |            |      | 11: Both edges                                                                    |
| 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 prohibited.

|             | 31 | 30    | 29    | 28 | 27 | 26  | 25 | 24     |
|-------------|----|-------|-------|----|----|-----|----|--------|
| bit symbol  | -  |       | EMCGB |    | EM | STB | -  | INTBEN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 23 | 22    | 21    | 20 | 19 | 18  | 17 | 16     |
| bit symbol  | -  |       | EMCGA |    | EM | STA | -  | INTAEN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 15 | 14    | 13    | 12 | 11 | 10  | 9  | 8      |
| bit symbol  | -  |       | EMCG9 |    | EM | ST9 | -  | INT9EN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 7  | 6     | 5     | 4  | 3  | 2   | 1  | 0      |
| bit symbol  | -  | EMCG8 |       |    | EM | ST8 | -  | INT8EN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |

#### 11.6.3.3 CGIMCGC(CG Interrupt Mode Control Register C)

| Bit   | Bit Symbol | Туре | Function                                                                                                     |
|-------|------------|------|--------------------------------------------------------------------------------------------------------------|
| 31    | -          | R    | Read as 0.                                                                                                   |
| 30-28 | EMCGB[2:0] | R/W  | active level setting of INTPHT11 standby clear request.<br><b>Set it as shown below.</b><br>011: Rising edge |
| 27-26 | EMSTB[1:0] | R    | Reads as undefined.                                                                                          |
| 25    | -          | R    | Reads as undefined.                                                                                          |
| 24    | INTBEN     | R/W  | INTPHT11 clear input<br>0:Disable<br>1: Enable                                                               |
| 23    | -          | R    | Read as 0.                                                                                                   |
| 22-20 | EMCGA[2:0] | R/W  | active level setting of INTPHT10 standby clear request.<br><b>Set it as shown below.</b><br>011: Rising edge |
| 19-18 | EMSTA[1:0] | R    | Reads as undefined.                                                                                          |
| 17    | -          | R    | Reads as undefined.                                                                                          |
| 16    | INTAEN     | R/W  | INTPHT10 clear input<br>0:Disable<br>1: Enable                                                               |
| 15    | -          | R    | Read as 0.                                                                                                   |
| 14-12 | EMCG9[2:0] | R/W  | active level setting of INTPHT01 standby clear request.<br><b>Set it as shown below.</b><br>011: Rising edge |
| 11-10 | EMST9[1:0] | R    | Reads as undefined.                                                                                          |
| 9     | -          | R    | Reads as undefined.                                                                                          |
| 8     | INT9EN     | R/W  | INTPHT01 clear input<br>0:Disable<br>1: Enable                                                               |
| 7     | -          | R    | Read as 0.                                                                                                   |
| 6-4   | EMCG8[2:0] | R/W  | active level setting of INTPHT00 standby clear request.<br><b>Set it as shown below.</b><br>011: Rising edge |
| 3-2   | EMST8[1:0] | R    | Reads as undefined.                                                                                          |
| 1     | -          | R    | Reads as undefined.                                                                                          |
| 0     | INT8EN     | R/W  | INTPHT00 clear input<br>0:Disable<br>1: Enable                                                               |

Note: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is prohibited.

|             | 31 | 30    | 29    | 28 | 27 | 26  | 25 | 24     |
|-------------|----|-------|-------|----|----|-----|----|--------|
| bit symbol  | -  |       | EMCGF |    | EM | STF | -  | INTFEN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 23 | 22    | 21    | 20 | 19 | 18  | 17 | 16     |
| bit symbol  | -  |       | EMCGE |    | EM | STE | -  | INTEEN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 15 | 14    | 13    | 12 | 11 | 10  | 9  | 8      |
| bit symbol  | -  |       | EMCGD |    | EM | STD | -  | INTDEN |
| After reset | 0  | 0     | 1     | 0  | 0  | 0   | 0  | 0      |
|             | 7  | 6     | 5     | 4  | 3  | 2   | 1  | 0      |
| bit symbol  | -  | EMCGC |       |    | EM | STC | -  | INTCEN |
| After reset | 0  | 0     |       | 0  | 0  | 0   | 0  | 0      |

### 11.6.3.4 CGIMCGD(CG Interrupt Mode Control Register D)

| Bit   | Bit Symbol | Туре | Function                                                |
|-------|------------|------|---------------------------------------------------------|
| 31    | -          | R    | Read as 0.                                              |
| 30-28 | EMCGF[2:0] | R/W  | active level setting of INTPHT31 standby clear request. |
|       |            |      | Set it as shown below.                                  |
|       |            |      | 011: Rising edge                                        |
| 27-26 | EMSTF[1:0] | R    | Reads as undefined.                                     |
| 25    | -          | R    | Reads as undefined.                                     |
| 24    | INTFEN     | R/W  | INTPHT31 clear input                                    |
|       |            |      | 0:Disable                                               |
|       |            |      | 1: Enable                                               |
| 23    | -          | R    | Read as 0.                                              |
| 22-20 | EMCGE[2:0] | R/W  | active level setting of INTPHT30 standby clear request. |
|       |            |      | Set it as shown below.                                  |
|       |            |      | 011: Rising edge                                        |
| 19-18 | EMSTE[1:0] | R    | Reads as undefined.                                     |
| 17    | -          | R    | Reads as undefined.                                     |
| 16    | INTEEN     | R/W  | INTPHT30 clear input                                    |
|       |            |      | 0:Disable                                               |
|       |            |      | 1: Enable                                               |
| 15    | -          | R    | Read as 0.                                              |
| 14-12 | EMCGD[2:0] | R/W  | active level setting of INTPHT21 standby clear request. |
|       |            |      | Set it as shown below.                                  |
|       |            |      | 011: Rising edge                                        |
| 11-10 | EMSTD[1:0] | R    | Reads as undefined.                                     |
| 9     | -          | R    | Reads as undefined.                                     |
| 8     | INTDEN     | R/W  | INTPHT21 clear input                                    |
|       |            |      | 0:Disable                                               |
|       |            |      | 1: Enable                                               |
| 7     | -          | R    | Read as 0.                                              |
| 6-4   | EMCGC[2:0] | R/W  | active level setting of INTPHT20 standby clear request. |
|       |            |      | Set it as shown below.                                  |
|       |            |      | 011: Rising edge                                        |
| 3-2   | EMSTC[1:0] | R    | Reads as undefined.                                     |
| 1     | -          | R    | Reads as undefined.                                     |

# TOSHIBA

| Bit | Bit Symbol | Туре | Function             |
|-----|------------|------|----------------------|
| 0   | INTCEN     | R/W  | INTPHT20 clear input |
|     |            |      | 0:Disable            |
|     |            |      | 1: Enable            |

Note: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is prohibited.

|             | 31 | 30 | 29     | 28 | 27  | 26   | 25 | 24      |
|-------------|----|----|--------|----|-----|------|----|---------|
| bit symbol  | -  |    | EMCG13 |    | EMS | ST13 | -  | INT13EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |
|             | 23 | 22 | 21     | 20 | 19  | 18   | 17 | 16      |
| bit symbol  | -  |    | EMCG12 |    | EMS | ST12 | -  | INT12EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |
|             | 15 | 14 | 13     | 12 | 11  | 10   | 9  | 8       |
| bit symbol  | -  |    | EMCG11 |    | EMS | GT11 | -  | INT11EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |
|             | 7  | 6  | 5      | 4  | 3   | 2    | 1  | 0       |
| bit symbol  | -  |    | EMCG10 |    | EMS | GT10 | -  | INT10EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |

#### 11.6.3.5 CGIMCGE(CG Interrupt Mode Control Register E)

| Bit   | Bit Symbol  | Туре | Function                                                  |
|-------|-------------|------|-----------------------------------------------------------|
| 31    | -           | R    | Read as 0.                                                |
| 30-28 | EMCG13[2:0] | R/W  | active level setting of INTPHEVRY3 standby clear request. |
|       |             |      | Set it as shown below.                                    |
|       |             |      | 011: Rising edge                                          |
| 27-26 | EMST13[1:0] | R    | Reads as undefined.                                       |
| 25    | -           | R    | Reads as undefined.                                       |
| 24    | INT13EN     | R/W  | INTPHEVRY3 clear input                                    |
|       |             |      | 0:Disable                                                 |
|       |             |      | 1: Enable                                                 |
| 23    | -           | R    | Read as 0.                                                |
| 22-20 | EMCG12[2:0] | R/W  | active level setting of INTPHEVRY2 standby clear request. |
|       |             |      | Set it as shown below.                                    |
|       |             |      | 011: Rising edge                                          |
| 19-18 | EMST12[1:0] | R    | Reads as undefined.                                       |
| 17    | -           | R    | Reads as undefined.                                       |
| 16    | INT12EN     | R/W  | INTPHEVRY2 clear input                                    |
|       |             |      | 0:Disable                                                 |
|       |             |      | 1: Enable                                                 |
| 15    | -           | R    | Read as 0.                                                |
| 14-12 | EMCG11[2:0] | R/W  | active level setting of INTPHEVRY1 standby clear request. |
|       |             |      | Set it as shown below.                                    |
|       |             |      | 011: Rising edge                                          |
| 11-10 | EMST11[1:0] | R    | Reads as undefined.                                       |
| 9     | -           | R    | Reads as undefined.                                       |
| 8     | INT11EN     | R/W  | INTPHEVRY1 clear input                                    |
|       |             |      | 0:Disable                                                 |
|       |             |      | 1: Enable                                                 |
| 7     | -           | R    | Read as 0.                                                |
| 6-4   | EMCG10[2:0] | R/W  | active level setting of INTPHEVRY0 standby clear request. |
|       |             |      | Set it as shown below.                                    |
|       |             |      | 011: Rising edge                                          |
| 3-2   | EMST10[1:0] | R    | Reads as undefined.                                       |
| 1     | -           | R    | Reads as undefined.                                       |

# TOSHIBA

| Bit | Bit Symbol | Туре | Function               |
|-----|------------|------|------------------------|
| 0   | INT10EN    | R/W  | INTPHEVRY0 clear input |
|     |            |      | 0:Disable              |
|     |            |      | 1: Enable              |

Note: Please specify the bit for the edge first and then specify the bit for the <INTxEN>. Setting them simultaneously is prohibited.

|             | 31 | 30 | 29     | 28 | 27  | 26   | 25 | 24      |
|-------------|----|----|--------|----|-----|------|----|---------|
| bit symbol  | -  |    | EMCG17 |    | EMS | GT17 | -  | INT17EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |
|             | 23 | 22 | 21     | 20 | 19  | 18   | 17 | 16      |
| bit symbol  | -  |    | EMCG16 |    | EMS | GT16 | -  | INT16EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |
|             | 15 | 14 | 13     | 12 | 11  | 10   | 9  | 8       |
| bit symbol  | -  |    | EMCG15 |    | EMS | GT15 | -  | INT15EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |
|             | 7  | 6  | 5      | 4  | 3   | 2    | 1  | 0       |
| bit symbol  | -  |    | EMCG14 |    | EMS | ST14 | -  | INT14EN |
| After reset | 0  | 0  | 1      | 0  | 0   | 0    | 0  | 0       |

#### 11.6.3.6 CGIMCGF(CG Interrupt Mode Control Register F)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                                               |
|-------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | -           | R    | Read as 0.                                                                                                                                                                             |
| 30-28 | EMCG17[2:0] | R/W  | active level setting of INTB standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level                                                             |
|       |             |      | 010: Falling edge<br>011: Rising edge<br>100: Both edges                                                                                                                               |
| 27-26 | EMST17[1:0] | R    | active level of INTB standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 25    | -           | R    | Reads as undefined.                                                                                                                                                                    |
| 24    | INT17EN     | R/W  | INTB clear input<br>0:Disable<br>1: Enable                                                                                                                                             |
| 23    | -           | R    | Read as 0.                                                                                                                                                                             |
| 22-20 | EMCG16[2:0] | R/W  | active level setting of INTA standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |
| 19-18 | EMST16[1:0] | R    | active level of INTA standby clear request<br>00: -<br>01: Rising edge<br>10: Falling edge<br>11: Both edges                                                                           |
| 17    | -           | R    | Reads as undefined.                                                                                                                                                                    |
| 16    | INT16EN     | R/W  | INTA clear input<br>0:Disable<br>1: Enable                                                                                                                                             |
| 15    | -           | R    | Read as 0.                                                                                                                                                                             |
| 14-12 | EMCG15[2:0] | R/W  | active level setting of INT9 standby clear request. (101~111: setting prohibited)<br>000: "Low" level<br>001: "High" level<br>010: Falling edge<br>011: Rising edge<br>100: Both edges |

| Bit   | Bit Symbol  | Туре | Function                                                                          |
|-------|-------------|------|-----------------------------------------------------------------------------------|
| 11-10 | EMST15[1:0] | R    | active level of INT9 standby clear request                                        |
|       |             |      | 00: -                                                                             |
|       |             |      | 01: Rising edge                                                                   |
|       |             |      | 10: Falling edge                                                                  |
|       |             |      | 11: Both edges                                                                    |
| 9     | -           | R    | Reads as undefined.                                                               |
| 8     | INT15EN     | R/W  | INT9 clear input                                                                  |
|       |             |      | 0:Disable                                                                         |
|       |             |      | 1: Enable                                                                         |
| 7     | -           | R    | Read as 0.                                                                        |
| 6-4   | EMCG14[2:0] | R/W  | active level setting of INT8 standby clear request. (101~111: setting prohibited) |
|       |             |      | 000: "Low" level                                                                  |
|       |             |      | 001: "High" level                                                                 |
|       |             |      | 010: Falling edge                                                                 |
|       |             |      | 011: Rising edge                                                                  |
|       |             |      | 100: Both edges                                                                   |
| 3-2   | EMST14[1:0] | R    | active level of INT8 standby clear request                                        |
|       |             |      | 00: -                                                                             |
|       |             |      | 01: Rising edge                                                                   |
|       |             |      | 10: Falling edge                                                                  |
|       |             |      | 11: Both edges                                                                    |
| 1     | -           | R    | Reads as undefined.                                                               |
| 0     | INT14EN     | 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 prohibited.

Note:Be sure to set active state of the clear request if interrupt is enabled for clearing the STOP1/ STOP2/ IDLE standby modes.

- 1. When using interrupt, be sure to follow the sequence of actions shown below:
  - If shared with other general ports, enable the port to receive the interrupt.
    - Setup conditions such as active state when initializing.
    - Clear interrupt requests.
    - Enable interrupts.
- 2. Each setup must be done while interrupt is in a disable condition.
- 3. As an interrupt of STOP1 release, it is available to set 24 factors of INT0 to INT7, INT8 to INTB, INTPHT00 to INTPHT31 and INTPHEVRY0 to INTPHEVRY3 interrupts. It is set by CG whether to be used for STOP1 release interrupt, and the edge/level when in active condition.
- 4. As an interrupt of STOP2 release, it is available to set 12 factors of IINT0 to INT7 and INT8 to INTB interrupts. Set "rising edge" CG whether to be used for STOP2 release interrupt, and the setup active condition.
- 5. In the assigned factors to STOP1/STOP2/IDLE standby modes release request interrupt, INT0 to INT7 and INT8 to INTB are available to be used as normal interrupt without setting CG.

|             | 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  | 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  | -  | -  | -  |    |    | ICRCG |    |    |
| After reset | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  |

#### 11.6.3.7 CGICRCG(CG Interrupt Request Clear Register)

| Bit  | Bit Symbol | Туре |                     | Function         |                    |                                       |  |  |  |  |  |
|------|------------|------|---------------------|------------------|--------------------|---------------------------------------|--|--|--|--|--|
| 31-5 | -          | R    | Read as 0.          |                  |                    |                                       |  |  |  |  |  |
| 4-0  | ICRCG[4:0] | W    | Clear interrupt rec | quests.          |                    |                                       |  |  |  |  |  |
|      |            |      | 0_0000: INT0        | 0_1000: INTPHT00 | 1_0000: INTPHEVRY0 | 1_1000 to 1_1111: setting prohibited. |  |  |  |  |  |
|      |            |      | 0_0001: INT1        | 0_1001: INTPHT01 | 1_0001: INTPHEVRY1 |                                       |  |  |  |  |  |
|      |            |      | 0_0010: INT2        | 0_1010: INTPHT10 | 1_0010: INTPHEVRY2 |                                       |  |  |  |  |  |
|      |            |      | 0_0011: INT3        | 0_1011: INTPHT11 | 1_0011: INTPHEVRY3 |                                       |  |  |  |  |  |
|      |            |      | 0_0100: INT4        | 0_1100: INTPHT20 | 1_0100: INT8       |                                       |  |  |  |  |  |
|      |            |      | 0_0101: INT5        | 0_1101: INTPHT21 | 1_0101: INT9       |                                       |  |  |  |  |  |
|      |            |      | 0_0110: INT6        | 0_1110: INTPHT30 | 1_0110: INTA       |                                       |  |  |  |  |  |
|      |            |      | 0_0111: INT7        | 0_1111: INTPHT31 | 1_0111: INTB       |                                       |  |  |  |  |  |
|      |            |      | Read as 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  | -  | -  | -  | -  | -  | -  | -       | -       |
| 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       | 0       |
|             | 7  | 6  | 5  | 4  | 3  | 2  | 1       | 0       |
| bit symbol  | -  | -  | -  | -  | -  | -  | NMIFLG1 | NMIFLG0 |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0       |

#### 11.6.3.8 CGNMIFLG(NMI Flag Register)

| 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<br>0: not applicable<br>1: generated from WDT               |

Note: <NMIFLG> are cleared to "0" when they are read.

|                 | 31 | 30 | 29      | 28      | 27        | 26      | 25        | 24      |
|-----------------|----|----|---------|---------|-----------|---------|-----------|---------|
| bit symbol      | -  | -  | -       | -       | -         | -       | -         | -       |
| After pin reset | 0  | 0  | 0       | 0       | 0         | 0       | 0         | 0       |
|                 | 23 | 22 | 21      | 20      | 19        | 18      | 17        | 16      |
| bit symbol      | -  | -  | -       | -       | -         | -       | -         | -       |
| After pin reset | 0  | 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         | 0       |
|                 | 7  | 6  | 5       | 4       | 3         | 2       | 1         | 0       |
| bit symbol      | -  | -  | OFDRSTF | DBGRSTF | STOP2RSTF | WDTRSTF | -         | PINRSTF |
| After pin reset | 0  | 0  | 0       | 0       | 0         | 0       | Undefined | 1       |

#### 11.6.3.9 CGRSTFLG (Reset Flag Register)

| Bit  | Bit Symbol | Туре | Function                            |
|------|------------|------|-------------------------------------|
| 31-6 | -          | R    | Read as 0.                          |
| 5    | OFDRSTF    | R/W  | OFD reset flag                      |
|      |            |      | 0: "0" is written                   |
|      |            |      | 1: Reset from OFD                   |
| 4    | DBGRSTF    | R/W  | Debug reset flag (Note1)            |
|      |            |      | 0: "0" is written                   |
|      |            |      | 1: Reset from SYSRESETREQ           |
| 3    | STOP2RSTF  | R/W  | STOP2 reset flag                    |
|      |            |      | 0: "0" is written                   |
|      |            |      | 1: Reset flag by STOP2 mode release |
| 2    | WDTRSTF    | R/W  | WDT reset flag                      |
|      |            |      | 0: "0" is written                   |
|      |            |      | 1: Reset from WDT                   |
| 1    | -          | R/W  | Read as undefined.                  |
|      |            |      | Write as 0.                         |
| 0    | PINRSTF    | R/W  | RESET pin flag                      |
|      |            |      | 0: "0" is written                   |
|      |            |      | 1: Reset from RESET pin.            |

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: This product is initialized by the external reset.

## 12. Input/Output Ports

### 12.1 Port Functions

#### 12.1.1 Function Lists

TMPM341FDXBG/FYXBG has 86 ports. Besides the ports function, these ports can be used as I/O pins for peripheral functions.

Table 12-1, Table 12-2 and Table 12-3 show the port function table.

| Table 12-1 Port Function List (Port A-Por | tC) |
|-------------------------------------------|-----|
|-------------------------------------------|-----|

| Port   | Pin | Input/<br>Output | Programmable<br>Pull-up<br>Pull-down | Schmitt<br>input | Noise<br>Filter | Program-<br>mable<br>Open-drain | Function pin         |
|--------|-----|------------------|--------------------------------------|------------------|-----------------|---------------------------------|----------------------|
|        | PA0 | I/O              | Pull-up                              | _                | _               | o                               | D0/AD0               |
| ľ      | PA1 | I/O              | Pull-up                              | -                | -               | 0                               | D1/AD1               |
|        | PA2 | I/O              | Pull-up                              | -                | -               | о                               | D2/AD2               |
| Dert A | PA3 | I/O              | Pull-up                              | -                | -               | 0                               | D3/AD3               |
| Port A | PA4 | I/O              | Pull-up                              | -                | -               | 0                               | D4/AD4               |
|        | PA5 | I/O              | Pull-up                              | -                | -               | 0                               | D5/AD5               |
|        | PA6 | I/O              | Pull-up                              | -                | -               | о                               | D6/AD6               |
|        | PA7 | I/O              | Pull-up                              | -                | -               | 0                               | D7/AD7               |
|        | PB0 | I/O              | Pull-up                              | -                | -               | 0                               | D8/AD8/A0            |
|        | PB1 | I/O              | Pull-up                              | -                | -               | 0                               | D9/AD9/A1            |
|        | PB2 | I/O              | Pull-up                              | -                | -               | 0                               | D10/AD10/A2          |
| D. (D  | PB3 | I/O              | Pull-up                              | -                | -               | 0                               | D11/AD11/A3          |
| Port B | PB4 | I/O              | Pull-up                              | -                | -               | 0                               | D12/AD12/A4          |
|        | PB5 | I/O              | Pull-up                              | -                | -               | 0                               | D13/AD13/A5          |
|        | PB6 | I/O              | Pull-up                              | -                | -               | 0                               | D14/AD14/A6          |
|        | PB7 | I/O              | Pull-up                              | -                | -               | 0                               | D15/AD15/A7          |
|        | PC0 | I/O              | Pull-up                              | 0                | _               | o                               | A0/TXD1/TB2IN0       |
|        | PC1 | I/O              | Pull-up                              | 0                | -               | 0                               | A1/RXD1/TB2IN1       |
|        | PC2 | I/O              | Pull-up                              | 0                | -               | 0                               | A2/SCLK1/TB0OUT/CTS1 |
| Dart C | PC3 | I/O              | Pull-up                              | 0                | 0               | о                               | A3/INT2/TB1OUT       |
| Port C | PC4 | I/O              | Pull-up                              | 0                | -               | o                               | A4/TXD2/TB3IN0       |
|        | PC5 | I/O              | Pull-up                              | 0                | -               | 0                               | A5/RXD2/TB3IN1       |
|        | PC6 | I/O              | Pull-up                              | 0                | -               | 0                               | A6/SCLK2/TB4IN0/CTS2 |
|        | PC7 | I/O              | Pull-up                              | 0                | 0               | 0                               | A7/INT3/TB4IN1       |

o : Exist

- : Not exist

Note: The noise elimination width of the noise filter is approximately 30 ns under typical conditions.

| 12.1 | Port | Functions |
|------|------|-----------|
|------|------|-----------|

| Port   | Pin | Input/Out-<br>put | Programmable<br>Pull-up<br>Pull-down | Schmitt<br>Input | Noise<br>Filter | Program-<br>mable<br>Open-drain | Function pin           |
|--------|-----|-------------------|--------------------------------------|------------------|-----------------|---------------------------------|------------------------|
|        | PD0 | I/O               | Pull-up                              | 0                | -               | o                               | A8/SO1/SDA1/TB7OUT     |
|        | PD1 | I/O               | Pull-up                              | 0                | -               | 0                               | A9/SI1/SCL1/TB8OUT     |
|        | PD2 | I/O               | Pull-up                              | 0                | -               | 0                               | A10/SCK1/TB9OUT        |
| Dent D | PD3 | I/O               | Pull-up                              | 0                | 0               | 0                               | A11/INT4/ADTRG         |
| Port D | PD4 | I/O               | Pull-up                              | 0                | -               | о                               | A12/SPDO               |
|        | PD5 | I/O               | Pull-up                              | 0                | -               | о                               | A13/SPDI               |
|        | PD6 | I/O               | Pull-up                              | 0                | -               | о                               | A14/SPCLK              |
|        | PD7 | I/O               | Pull-up                              | 0                | -               | o                               | A15/SPFSS/SCOUT        |
|        | PE0 | I/O               | Pull-up                              | 0                | -               | o                               | TXD0/A16               |
|        | PE1 | I/O               | Pull-up                              | 0                | _               | 0                               | RXD0/A17               |
|        | PE2 | I/O               | Pull-up                              | 0                | -               | 0                               | SCLK0/A18/TB2OUT/ CTS0 |
| Dert F | PE3 | I/O               | Pull-up                              | 0                | 0               | 0                               | INT5/A19/TB3OUT        |
| Port E | PE4 | I/O               | Pull-up                              | 0                | -               | o                               | A20/TD0OUT0            |
|        | PE5 | I/O               | Pull-up                              | 0                | -               | 0                               | A21/TD0OUT1            |
|        | PE6 | I/O               | Pull-up                              | 0                | -               | 0                               | A22/TD1OUT0            |
|        | PE7 | I/O               | Pull-up                              | 0                | -               | о                               | A23/TD1OUT1            |
|        | PF0 | Output            | After Reset,<br>Pull-up              | 0                | -               | o                               | BOOT/TB6OUT            |
|        | PF1 | I/O               | Pull-up                              | 0                | -               | 0                               | RD                     |
|        | PF2 | I/O               | Pull-up                              | 0                | -               | 0                               | WR                     |
| Port F | PF3 | I/O               | Pull-up                              | 0                | -               | о                               | BELL                   |
|        | PF4 | I/O               | Pull-up                              | 0                | 0               | о                               | BELH/INT6/TB5IN0       |
|        | PF5 | I/O               | Pull-up                              | 0                | 0               | о                               | CS1/INT7/TB5IN1        |
|        | PF6 | I/O               | Pull-up                              | 0                | -               | о                               | CS0                    |
|        | PF7 | I/O               | Pull-up                              | 0                | -               | o                               | ALE                    |
|        | PG0 | I/O               | Pull-up                              | o                | 1               | o                               | SO0/SDA0/TB7IN0        |
|        | PG1 | I/O               | Pull-up                              | 0                | -               | o                               | SI0/SCL0/TB7IN1        |
|        | PG2 | I/O               | Pull-up                              | 0                | 0               | 0                               | SCK0/INT8              |
| Dect O | PG3 | I/O               | Pull-up                              | 0                | 0               | o                               | INT0                   |
| Port G | PG4 | I/O               | Pull-up                              | 0                | -               | 0                               | TXD3/TB8IN0            |
|        | PG5 | I/O               | Pull-up                              | 0                | -               | o                               | RXD3/TB8IN1            |
|        | PG6 | I/O               | Pull-up                              | 0                | -               | 0                               | SCLK3/TB9IN0/CTS3      |
|        | PG7 | I/O               | Pull-up                              | 0                | 0               | о                               | INT1/TB9IN1            |

#### Table 12-2 Port Function List (Port D-Port G)

o : Exist

- : Not exist

Note: The noise elimination width of the noise filter is approximately 30 ns under typical conditions.

## TOSHIBA

| Port   | Pin | Input/Out-<br>put | Programmable<br>Pull-up<br>Pull-down | Schmitt<br>input | Noise<br>Filter | Program-<br>mable<br>Open-drain | Function pin      |
|--------|-----|-------------------|--------------------------------------|------------------|-----------------|---------------------------------|-------------------|
|        | PH0 | I/O               | Pull-up                              | 0                | -               | о                               | TXD4              |
|        | PH1 | I/O               | Pull-up                              | 0                | -               | о                               | RXD4              |
|        | PH2 | I/O               | Pull-up                              | 0                | -               | о                               | SCLK4/CTS4        |
| Port H | PH3 | I/O               | Pull-up                              | 0                | -               | 0                               | PHC3IN0/TB4OUT    |
|        | PH4 | I/O               | Pull-up                              | 0                | -               | о                               | PHC3IN1/TB5OUT    |
|        | PH5 | I/O               | Pull-up                              | 0                | -               | 0                               | TRACEDATA3        |
|        | PH6 | I/O               | Pull-up                              | 0                | -               | о                               | TRACEDATA2        |
|        | PI0 | I/O               | Pull-up                              | 0                | _               | о                               | TRACEDATA1        |
|        | PI1 | I/O               | Pull-up                              | 0                | -               | o                               | TRACEDATA0        |
|        | PI2 | I/O               | Pull-up                              | 0                | -               | 0                               | TRACECLK          |
|        | PI3 | I/O               | After Reset,<br>Pull-up              | 0                | 0               | -                               | TRST              |
| Port I | Pl4 | I/O               | After Reset,<br>Pull-up              | 0                | -               | -                               | ТDI               |
|        | PI5 | I/O               | After Reset,<br>Pull-down            | 0                | -               | -                               | TCK/SWCLK         |
|        | Pl6 | I/O               | After Reset,<br>Pull-up              | 0                | -               | -                               | TMS/SWDIO         |
|        | PI7 | I/O               | Pull-up                              | 0                | -               | -                               | TDO/SWV           |
|        | PJ0 | I/O               | Pull-up                              | 0                | -               | -                               | AIN00/PHC0IN0     |
|        | PJ1 | I/O               | Pull-up                              | 0                | -               | -                               | AIN01/PHC0IN1     |
|        | PJ2 | I/O               | Pull-up                              | 0                | -               | -                               | AIN02/PHC1IN0     |
| Dert   | PJ3 | I/O               | Pull-up                              | 0                | -               | -                               | AIN03/PHC1IN1     |
| Port J | PJ4 | I/O               | Pull-up                              | 0                | -               | -                               | AIN04/PHC2IN0     |
|        | PJ5 | I/O               | Pull-up                              | 0                | -               | -                               | AIN05/PHC2IN1     |
|        | PJ6 | I/O               | Pull-up                              | 0                | -               | -                               | AIN06/TB0IN0      |
|        | PJ7 | I/O               | Pull-up                              | 0                | 0               | -                               | AIN07/INT9/TB0IN1 |
|        | PK0 | I/O               | Pull-up                              | 0                | -               | -                               | AIN08/TB1IN0      |
|        | PK1 | I/O               | Pull-up                              | 0                | 0               | -                               | AIN09/INTA/TB1IN1 |
|        | PK2 | I/O               | Pull-up                              | 0                | -               | -                               | AIN10/TB6IN0      |
| Port K | PK3 | I/O               | Pull-up                              | 0                | 0               | -                               | AIN11/INTB/TB6IN1 |
|        | PK4 | I/O               | Pull-up                              | 0                | -               | -                               | AIN12             |
|        | PK5 | I/O               | Pull-up                              | 0                | -               | -                               | AIN13             |
|        | PK6 | I/O               | Pull-up                              | 0                | -               | -                               | AIN14             |

#### Table 12-3 Port Function List (Port H-Port K)

o : Exist

- : Not exist

Note: The noise elimination width of the noise filter is approximately 30 ns under typical conditions.

### 12.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 functions. 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 program 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.

### 12.1.3 Port States in STOP Mode

On the one hand, input and output in STOP1 mode are enabled/disabled by the CGSTBYCR<DRVE> bit; on the other hand input and output in STOP2 mode are enabled/disabled by the CGSTBYCR<PTKEEP> bit.

If PxIE or PxCR is enabled with  $\langle DRVE \rangle = 1$  or  $\langle PTKEEP \rangle = "0" \rightarrow "1"$ , input or output is enabled respectively in STOP1/STOP2 mode. If  $\langle DRVE \rangle = 0$ , both input and output are disabled in STOP1 mode except for some ports even if PxIE or PxCR are enabled. However, to transmit from Normal mode to STOP2 mode, the  $\langle PTKEEP \rangle$  bit need to be set "0" to "1".

Table 12-4 shows the pin conditions in STOP mode.

Table 12-4 Port conditions in STOP mode

|             | Pin Name                                                                                                                             | I/O         | <drve> = 0</drve>                                             | <drve> = 1</drve> | <ptkeep> = 0 to 1</ptkeep> |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------------------------------------|-------------------|----------------------------|--|
| Exclud-     | X1                                                                                                                                   | Input only  | ×                                                             | ×                 |                            |  |
| ing<br>port | X2                                                                                                                                   | Output only | "High" Level Output                                           | "High" Le         | vel Output                 |  |
| port        | RESET, NMI, MODE, INTLV, BSC, ENDIAN                                                                                                 | Input only  | 0                                                             |                   | 0                          |  |
|             | PI6, PI7                                                                                                                             | Input       | ×                                                             | Depends           | on PxIE[m]                 |  |
|             | [When used for debug (PxFRn <pxmfn>=1)<br/>and output is enabled (PxCR<pxmc>=1)]<br/>(note)</pxmc></pxmfn>                           | Output      | Enabled when data is valid.<br>Disabled when data is invalid. |                   |                            |  |
|             | PC3, PC7, PD3, PE3, PF4, PF5, PG2, PG3,                                                                                              | Input       | 0                                                             | 0                 |                            |  |
| Port        | PG7, PJ7, PK1, PK3<br>[When used for interrupt<br>(PxFRn <pxmfn>=1) and input is enabled<br/>(PxIE<pxmie>=1)] (note)</pxmie></pxmfn> | Output      | ×                                                             | Depends o         | n PxCR[m].                 |  |
|             | Other parts                                                                                                                          | Input       | ×                                                             | Depends of        | on PxIE[m].                |  |
|             | Other ports                                                                                                                          | Output      | ×                                                             | Depends o         | n PxCR[m].                 |  |

o :Input or output enabled

× :Input or output disabled

Note:"x" indicates a port number, "m" a corresponding bit and "n" a function register number.

#### 12.1.4 Precautions for Mode Transition between STOP1 and STOP2

If PI5 is configured as a debug function pin of TCK/SWCLK, it prevents the low power consumption mode from being fully effective.

Configure PI5 to function as a general-purpose port if the debug function is not used.

### 12.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 "12.3 Block Diagrams of Ports".

#### 12.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 you use the port A as the external bus interface, set "1" to the registers of PACR, PAFR1 and PAIE.

#### 12.2.1.1 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                     |
| Reserved                           | -      | 0x000C                     |
| Reserved                           | -      | 0x0010                     |
| Reserved                           | -      | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port A open drain control register | PAOD   | 0x0028                     |
| Port A pull-up control register    | PAPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port A input control register      | PAIE   | 0x0038                     |

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PA7 | PA6 | PA5 | PA4 | PA3 | PA2 | PA1 | PA0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

#### 12.2.1.2 PADATA (Port A data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7-0  | PA7-PA0    | R/W  | Port A data register. |

#### 12.2.1.3 PACR (Port A 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   | 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    | 0    |
|             | 7    | 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 | -          | R    | Read as 0. |
| 7-0  | PA7C-PA0C  | R/W  | Output     |
|      |            |      | 0: disable |
|      |            |      | 1: enable  |

|             | 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     | 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  | PA7F1 | PA6F1 | PA5F1 | PA4F1 | PA3F1 | PA2F1 | PA1F1 | PA0F1 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.1.4 PAFR1 (Port A function register 1)

| 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  |

|             | 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     | 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  | PA7OD | PA6OD | PA5OD | PA4OD | PA3OD | PA2OD | PA10D | PA0OD |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.1.5 PAOD (Port A open drain control register)

| Bit  | Bit Symbol      | Туре | Function                 |
|------|-----------------|------|--------------------------|
| 31-8 | -               | R    | Read as 0.               |
| 7-0  | PA7OD-<br>PA0OD | R/W  | 0: CMOS<br>1: Open drain |

#### 12.2.1.6 PAPUP (Port A 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    | 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     | 0     |
|             | 7     | 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 | -           | R    | Read as 0. |
| 7-0  | PA7UP-PA0UP | R/W  | Pull-up    |
|      |             |      | 0: Disable |
|      |             |      | 1: Enable  |

|             | 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     | 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  | PA7IE | PA6IE | PA5IE | PA4IE | PA3IE | PA2IE | PA1IE | PA0IE |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.1.7 PAIE (Port A input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-8 | -           | R    | Read as 0.                       |
| 7-0  | PA7IE-PA0IE | R/W  | Input<br>0: DIsable<br>1: Enable |

### 12.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 two types of function register. If you use the port B as a general-purpose port, set "0" to the corresponding bit of the two registers. If you use the port B 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.

#### 12.2.2.1 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 function register 2         | PBFR2  | 0x000C                     |
| Reserved                           | -      | 0x0010                     |
| Reserved                           | -      | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port B open drain control register | PBOD   | 0x0028                     |
| Port B pull-up control register    | PBPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port B input control register      | PBIE   | 0x0038                     |

Note: Access to the "reserved" areas is prohibited.

#### 12.2 Port functions

|             | 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   | 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  | PB7 | PB6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

#### 12.2.2.2 PBDATA (Port B data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7-0  | PB7-PB0    | R/W  | Port B data register. |

#### 12.2.2.3 PBCR (Port B 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   | 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    | 0    |
|             | 7    | 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-PB0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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     | 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  | PB7F1 | PB6F1 | PB5F1 | PB4F1 | PB3F1 | PB2F1 | PB1F1 | PB0F1 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.2.4 PBFR1 (Port B function register 1)

| 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   |

#### 12.2 Port functions

|             | 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     | 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  | PB7F2 | PB6F2 | PB5F2 | PB4F2 | PB3F2 | PB2F2 | PB1F2 | PB0F2 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.2.5 PBFR2 (Port B function register 2)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PB7F2      | R/W  | 0: PORT    |
|      |            |      | 1: A7      |
| 6    | PB6F2      | R/W  | 0: PORT    |
|      |            |      | 1: A6      |
| 5    | PB5F2      | R/W  | 0: PORT    |
|      |            |      | 1: A5      |
| 4    | PB4F2      | R/W  | 0: PORT    |
|      |            |      | 1: A4      |
| 3    | PB3F2      | R/W  | 0: PORT    |
|      |            |      | 1: A3      |
| 2    | PB2F2      | R/W  | 0: PORT    |
|      |            |      | 1: A2      |
| 1    | PB1F2      | R/W  | 0: PORT    |
|      |            |      | 1: A1      |
| 0    | PB0F2      | R/W  | 0: PORT    |
|      |            |      | 1: A0      |

|             | 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     | 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  | PB7OD | PB6OD | PB5OD | PB4OD | PB3OD | PB2OD | PB10D | PB0OD |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.2.6 PBOD (Port B open drain control register)

| Bit  | Bit Symbol      | Туре | Function                 |
|------|-----------------|------|--------------------------|
| 31-8 | -               | R    | Read as 0.               |
| 7-0  | PB7OD-<br>PB0OD | R/W  | 0: CMOS<br>1: Open drain |

#### 12.2.2.7 PBPUP (Port B 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    | 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     | 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     | 0     |

| Bit  | Bit Symbol  | Туре | Function   |
|------|-------------|------|------------|
| 31-8 | -           | R    | Read as 0. |
| 7-0  | PB7UP-PB0UP | R/W  | Pull-up    |
|      |             |      | 0: Disable |
|      |             |      | 1: Enable  |

|             | 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     | 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  | PB7IE | PB6IE | PB5IE | PB4IE | PB3IE | PB2IE | PB1IE | PB0IE |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.2.8 PBIE (Port B input control register)

| Bit  | Bit Symbol  | Туре | Function            |
|------|-------------|------|---------------------|
| 31-8 | -           | R    | Read as 0.          |
| 7-0  | PB7IE-PB0IE | R/W  | Input<br>0: Disable |
|      |             |      | 1: Enable           |

# 12.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 general purpose serial interface (UART/SIO), the 16-bits timer (TMRB) and the external interrupt input.

Reset initializes all bits of the port C as general-purpose ports with input, output and pull-up disabled.

The port C has four types of function register. If you use the port C as a general-purpose port, set "0" to the corresponding bit of the four 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 other function registers at the same time.

Note: In modes other than STOP mode, interrupt input is enabled regardless of the PCFR register setting if input is enabled in PCIE. Make sure to disable unused interrupts when programming the device.

|                                    |        | 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 function register 4         | PCFR4  | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port C open drain control register | PCOD   | 0x0028                     |
| Port C pull-up control register    | PCPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port C input control register      | PCIE   | 0x0038                     |

#### 12.2.3.1 Port C Register

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.3.2 PCDATA (Port C data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7-0  | PC7-PC0    | R/W  | Port C data register. |

### 12.2.3.3 PCCR (Port C 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   | 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    | 0    |
|             | 7    | 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-PC0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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     | 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  | PC7F1 | PC6F1 | PC5F1 | PC4F1 | PC3F1 | PC2F1 | PC1F1 | PC0F1 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

# 12.2.3.4 PCFR1 (Port C function register 1)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PC7F1      | R/W  | 0: PORT    |
|      |            |      | 1: A7      |
| 6    | PC6F1      | R/W  | 0: PORT    |
|      |            |      | 1: A6      |
| 5    | PC5F1      | R/W  | 0: PORT    |
|      |            |      | 1: A5      |
| 4    | PC4F1      | R/W  | 0: PORT    |
|      |            |      | 1: A4      |
| 3    | PC3F1      | R/W  | 0: PORT    |
|      |            |      | 1: A3      |
| 2    | PC2F1      | R/W  | 0: PORT    |
|      |            |      | 1: A2      |
| 1    | PC1F1      | R/W  | 0: PORT    |
|      |            |      | 1: A1      |
| 0    | PC0F1      | R/W  | 0: PORT    |
|      |            |      | 1: A0      |

|             | 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     | 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  | PC7F2 | PC6F2 | PC5F2 | PC4F2 | PC3F2 | PC2F2 | PC1F2 | PC0F2 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.3.5 PCFR2 (Port C function register 2)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PC7F2      | R/W  | 0: PORT    |
|      |            |      | 1: INT3    |
| 6    | PC6F2      | R/W  | 0: PORT    |
|      |            |      | 1: SCLK2   |
| 5    | PC5F2      | R/W  | 0: PORT    |
|      |            |      | 1: RXD2    |
| 4    | PC4F2      | R/W  | 0: PORT    |
|      |            |      | 1: TXD2    |
| 3    | PC3F2      | R/W  | 0: PORT    |
|      |            |      | 1: INT2    |
| 2    | PC2F2      | R/W  | 0: PORT    |
|      |            |      | 1: SCLK1   |
| 1    | PC1F2      | R/W  | 0: PORT    |
|      |            |      | 1: RXD1    |
| 0    | PC0F2      | R/W  | 0: PORT    |
|      |            |      | 1: TXD1    |

|             | 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     | 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  | PC7F3 | PC6F3 | PC5F3 | PC4F3 | PC3F3 | PC2F3 | PC1F3 | PC0F3 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.3.6 PCFR3 (Port C function register 3)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PC7F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB4IN1  |
| 6    | PC6F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB4IN0  |
| 5    | PC5F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB3IN1  |
| 4    | PC4F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB3IN0  |
| 3    | PC3F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB1OUT  |
| 2    | PC2F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB0OUT  |
| 1    | PC1F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB2IN1  |
| 0    | PC0F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB2IN0  |

|             | 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  | 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  | -  | PC6F4 | -  | -  | -  | PC2F4 | -  | -  |
| After reset | 0  | 0     | 0  | 0  | 0  | 0     | 0  | 0  |

### 12.2.3.7 PCFR4 (Port C function register 4)

| Bit  | Bit Symbol | Туре | Function           |
|------|------------|------|--------------------|
| 31-7 | -          | R    | Read as 0.         |
| 6    | PC6F4      | R/W  | 0: PORT<br>1: CTS2 |
| 5-3  | -          | R    | Read as 0.         |
| 2    | PC2F4      | R/W  | 0: PORT<br>1: CTS1 |
| 1-0  | -          | R    | Read as 0.         |

# 12.2.3.8 PCOD (Port C 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    | 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     | 0     |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | PC70D | PC6OD | PC50D | PC4OD | PC3OD | PC2OD | PC10D | PC00D |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit  | Bit Symbol      | Туре | Function                 |
|------|-----------------|------|--------------------------|
| 31-8 | -               | R    | Read as 0.               |
| 7-0  | PC7OD-<br>PC0OD | R/W  | 0: CMOS<br>1: Open drain |

|             | 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     | 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  | PC7UP | PC6UP | PC5UP | PC4UP | PC3UP | PC2UP | PC1UP | PC0UP |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.3.9 PCPUP (Port C pull-up control register)

| Bit  | Bit Symbol  | Туре | Function                           |
|------|-------------|------|------------------------------------|
| 31-8 | -           | R    | Read as 0.                         |
| 7-0  | PC7UP-PC0UP | R/W  | Pull-up<br>0: Disable<br>1: Enable |

### 12.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     | 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     | 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     | 0     |

| Bit  | Bit Symbol  | Туре | Function   |
|------|-------------|------|------------|
| 31-8 | -           | R    | Read as 0. |
| 7-0  | PC7IE-PC0IE | R/W  | input      |
|      |             |      | 0: Disable |
|      |             |      | 1: Enable  |

# 12.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 bus interface (I2C/SIO), the external interrupt input, the synchronous serial interface (SSP), the 16-bits timer (TMRB), the clock output and the A/DC trigger input.

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 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 other function registers at the same time.

Note: In modes other than STOP mode, interrupt input is enabled regardless of the PDFR register setting if input is enabled in PDIE. Make sure to disable unused interrupts when programming the device.

|                                    |        | Base Address = 0x400C_0300 |
|------------------------------------|--------|----------------------------|
| Register name                      |        | Address (Base+)            |
| Port D data register               | PDDATA | 0x0000                     |
| Port D output control register     | PDCR   | 0x0004                     |
| Port D function register 1         | PDFR1  | 0x0008                     |
| Port D function register 2         | PDFR2  | 0x000C                     |
| Port D function register 3         | PDFR3  | 0x0010                     |
| Reserved                           | -      | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port D open drain control register | PDOD   | 0x0028                     |
| Port D pull-up control register    | PDPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port D input control register      | PDIE   | 0x0038                     |

#### 12.2.4.1 Port D Register

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PD7 | PD6 | PD5 | PD4 | PD3 | PD2 | PD1 | PD0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.4.2 PDDATA (Port D data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7-0  | PD7-PD0    | R/W  | Port D data register. |

# 12.2.4.3 PDCR (Port D 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   | 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    | 0    |
|             | 7    | 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-PD0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             |       | <b>(</b> |       |       |       |       |       |      |
|-------------|-------|----------|-------|-------|-------|-------|-------|------|
|             |       | -        | -     |       |       | -     | -     | -    |
|             | 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     | 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  | PD7F1 | PD6F1    | PD5F1 | PD4F1 | PD3F1 | PD2F1 | PD1F1 | PD0F |
| After reset | 0     | 0        | 0     | 0     | 0     | 0     | 0     | 0    |

#### 12.2.4.4 PDFR1 (Port D function register 1)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PD7F1      | R/W  | 0: PORT    |
|      |            |      | 1: A15     |
| 6    | PD6F1      | R/W  | 0: PORT    |
|      |            |      | 1: A14     |
| 5    | PD5F1      | R/W  | 0: PORT    |
|      |            |      | 1: A13     |
| 4    | PD4F1      | R/W  | 0: PORT    |
|      |            |      | 1: A12     |
| 3    | PD3F1      | R/W  | 0: PORT    |
|      |            |      | 1: A11     |
| 2    | PD2F1      | R/W  | 0: PORT    |
|      |            |      | 1: A10     |
| 1    | PD1F1      | R/W  | 0: PORT    |
|      |            |      | 1: A9      |
| 0    | PD0F1      | R/W  | 0: PORT    |
|      |            |      | 1: A8      |

|             | 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     | 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  | PD7F2 | PD6F2 | PD5F2 | PD4F2 | PD3F2 | PD2F2 | PD1F2 | PD0F2 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.4.5 PDFR2 (Port D function register 2)

| Bit  | Bit Symbol | Туре | Function    |
|------|------------|------|-------------|
| 31-8 | -          | R    | Read as 0.  |
| 7    | PD7F2      | R/W  | 0: PORT     |
|      |            |      | 1: SPSS     |
| 6    | PD6F2      | R/W  | 0: PORT     |
|      |            |      | 1: SPCK     |
| 5    | PD5F2      | R/W  | 0: PORT     |
|      |            |      | 1: SPDI     |
| 4    | PD4F2      | R/W  | 0: PORT     |
|      |            |      | 1: SPDO     |
| 3    | PD3F2      | R/W  | 0: PORT     |
|      |            |      | 1: INT4     |
| 2    | PD2F2      | R/W  | 0: PORT     |
|      |            |      | 1: SCK1     |
| 1    | PD1F2      | R/W  | 0: PORT     |
|      |            |      | 1: SI1/SCL1 |
| 0    | PD0F2      | R/W  | 0: PORT     |
|      |            |      | 1: SO1/SDA1 |

|             | 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     | 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  | PD7F3 | -  | -  | -  | PD3F3 | PD2F3 | PD1F3 | PD0F3 |
| After reset | 0     | 0  | 0  | 0  | 0     | 0     | 0     | 0     |

### 12.2.4.6 PDFR3 (Port D function register 3)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PD7F3      | R/W  | 0: PORT    |
|      |            |      | 1: SCOUT   |
| 6-4  | -          | R    | Read as 0. |
| 3    | PD3F3      | R/W  | 0: PORT    |
|      |            |      | 1: ADTRG   |
| 2    | PD2F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB9OUT  |
| 1    | PD1F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB8OUT  |
| 0    | PD0F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB7OUT  |

|             | 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     | 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  | PD7OD | PD6OD | PD5OD | PD4OD | PD3OD | PD2OD | PD10D | PD00D |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.4.7 PDOD (Port D open drain control register)

| Bit  | Bit Symbol      | Туре | Function                 |
|------|-----------------|------|--------------------------|
| 31-8 | -               | R    | Read as 0.               |
| 7-0  | PD7OD-<br>PD0OD | R/W  | 0: CMOS<br>1: Open drain |

### 12.2.4.8 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     | 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     | 0     |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | PD7UP | PD6UP | PD5UP | PD4UP | PD3UP | PD2UP | PD1UP | PD0UP |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit  | Bit Symbol  | Туре | Function   |
|------|-------------|------|------------|
| 31-8 | -           | R    | Read as 0. |
| 7-0  | PD7UP-PD0UP | R/W  | Pull-up    |
|      |             |      | 0: Disable |
|      |             |      | 1: Enable  |

|             | 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     | 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  | PD7IE | PD6IE | PD5IE | PD4IE | PD3IE | PD2IE | PD1IE | PD0IE |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.4.9 PDIE (Port D input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-8 | -           | R    | Read as 0.                       |
| 7-0  | PD7IE-PD0IE | R/W  | Input<br>0: Disable<br>1: Enable |

# 12.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 general purpose serial interface (SIO/UART), the external interrupt input, the 16-bits timer (TMRB) and the high resolution PPG output (TMRD).

Reset initializes all bits of the port E as general-purpose ports with input, output and pull-up disabled.

The port E has four types of function register. If you use the port E as a general-purpose port, set "0" to the corresponding bit of the four 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 other function registers at the same time.

Note: In modes other than STOP mode, interrupt input is enabled regardless of the PEFR register setting if input is enabled in PEIE. Make sure to disable unused interrupts when programming the device.

|                                    |        | 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 function register 4         | PEFR4  | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port E open drain control register | PEOD   | 0x0028                     |
| Port E pull-up control register    | PEPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port E input control register      | PEIE   | 0x0038                     |

#### 12.2.5.1 Port E Register

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PE7 | PE6 | PE5 | PE4 | PE3 | PE2 | PE1 | PE0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.5.2 PEDATA (Port E data register)

| Bit  | Bit Symbol | Туре | Function             |
|------|------------|------|----------------------|
| 31-8 | -          | R    | Read as 0.           |
| 7-0  | PE7-PE0    | R/W  | Port E data register |

### 12.2.5.3 PECR (Port E 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   | 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    | 0    |
|             | 7    | 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-PE0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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     | 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  | -  | -  | -  | -  | PE3F1 | PE2F1 | PE1F1 | PE0F1 |
| After reset | 0  | 0  | 0  | 0  | 0     | 0     | 0     | 0     |

### 12.2.5.4 PEFR1 (Port E function register 1)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-4 | -          | R    | Read as 0. |
| 3    | PE3F1      | R/W  | 0: PORT    |
|      |            |      | 1: INT5    |
| 2    | PE2F1      | R/W  | 0: PORT    |
|      |            |      | 1: SCLK0   |
| 1    | PE1F1      | R/W  | 0: PORT    |
|      |            |      | 1: RXD0    |
| 0    | PE0F1      | R/W  | 0: PORT    |
|      |            |      | 1: TXD0    |

|             | 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     | 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  | PE7F2 | PE6F2 | PE5F2 | PE4F2 | PE3F2 | PE2F2 | PE1F2 | PE0F2 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.5.5 PEFR2 (Port E function register 2)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PE7F2      | R/W  | 0: PORT    |
|      |            |      | 1: A23     |
| 6    | PE6F2      | R/W  | 0: PORT    |
|      |            |      | 1: A22     |
| 5    | PE5F2      | R/W  | 0: PORT    |
|      |            |      | 1: A21     |
| 4    | PE4F2      | R/W  | 0: PORT    |
|      |            |      | 1: A20     |
| 3    | PE3F2      | R/W  | 0: PORT    |
|      |            |      | 1: A19     |
| 2    | PE2F2      | R/W  | 0: PORT    |
|      |            |      | 1: A18     |
| 1    | PE1F2      | R/W  | 0: PORT    |
|      |            |      | 1: A17     |
| 0    | PE0F2      | R/W  | 0: PORT    |
|      |            |      | 1: A16     |

|             | 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  | 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  | PE7F3 | PE6F3 | PE5F3 | PE4F3 | PE3F3 | PE2F3 | -  | -  |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0  | 0  |

### 12.2.5.6 PEFR3 (Port E function register 3)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PE7F3      | R/W  | 0: PORT    |
|      |            |      | 1: TD10UT1 |
| 6    | PE6F3      | R/W  | 0: PORT    |
|      |            |      | 1: TD10UT0 |
| 5    | PE5F3      | R/W  | 0: PORT    |
|      |            |      | 1: TD0OUT1 |
| 4    | PE4F3      | R/W  | 0: PORT    |
|      |            |      | 1: TD0OUT0 |
| 3    | PE3F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB3OUT  |
| 2    | PE2F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB2OUT  |
| 1-0  | -          | R    | Read as 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  | -  | -  | -  | -  | -  | -     | -  | -  |
| 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  | 0  |
|             | 7  | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| bit symbol  | -  | -  | -  | -  | -  | PE2F4 | -  | -  |
| After reset | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  |

### 12.2.5.7 PEFR4 (Port E function register 4)

| Bit  | Bit Symbol | Туре | Function           |
|------|------------|------|--------------------|
| 31-3 | -          | R    | Read as 0.         |
| 2    | PE2F4      | R/W  | 0: PORT<br>1: CTS0 |
| 1-0  | -          | R    | Read as 0.         |

# 12.2.5.8 PEOD (Port E 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    | 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     | 0     |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | PE7OD | PE6OD | PE5OD | PE4OD | PE3OD | PE2OD | PE10D | PE00D |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit  | Bit Symbol      | Туре | Function                 |
|------|-----------------|------|--------------------------|
| 31-8 | -               | R    | Read as 0.               |
| 7-0  | PE7OD-<br>PE0OD | R/W  | 0: CMOS<br>1: Open-drain |

|             | 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     | 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  | PE7UP | PE6UP | PE5UP | PE4UP | PE3UP | PE2UP | PE1UP | PE0UP |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.5.9 PEPUP (Port E pull-up control register)

| Bit  | Bit Symbol  | Туре | Function                           |
|------|-------------|------|------------------------------------|
| 31-8 | -           | R    | Read as 0.                         |
| 7-0  | PE7UP-PE0UP | R/W  | Pull-up<br>0: Disable<br>1: Enable |

### 12.2.5.10 PEIE (Port E 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     | 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  | PE7IE | PE6IE | PE5IE | PE4IE | PE3IE | PE2IE | PE1IE | PE0IE |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit  | Bit Symbol  | Туре | Function   |
|------|-------------|------|------------|
| 31-8 | -           | R    | Read as 0. |
| 7-0  | PE7IE-PE0IE | R/W  | Input      |
|      |             |      | 0: Disable |
|      |             |      | 1: Enable  |

#### 12.2.6 Port F (PF0 to PF7)

The port F is a general-purpose, 1-bit output port and 7-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 F performs the functions of the external bus interface, the external interrupt input, 16-bit timer (TMRB) and the mode setting function.

The port F has three types 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. Do not set "1" to the other function registers at the same time.

Reset initializes all bits of the port F as general-purpose ports. The bit of PF0 output is disabled and the pull-up setting is enabled, the bits of PF<7:1> input/output and all bits of pull-up setting are disabled.

According to the mode setting function, while a reset signal is in "Low" state, the  $\lceil PF0/\overline{BOOT} \rfloor$  input and pull-up are enabled. At the rising edge of the reset signal, if  $\lceil PF0 \rfloor$  is "High", the device enters single mode and boots from the on-chip flash memory. If  $\lceil PF0 \rfloor$  is "Low", the device enters single BOOT mode and boots from the internal BOOT program.For details of single boot mode, refer to "Flash Memory Operation".

Note: In modes other than STOP mode, interrupt input is enabled regardless of the PFFR register setting if input is enabled in PFIE. Make sure to disable unused interrupts when programming the device.

|                                    |        | 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 function register 2         | PFFR2  | 0x000C                     |
| Port F function register 3         | PFFR3  | 0x0010                     |
| Reserved                           | -      | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port F open drain control register | PFOD   | 0x0028                     |
| Port F pull-up control register    | PFPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port F input control register      | PFIE   | 0x0038                     |

#### 12.2.6.1 Port F Register

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PF7 | PF6 | PF5 | PF4 | PF3 | PF2 | PF1 | PF0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.6.2 PFDATA (Port F data register)

| Bit  | Bit Symbol | Туре | Function             |
|------|------------|------|----------------------|
| 31-8 | -          | R    | Read as 0.           |
| 7-0  | PF7-PF0    | R/W  | Port F data register |

### 12.2.6.3 PFCR (Port F 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   | 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    | 0    |
|             | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| bit symbol  | PF7C | PF6C | PF5C | PF4C | PF3C | PF2C | PF1C | PF0C |
| After reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7-0  | PF7C-PF0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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     | 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  | PF7F1 | PF6F1 | PF5F1 | PF4F1 | PF3F1 | PF2F1 | PF1F1 | PF0F1 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

# 12.2.6.4 PFFR1 (Port F function register 1)

| Bit  | Bit Symbol | Туре | Function          |
|------|------------|------|-------------------|
| 31-8 | -          | R    | Read as 0.        |
| 7    | PF7F1      | R/W  | 0: PORT           |
|      |            |      | 1: ALE            |
| 6    | PF6F1      | R/W  | 0: PORT           |
|      |            |      | 1: <del>CS0</del> |
| 5    | PF5F1      | R/W  | 0: PORT           |
|      |            |      | 1: <del>CS1</del> |
| 4    | PF4F1      | R/W  | 0: PORT           |
|      |            |      | 1: BELH           |
| 3    | PF3F1      | R/W  | 0: PORT           |
|      |            |      | 1: BELL           |
| 2    | PF2F1      | R/W  | 0: PORT           |
|      |            |      | 1: WR             |
| 1    | PF1F1      | R/W  | 0: PORT           |
|      |            |      | 1: RD             |
| 0    | PF0F1      | R/W  | 0: PORT           |
|      |            |      | 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  | -  | -  | -     | -     | -  | -  | -  | -  |
| 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  | 0  |
|             | 7  | 6  | 5     | 4     | 3  | 2  | 1  | 0  |
| bit symbol  | -  | -  | PF5F2 | PF4F2 | -  | -  | -  | -  |
| After reset | 0  | 0  | 0     | 0     | 0  | 0  | 0  | 0  |

# 12.2.6.5 PFFR2 (Port F function register 2)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-6 | -          | R    | Read as 0. |
| 5    | PF5F2      | R/W  | 0: PORT    |
|      |            |      | 1: INT7    |
| 4    | PF4F2      | R/W  | 0: PORT    |
|      |            |      | 1: INT6    |
| 3-0  | -          | R    | Read as 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  | -  | -  | -     | -     | -  | -  | -  | -     |
| 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  | 0     |
|             | 7  | 6  | 5     | 4     | 3  | 2  | 1  | 0     |
| bit symbol  | -  | -  | PF5F3 | PF4F3 | -  | -  | -  | PF0F3 |
| After reset | 0  | 0  | 0     | 0     | 0  | 0  | 0  | 0     |

# 12.2.6.6 PFFR3 (Port F function register 3)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-6 | -          | R    | Read as 0. |
| 5    | PF5F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB5IN1  |
| 4    | PF4F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB5IN0  |
| 3-1  | -          | R    | Read as 0. |
| 0    | PF0F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB6OUT  |

|             | 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     | 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  | PF70D | PF6OD | PF5OD | PF4OD | PF3OD | PF2OD | PF10D | PF0OD |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.6.7 PFOD (Port F open drain control register)

| Bit  | Bit Symbol  | Туре | Function      |
|------|-------------|------|---------------|
| 31-8 | -           | R    | Read as 0.    |
| 7-0  | PF70D-PF00D | R/W  | 0: CMOS       |
|      |             |      | 1: Open-drain |

### 12.2.6.8 PFPUP (Port F 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    | 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     | 0            |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0            |
| bit symbol  | PF7UP | PF6UP | PF5UP | PF4UP | PF3UP | PF2UP | PF1UP | <b>PF0UP</b> |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1            |

| Bit  | Bit Symbol  | Туре | Function             |
|------|-------------|------|----------------------|
| 31-8 | -           | R    | Read as 0.           |
| 7-1  | PF7UP-PF1UP | R/W  | Pull-up              |
|      |             |      | 0: Disable           |
|      |             |      | 1: Enable            |
| 0    | PF0UP       | R/W  | Pull-up              |
|      |             |      | 0: -                 |
|      |             |      | 1: Always set to "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  | -     | -     | -     | -     | -     | -     | -     | -  |
| 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     | 0  |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0  |
| bit symbol  | PF7IE | PF6IE | PF5IE | PF4IE | PF3IE | PF2IE | PF1IE | -  |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0  |

### 12.2.6.9 PFIE (Port F input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-8 | -           | R    | Read as 0.                       |
| 7-1  | PF7IE-PF1IE | R/W  | Input<br>0: Disable<br>1: Enable |
| 0    | -           | R    | Read as 0.                       |

# 12.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 (I2C/SIO), the general purpose serial interface (SIO/UART), the external interrupt input and the 16-bits timer (TMRB). Moreover the port G performs 5 voltage tolerant input pin.

The port G has three types 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 other function registers at the same time.

Reset initializes all bits of the port G as general-purpose ports with input, output and pull-up disabled.

Note: In modes other than STOP mode, interrupt input is enabled regardless of the PGFR register setting if input is enabled in PGIE. Make sure to disable unused interrupts when programming the device.

Note:Port G is 5 voltage tolerant input pin. When 5 voltage pull-up is required, it should be designed by outer pull-up. Therefore, do not use the programmable pull-up in this product.

Note: The outer 5 voltage pull-up is configured after all of voltage sources in this product is powered-on.

|                                    |        | Base Address = 0x400C_0600 |
|------------------------------------|--------|----------------------------|
| Register name                      |        | Address (Base+)            |
| Port G data register               | PGDATA | 0x0000                     |
| Port G output control register     | PGCR   | 0x0004                     |
| Reserved                           | -      | 0x0008                     |
| Port G function register 2         | PGFR2  | 0x000C                     |
| Port G function register 3         | PGFR3  | 0x0010                     |
| Port G function register 4         | PGFR4  | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port G open drain control register | PGOD   | 0x0028                     |
| Port G pull-up control register    | PGPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port G input control register      | PGIE   | 0x0038                     |

#### 12.2.7.1 Port G Register

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PG7 | PG6 | PG5 | PG4 | PG3 | PG2 | PG1 | PG0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.7.2 PGDATA (Port G data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7-0  | PG7-PG0    | R/W  | Port G data register. |

### 12.2.7.3 PGCR (Port G 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   | 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    | 0    |
|             | 7    | 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 | -          | R    | Read as 0. |
| 7-0  | PG7C-PG0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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     | 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  | PG7F2 | PG6F2 | PG5F2 | PG4F2 | PG3F2 | PG2F2 | PG1F2 | PG0F2 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.7.4 PGFR2 (Port G function register 2)

| Bit  | Bit Symbol | Туре | Function    |
|------|------------|------|-------------|
| 31-8 | -          | R    | Read as 0.  |
| 7    | PG7F2      | R/W  | 0: PORT     |
|      |            |      | 1: INT1     |
| 6    | PG6F2      | R/W  | 0: PORT     |
|      |            |      | 1: SCLK3    |
| 5    | PG5F2      | R/W  | 0: PORT     |
|      |            |      | 1: RXD3     |
| 4    | PG4F2      | R/W  | 0: PORT     |
|      |            |      | 1: TXD3     |
| 3    | PG3F2      | R/W  | 0: PORT     |
|      |            |      | 1: INTO     |
| 2    | PG2F2      | R/W  | 0: PORT     |
|      |            |      | 1: SCK0     |
| 1    | PG1F2      | R/W  | 0: PORT     |
|      |            |      | 1: SI0/SCL0 |
| 0    | PG0F2      | R/W  | 0: PORT     |
|      |            |      | 1: SO0/SDA0 |

|             | 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     | 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  | PG7F3 | PG6F3 | PG5F3 | PG4F3 | -  | PG2F3 | PG1F3 | PG0F3 |
| After reset | 0     | 0     | 0     | 0     | 0  | 0     | 0     | 0     |

### 12.2.7.5 PGFR3 (Port G function register 3)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PG7F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB9IN1  |
| 6    | PG6F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB9IN0  |
| 5    | PG5F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB8IN1  |
| 4    | PG4F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB8IN0  |
| 3    | -          | R    | Read as 0. |
| 2    | PG2F3      | R/W  | 0: PORT    |
|      |            |      | 1: INT8    |
| 1    | PG1F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB7IN1  |
| 0    | PG0F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB7IN0  |

|             | 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  | 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  | -  | PG6F4 | -  | -  | -  | -  | -  | -  |
| After reset | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0  |

# 12.2.7.6 PGFR4 (Port G function register 4)

| Bit  | Bit Symbol | Туре | Function           |
|------|------------|------|--------------------|
| 31-7 | -          | R    | Read as 0.         |
| 6    | PG6F4      | R/W  | 0: PORT<br>1: CTS3 |
| 5-0  | -          | R    | Read as 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  | -     | -     | -     | -     | -     | -     | -     | -     |
| 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     | 0     |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | PG70D | PG6OD | PG5OD | PG4OD | PG3OD | PG2OD | PG10D | PG0OD |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.7.7 PGOD (Port G open drain control register)

| Bit  | Bit Symbol      | Туре | Function                 |
|------|-----------------|------|--------------------------|
| 31-8 | -               | R    | Read as 0.               |
| 7-0  | PG7OD-<br>PG0OD | R/W  | 0: CMOS<br>1: Open-drain |

#### 12.2.7.8 PGPUP (Port G 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    | 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     | 0     |
|             | 7     | 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 | -               | R    | Read as 0.                         |
| 7-0  | PG7UP-<br>PG0UP | R/W  | Pull-up<br>0: Disable<br>1: Enable |

|             | 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     | 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  | PG7IE | PG6IE | PG5IE | PG4IE | PG3IE | PG2IE | PG1IE | PG0IE |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.7.9 PGIE (Port G input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-8 | -           | R    | Read as 0.                       |
| 7-0  | PG7IE-PG0IE | R/W  | Input<br>0: Disable<br>1: Enable |

#### 12.2.8 Port H (PH0 to PH6)

The port H 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 H performs the debug trace interface, the general purpose serial interface (UART/SIO) and the two-phase pulse timer input (PHCNT). Moreover the PH<2:0> of port H performs 5 voltage tolerant input pins.

The port H has four types of function register. If you use the port H as a general-purpose port, set "0" to the corresponding bit of the four 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 other function registers at the same time.

Reset initializes all bits of the port G as general-purpose ports with input, output and pull-up disabled.

Note:The PH<2:0> of Port H are 5 voltage tolerant input pins. When 5 voltage pull-up is required, it should be designed by outer pull-up. Therefore, do not use the programmable pull-up in this product.

Note: The outer 5 voltage pull-up is configured after all of voltage sources in this product is powered-on.

|                                    |        | 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 function register 3         | PHFR3  | 0x0010                     |
| Port H function register 4         | PHFR4  | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port H open drain control register | PHOD   | 0x0028                     |
| Port H pull-up control register    | PHPUP  | 0x002C                     |
| Reserved                           | -      | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port H input control register      | PHIE   | 0x0038                     |

#### 12.2.8.1 Port H Register

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | -  | PH6 | PH5 | PH4 | PH3 | PH2 | PH1 | PH0 |
| After reset | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.8.2 PHDATA (Port H data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-7 | -          | R    | Read as 0.            |
| 6-0  | PH6-PH0    | R/W  | Port H data register. |

# 12.2.8.3 PHCR (Port H 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   | 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    | 0    |
|             | 7  | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| bit symbol  | -  | PH6C | PH5C | PH4C | PH3C | PH2C | PH1C | PH0C |
| After reset | 0  | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-7 | -          | R    | Read as 0. |
| 6-0  | PH6C-PH0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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  | 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  | -  | PH6F1 | PH5F1 | -  | -  | -  | -  | -  |
| After reset | 0  | 0     | 0     | 0  | 0  | 0  | 0  | 0  |

### 12.2.8.4 PHFR1 (Port H function register 1)

| Bit  | Bit Symbol | Туре | Function      |
|------|------------|------|---------------|
| 31-7 | -          | R    | Read as 0.    |
| 6    | PH6F1      | R/W  | 0: PORT       |
|      |            |      | 1: TRACEDATA2 |
| 5    | PH5F1      | R/W  | 0: PORT       |
|      |            |      | 1: TRACEDATA3 |
| 4-0  | -          | R    | Read as 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  | -  | -  | -  | -     | -     | -     | -     | -     |
| 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     | 0     |
|             | 7  | 6  | 5  | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | -  | -  | -  | PH4F2 | PH3F2 | PH2F2 | PH1F2 | PH0F2 |
| After reset | 0  | 0  | 0  | 0     | 0     | 0     | 0     | 0     |

# 12.2.8.5 PHFR2 (Port H function register 2)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-5 | -          | R    | Read as 0.            |
| 4    | PH4F2      | R/W  | 0: PORT<br>1: PHC3IN1 |
| 3    | PH3F2      | R/W  | 0: PORT<br>1: PHC3IN0 |
| 2    | PH2F2      | R/W  | 0: PORT<br>1: SCLK4   |
| 1    | PH1F2      | R/W  | 0: PORT<br>1: RXD4    |
| 0    | PH0F2      | R/W  | 0: PORT<br>1: TXD4    |

|             | 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  | 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  | -  | -  | -  | PH4F3 | PH3F3 | -  | -  | -  |
| After reset | 0  | 0  | 0  | 0     | 0     | 0  | 0  | 0  |

### 12.2.8.6 PHFR3 (Port H function register 3)

| Bit  | Bit Symbol | Туре | Function             |
|------|------------|------|----------------------|
| 31-5 | -          | R    | Read as 0.           |
| 4    | PH4F3      | R/W  | 0: PORT<br>1: TB5OUT |
| 3    | PH3F3      | R/W  | 0: PORT<br>1: TB4OUT |
| 2-0  | PH0F2      | R    | Read as 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  | -  | -  | -  | -  | -  | -     | -  | -  |
| 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  | 0  |
|             | 7  | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| bit symbol  | -  | -  | -  | -  | -  | PH2F4 | -  | -  |
| After reset | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  |

# 12.2.8.7 PHFR4 (Port H function register 4)

| Bit  | Bit Symbol | Туре | Function           |
|------|------------|------|--------------------|
| 31-3 | -          | R    | Read as 0.         |
| 2    | PH2F4      | R/W  | 0: PORT<br>1: CTS4 |
| 1-0  | -          | R    | Read as 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  | -  | -     | -     | -     | -     | -     | -     | -     |
| 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     | 0     |
|             | 7  | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | -  | PH6OD | PH5OD | PH4OD | PH3OD | PH2OD | PH10D | PH0OD |
| After reset | 0  | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 12.2.8.8 PHOD (Port H open drain control register)

| Bit  | Bit Symbol      | Туре | Function                 |
|------|-----------------|------|--------------------------|
| 31-7 | -               | R    | Read as 0.               |
| 6-0  | PH6OD-<br>PH0OD | R/W  | 0: CMOS<br>1: Open-drain |

#### 12.2.8.9 PHPUP (Port H 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    | 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     | 0     |
|             | 7  | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | -  | PH6UP | PH5UP | PH4UP | PH3UP | PH2UP | PH1UP | PH0UP |
| After reset | 0  | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit  | Bit Symbol  | Туре | Function   |
|------|-------------|------|------------|
| 31-7 | -           | R    | Read as 0. |
| 6-0  | PH6UP-PH0UP | R/W  | Pull-up    |
|      |             |      | 0: Disable |
|      |             |      | 1: Enable  |

|             | 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     | 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  | -  | PH6IE | PH5IE | PH4IE | PH3IE | PH2IE | PH1IE | PHOIE |
| After reset | 0  | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.8.10 PHIE (Port H input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-7 | -           | R    | Read as 0.                       |
| 6-0  | PH6IE-PH0IE | R/W  | Input<br>0: Disable<br>1: Enable |

### 12.2.9 Port I (PI0 to PI7)

The port I 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 I performs the debug interface and the debug trace interface.

PI3, PI4, PI5, PI6 and PI7 are assigned as the debug interface after reset. PI3 is initialized as the TRST pin with input and pull-up enabled. PI4 is initialized as the TDI pin with input and pull-up enabled. PI5 is initialized as the TCK/SWCLK pin with input and pull-down enabled. PI6 is initialized as the TMS/SWDIO pin with input, output and pull-up enabled. PI7 is initialized as the TDO/SWV pin with output enabled. The other pins operate as general-purpose-ports, and input, output and pull-up are disabled.

Note 1: If PI6 or PI7 is configured as the TMS/SWDIO or TDO/SWV pin, output is enabled even in STOP1/ STOP2 mode regardless of the CGSTBYCR<DRVE>/<PTKEEP> bit setting

Note 2: If PI5 is configured as the TCK/SWCLK pin, it prevents the low power consumption mode from being fully effective. Configure PI5 to function as a general-purpose port if the TCK/SWCLK is not used.

|                                    |        | 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                     |
| Reserved                           | -      | 0x000C                     |
| Reserved                           | -      | 0x0010                     |
| Reserved                           | -      | 0x0014                     |
| Reserved                           | -      | 0x0018                     |
| Reserved                           | -      | 0x001C                     |
| Reserved                           | -      | 0x0020                     |
| Reserved                           | -      | 0x0024                     |
| Port I open drain control register | PIOD   | 0x0028                     |
| Port I pull-up control register    | PIPUP  | 0x002C                     |
| Port I pull-down control register  | PIPDN  | 0x0030                     |
| Reserved                           | -      | 0x0034                     |
| Port I input control register      | PIIE   | 0x0038                     |

#### 12.2.9.1 Port I Register

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PI7 | PI6 | PI5 | PI4 | PI3 | PI2 | PI1 | P10 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.9.2 PIDATA (Port I data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7-0  | PI7-PI0    | R/W  | Port I data register. |

### 12.2.9.3 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   | 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    | 0    |
|             | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| bit symbol  | PI7C | PI6C | PI5C | PI4C | PI3C | PI2C | PI1C | PI0C |
| After reset | 1    | 1    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7-0  | PI7C-PI0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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     | 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  | PI7F1 | PI6F1 | PI5F1 | PI4F1 | PI3F1 | PI2F1 | PI1F1 | PI0F1 |
| After reset | 1     | 1     | 1     | 1     | 1     | 0     | 0     | 0     |

# 12.2.9.4 PIFR1(Port I function register 1)

| Bit  | Bit Symbol | Туре | Function      |
|------|------------|------|---------------|
| 31-8 | -          | R    | Read as 0.    |
| 7    | PI7F1      | R/W  | 0: PORT       |
|      |            |      | 1: TDO/SWV    |
| 6    | PI6F1      | R/W  | 0: PORT       |
|      |            |      | 1: TMS/SWDIO  |
| 5    | PI5F1      | R/W  | 0: PORT       |
|      |            |      | 1: TCK/SWCLK  |
| 4    | PI4F1      | R/W  | 0: PORT       |
|      |            |      | 1: TDI        |
| 3    | PI3F1      | R/W  | 0: PORT       |
|      |            |      | 1: TRST       |
| 2    | PI2F1      | R/W  | 0: PORT       |
|      |            |      | 1: TRACECLK   |
| 1    | PI1F1      | R/W  | 0: PORT       |
|      |            |      | 1: TRACEDATA0 |
| 0    | PI0F1      | R/W  | 0: PORT       |
|      |            |      | 1: TRACEDATA1 |

|             | 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     | 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  | -  | -  | -  | -  | -  | PI2OD | PI10D | PI0OD |
| After reset | 0  | 0  | 0  | 0  | 0  | 0     | 0     | 0     |

#### 12.2.9.5 PIOD (Port I open drain control register)

| Bit  | Bit Symbol  | Туре | Function      |
|------|-------------|------|---------------|
| 31-3 | -           | R    | Read as 0.    |
| 2-0  | PI2OD-PI0OD | R/W  | 0: CMOS       |
|      |             |      | 1: Open-drain |

|             | 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     | 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  | PI7UP | PI6UP | -  | PI4UP | PI3UP | PI2UP | PI1UP | PIOUP |
| After reset | 0     | 1     | 0  | 1     | 1     | 0     | 0     | 0     |

### 12.2.9.6 PIPUP (Port I pull-up control register)

| Bit  | Bit Symbol  | Туре | Function                                             |
|------|-------------|------|------------------------------------------------------|
| 31-8 | -           | R    | Read as 0.                                           |
| 7    | PI7UP       | R/W  | Pull-up                                              |
|      |             |      | 0: Disable                                           |
|      |             |      | 1: Enable                                            |
| 6    | PI6UP       | R/W  | Pull-up                                              |
|      |             |      | 0: Disable                                           |
|      |             |      | 1: Enable, Always set to "1" as the debug interface. |
| 5    | -           | R    | Read as 0.                                           |
| 4-3  | PI4UP-PI3UP | R/W  | Pull-up                                              |
|      |             |      | 0: Disable                                           |
|      |             |      | 1: Enable, Always set to "1" as the debug interface. |
| 2-0  | PI2UP-PI0UP | R/W  | Pull-up                                              |
|      |             |      | 0: Disable                                           |
|      |             |      | 1: Enable                                            |

|             | 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  | 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  | -  | -  | PI5DN | -  | -  | -  | -  | -  |
| After reset | 0  | 0  | 1     | 0  | 0  | 0  | 0  | 0  |

#### 12.2.9.7 PIPDN (Port I pull-down control register)

| Bit  | Bit Symbol | Туре | Function                                             |
|------|------------|------|------------------------------------------------------|
| 31-6 | -          | R    | Read as 0.                                           |
| 5    | PI5DN      | R/W  | Pull-up                                              |
|      |            |      | 0: Disable                                           |
|      |            |      | 1: Enable, Always set to "1" as the debug interface. |
| 4-0  | -          | R    | Read as 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  | -     | -     | -     | -     | -     | -     | -     | -     |
| 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     | 0     |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | PI7IE | PI6IE | PI5IE | PI4IE | PI3IE | PI2IE | PI1IE | PIOIE |
| After reset | 0     | 1     | 1     | 1     | 1     | 0     | 0     | 0     |

### 12.2.9.8 PIIE (Port I input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-8 | -           | R    | Read as 0.                       |
| 7-0  | PI7IE-PI0IE | R/W  | Input<br>0: Disable<br>1: Enable |

### 12.2.10 Port J (PJ0 to PJ7)

The port J 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 J performs the A/D converter, the external interrupt input, the 16-bit timer (TMRB) and the two-phase pulse timer input (PHCNT).

The port J has two types of function register. If you use the port J as a general-purpose port, set "0" to the corresponding bit of the two registers. If you use the port J 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.

Reset initializes all bits of the port J as general-purpose ports with input, output and pull-up disabled.

To use the Port J as an analog input of the AD converter, disable input on PJIE and disable pull-up on PJPUP.

Note:Unless you use all the bits of port J and port K as analog input pins, conversion accuracy may be reduced. Be sure to verify that this causes no problem on your system.

Note: In modes other than STOP mode, interrupt input is enabled regardless of the PJFR register setting if input is enabled in PJIE. Make sure to disable unused interrupts when programming the device.

#### 12.2.10.1 Port J Register

|                                 |        | Base Address = 0x400C_0900 |
|---------------------------------|--------|----------------------------|
| Register name                   |        | Address (Base+)            |
| Port J data register            | PJDATA | 0x0000                     |
| Port J output control register  | PJCR   | 0x0004                     |
| Reserved                        | -      | 0x0008                     |
| Port J function register 2      | PJFR2  | 0x000C                     |
| Port J function register 3      | PJFR3  | 0x0010                     |
| Reserved                        | -      | 0x0014                     |
| Reserved                        | -      | 0x0018                     |
| Reserved                        | -      | 0x001C                     |
| Reserved                        | -      | 0x0020                     |
| Reserved                        | -      | 0x0024                     |
| Reserved                        | -      | 0x0028                     |
| Port J pull-up control register | PJPUP  | 0x002C                     |
| Reserved                        | -      | 0x0030                     |
| Reserved                        | -      | 0x0034                     |
| Port J input control register   | PJIE   | 0x0038                     |

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | PJ7 | PJ6 | PJ5 | PJ4 | PJ3 | PJ2 | PJ1 | PJ0 |
| After reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.10.2 PJDATA (Port J data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7-0  | PJ7-PJ0    | R/W  | Port J data register. |

### 12.2.10.3 PJCR (Port J 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   | 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    | 0    |
|             | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| bit symbol  | PJ7C | PJ6C | PJ5C | PJ4C | PJ3C | PJ2C | PJ1C | PJ0C |
| After reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7-0  | PJ7C-PJ0C  | R/W  | Output     |
|      |            |      | 0: Disable |
|      |            |      | 1: Enable  |

|             | 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  | 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  | PJ7F2 | -  | -  | -  | -  | -  | -  | -  |
| After reset | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### 12.2.10.4 PJFR2 (Port J function register 2)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PJ7F2      | R/W  | 0: PORT    |
|      |            |      | 1: INT9    |
| 6-0  | -          | R    | Read as 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  | -     | -     | -     | -     | -     | -     | -     | -     |
| 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     | 0     |
|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| bit symbol  | PJ7F3 | PJ6F3 | PJ5F3 | PJ4F3 | PJ3F3 | PJ2F3 | PJ1F3 | PJ0F3 |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.10.5 PJFR3 (Port J function register 3)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-8 | -          | R    | Read as 0. |
| 7    | PJ7F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB0IN1  |
| 6    | PJ6F3      | R/W  | 0: PORT    |
|      |            |      | 1: TB0IN0  |
| 5    | PJ5F3      | R/W  | 0: PORT    |
|      |            |      | 1: PHC2IN1 |
| 4    | PJ4F3      | R/W  | 0: PORT    |
|      |            |      | 1: PHC2IN0 |
| 3    | PJ3F3      | R/W  | 0: PORT    |
|      |            |      | 1: PHC1IN1 |
| 2    | PJ2F3      | R/W  | 0: PORT    |
|      |            |      | 1: PHC1IN0 |
| 1    | PJ1F3      | R/W  | 0: PORT    |
|      |            |      | 1: PHC0IN1 |
| 0    | PJ0F3      | R/W  | 0: PORT    |
|      |            |      | 1: PHC0IN0 |

|             | 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     | 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  | PJ7UP | PJ6UP | PJ5UP | PJ4UP | PJ3UP | PJ2UP | PJ1UP | PJOUP |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

# 12.2.10.6 PJPUP (Port J pull-up control register)

| Bit  | Bit Symbol  | Туре | Function                           |
|------|-------------|------|------------------------------------|
| 31-8 | -           | R    | Read as 0.                         |
| 7-0  | PJ7UP-PJ0UP | R/W  | Pull-up<br>0: Disable<br>1: Enable |

|             | 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     | 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  | PJ7IE | PJ6IE | PJ5IE | PJ4IE | PJ3IE | PJ2IE | PJ1IE | PJ0IE |
| After reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.10.7 PJIE (Port J input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-8 | -           | R    | Read as 0.                       |
| 7-0  | PJ7IE-PJ0IE | R/W  | Input<br>0: Disable<br>1: Enable |

### 12.2.11 Port K (PK0 to PK6)

The port K 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 K performs the A/D converter, the external interrupt input and the 16-bit timer (TMRB).

The port K has two types of function register. If you use the port K as a general-purpose port, set "0" to the corresponding bit of the two registers. If you use the port K 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.

Reset initializes all bits of the port J as general-purpose ports with input, output and pull-up disabled.

To use the Port K as an analog input of the AD converter, disable input on PKIE and disable pull-up on PJPUP.

Note:Unless you use all the bits of port J and port K as analog input pins, conversion accuracy may be reduced. Be sure to verify that this causes no problem on your system.

Note: In modes other than STOP mode, interrupt input is enabled regardless of the PKFR register setting if input is enabled in PKIE. Make sure to disable unused interrupts when programming the device.

#### 12.2.11.1 Port K Register

|                                 |        | Base Address = 0x400C_0A00 |
|---------------------------------|--------|----------------------------|
| Register name                   |        | Address (Base+)            |
| Port K data register            | PKDATA | 0x0000                     |
| Port K output control register  | PKCR   | 0x0004                     |
| Reserved                        | -      | 0x0008                     |
| Port K function register 2      | PKFR2  | 0x000C                     |
| Port K function register 3      | PKFR3  | 0x0010                     |
| Reserved                        | -      | 0x0014                     |
| Reserved                        | -      | 0x0018                     |
| Reserved                        | -      | 0x001C                     |
| Reserved                        | -      | 0x0020                     |
| Reserved                        | -      | 0x0024                     |
| Reserved                        | -      | 0x0028                     |
| Port K pull-up control register | PKPUP  | 0x002C                     |
| Reserved                        | -      | 0x0030                     |
| Reserved                        | -      | 0x0034                     |
| Port K input control register   | PKIE   | 0x0038                     |

Note: Access to the "reserved" areas is prohibited.

|             | 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   | 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  | -  | PK6 | PK5 | PK4 | PK3 | PK2 | PK1 | PK0 |
| After reset | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### 12.2.11.2 PKDATA (Port K data register)

| Bit  | Bit Symbol | Туре | Function              |
|------|------------|------|-----------------------|
| 31-8 | -          | R    | Read as 0.            |
| 7    | -          | R/W  | Reserved              |
| 6-0  | PK6-PK0    | R/W  | Port K data register. |

#### 12.2.11.3 PKCR (Port K 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   | 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    | 0    |
|             | 7  | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| bit symbol  | -  | PK6C | PK5C | PK4C | PK3C | PK2C | PK1C | PK0C |
| After reset | 0  | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit  | Bit Symbol | Туре | Function                          |
|------|------------|------|-----------------------------------|
| 31-8 | -          | R    | Read as 0.                        |
| 7    | -          | R/W  | Reserved                          |
| 6-0  | PK6C-PK0C  | R/W  | Output<br>0: Disable<br>1: Enable |

|             | 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     | 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  | -  | -  | -  | -  | PK3F2 | -  | PK1F2 | -  |
| After reset | 0  | 0  | 0  | 0  | 0     | 0  | 0     | 0  |

# 12.2.11.4 PKFR2 (Port K function register 2)

| Bit  | Bit Symbol | Туре | Function   |
|------|------------|------|------------|
| 31-4 | -          | R    | Read as 0. |
| 3    | PK3F2      | R/W  | 0: PORT    |
|      |            |      | 1: INTB    |
| 2    | -          | R    | Read as 0. |
| 1    | PK1F2      | R/W  | 0: PORT    |
|      |            |      | 1: INTA    |
| 0    | -          | R    | Read as 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  | -  | -  | -  | -  | -     | -     | -     | -     |
| 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     | 0     |
|             | 7  | 6  | 5  | 4  | 3     | 2     | 1     | 0     |
| bit symbol  | -  | -  | -  | -  | PK3F3 | PK2F3 | PK1F3 | PK0F3 |
| After reset | 0  | 0  | 0  | 0  | 0     | 0     | 0     | 0     |

### 12.2.11.5 PKFR3 (Port K function register 3)

| Bit  | Bit Symbol | Туре | Function             |
|------|------------|------|----------------------|
| 31-4 | -          | R    | Read as 0.           |
| 3    | PK3F3      | R/W  | 0: PORT<br>1: TB6IN1 |
| 2    | PK2F3      | R/W  | 0: PORT<br>1: TB6IN0 |
| 1    | PK1F3      | R/W  | 0: PORT<br>1: TB1IN1 |
| 0    | PK0F3      | R/W  | 0: PORT<br>1: TB1IN0 |

|             | 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     | 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  | -  | PK6UP | PK5UP | PK4UP | PK3UP | PK2UP | PK1UP | PK0UP |
| After reset | 0  | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.11.6 PKPUP (Port K pull-up control register)

| Bit  | Bit Symbol  | Туре | Function                           |
|------|-------------|------|------------------------------------|
| 31-8 | -           | R    | Read as 0.                         |
| 7    | -           | R/W  | Reserved                           |
| 6-0  | PK6UP-PK0UP | R/W  | Pull-up<br>0: Disable<br>1: Enable |

|             | 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     | 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  | -  | PK6IE | PK5IE | PK4IE | PK3IE | PK2IE | PK1IE | PK0IE |
| After reset | 0  | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

### 12.2.11.7 PKIE (Port K input control register)

| Bit  | Bit Symbol  | Туре | Function                         |
|------|-------------|------|----------------------------------|
| 31-8 | -           | R    | Read as 0.                       |
| 7    | -           | R/W  | Reserved                         |
| 6-0  | PK7IE-PK0IE | R/W  | Input<br>0: Disable<br>1: Enable |

# 12.3 Block Diagrams of Ports

# 12.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".

| Туре | GP Port | Function    | Analog | Pull-up | Pull-down | Programmable<br>open-drain | Note                                                  |  |
|------|---------|-------------|--------|---------|-----------|----------------------------|-------------------------------------------------------|--|
| FT1  | I/O     | I/O         | -      | R       | -         | 0                          |                                                       |  |
| FT2  | I/O     | I/O         | -      | NoR     | NoR       | о                          | Function output triggered by<br>enable signal         |  |
| FT3  | I/O     | I/O         | -      | R       | -         | o                          | Function output triggered by<br>enable signal         |  |
| FT4  | I/O     | Input (int) | -      | R       | -         | 0                          | with Noise filter                                     |  |
| FT5  | I/O     | Input       | 0      | R       | -         | -                          |                                                       |  |
| FT6  | Output  | Output      | -      | NoR     | -         | о                          | BOOT input enabled during reset                       |  |
| FT7  | I/O     | I/O         | -      | R       | -         | -                          | Function input/output trig-<br>gered by enable signal |  |
| FT8  | I/O     | Input       | -      | R       | -         | 0                          |                                                       |  |

int: Interrupt input

-: Not exist

o: Exist

R: Forced disable during reset.

NoR: Unaffected by reset.

12.3.2 Type FT1



Figure 12-1 Port Type FT1

12.3.3 Type FT2



Figure 12-2 Port type FT2

12.3.4 Type FT3



Figure 12-3 Port Type FT3

12.3.5 Type FT4



Figure 12-4 Port Type FT4

12.3.6 Type FT5



Figure 12-5 Port Type FT5

12.3.7 Type FT6



Figure 12-6 Port Type FT6

12.3.8 Type FT7



Figure 12-7 Port Type FT7

12.3.9 Type FT8



Figure 12-8 Port Type FT8

### 12.4 Appendix (Port setting List)

The following table shows the register setting for each function.

Initialization of the ports where the  $[\cdot]$  does not exist in the "After reset" field is set to "0" for all register settings. Setting for the bit "x" can be arbitrarily-specified.

### 12.4.1 Port A Setting

| Pin | Port<br>Type | Function              | After<br>reset | PACR | PAFR1 | PAOD | PAPUP | PAIE |
|-----|--------------|-----------------------|----------------|------|-------|------|-------|------|
|     |              | Input Port            |                | 0    | 0     | x    | x     | 1    |
| PA0 | FT1          | Output Port           |                | 1    | 0     | x    | x     | 0    |
|     | FT7          | D0/AD0 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |
|     | <b>FT4</b>   | Input Port            |                | 0    | 0     | x    | x     | 1    |
| PA1 | FT1          | Output Port           |                | 1    | 0     | x    | x     | 0    |
|     | FT7          | D1/AD1 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |
|     | 574          | Input Port            |                | 0    | 0     | x    | x     | 1    |
| PA2 | FT1          | Output Port           |                | 1    | 0     | x    | x     | 0    |
|     | FT7          | D2/AD2 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |
|     | <b>FT4</b>   | Input Port            |                | 0    | 0     | x    | x     | 1    |
| PA3 | FT1          | Output Port           |                | 1    | 0     | x    | x     | 0    |
|     | FT7          | D3/AD3 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |
|     | FT1          | Input Port            |                | 0    | 0     | x    | x     | 1    |
| PA4 | FIT          | Output Port           |                | 1    | 0     | x    | x     | 0    |
|     | FT7          | D4/AD4 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |
|     | <b>FT4</b>   | Input Port            |                | 0    | 0     | х    | x     | 1    |
| PA5 | FT1          | Output Port           |                | 1    | 0     | х    | x     | 0    |
|     | FT7          | D5/AD5 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |
|     | FT1          | Input Port            |                | 0    | 0     | х    | x     | 1    |
| PA6 | FIT          | Output Port           |                | 1    | 0     | х    | x     | 0    |
|     | FT7          | D6/AD6 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |
|     | FT1          | Input Port            |                | 0    | 0     | х    | x     | 1    |
| PA7 |              | Output Port           |                | 1    | 0     | х    | x     | 0    |
|     | FT7          | D7/AD7 (Input/Output) |                | 1    | 1     | 0    | x     | 1    |

# 12.4.2 Port B Setting

| Pin | Port<br>Type | Function                | After re-<br>set | PBCR | PBFR1 | FBFR2 | PBOD | PBPUP | PBIE |
|-----|--------------|-------------------------|------------------|------|-------|-------|------|-------|------|
|     | <b>FT</b> 4  | Input Port              |                  | 0    | 0     | 0     | х    | x     | 1    |
| PB0 | FT1          | Output Port             |                  | 1    | 0     | 0     | х    | x     | 0    |
| FDU | FT7          | D8/AD8 (Input/Output)   |                  | 1    | 1     | 0     | 0    | x     | 1    |
|     | FT1          | A0 (Output)             |                  | 1    | 0     | 1     | 0    | x     | 0    |
|     | FT1          | Input Port              |                  | 0    | 0     | 0     | х    | x     | 1    |
| PB1 | FII          | Output Port             |                  | 1    | 0     | 0     | х    | x     | 0    |
| РВТ | FT7          | D9/AD9 (Input/Output)   |                  | 1    | 1     | 0     | 0    | x     | 1    |
|     | FT1          | A1 (Output)             |                  | 1    | 0     | 1     | 0    | x     | 0    |
|     | <b>FT4</b>   | Input Port              |                  | 0    | 0     | 0     | х    | x     | 1    |
| DDO | FT1          | Output Port             |                  | 1    | 0     | 0     | х    | x     | 0    |
| PB2 | FT7          | D10/AD10 (Input/Output) |                  | 1    | 1     | 0     | 0    | x     | 1    |
|     | FT1          | A2 (Output)             |                  | 1    | 0     | 1     | 0    | x     | 0    |
|     | <b>FT4</b>   | Input Port              |                  | 0    | 0     | 0     | х    | x     | 1    |
| PB3 | FT1          | Output Port             |                  | 1    | 0     | 0     | х    | x     | 0    |
|     | FT7          | D11/AD11 (Input/Output) |                  | 1    | 1     | 0     | 0    | x     | 1    |
|     | FT1          | A3 (Output)             |                  | 1    | 0     | 1     | 0    | x     | 0    |
|     | <b>FT</b> 4  | Input Port              |                  | 0    | 0     | 0     | х    | x     | 1    |
| PB4 | FT1          | Output Port             |                  | 1    | 0     | 0     | х    | x     | 0    |
| PB4 | FT7          | D12/AD12 (Input/Output) |                  | 1    | 1     | 0     | 0    | x     | 1    |
|     | FT1          | A4 (Output)             |                  | 1    | 0     | 1     | 0    | x     | 0    |
|     | <b>FT4</b>   | Input Port              |                  | 0    | 0     | 0     | x    | x     | 1    |
| PB5 | FT1          | Output Port             |                  | 1    | 0     | 0     | х    | x     | 0    |
| PB5 | FT7          | D13/AD13 (Input/Output) |                  | 1    | 1     | 0     | 0    | x     | 1    |
|     | FT1          | A5 (Output)             |                  | 1    | 0     | 1     | 0    | x     | 0    |
|     | FT1          | Input Port              |                  | 0    | 0     | 0     | х    | х     | 1    |
| PB6 |              | Output Port             |                  | 1    | 0     | 0     | х    | х     | 0    |
| PDO | FT7          | D14/AD14 (Input/Output) |                  | 1    | 1     | 0     | 0    | х     | 1    |
|     | FT1          | A6 (Output)             |                  | 1    | 0     | 1     | 0    | х     | 0    |
|     | FT1          | Input Port              |                  | 0    | 0     | 0     | х    | х     | 1    |
| 700 |              | Output Port             |                  | 1    | 0     | 0     | х    | х     | 0    |
| PB7 | FT7          | D15/AD15 (Input/Output) |                  | 1    | 1     | 0     | 0    | х     | 1    |
|     | FT1          | A7 (Output)             |                  | 1    | 0     | 1     | 0    | х     | 0    |

### 12.4.3 Port C Setting

Table 12-8 Port Setting List (Port C)

| Pin | Port<br>Type | Function        | After<br>reset | PCCR | PCFR1 | PCFR2 | PCFR3 | PCFR4 | PCOD | PCPUP | PCIE |
|-----|--------------|-----------------|----------------|------|-------|-------|-------|-------|------|-------|------|
|     | <b>FT4</b>   | Input Port      |                | 0    | 0     | 0     | 0     | 0     | х    | x     | 1    |
|     | FT1          | Output Port     |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PC0 |              | A0 (Output)     |                | 1    | 1     | 0     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | TXD1 (Output)   |                | 1    | 0     | 1     | 0     | 0     | х    | x     | 0    |
|     |              | TB2IN0 (Input)  |                | 0    | 0     | 0     | 1     | 0     | 0    | x     | 1    |
|     | <b>FT</b> 4  | Input Port      |                | 0    | 0     | 0     | 0     | 0     | х    | x     | 1    |
|     | FT1          | Output Port     |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PC1 |              | A1 (Output)     |                | 1    | 1     | 0     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | RXD1 (Input)    |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     |              | TB2IN1 (Input)  |                | 0    | 0     | 0     | 1     | 0     | 0    | x     | 1    |
|     |              | Input Port      |                | 0    | 0     | 0     | 0     | 0     | х    | x     | 1    |
|     | FT1          | Output Port     |                | 1    | 0     | 0     | 0     | 0     | х    | x     | 0    |
|     |              | A2 (Output)     |                | 1    | 1     | 0     | 0     | 0     | 0    | x     | 0    |
| PC2 |              | SCLK1 (Input)   |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | SCLK1 (Output)  |                | 1    | 0     | 1     | 0     | 0     | х    | x     | 0    |
|     |              | TB0OUT (Output) |                | 1    | 0     | 0     | 1     | 0     | х    | x     | 0    |
|     |              | CTS1 (Input)    |                | 0    | 0     | 0     | 0     | 1     | 0    | x     | 1    |
|     |              | Input Port      |                | 0    | 0     | 0     | 0     | 0     | х    | x     | 1    |
|     | FT1          | Output Port     |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PC3 | FT1          | A3 (Output)     |                | 1    | 1     | 0     | 0     | 0     | 0    | x     | 0    |
|     | FT4          | INT2 (Input)    |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | TB1OUT (Output) |                | 1    | 0     | 0     | 1     | 0     | x    | x     | 0    |
|     |              | Input Port      |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port     |                | 1    | 0     | 0     | 0     | 0     | х    | x     | 0    |
| PC4 |              | A4 (Output)     |                | 1    | 1     | 0     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | TXD2 (Output)   |                | 1    | 0     | 1     | 0     | 0     | х    | x     | 0    |
|     |              | TB3IN0 (Input)  |                | 0    | 0     | 0     | 1     | 0     | 0    | x     | 1    |
|     |              | Input Port      |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port     |                | 1    | 0     | 0     | 0     | 0     | х    | x     | 0    |
| PC5 |              | A5 (Output)     |                | 1    | 1     | 0     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | RXD2 (Input)    |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     |              | TB3IN1 (Input)  |                | 0    | 0     | 0     | 1     | 0     | 0    | х     | 1    |
|     |              | Input Port      |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port     |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
|     |              | A6 (Output)     |                | 1    | 1     | 0     | 0     | 0     | 0    | х     | 0    |
| PC6 |              | SCLK2 (Input)   |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | SCLK2 (Output)  |                | 1    | 0     | 1     | 0     | 0     | x    | x     | 0    |
|     |              | TB4IN0 (Input)  |                | 0    | 0     | 0     | 1     | 0     | 0    | x     | 1    |
|     |              | CTS2 (Input)    |                | 0    | 0     | 0     | 0     | 1     | 0    | x     | 1    |

Table 12-8 Port Setting List (Port C)

| Pin | Port<br>Type | Function       | After<br>reset | PCCR | PCFR1 | PCFR2 | PCFR3 | PCFR4 | PCOD | PCPUP | PCIE |
|-----|--------------|----------------|----------------|------|-------|-------|-------|-------|------|-------|------|
|     | <b>FT4</b>   | Input Port     |                | 0    | 0     | 0     | 0     | 0     | х    | х     | 1    |
|     | FT1          | Output Port    |                | 1    | 0     | 0     | 0     | 0     | х    | x     | 0    |
| PC7 | FT1          | A7 (Output)    |                | 1    | 1     | 0     | 0     | 0     | 0    | х     | 0    |
|     | FT4          | INT3 (Input)   |                | 0    | 0     | 1     | 0     | 0     | 0    | х     | 1    |
|     | FT1          | TB4IN1 (Input) |                | 0    | 0     | 0     | 1     | 0     | 0    | х     | 1    |

### 12.4.4 Port D Setting

Table 12-9 Port Setting List (Port D)

| Pin  | Port<br>Type | Function            | After re-<br>set | PDCR | PDFR1 | PDFR2 | PDFR3 | PDOD | PDPUP | PDIE |
|------|--------------|---------------------|------------------|------|-------|-------|-------|------|-------|------|
|      | <b>FT4</b>   | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| DD0  |              | A8 (Output)         |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
| PD0  | <b>FT4</b>   | SO1 (Output)        |                  | 1    | 0     | 1     | 0     | x    | x     | 0    |
|      | FT1          | SDA1 (Input/Output) |                  | 1    | 0     | 1     | 0     | 1    | x     | 1    |
|      |              | TB7OUT (Output)     |                  | 1    | 0     | 0     | 1     | x    | x     | 0    |
|      | <b>FT4</b>   | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| 554  |              | A9 (Output)         |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
| PD1  |              | SI1 (Input)         |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | FT1          | SCL1 (Input/Output) |                  | 1    | 0     | 1     | 0     | 1    | x     | 1    |
|      |              | TB8OUT (Output)     |                  | 1    | 0     | 0     | 1     | x    | x     | 0    |
|      |              | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| 550  |              | A10 (Output)        |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
| PD2  |              | SCK1 (Input)        |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | FT1          | SCK1 (Output)       |                  | 1    | 0     | 1     | 0     | x    | x     | 0    |
|      |              | TB9OUT (Output)     |                  | 1    | 0     | 0     | 1     | x    | x     | 0    |
|      |              | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PD3  | FT1          | A11 (Output)        |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
|      | FT4          | INT4 (Input)        |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | FT1          | ADTRG (Input)       |                  | 0    | 0     | 0     | 1     | 0    | x     | 1    |
|      |              | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
| 55.4 | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PD4  | FT1          | A12 (Output)        |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
|      | FT3          | SPDO (Output)       |                  | 1    | 0     | 1     | 0     | x    | x     | 0    |
|      |              | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PD5  | FT1          | A13 (Output)        |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
|      | FT3          | SPDI (Input)        |                  | 0    | 0     | 1     | 0     | x    | x     | 1    |
|      |              | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PD6  | FT1          | A14 (Output)        |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
|      |              | SPCLK (Input)       |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | FT3          | SPCLK (Output)      |                  | 1    | 0     | 1     | 0     | x    | x     | 0    |
|      |              | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| 555  | FT1          | A15 (Output)        |                  | 1    | 1     | 0     | 0     | 0    | x     | 0    |
| PD7  | FTA          | SPSS (Input)        |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | FT3          | SPSS (Output)       |                  | 1    | 0     | 1     | 0     | x    | x     | 0    |
|      | FT1          | SCOUT (Output)      |                  | 1    | 0     | 0     | 1     | х    | x     | 0    |

# 12.4.5 Port E Setting

Table 12-10 Port Setting List (Port E)

| Pin | Port<br>Type | Function         | After<br>reset | PECR | PEFR1 | PEFR2 | PEFR3 | PEFR4 | PEOD | PEPUP | PEIE |
|-----|--------------|------------------|----------------|------|-------|-------|-------|-------|------|-------|------|
|     |              | Input Port       |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
| 550 | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PE0 | <b>FT4</b>   | TXD0 (Output)    |                | 1    | 1     | 0     | 0     | 0     | x    | x     | 0    |
|     | FT1          | A16 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | x     | 0    |
|     |              | Input Port       |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PE1 |              | RXD0 (Input)     |                | 0    | 1     | 0     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | A17 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | x     | 0    |
|     |              | Input Port       |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
|     |              | SCLK0 (Input)    |                | 0    | 1     | 0     | 0     | 0     | 0    | x     | 1    |
| PE2 |              | SCLK0 (Output)   |                | 1    | 1     | 0     | 0     | 0     | x    | x     | 0    |
|     | FT1          | A18 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | x     | 0    |
|     |              | TB2OUT (Output)  |                | 1    | 0     | 0     | 1     | 0     | x    | x     | 0    |
|     |              | CTS0 (Input)     |                | 0    | 0     | 0     | 0     | 1     | x    | x     | 1    |
|     |              | Input Port       |                | 0    | 0     | 0     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PE3 | FT4          | INT5 (Input)     |                | 0    | 1     | 0     | 0     | 0     | 0    | x     | 1    |
|     |              | A19 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | TB3OUT (Output)  |                | 1    | 0     | 0     | 1     | 0     | x    | x     | 0    |
|     |              | Input Port       |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PE4 |              | A20 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | TD0OUT0 (Output) |                | 1    | 0     | 0     | 1     | 0     | x    | x     | 0    |
|     | <b>FT4</b>   | Input Port       |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
| DEC | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PE5 | <b>FT4</b>   | A21 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | TD0OUT1 (Output) |                | 1    | 0     | 0     | 1     | 0     | х    | x     | 0    |
|     | <b>FT4</b>   | Input Port       |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
| 550 | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PE6 |              | A22 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | х     | 0    |
|     | FT1          | TD1OUT0 (Output) |                | 1    | 0     | 0     | 1     | 0     | x    | x     | 0    |
|     |              | Input Port       |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port      |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PE7 |              | A23 (Output)     |                | 1    | 0     | 1     | 0     | 0     | 0    | x     | 0    |
|     | FT1          | TD1OUT1 (Output) |                | 1    | 0     | 0     | 1     | 0     | x    | x     | 0    |

# 12.4.6 Port F Setting

| Pin | Port<br>Type | Function        | After re-<br>set | PFCR | PFFR1 | PFFR2 | PFFR3 | PFOD | PFPUP | PFIE |
|-----|--------------|-----------------|------------------|------|-------|-------|-------|------|-------|------|
| 550 | FT6          | Output Port     |                  | 1    | 0     | 0     | 0     | х    | 1     | 0    |
| PF0 | FT1          | TB6OUT (output) |                  | 1    | 0     | 0     | 1     | x    | 1     | 0    |
|     | FT1          | Input Port      |                  | 0    | 0     | 0     | 0     | х    | x     | 1    |
| PF1 |              | Output Port     |                  | 1    | 0     | 0     | 0     | х    | x     | 0    |
|     | FT1          | RD (output)     |                  | 1    | 1     | 0     | 0     | х    | x     | 0    |
|     | FT1          | Input Port      |                  | 0    | 0     | 0     | 0     | х    | x     | 1    |
| PF2 |              | Output Port     |                  | 1    | 0     | 0     | 0     | х    | x     | 0    |
|     | FT1          | WR (output)     |                  | 1    | 1     | 0     | 0     | x    | x     | 0    |
|     | <b>FT4</b>   | Input Port      |                  | 0    | 0     | 0     | 0     | х    | x     | 1    |
| PF3 | FT1          | Output Port     |                  | 1    | 0     | 0     | 0     | х    | x     | 0    |
|     | FT1          | BELL (output)   |                  | 1    | 1     | 0     | 0     | х    | x     | 0    |
|     | FT1          | Input Port      |                  | 0    | 0     | 0     | 0     | х    | x     | 1    |
|     | FII          | Output Port     |                  | 1    | 0     | 0     | 0     | х    | x     | 0    |
| PF4 | FT1          | BELH (output)   |                  | 1    | 1     | 0     | 0     | х    | x     | 0    |
|     | FT4          | INT6 (Input)    |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|     | FT1          | TB5IN0 (Input)  |                  | 0    | 0     | 0     | 1     | 0    | x     | 1    |
|     | <b>FT4</b>   | Input Port      |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|     | FT1          | Output Port     |                  | 1    | 0     | 0     | 0     | х    | x     | 0    |
| PF5 | FT1          | CS1 (output)    |                  | 1    | 1     | 0     | 0     | х    | x     | 0    |
|     | FT4          | INT7 (Input)    |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|     | FT1          | TB5IN1 (Input)  |                  | 0    | 0     | 0     | 1     | 0    | x     | 1    |
|     | FT1          | Input Port      |                  | 0    | 0     | 0     | 0     | х    | х     | 1    |
| PF6 |              | Output Port     |                  | 1    | 0     | 0     | 0     | х    | х     | 0    |
|     | FT1          | CS0 (output)    |                  | 1    | 1     | 0     | 0     | х    | х     | 0    |
|     | FT1          | Input Port      |                  | 0    | 0     | 0     | 0     | х    | х     | 1    |
| PF7 |              | Output Port     |                  | 1    | 0     | 0     | 0     | х    | x     | 0    |
|     | FT1          | ALE (output)    |                  | 1    | 1     | 0     | 0     | х    | х     | 0    |

Note: The PF0 input and pull-up are enabled and act as BOOT input pin while a RESET is in "Low" state.

### 12.4.7 Port G Setting

Table 12-12 Port Setting List (Port G)

| Pin  | Port<br>Type | Function            | After re-<br>set | PGCR | PGFR2 | PGFR3 | PGFR4 | PGOD | PGPUP | PGIE |
|------|--------------|---------------------|------------------|------|-------|-------|-------|------|-------|------|
|      | <b>FT4</b>   | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PG0  |              | SO0 (Output)        |                  | 1    | 1     | 0     | 0     | x    | x     | 0    |
|      | FT1          | SDA0 (Input/Output) |                  | 1    | 1     | 0     | 0     | 1    | x     | 1    |
|      |              | TB7IN0 (Input)      |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | FT1          | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      |              | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PG1  |              | SI0 (Input)         |                  | 0    | 1     | 0     | 0     | 0    | x     | 1    |
|      | FT1          | SCL0 (Input/Output) |                  | 1    | 1     | 0     | 0     | 1    | x     | 1    |
|      |              | TB7IN1 (Input)      |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | ET4          | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PG2  |              | SCK0 (Input)        |                  | 0    | 1     | 0     | 0     | 0    | x     | 1    |
|      | FT1          | SCK0 (Output)       |                  | 1    | 1     | 0     | 0     | x    | x     | 0    |
|      | FT4          | INT8 (Input)        |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | 574          | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
| PG3  | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
|      | FT4          | INT0 (Input)        |                  | 0    | 1     | 0     | 0     | 0    | x     | 1    |
|      | 574          | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
| DO 4 | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PG4  | ET4          | TXD3 (Output)       |                  | 1    | 1     | 0     | 0     | x    | x     | 0    |
|      | FT1          | TB8IN0 (Input)      |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | <b>FT4</b>   | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
| PG5  | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PG5  | FT1          | RXD3 (Input)        |                  | 0    | 1     | 0     | 0     | 0    | x     | 1    |
|      |              | TB8IN0 (Input)      |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      | <b>FT4</b>   | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
|      | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| DOG  |              | SCLK3 (Input)       |                  | 0    | 1     | 0     | 0     | 0    | x     | 1    |
| PG6  |              | SCLK3 (Output)      |                  | 1    | 1     | 0     | 0     | x    | x     | 0    |
|      | FT1          | TB9IN0 (Input)      |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |
|      |              | CTS3 (Input)        |                  | 0    | 0     | 0     | 1     | x    | x     | 1    |
|      |              | Input Port          |                  | 0    | 0     | 0     | 0     | x    | x     | 1    |
| D07  | FT1          | Output Port         |                  | 1    | 0     | 0     | 0     | x    | x     | 0    |
| PG7  | FT4          | INT1 (Input)        |                  | 0    | 1     | 0     | 0     | 0    | x     | 1    |
|      | FT1          | TB9IN1 (Input)      |                  | 0    | 0     | 1     | 0     | 0    | x     | 1    |

Note: Port G is 5 voltage tolerant input pin. However, the programmable pull-up voltage is up to DVDD3A voltage level. So the pull-up of 5 voltage torelant input pin should be designed by outer pull-up registance.

### 12.4.8 Port H Setting

Table 12-13 Port Setting List (Port H)

| Pin | Port<br>Type | Function            | After<br>reset | PHCR | PHFR1 | PHFR2 | PHFR3 | PHFR4 | PHOD | PHPUP | PHIE |
|-----|--------------|---------------------|----------------|------|-------|-------|-------|-------|------|-------|------|
|     | ET4          | Input Port          |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
| PH0 | FT1          | Output Port         |                | 1    | 0     | 0     | 0     | 0     | х    | x     | 0    |
|     | FT1          | TXD4 (Output)       |                | 1    | 0     | 1     | 0     | 0     | x    | x     | 0    |
|     | FT1          | Input Port          |                | 0    | 0     | 0     | 0     | 0     | х    | x     | 1    |
| PH1 | FII          | Output Port         |                | 1    | 0     | 0     | 0     | 0     | х    | x     | 0    |
|     | FT1          | RXD4 (Input)        |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | Input Port          |                | 0    | 0     | 0     | 0     | 0     | х    | x     | 1    |
|     | FII          | Output Port         |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PH2 |              | SCLK4 (Input)       |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | SCLK4 (Output)      |                | 1    | 0     | 1     | 0     | 0     | х    | x     | 0    |
|     |              | CTS4 (Input)        |                | 0    | 0     | 0     | 0     | 1     | 0    | x     | 1    |
|     | FT1          | Input Port          |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
| PH3 | FII          | Output Port         |                | 1    | 0     | 0     | 0     | 0     | х    | x     | 0    |
| РПЭ | FT8          | PHC3IN0 (Input)     |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | TB4OUT (Output)     |                | 1    | 0     | 0     | 1     | 0     | х    | x     | 0    |
|     | FT1          | Input Port          |                | 0    | 0     | 0     | 0     | 0     | х    | x     | 1    |
| PH4 | FII          | Output Port         |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
| PH4 | FT8          | PHC3IN1 (Input)     |                | 0    | 0     | 1     | 0     | 0     | 0    | x     | 1    |
|     | FT1          | TB5OUT (Output)     |                | 1    | 0     | 0     | 1     | 0     | х    | x     | 0    |
|     | FT1          | Input Port          |                | 0    | 0     | 0     | 0     | 0     | x    | x     | 1    |
| PH5 | FIT          | Output Port         |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
|     | FT1          | TRACEDATA3 (Output) |                | 1    | 1     | 0     | 0     | 0     | 0    | 0     | 0    |
|     | <b>FT1</b>   | Input Port          |                | 0    | 0     | 0     | 0     | 0     | х    | х     | 1    |
| PH6 | FT1          | Output Port         |                | 1    | 0     | 0     | 0     | 0     | x    | x     | 0    |
|     | FT1          | TRACEDATA2 (Output) |                | 1    | 1     | 0     | 0     | 0     | 0    | 0     | 0    |

Note: The bit<2:1> of Port G are 5 voltage tolerant input pins. However, the programmable pull-up voltage is up to DVDD3A voltage level. So the pull-up of 5 voltage torelant input pin should be designed by outer pull-up registance.

# 12.4.9 Port I Setting

| Pin  | Port<br>Type | Function                             | After re-<br>set | PICR | PIFR1 | PIOD | PIPUP | PIPDN                                                                                                                                                                       | PIIE |
|------|--------------|--------------------------------------|------------------|------|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|      | 574          | Input Port                           |                  | 0    | 0     | x    | х     | x                                                                                                                                                                           | 1    |
| PI0  | FT1          | Output Port                          |                  | 1    | 0     | x    | x     | x                                                                                                                                                                           | 0    |
|      | FT1          | TRACEDATA1 (Output)                  |                  | 1    | 1     | 0    | 0     | 0                                                                                                                                                                           | 0    |
|      | FT1          | Input Port                           |                  | 0    | 0     | х    | х     | x                                                                                                                                                                           | 1    |
| PI1  |              | Output Port                          |                  | 1    | 0     | x    | x     | x                                                                                                                                                                           | 0    |
|      | FT1          | TRACEDATA0 (Output)                  |                  | 1    | 1     | 0    | 0     | 0                                                                                                                                                                           | 0    |
|      | <b>FT</b> 4  | Input Port                           |                  | 0    | 0     | x    | х     | х                                                                                                                                                                           | 1    |
| PI2  | FT1          | Output Port                          |                  | 1    | 0     | x    | х     | x                                                                                                                                                                           | 0    |
|      | FT1          | TRACECLK (Output)                    |                  | 1    | 1     | 0    | 0     | 0                                                                                                                                                                           | 0    |
|      | FT1          | Input Port                           |                  | 0    | 0     | x    | 1     | x<br>x<br>0<br>x<br>x<br>0<br>x<br>x<br>0<br>x<br>x<br>0<br>x<br>x<br>0<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>1<br>1<br>1<br>1                                              | 1    |
| PI3  | FIT          | Output Port                          |                  | 1    | 0     | x    | 1     | x                                                                                                                                                                           | 0    |
|      | FT2          | TRST (Input)                         | 2                | 0    | 1     | 0    | 1     | 0                                                                                                                                                                           | 1    |
|      | FT1          | Input Port                           |                  | 0    | 0     | x    | 1 x   | x                                                                                                                                                                           | 1    |
| PI4  | ГП           | Output Port                          |                  | 1    | 0     | x    | 1     | x                                                                                                                                                                           | 0    |
|      | FT2          | TDI (Input)                          | 2                | 0    | 1     | 0    | 1     | 0                                                                                                                                                                           | 1    |
|      | FT1          | Input Port                           |                  | 0    | 0     | х    | х     | 0<br>x<br>x<br>0<br>x<br>x<br>0<br>x<br>x<br>0<br>1<br>1<br>1<br>x<br>x<br>0<br>0<br>1<br>1<br>1<br>x<br>x<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 1    |
| PI5  | FIT          | Output Port                          |                  | 1    | 0     | x    | х     | 1                                                                                                                                                                           | 0    |
| 110  | FT2          | TCK (Input)/<br>SWCLK (Input)        | 2                | 0    | 1     | 0    | 0     | 1                                                                                                                                                                           | 1    |
|      | FT1          | Input Port                           |                  | 0    | 0     | x    | 1     | x                                                                                                                                                                           | 1    |
| PI6  | FIT          | Output Port                          |                  | 1    | 0     | x    | 1     | x                                                                                                                                                                           | 0    |
| . 10 | FT2          | TMS (Input)/<br>SWDIO (Input/Output) | 2                | 1    | 1     | 0    | 1     | 0                                                                                                                                                                           | 1    |
|      | <b>FT</b> 4  | Input Port                           |                  | 0    | 0     | x    | х     | x                                                                                                                                                                           | 1    |
| PI7  | FT1          | Output Port                          |                  | 1    | 0     | x    | х     | x                                                                                                                                                                           | 0    |
| Γ1/  | FT2          | TDO (Output)/<br>SWV (Output)        | 2                | 1    | 1     | 0    | 0     | 0                                                                                                                                                                           | 0    |

### 12.4.10 Port J Setting

| pin  | Port<br>Type | Function        | After re-<br>set | PJCR | PJFR2 | PJFR3 | PJPUP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | PJIE |
|------|--------------|-----------------|------------------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|      |              | Input Port      |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
| D IA | FT1          | Output Port     |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
| PJ0  | FT8          | PHC0IN0 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN00 (Input)   |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
|      |              | Input Port      |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
| D.M  | FT1          | Output Port     |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
| PJ1  | FT8          | PHC0IN1 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN01 (Input)   |                  | 0    | 0     | 0     | x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x                                                                                                                                                                                                                             | 0    |
|      |              | Input Port      |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
| 5.10 | FT1          | Output Port     |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
| PJ2  | FT8          | PHC1IN0 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN02 (Input)   |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
|      |              | Input Port      |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT1          | Output Port     |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
| PJ3  | FT8          | PHC1IN1 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN03 (Input)   |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
|      |              | Input Port      |                  | 0    | 0     | 0     | 0<br>×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1    |
|      | FT1          | Output Port     |                  | 1    | 0     | 0     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0    |
| PJ4  | FT8          | PHC2IN0 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN04 (Input)   |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
|      |              | Input Port      |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT1          | Output Port     |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
| PJ5  | FT8          | PHC2IN1 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN05 (Input)   |                  | 0    | 0     | 0     | x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x | 0    |
|      |              | Input Port      |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT1          | Output Port     |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
| PJ6  | FT1          | TB0IN0 (Input)  |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN06 (Input)   |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
|      |              | Input Port      |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT1          | Output Port     |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0    |
| PJ7  | FT4          | INT9 (Input)    |                  | 0    | 1     | 0     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT1          | TB0IN1 (Input)  |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1    |
|      | FT5          | AIN07 (Input)   |                  | 0    | 0     | 0     | x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x                                                                                 | 0    |

Table 12-15 Port Setting List (Port J)

# TOSHIBA

# 12.4.11 Port K Setting

| Table | 12-16 | Port | Setting | List | (Port | K) |
|-------|-------|------|---------|------|-------|----|
|-------|-------|------|---------|------|-------|----|

| Pin  | Port<br>Type | Function       | After re-<br>set | PKCR | PKFR2 | PKFR3 | PKPUP                                                                                                                                                                                                                                                                                                                                                           | PKIE |
|------|--------------|----------------|------------------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|      | <b>FT</b> 4  | Input Port     |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
| DICO | FT1          | Output Port    |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 0    |
| PK0  | FT1          | TB1IN0 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
|      | FT5          | AIN08 (Input)  |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      |              | Input Port     |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
|      | FT1          | Output Port    |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 0    |
| PK1  | FT4          | INTA (Input)   |                  | 0    | 1     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
|      | FT1          | TB1IN1 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
|      | FT5          | AIN09 (Input)  |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      | <b>FT</b> 4  | Input Port     |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
| DKO  | FT1          | Output Port    |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 0    |
| PK2  | FT1          | TB6IN0 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
|      | FT5          | AIN10 (Input)  |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      | FT1          | Input Port     |                  | 0    | 0     | 0     | 0<br>x<br>x                                                                                                                                                                                                                                                                                                                                                     | 1    |
|      | FIT          | Output Port    |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 0    |
| PK3  | FT4          | INTB (Input)   |                  | 0    | 1     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
|      | FT1          | TB6IN1 (Input) |                  | 0    | 0     | 1     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
|      | FT5          | AIN11 (Input)  |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      |              | Input Port     |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
| PK4  | FT1          | Output Port    |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      | FT5          | AIN12 (Input)  |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      | FT1          | Input Port     |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
| PK5  |              | Output Port    |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      | FT5          | AIN13 (Input)  |                  | 0    | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      | FT1          | Input Port     |                  | 0    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 1    |
| PK6  |              | Output Port    |                  | 1    | 0     | 0     | x                                                                                                                                                                                                                                                                                                                                                               | 0    |
|      | FT5          | AIN14 (Input)  |                  | 0    | 0     | 0     | x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>0<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x<br>x | 0    |

- 12. Input/Output Ports
- 12.4 Appendix (Port setting List)

# TOSHIBA

# 13. 16-bit Timer/Event Counters(TMRB)

### 13.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.

- Frequency measurement
- Pulse width measurement
- Time difference measurement

In the following explanation of this section, "x" indicates a channel number.

# 13.2 Differences in the Specifications

TMPM341FDXBG/FYXBG contains 10-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 13-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 7 through TMRB 9 can be used as the capture trigger of other channels.
  - TB7OUT  $\rightarrow$  available for TMRB0 through TMRB1
  - TB8OUT  $\rightarrow$  available for TMRB2 through TMRB3
  - TB9OUT  $\rightarrow$  available for TMRB4 through TMRB6
- 2. The start trigger of the timer synchronous mode (with TBxRUN)
  - TMRB0  $\rightarrow$  can start TMRB0 through TMRB3 synchronously
  - TMRB4  $\rightarrow$  can start TMRB4 through TMRB7 synchronously
- 3. The start trigger of the timer prescaler synchronous mode (with TBxPRUN)
  - TMRB0  $\rightarrow$  can start TMRB0 through TMRB3 synchronously
  - TMRB4  $\rightarrow$  can start TMRB4 through TMRB7 synchronously

| Specifica-<br>tion | Extern                            | al pins                                              |                    | tion between<br>ners              | Inter                  | rupt                | Internal connection                               |                                      |                                                                                      |                                                   |
|--------------------|-----------------------------------|------------------------------------------------------|--------------------|-----------------------------------|------------------------|---------------------|---------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------|
| Channel            | Timer flip-<br>flop output<br>pin | External<br>clock/cap-<br>ture trigger<br>input pins | Capture<br>trigger | Synchro-<br>nous start<br>trigger | Capture in-<br>terrupt | TMRB in-<br>terrupt | A/DC high-<br>est priority<br>conversion<br>start | ADC<br>normal<br>conversion<br>start | Timer flip-<br>flop output<br>TBxOUT to<br>SIO/UART<br>(TXTRG<br>:transfer<br>clock) | Two phase<br>pulse input<br>to capture<br>trigger |
| TMRB0              | TB0OUT                            | TB0IN0<br>TB0IN1                                     | TB7OUT             | -                                 | INTCAP00<br>INTCAP01   | INTTB0              | -                                                 | -                                    | -                                                                                    | -                                                 |
| TMRB1              | TB1OUT                            | TB1IN0<br>TB1IN1                                     | TB7OUT             | TB0PRUN,T<br>B0RUN                | INTCAP10<br>INTCAP11   | INTTB1              | -                                                 | -                                    | -                                                                                    | -                                                 |
| TMRB2              | TB2OUT                            | TB2IN0<br>TB2IN1                                     | TB8OUT             | TB0PRUN,T<br>B0RUN                | INTCAP20<br>INTCAP21   | INTTB2              | -                                                 | -                                    | -                                                                                    | PHC0IN0<br>PHC0IN1                                |
| TMRB3              | TB3OUT                            | TB3IN0<br>TB3IN1                                     | TB8OUT             | TB0PRUN,T<br>B0RUN                | INTCAP30<br>INTCAP31   | INTTB3              | -                                                 | -                                    | -                                                                                    | PHC0IN1                                           |
| TMRB4              | TB4OUT                            | TB4IN0<br>TB4IN1                                     | TB9OUT             | -                                 | INTCAP40<br>INTCAP41   | INTTB4              | TB4RG0<br>Match                                   | -                                    | -                                                                                    | PHC1IN0<br>PHC1IN1                                |
| TMRB5              | TB5OUT                            | TB5IN0<br>TB5IN1                                     | TB9OUT             | TB4PRUN,T<br>B4RUN                | INTCAP50<br>INTCAP51   | INTTB5              | -                                                 | TB5RG0<br>Match                      | -                                                                                    | PHC1IN1                                           |
| TMRB6              | TB6OUT                            | TB6IN0<br>TB6IN1                                     | TB9OUT             | TB4PRUN,T<br>B4RUN                | INTCAP60<br>INTCAP61   | INTTB6              | -                                                 | -                                    | -                                                                                    | PHC2IN0<br>PHC2IN1                                |
| TMRB7              | TB7OUT                            | TB7IN0<br>TB7IN1                                     | _                  | TB4PRUN,T<br>B4RUN                | INTCAP70<br>INTCAP71   | INTTB7              | -                                                 | -                                    | -                                                                                    | PHC2IN1                                           |
| TMRB8              | TB8OUT                            | TB8IN0<br>TB8IN1                                     | -                  | -                                 | INTCAP80<br>INTCAP81   | INTTB8              | -                                                 | -                                    | SIO0,<br>SIO1, SIO2                                                                  | PHC3IN0<br>PHC3IN1                                |
| TMRB9              | TB9OUT                            | TB9IN0<br>TB9IN1                                     | _                  | -                                 | INTCAP90<br>INTCAP91   | INTTB9              | -                                                 | -                                    | SIO3, SIO4                                                                           | PHC3IN1                                           |

### 13.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 13-1 TMRBx Block Diagram(x= 0 to 9)

# 13.4 Registers

### 13.4.1 Register list according to channel

The following table shows the register names and addresses of each channel.

| Channel x | Base Address |
|-----------|--------------|
| Channel0  | 0x400C_4000  |
| Channel1  | 0x400C_4100  |
| Channel2  | 0x400C_4200  |
| Channel3  | 0x400C_4300  |
| Channel4  | 0x400C_4400  |
| Channel5  | 0x400C_4500  |
| Channel6  | 0x400C_4600  |
| Channel7  | 0x400C_4700  |
| Channel8  | 0x400C_4800  |
| Channel9  | 0x400C_4900  |

| Register name(x=0~9)        |         | Address(Base+) |
|-----------------------------|---------|----------------|
| Enable register             | TBxEN   | 0x0000         |
| RUN register                | TBxRUN  | 0x0004         |
| Control register            | TBxCR   | 0x0008         |
| Mode register               | TBxMOD  | 0x000C         |
| Flip-flop control register  | TBxFFCR | 0x0010         |
| Status register             | TBxST   | 0x0014         |
| Interrupt mask register     | TBxIM   | 0x0018         |
| Up counter capture register | TBxUC   | 0x001C         |
| Timer register 0            | TBxRG0  | 0x0020         |
| Timer register 1            | TBxRG1  | 0x0024         |
| Capture register 0          | TBxCP0  | 0x0028         |
| Capture register 1          | TBxCP1  | 0x002C         |
| DMA request enable register | TBxDMA  | 0x0030         |

Note: Timer control register, timer mode register and timer flip-flop control register can not be changed during timer operation. Make any changes of the above regsters after timer stopped.

# 13.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  | -    | -      | -  | -  | -  | -  | -  | -  |
| 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  | 0  |
|             | 7    | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
| bit symbol  | TBEN | TBHALT | -  | -  | -  | -  | -  | -  |
| After reset | 0    | 0      | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                       |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                                                                                                                                     |
| 7    | TBEN       | R/W  | TMRBx operation 0: Disabled                                                                                                                                                                                                                                    |
|      |            |      | 1: Enabled<br>Specifies the TMRB operation. When the operation is disabled, no clock is supplied to the other registers<br>in the TMRB module. This can reduce power consumption. (This disables reading from and writing to the oth-                          |
|      |            |      | er registers except TBxEN register.)<br>To use the TMRB, enable the TMRB operation (set to "1") before programming each register in the TMRB<br>module. If the TMRB operation is executed and then disabled, the settings will be maintained in each register. |
| 6    | TBHALT     | R/W  | Clock operation during debug HALT<br>0: run<br>1: stop<br>Specifies the TMRB clock setting to run or stop when the debug tool transits to HALT mode while in use.                                                                                              |
| 5-0  | -          | R    | Read as 0.                                                                                                                                                                                                                                                     |

# 13.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  | -  | -  | -  | -  | -  | -      | -  | -     |
| 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  | 0     |
|             | 7  | 6  | 5  | 4  | 3  | 2      | 1  | 0     |
| bit symbol  | -  | -  | -  | -  | -  | TBPRUN | -  | TBRUN |
| After reset | 0  | 0  | 0  | 0  | 0  | 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            |

|             | 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      | 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  | TBWBF | -  | TBSYNC | -  | I2TB | TBINSEL | TRGSEL | CSSEL |
| After reset | 0     | 0  | 0      | 0  | 0    | 0       | 0      | 0     |

# 13.4.4 TBxCR (Control register)

| Bit  | Bit Symbol | Туре | Function                                                                                       |
|------|------------|------|------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                     |
| 7    | TBWBF      | R/W  | Double Buffer                                                                                  |
|      |            |      | 0: Disabled                                                                                    |
|      |            |      | 1: Enabled                                                                                     |
| 6    | -          | R/W  | Write 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    | TBINSEL    | R/W  | Selects the external inputs.                                                                   |
|      |            |      | 0: TBxIN0/1                                                                                    |
|      |            |      | 1: PHCxIN0/1                                                                                   |
|      |            |      | Controls the external inputs selection between TBxIN0/1 or PHCxIN0/1.                          |
| 1    | TRGSEL     | R/W  | Selects the external triggers.                                                                 |
|      |            |      | 0: rising                                                                                      |
|      |            |      | 1: falling                                                                                     |
|      |            |      | Controls the edgge selection (of signal to TBxIN0 pin) when the external triggers is selected. |
| 0    | CSSEL      | R/W  | Selects the count start                                                                        |
|      |            |      | 0: starts by software                                                                          |
|      |            |      | 1: starts by external trigger                                                                  |

### 13.4.5 TBxMOD (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  | -  | -    | -   | -   | -     | -  | -     | -  |
| 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     | 0  |
|             | 7  | 6    | 5   | 4   | 3     | 2  | 1     | 0  |
| bit symbol  | -  | TBCP | TBC | CPM | TBCLE |    | TBCLK |    |
| After reset | 0  | 1    | 0   | 0   | 0     | 0  | 0     | 0  |

| Bit  | Bit Symbol | Туре | Function                                                                                                                                           |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                         |
| 7    | -          | R/W  | Write 0.                                                                                                                                           |
|      | TBCP       | w    | Capture control by software                                                                                                                        |
|      |            |      | 0: Capture by software                                                                                                                             |
| 6    |            |      | 1: Don't care                                                                                                                                      |
|      |            |      | When "0" is written, the capture register 0 (TBxCP0) takes count value.                                                                            |
|      |            |      | Read as 1.                                                                                                                                         |
| 5-4  | TBCPM[1:0] | R/W  | Capture timing (Refer to Table 13-2)                                                                                                               |
|      |            |      | 00: Disable Capture timing                                                                                                                         |
|      |            |      | 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 (TBnCP0) upon rising of 16-bit timer match output (TBxOUT)                                              |
|      |            |      | and into capture register 1 (TBnCP1) upon falling of TBxOUT. ( $x = 7$ , $n = 0,1$ ), ( $x = 8$ , $n = 2,3$ ), ( $x = 9$ , $n = 4,5,6$ ),          |
|      |            |      | (TMRB0 to 1: TB7OUT, TMRB2 to 3: TB8OUT, TMRB4 to 6: TB9OUTÅj                                                                                      |
|      |            | DAA  |                                                                                                                                                    |
| 3    | 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.<br>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).                                                                                                    |
|      |            | DAA  |                                                                                                                                                    |
| 2-0  | TBCLK[2:0] | R/W  | Selects the TMRBx source clock.                                                                                                                    |
|      |            |      | 000: TBxIN0 pin input<br>001: φT1                                                                                                                  |
|      |            |      | 010: φΤ4                                                                                                                                           |
|      |            |      | 010. φ14<br>011: φT16                                                                                                                              |
|      |            |      | 100: φT32                                                                                                                                          |
|      |            |      | 101: φΤ64                                                                                                                                          |
|      |            |      | 110: φ104<br>110: φ1128                                                                                                                            |
|      |            |      | 111: φT256                                                                                                                                         |
|      | ļ          |      | 111. ψ1230                                                                                                                                         |

Note: When the channel of TBxMOD register is 7, 8 or 9, the setting of <TBCPM[1:0]>="11" is prohibited.

| TMRB Channel | TBCPM1 | TBCPM0 | Capture register | Capture timing     | Two pulse counter channel |
|--------------|--------|--------|------------------|--------------------|---------------------------|
| TMRB2        | 0      | 1      | TB2CP0, TB2CP1   | PHC0IN0↑, PHC0IN1↑ |                           |
| TMRB2        | 4      | 0      | TB2CP0, TB2CP1   | PHC0IN0↑, PHC0IN0↓ | PHCNT0                    |
| TMRB3        | 1      | 0      | TB3CP0, TB3CP1   | PHC0IN1↑, PHC0IN1↓ |                           |
|              | 0      | 1      | TB4CP0, TB4CP1   | PHC1IN0↑, PHC1IN1↑ |                           |
| TMRB4        | 4      | 0      | TB4CP0, TB4CP1   | PHC1IN0↑, PHC1IN0↓ | PHCNT1                    |
| TMRB5        | 1      | 0      | TB5CP0, TB5CP1   | PHC1IN1↑, PHC1IN1↓ |                           |
| TMDDC        | 0      | 1      | TB6CP0, TB6CP1   | PHC2IN0↑, PHC2IN1↑ |                           |
| TMRB6        | 1      | 0      | TB6CP0, TB6CP1   | PHC2IN0↑, PHC2IN0↓ | PHCNT2                    |
| TMRB7        | 1      | 0      | TB7CP0, TB7CP1   | PHC2IN1↑, PHC2IN1↓ |                           |
| тирро        | 0      | 1      | TB8CP0, TB8CP1   | PHC3IN0↑, PHC3IN1↑ |                           |
| TMRB8        | 1      | 0      | TB8CP0, TB8CP1   | PHC3IN0↑, PHC3IN0↓ | PHCNT3                    |
| TMRB9        | Ĩ      | U      | TB9CP0, TB9CP1   | PHC3IN1↑, PHC3IN1↓ |                           |

Table 13-2 Relationship between <TBCPM[1:0]>, capture register and two phase plus counter input

Note: TMRB0 and TMRB1 do not have capture function of two pulse counter input.

Note:Do not make any changes of TBxMOD regster while corresponding TMRBx or PHCNTx is running.

#### 13.4 Registers

|             | 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   | 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  | -  | -  | TBC1T1 | TBC0T1 | TBE1T1 | TBE0T1 | TBF | FOC |
| After reset | 1  | 1  | 0      | 0      | 0      | 0      | 1   | 1   |

# 13.4.6 TBxFFCR (Flip-flop control register)

| 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".                                                                                        |

|             | 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      | 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  | -  | -  | -  | -  | -  | INTTBOF | INTTB1 | INTTB0 |
| After reset | 0  | 0  | 0  | 0  | 0  | 0       | 0      | 0      |

### 13.4.7 TBxST (Status register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                    |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3 | -          | R    | Read as 0.                                                                                                                                                  |
| 2    | INTTBOF    | R    | Overflow flag<br>0:No overflow occurs<br>1:Overflow occurs<br>When an up-counter is overflow, "1" is set.                                                   |
| 1    | INTTB1     | R    | Match flag (TBxRG1)<br>0:No detection of a mach<br>1:Detects a match with TBxRG1<br>When a match with the timer register 1 (TBxRG1) is detected,"1" is set. |
| 0    | INTTB0     | R    | Match flag (TBxRG0)<br>0:No match is detected<br>1:Detects a match with TBxRG0<br>When a match with the timer register 0 (TBxRG0) is detected, "1" is set.  |

Note 1: When the interrupt mask configuration is disabled by the corresponding bit of TBxIM register, the interrupt is issued to the CPU.

Note 2: To clear the flag, TBxST register should be read.

Note 3: Even if mask configuration by TBxIM register is valid, the status is set to TBxST 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     | 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  | -  | -  | -  | -  | -  | TBIMOF | TBIM1 | TBIM0 |
| After reset | 0  | 0  | 0  | 0  | 0  | 0      | 0     | 0     |

# 13.4.8 TBxIM (Interrupt mask register)

| Bit  | Bit Symbol | Туре | Function                                                                               |
|------|------------|------|----------------------------------------------------------------------------------------|
| 31-3 | -          | R    | Read as 0.                                                                             |
| 2    | TBIMOF     | R/W  | Overflow interrupt mask                                                                |
|      |            |      | 0:Disable                                                                              |
|      |            |      | 1:Enable                                                                               |
|      |            |      | Sets the up-counter overflow interrupt to disable or enable.                           |
| 1    | TBIM1      | 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. |

Note: Even if mask configuration by TBxIM register is valid, the status is set to TBxST 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  | 0  |
|             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |
| bit symbol  |    |    |    | TB | UC |    |    |    |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| bit symbol  |    |    |    | TB | UC |    |    |    |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

# 13.4.9 TBxUC (Up counter capture register)

| 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. |

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | TBI | RG0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | TBI | RG0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

# 13.4.10 TBxRG0 (Timer register 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. |

# 13.4.11 TBxRG1 (Timer 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  | -  | -     | -  | -   | -   | -  | -  | -  |  |
| After reset | 0  | 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  | 6     | 5  | 4   | 3   | 2  | 1  | 0  |  |
| bit symbol  |    | TBRG1 |    |     |     |    |    |    |  |
| After reset | 0  | 0     | 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. |

|             | 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         | 0         |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
| bit symbol  |           | -         |           | TBO       | CP0       |           |           |           |
| After reset | Undefined |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  |           |           |           | TBO       | CP0       |           |           |           |
| After reset | Undefined |

# 13.4.12 TBxCP0 (Capture register 0)

| 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. |

# 13.4.13 TBxCP1 (Capture 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  | -         | -         | -         | -         | -         | -         | -         | -         |
| After reset | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |
|             | 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
| bit symbol  |           |           |           | TBO       | CP1       |           |           |           |
| After reset | Undefined |
|             | 7         | 6         | 5         | 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. |

13.4 Registers

|             | 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        | 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  | -  | -  | -  | -  | -  | TBDMAEN2 | TBDMAEN1 | TBDMAEN0 |
| After reset | 0  | 0  | 0  | 0  | 0  | 0        | 0        | 0        |

### 13.4.14 TBxDMA(DMA request enable register)

| Bit  | Bit Symbol | Туре | Function                                                         |
|------|------------|------|------------------------------------------------------------------|
| 31-3 | -          | R    | Read as 0.                                                       |
| 2    | TBDMAEN2   | R/W  | Selects DMA request:compare match.<br>0: Disabled<br>1 :Enabled  |
| 1    | TBDMAEN1   | R/W  | Selects DMA request:input capture 1<br>0: Disabled<br>1: Enabled |
| 0    | TBDMAEN0   | R/W  | Selects DMA request:input capture 0<br>0: Disabled<br>1: Enabled |

Note: When mask configuration by TBxIM register is valid, DMA request does not issue even if it is enabled.

Note: The assignment of DMA request factor differs by chennel, TMRB0 to 9 . Refer to Chapter "DMAC " for details.

### 13.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 13-3.

### 13.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 fperiph/1, fperiph/2, fperiph/4, fperiph/8, fperiph/16 or fperiph/32 selected by CGSYSCR<PRCK[2:0]> in the CG.The peripheral clock, fperiph, is either fgear, a clock selected by CGSYSCR<FPSEL> 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. Table 13-3 and Table 13-4 show prescaler output clock resolutions.

|  | Table 13-3 | Prescaler | Output | Clock | Resolutions( | fc = 40MHz |
|--|------------|-----------|--------|-------|--------------|------------|
|--|------------|-----------|--------|-------|--------------|------------|

| Select                                         | Clock gear value                   | Select                                                | Prescaler output clock function |                              |                               |  |
|------------------------------------------------|------------------------------------|-------------------------------------------------------|---------------------------------|------------------------------|-------------------------------|--|
| peripheral clock<br>CGSYSCR<br><fpsel></fpsel> | CGSYSCR<br><gear[2:0]></gear[2:0]> | prescaler clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1                             | φΤ4                          | φT16                          |  |
|                                                |                                    | 000 (fperiph/1)                                       | fc/2¹ (0.05 μs)                 | fc/2 <sup>3</sup> (0.2 µs)   | fc/2 <sup>5</sup> (0.8 µs)    |  |
|                                                |                                    | 001 (fperiph/2)                                       | fc/2² (0.1 µs)                  | fc/24 (0.4 µs)               | fc/2 <sup>6</sup> (1.6 µs)    |  |
|                                                | 000 (fa)                           | 010 (fperiph/4)                                       | fc/2 <sup>3</sup> (0.2 µs)      | fc/2 <sup>5</sup> (0.8 µs)   | fc/2 <sup>7</sup> (3.2 µs)    |  |
|                                                | 000 (fc)                           | 011 (fperiph/8)                                       | fc/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs)   | fc/2 <sup>8</sup> (6.4 µs)    |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2 <sup>5</sup> (0.8 µs)      | fc/2 <sup>7</sup> (3.2 µs)   | fc/2 <sup>9</sup> (12.8 µs)   |  |
|                                                |                                    | 101 (fperiph/32)                                      | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |  |
|                                                |                                    | 000 (fperiph/1)                                       | fc/2² (0.1 µs)                  | fc/24 (0.4 µs)               | fc/2 <sup>6</sup> (1.6 µs)    |  |
|                                                |                                    | 001 (fperiph/2)                                       | fc/2 <sup>3</sup> (0.2 µs)      | fc/2 <sup>5</sup> (0.8 µs)   | fc/2 <sup>7</sup> (3.2 µs)    |  |
|                                                | 100 (fc/2)                         | 010 (fperiph/4)                                       | fc/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs)   | fc/2 <sup>8</sup> (6.4 µs)    |  |
|                                                |                                    | 011 (fperiph/8)                                       | fc/2 <sup>5</sup> (0.8 µs)      | fc/2 <sup>7</sup> (3.2 µs)   | fc/2º (12.8 µs)               |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |  |
| 0 (fgear)                                      |                                    | 101 (fperiph/32)                                      | fc/27 (3.2 µs)                  | fc/2 <sup>9</sup> (12.8 μs)  | fc/2 <sup>11</sup> (51.2 µs)  |  |
| U (igeal)                                      | 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/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs)   | fc/2 <sup>8</sup> (6.4 µs)    |  |
|                                                |                                    | 010 (fperiph/4)                                       | fc/2 <sup>5</sup> (0.8 µs)      | fc/2 <sup>7</sup> (3.2 µs)   | fc/2 <sup>9</sup> (12.8 µs)   |  |
|                                                |                                    | 011 (fperiph/8)                                       | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2 <sup>7</sup> (3.2 µs)      | fc/2 <sup>9</sup> (12.8 μs)  | fc/2 <sup>11</sup> (51.2 µs)  |  |
|                                                |                                    | 101 (fperiph/32)                                      | fc/2 <sup>8</sup> (6.4 µs)      | fc/2 <sup>10</sup> (25.6 µs) | fc/2 <sup>12</sup> (102.4 µs) |  |
|                                                | 110 (fc/8)                         | 000 (fperiph/1)                                       | fc/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs)   | fc/2 <sup>8</sup> (6.4 µs)    |  |
|                                                |                                    | 001 (fperiph/2)                                       | fc/2 <sup>5</sup> (0.8 μs)      | fc/2 <sup>7</sup> (3.2 µs)   | fc/2 <sup>9</sup> (12.8 µs)   |  |
|                                                |                                    | 010 (fperiph/4)                                       | fc/2 <sup>6</sup> (1.6 μs)      | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |  |
|                                                |                                    | 011 (fperiph/8)                                       | fc/2 <sup>7</sup> (3.2 µs)      | fc/2 <sup>9</sup> (12.8 µs)  | fc/2 <sup>11</sup> (51.2 µs)  |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2 <sup>8</sup> (6.4 µs)      | fc/2 <sup>10</sup> (25.6 µs) | fc/2 <sup>12</sup> (102.4 µs) |  |
|                                                |                                    | 101 (fperiph/32)                                      | fc/2 <sup>9</sup> (12.8 μs)     | fc/2 <sup>11</sup> (51.2 μs) | fc/2 <sup>13</sup> (204.8 µs) |  |

| Select                                         | Clock gear value                   | Select                                                | Prescaler output clock function |                            |                              |  |
|------------------------------------------------|------------------------------------|-------------------------------------------------------|---------------------------------|----------------------------|------------------------------|--|
| peripheral clock<br>CGSYSCR<br><fpsel></fpsel> | CGSYSCR<br><gear[2:0]></gear[2:0]> | prescaler clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ1                             | φΤ4                        | φT16                         |  |
|                                                |                                    | 000 (fperiph/1)                                       | fc/21 (0.05 µs)                 | fc/23 (0.2 µs)             | fc/2 <sup>5</sup> (0.8 µs)   |  |
|                                                |                                    | 001 (fperiph/2)                                       | fc/2² (0.1 µs)                  | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   |  |
|                                                | 000 (5)                            | 010 (fperiph/4)                                       | fc/23 (0.2 µs)                  | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (3.2 µs)   |  |
|                                                | 000 (fc)                           | 011 (fperiph/8)                                       | fc/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs)   |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2 <sup>5</sup> (0.8 μs)      | fc/2 <sup>7</sup> (3.2 µs) | fc/2 <sup>9</sup> (12.8 μs)  |  |
|                                                |                                    | 101 (fperiph/32)                                      | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>8</sup> (6.4 µs) | fc/2 <sup>10</sup> (25.6 µs) |  |
|                                                |                                    | 000 (fperiph/1)                                       | -                               | fc/2 <sup>3</sup> (0.2 µs) | fc/2 <sup>5</sup> (0.8 µs)   |  |
|                                                |                                    | 001 (fperiph/2)                                       | fc/2 <sup>2</sup> (0.1 µs)      | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   |  |
|                                                | 100 (fc/2)                         | 010 (fperiph/4)                                       | fc/23 (0.2 µs)                  | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (3.2 µs)   |  |
|                                                |                                    | 011 (fperiph/8)                                       | fc/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs)   |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2⁵ (0.8 µs)                  | fc/2 <sup>7</sup> (3.2 µs) | fc/2 <sup>9</sup> (12.8 μs)  |  |
|                                                |                                    | 101 (fperiph/32)                                      | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>8</sup> (6.4 µs) | fc/2 <sup>10</sup> (25.6 µs) |  |
| 1 (fc)                                         | 101 (fc/4)                         | 000 (fperiph/1)                                       | -                               | fc/23 (0.2 µs)             | fc/2 <sup>5</sup> (0.8 µs)   |  |
|                                                |                                    | 001 (fperiph/2)                                       | -                               | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   |  |
|                                                |                                    | 010 (fperiph/4)                                       | fc/23 (0.2 µs)                  | fc/2 <sup>5</sup> (0.8 µs) | fc/2 <sup>7</sup> (3.2 µs)   |  |
|                                                |                                    | 011 (fperiph/8)                                       | fc/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs)   |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2 <sup>5</sup> (0.8 µs)      | fc/2 <sup>7</sup> (3.2 µs) | fc/2 <sup>9</sup> (12.8 µs)  |  |
|                                                |                                    | 101 (fperiph/32)                                      | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>8</sup> (6.4 µs) | fc/2 <sup>10</sup> (25.6 µs) |  |
|                                                | 110 (fc/8)                         | 000 (fperiph/1)                                       | -                               | -                          | fc/2⁵ (0.8 µs)               |  |
|                                                |                                    | 001 (fperiph/2)                                       | -                               | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   |  |
|                                                |                                    | 010 (fperiph/4)                                       | -                               | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (3.2 µs)   |  |
|                                                |                                    | 011 (fperiph/8)                                       | fc/24 (0.4 µs)                  | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs)   |  |
|                                                |                                    | 100 (fperiph/16)                                      | fc/2 <sup>5</sup> (0.8 µs)      | fc/2 <sup>7</sup> (3.2 µs) | fc/2º (12.8 µs)              |  |
|                                                |                                    | 101 (fperiph/32)                                      | fc/2 <sup>6</sup> (1.6 μs)      | fc/2 <sup>8</sup> (6.4 µs) | fc/2 <sup>10</sup> (25.6 µs) |  |

| Table 13-3 Prescaler | Output Clock Resolutions(fc = | : 40MHz) |
|----------------------|-------------------------------|----------|
|                      |                               | 1010112/ |

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.

# TOSHIBA

| Select                                         | Clock gear value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | Select                                                | Prescaler output clock function |                               |                                |                                |  |
|------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------|---------------------------------|-------------------------------|--------------------------------|--------------------------------|--|
| peripheral clock<br>CGSYSCR<br><fpsel></fpsel> |                                                        | prescaler clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ32                            | φT64                          | φΤ128                          | φΤ256                          |  |
|                                                |                                                        | 000 (fperiph/1)                                       | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>7</sup> (3.2 µs)    | fc/2 <sup>8</sup> (6.4 µs)     | fc/2 <sup>9</sup> (12.8 µs)    |  |
|                                                |                                                        | 001 (fperiph/2)                                       | fc/2 <sup>7</sup> (3.2 µs)      | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 µs)    | fc/2 <sup>10</sup> (25.6 µs)   |  |
|                                                | 000 (5)                                                | 010 (fperiph/4)                                       | fc/2 <sup>8</sup> (6.4 µs)      | fc/2 <sup>9</sup> (12.8 μs)   | fc/2 <sup>10</sup> (25.6 µs)   | fc/2 <sup>11</sup> (51.2 µs)   |  |
|                                                | 000 (fc)                                               | 011 (fperiph/8)                                       | fc/2 <sup>9</sup> (12.8 µs)     | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)   | fc/2 <sup>12</sup> (102.4 µs)  |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs)  | fc/2 <sup>13</sup> (204.8 µs)  |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>11</sup> (51.2 µs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs)  | fc/2 <sup>14</sup> (409.6 µs)  |  |
| 0 (fgear)                                      |                                                        | 000 (fperiph/1)                                       | fc/2 <sup>7</sup> (3.2 μs)      | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 μs)    | fc/2 <sup>10</sup> (25.6 µs)   |  |
|                                                | 100 (fc/2)                                             | 001 (fperiph/2)                                       | fc/2 <sup>8</sup> (6.4 µs)      | fc/2 <sup>9</sup> (12.8 μs)   | fc/2 <sup>10</sup> (25.6 µs)   | fc/2 <sup>11</sup> (51.2 µs)   |  |
|                                                |                                                        | 010 (fperiph/4)                                       | fc/2º (12.8 µs)                 | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)   | fc/212 (102.4 µs)              |  |
|                                                |                                                        | 011 (fperiph/8)                                       | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs)  | fc/2 <sup>13</sup> (204.8 µs)  |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/2 <sup>11</sup> (51.2 µs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs)  | fc/2 <sup>14</sup> (409.6 µs)  |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>12</sup> (102.4 µs)   | fc/2 <sup>13</sup> (204.8 µs) | fc/2 <sup>14</sup> (409.6 µs)  | fc/2 <sup>15</sup> (819.2 µs)  |  |
|                                                | 101 (fc/4)                                             | 000 (fperiph/1)                                       | fc/2 <sup>8</sup> (6.4 µs)      | fc/2 <sup>9</sup> (12.8 μs)   | fc/2 <sup>10</sup> (25.6 µs)   | fc/2 <sup>11</sup> (51.2 µs)   |  |
|                                                |                                                        | 001 (fperiph/2)                                       | fc/2º (12.8 µs)                 | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)   | fc/2 <sup>12</sup> (102.4 µs)  |  |
|                                                |                                                        | 010 (fperiph/4)                                       | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs)  | fc/2 <sup>13</sup> (204.8 µs)  |  |
|                                                |                                                        | 011 (fperiph/8)                                       | fc/2 <sup>11</sup> (51.2 µs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs)  | fc/2 <sup>14</sup> (409.6 µs)  |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/2 <sup>12</sup> (102.4 µs)   | fc/2 <sup>13</sup> (204.8 µs) | fc/2 <sup>14</sup> (409.6 µs)  | fc/2 <sup>15</sup> (819.2 µs)  |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>13</sup> (204.8 µs)   | fc/2 <sup>14</sup> (409.6 µs) | fc/2 <sup>15</sup> (819.2 µs)  | fc/2 <sup>16</sup> (1638.4 µs) |  |
|                                                | 110 (fc/8)                                             | 000 (fperiph/1)                                       | fc/2º (12.8 µs)                 | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)   | fc/2 <sup>12</sup> (102.4 µs)  |  |
|                                                |                                                        | 001 (fperiph/2)                                       | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 μs)  | fc/212 (102.4 µs)              | fc/2 <sup>13</sup> (204.8 µs)  |  |
|                                                |                                                        | 010 (fperiph/4)                                       | fc/2 <sup>11</sup> (51.2 μs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs)  | fc/2 <sup>14</sup> (409.6 µs)  |  |
|                                                |                                                        | 011 (fperiph/8)                                       | fc/212 (102.4 µs)               | fc/213 (204.8 µs)             | fc/214 (409.6 µs)              | fc/2 <sup>15</sup> (819.2 µs)  |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/213 (204.8 µs)               | fc/2 <sup>14</sup> (409.6 µs) | fc/2 <sup>15</sup> (819.2 µs)  | fc/2 <sup>16</sup> (1638.4 µs) |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>14</sup> (409.6 µs)   | fc/2 <sup>15</sup> (819.2 µs) | fc/2 <sup>16</sup> (1638.4 µs) | fc/2 <sup>17</sup> (3276.8 µs) |  |

| Select                                         | Clock gear value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | Select                                                | Prescaler output clock function |                               |                               |                               |  |
|------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------|---------------------------------|-------------------------------|-------------------------------|-------------------------------|--|
| peripheral clock<br>CGSYSCR<br><fpsel></fpsel> |                                                        | prescaler clock<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φΤ32                            | φT64                          | φΤ128                         | φΤ256                         |  |
|                                                |                                                        | 000 (fperiph/1)                                       | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>7</sup> (3.2 μs)    | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 µs)   |  |
|                                                |                                                        | 001 (fperiph/2)                                       | fc/2 <sup>7</sup> (3.2 μs)      | fc/2 <sup>8</sup> (6.4 µs)    | fc/2º (12.8 µs)               | fc/2 <sup>10</sup> (25.6 µs)  |  |
|                                                | 000 (5)                                                | 010 (fperiph/4)                                       | fc/2 <sup>8</sup> (6.4 μs)      | fc/2 <sup>9</sup> (12.8 μs)   | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)  |  |
|                                                | 000 (fc)                                               | 011 (fperiph/8)                                       | fc/2 <sup>9</sup> (12.8 µs)     | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs) |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>11</sup> (51.2 µs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs) | fc/2 <sup>14</sup> (409.6 µs) |  |
| 1 (fc)                                         |                                                        | 000 (fperiph/1)                                       | fc/2 <sup>6</sup> (1.6 μs)      | fc/2 <sup>7</sup> (3.2 μs)    | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 µs)   |  |
|                                                | 100 (fc/2)                                             | 001 (fperiph/2)                                       | fc/2 <sup>7</sup> (3.2 μs)      | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |  |
|                                                |                                                        | 010 (fperiph/4)                                       | fc/2 <sup>8</sup> (6.4 µs)      | fc/2 <sup>9</sup> (12.8 µs)   | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)  |  |
|                                                |                                                        | 011 (fperiph/8)                                       | fc/2º (12.8 µs)                 | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs) |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>11</sup> (51.2 µs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs) | fc/2 <sup>14</sup> (409.6 µs) |  |
|                                                | 101 (fc/4)                                             | 000 (fperiph/1)                                       | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>7</sup> (3.2 μs)    | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 µs)   |  |
|                                                |                                                        | 001 (fperiph/2)                                       | fc/2 <sup>7</sup> (3.2 μs)      | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 μs)   | fc/2 <sup>10</sup> (25.6 µs)  |  |
|                                                |                                                        | 010 (fperiph/4)                                       | fc/2 <sup>8</sup> (6.4 µs)      | fc/2º (12.8 µs)               | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 μs)  |  |
|                                                |                                                        | 011 (fperiph/8)                                       | fc/2 <sup>9</sup> (12.8 μs)     | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) | fc/213 (204.8 µs)             |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>11</sup> (51.2 µs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs) | fc/2 <sup>14</sup> (409.6 µs) |  |
|                                                | 110 (fc/8)                                             | 000 (fperiph/1)                                       | fc/2 <sup>6</sup> (1.6 µs)      | fc/2 <sup>7</sup> (3.2 μs)    | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>9</sup> (12.8 µs)   |  |
|                                                |                                                        | 001 (fperiph/2)                                       | fc/2 <sup>7</sup> (3.2 μs)      | fc/2 <sup>8</sup> (6.4 µs)    | fc/2º (12.8 µs)               | fc/2 <sup>10</sup> (25.6 µs)  |  |
|                                                |                                                        | 010 (fperiph/4)                                       | fc/2 <sup>8</sup> (6.4 µs)      | fc/2 <sup>9</sup> (12.8 µs)   | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 μs)  |  |
|                                                |                                                        | 011 (fperiph/8)                                       | fc/2º (12.8 µs)                 | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) |  |
|                                                |                                                        | 100 (fperiph/16)                                      | fc/2 <sup>10</sup> (25.6 µs)    | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs) |  |
|                                                |                                                        | 101 (fperiph/32)                                      | fc/2 <sup>11</sup> (51.2 μs)    | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>13</sup> (204.8 µs) | fc/2 <sup>14</sup> (409.6 µs) |  |

Table 13-4 Prescaler Output Clock Resolutions(fc = 40MHz)

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.

### 13.5.2 Up-counter (UC)

UC is a 16-bit binary counter.

Source clock

UC source clock, specified by TBxMOD<TBCLK[2:0]>, can be selected from either seven types -  $\phi$ T1,  $\phi$ T4,  $\phi$ T16,  $\phi$ T32,  $\phi$ T64,  $\phi$ T128 and  $\phi$ T256 - of prescaler output clock or the external clock of the TBxIN0 pin.

Count start/ stop

Counter operation is specified by TBxRUN<TBRUN>. UC starts counting if  $\langle TBRUN \rangle = "1"$ , and stops counting and clears counter value if  $\langle TBRUN \rangle = "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.

### 13.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  $\langle$ TBWBF> = "0", the double buffering becomes disable. If  $\langle$ 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.

#### 13.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>.

### 13.5.5 Capture registers (TBxCP0, TBxCP1)

This register captures an up-counter (UC) value.

#### 13.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.

### 13.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.

### 13.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.

### 13.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.

# TOSHIBA

## 13.6 Description of Operations for Each Mode

### 13.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 | Х | Х | Х | Х  | Х      | Х     | Х    | Enables TMRBx operation.                                      |
| TBxRUN                           | ←            | Х | Х | Х | Х | Х  | 0      | Х     | 0    | Stops count operation.                                        |
| Interrupt Set-Enable<br>Register | <del>~</del> | * | * | * | * | *  | *      | *     | *    | Permits INTTBx interrupt by setting corresponding bit to "1". |
| TBxFFCR                          | ←            | Х | Х | 0 | 0 | 0  | 0      | 1     | 1    | Disable to TBxFF0 reverse trigger                             |
| TBxMOD                           | ←            | 0 | 1 | 0 | 0 | 1  | *      | *     | *    | Changes to prescaler output clock as input clock. Specifies   |
|                                  |              |   |   |   |   | (* | ** = 0 | 01 to | 111) | Capture function to disable.                                  |
| TBxRG1                           | ←            | * | * | * | * | *  | *      | *     | *    | Specifies a time interval. (16 bits)                          |
|                                  | ←            | * | * | * | * | *  | *      | *     | *    |                                                               |
| TBxRUN                           | ←            | * | * | * | * | *  | 1      | Х     | 1    | Starts TMRBx.                                                 |

Note:X; Don't care -; No change

### 13.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.

|          |   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                          |
|----------|---|---|---|---|---|---|---|---|---|------------------------------------------|
| TBxEN    | ← | 1 | Х | Х | Х | Х | Х | Х | х | Enables TMRBx operation.                 |
| TBxRUN   | ← | Х | Х | Х | Х | Х | 0 | Х | 0 | Stops count operation.                   |
| PxIE[m]  | ← |   |   |   |   |   |   |   | 1 | Allocates corresponding port toTBxIN0.   |
| PxFR1[m] | ← |   |   |   |   |   |   |   | 1 | Allocates corresponding port to realing. |
| TBxFFCR  | ← | Х | Х | 0 | 0 | 0 | 0 | 1 | 1 | Disables to TBxFF0 reverse trigger       |
| TBxMOD   | ← | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Changes toTBxIN0 as an input clock       |
| TBxRUN   | ← | * | * | * | * | * | 1 | Х | 1 | Starts TMRBx.                            |
|          |   |   |   |   |   |   |   |   |   |                                          |
| TBxMOD   | ← | Х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Software capture is done.                |

Note 1: m: corresponding bit of port Note 2: X; Don't care

-; No change

### 13.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:

(Set value of TBxRG0) < (Set value of TBxRG1)



### Figure 13-2 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 13-3 Register Buffer Operation

The block diagram of this mode is shown below.





Each register in the 16-bit PPG output mode must be programmed as listed below.

|          |              | 7 | 6 | 5 | 4 | 3  | 2      | 1     | 0    |                                                                                                                                    |
|----------|--------------|---|---|---|---|----|--------|-------|------|------------------------------------------------------------------------------------------------------------------------------------|
| TBxEN    | ←            | 1 | Х | х | х | х  | х      | Х     | х    | Enables TMRBx operation.                                                                                                           |
| TBxRUN   | ←            | Х | Х | Х | Х | Х  | 0      | Х     | 0    | Stops count operation.                                                                                                             |
| TBxCR    | ←            | 0 | 0 | - | Х | -  | Х      | Х     | х    | Disables double buffering.                                                                                                         |
| TBxRG0   | ←            | * | * | * | * | *  | *      | *     | *    | Specifies a duty. (16 bits)                                                                                                        |
|          | ←            | * | * | * | * | *  | *      | *     | *    |                                                                                                                                    |
| TBxRG1   | ←            | * | * | * | * | *  | *      | *     | *    | Specifies a cycle. (16 bits)                                                                                                       |
|          | $\leftarrow$ | * | * | * | * | *  | *      | *     | *    |                                                                                                                                    |
| TBxCR    | $\leftarrow$ | 1 | 0 | Х | 0 | 0  | 0      | 0     | 0    | Enables the TBxRG0 double buffering.                                                                                               |
|          |              |   |   |   |   |    |        |       |      | (Changes the duty/cycle when the INTTBx interrupt is gener-<br>ated)                                                               |
| TBxFFCR  | ←            | х | х | 0 | 0 | 1  | 1      | 1     | 0    | Specifies to trigger TBxFF0 to reverse when a match with TBxRG0 or TBxRG1 is detected,and sets the initial value of TBxFF0 to "0." |
| TBxMOD   | ←            | 0 | 1 | 0 | 0 | 1  | *      | *     | *    | Designates the prescaler output clock as the input clock,and                                                                       |
|          |              |   |   |   |   | (* | ** = 0 | 01 to | 111) | disables the capture function.                                                                                                     |
| PxCR[m]  | $\leftarrow$ |   |   |   |   |    | 1      |       |      | Allocates corresponding port to TBxOUT.                                                                                            |
| PxFR1[m] | $\leftarrow$ |   |   |   |   |    | 1      |       |      | Allocates corresponding port to TBXCOT.                                                                                            |
| TBxRUN   | $\leftarrow$ | * | * | * | * | *  | 1      | Х     | 1    | Starts TMRBx.                                                                                                                      |
|          |              |   |   |   |   |    |        |       |      |                                                                                                                                    |

Note 1: m: corresponding bit of port Note 2: X; Don't care

-; No change

### 13.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 two pairs of 4-channel TMRB. If one channel starts, remaining 3 channels can be start synchronously. In the TMPM341FDXBG/FYXBG, the following combinations allow to use.

| Start trigger channel | Synchronous operation channel |
|-----------------------|-------------------------------|
| (Master channel)      | (Slave channel)               |
| TMRB0                 | TMRB1, TMRB2, TMRB3           |
| TMRB4                 | TMRB5, TMRB6, TMRB7           |

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.

- Note 1: The channels designated for synchronous output must be started by TBxRUN<TBPRUN,TBRUN>="1,1" before the start triggered by TMRB0 and TMRB4.
- Note 2: Set TBxCR<TBSYNC> to "0" unless the timer synchronous mode is used. The timer synchronous mode keeps the other channels operation waiting until TMRB0 and TMRB4 start operation.
- Note 3: TMRB0 and TMRB4 are the master clocks of the timer synchronous mode. Therefore, their <TBSYNC> bit must be set to "0".
- Note 4: This mode cannot be applied to TMRB8 and TMRB9.

#### 13.6.5 External trigger count start mode

The external trigger count start mode can be set to start counting by an external signal.

Set TBxCR<CSSEL> to select the count start mode.

- <CSSEL> = "0" : Start counting according to the timing of each timer channel.
- <CSSEL> = "1" : Start counting by an external signal.

Set TBxCR<TRGSEL> to select the active edge of the external trigger signal.

- <TRGSEL> = "0" : The rising edge of TBxIN0 is selected.
- <TRGSEL> = "1" : The falling edge of TBxIN0 is selected.

Timer synchronous mode has a priority if its mode is specified.

## 13.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

#### 13.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 TBxUC 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 13-5 One-shot Pulse Output (With Delay)".



Figure 13-5 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.)

Changes source clock to  $\Phi$ T1. Fetches a count value into the TBxCP0 at the rising edge of TBxIN0.

|                                    |              | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0  |                                                                                                          |
|------------------------------------|--------------|--------|--------|--------|--------|--------|--------|--------|----|----------------------------------------------------------------------------------------------------------|
| [Main processing] Capture          | settir       | ng by  | TBxII  | N0     |        |        |        |        |    |                                                                                                          |
| PxIE[m]                            | ←            |        |        |        |        |        |        |        | 1  | Allocates corresponding part to TDVING                                                                   |
| PxFR1[m]                           | ←            |        |        |        |        |        |        |        | 1  | Allocates corresponding port to TBxIN0.                                                                  |
| TBxEN                              | ←            | 1      | Х      | Х      | Х      | Х      | Х      | Х      | Х  | Enables TMRBx operation.                                                                                 |
| TBxRUN                             | ←            | Х      | Х      | Х      | Х      | Х      | 0      | Х      | 0  | Stops TMRBx operation                                                                                    |
| TBxMOD                             | ←            | 0      | 1      | 0      | 1      | 0      | 0      | 0      | 1  | Changes source clock to ΦT1. Fetches a count value into the TBxCP0 at the rising edge of TBxIN0.         |
| TBxFFCR                            | ←            | Х      | Х      | 0      | 0      | 0      | 0      | 1      | 0  | Clears TBxFF0 reverse trigger and disables.                                                              |
| PxCR[m]                            | ←            |        |        |        |        |        |        |        | 1  | Allegates corresponding part to TDVOLIT                                                                  |
| PxFR1[m]                           | ←            |        |        |        |        |        |        |        | 1  | Allocates corresponding port toTBxOUT.                                                                   |
| Interrupt Set-Enable<br>Register   | $\leftarrow$ | *      | *      | *      | *      | *      | *      | *      | *  | Permits to generate interrupts specified by INTCAPx0 inter-<br>rupt corresponding bit by setting to "1". |
| TBxRUN                             | ←            | *      | *      | *      | *      | *      | 1      | Х      | 1  | Starts the TMRBx module.                                                                                 |
| [Processing of INTCAPx0            | interro      | upt se | ervice | routir | ne] Pi | ulse o | output | settir | Ig |                                                                                                          |
| TBxRG0                             | ←            | *      | *      | *      | *      | *      | *      | *      | *  | Sets count value. (TBxCAP0 + 3ms/ΦT1)                                                                    |
| TBxRG1                             | ←            | *      | *      | *      | *      | *      | *      | *      | *  | Sets count value.(TBxCAP0 + (3+2)ms/ΦT1)                                                                 |
| TBxFFCR                            | ←            | Х      | Х      | -      | -      | 1      | 1      | -      | -  | Reverses TBxFF0 if TBxRG0 consistent with TBxRG1.                                                        |
| TBxIM                              | ←            | Х      | Х      | Х      | Х      | Х      | 1      | 0      | 1  | Masks except TBxRG1 correspondence interrupt.                                                            |
| Interrupt Set-Enable<br>Register   | ←            | *      | *      | *      | *      | *      | *      | *      | *  | Permits to generate interrupt specified by INTTBx interrupt corresponding bit setting to "1".            |
| [Processing of INTTBx inte         | errupt       | servi  | ce rou | utine] | Outp   | ut dis | able   |        |    |                                                                                                          |
| TBxFFCR                            | ←            | Х      | Х      | -      | -      | 0      | 0      | -      | -  | Clears TBxFF0 reverse trigger setting.                                                                   |
| Interrupt enable clear<br>register | ←            | *      | *      | *      | *      | *      | *      | *      | *  | Prohibits interrupts specified by INTTBx interrupt correspond-<br>ing bit by setting to "1".             |

Note 1: m: corresponding bit of port Note 2: X; Don't care -; No change

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 13-6 One-shot Pulse Output Triggered by an External Pulse (Without Delay)

### 13.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 TMRB3 and TMRB8. TB8OUT of the 16-bit timer TMRB8 is used to specify the measurement time.

TMRB3 count clock selects TB3IN0 input and performs count operation by using external clock input. If TB3MOD<TBCPM[1:0]> is set "11", TMRB3 count clock takes the counter value into the TB3CP0 at the rising edge of TB8OUT and takes the counter value into TB3CP1 at the falling edge of TB8OUT.

This setting allows a count value of the 16-bit up-counter UC to be taken into the capture register (TB3CP0) upon rising of a timer flip-flop output (TB8OUT) of the 16-bit timer (TMRB8), and an UC counter value to be taken into the capture register (TB3CP1) upon falling of TB8OUT of the 16-bit timer (TMRB8).

A frequency is then obtained from the difference between TB3CP0 and TB3CP1 based on the measurement, by generating the INTTB8 16-bit timer interrupt.

For example, if the difference between TB3CP0 and TB3CP1 is 100 and the level width setting value of TB8OUT is 0.5 s, the frequency is 200 Hz ( $100 \div 0.5 \text{ s} = 200 \text{ Hz}$ ).



Figure 13-7 Frequency Measurement

#### 13.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 × 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 13-8 Pulse Width Measurement" and this difference is multiplied by the cycle of the prescaler output clock to obtain the "Low" level width.



Figure 13-8 Pulse Width Measurement

#### 13.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.





# 14. Two-phase pulse input counter (PHCNT)

### 14.1 Outline

The counter is increment or decremented by one depending on the state transition of the two phase pulse that is input through PHCxIN0 and PHCxIN1 and has phase difference. PHCxIN0 and PHCxIN1 have a noise canceller which is selected either enabled and disabled.

Two-phase pulse input counter has two compare register. An interrupt is occurred when the up-and- down counter matches them. And an interrupt is also occurred by increment or decrement the up-and-down counter.

Two-phase pulse input counter has three operation mode, they are controlled by register.

- 1. Normal operation mode (up/down at the fourth count)
- 2. Quadruple mode (up/down at each count)
- 3. Multiplied by two mode
  - PHCxIN0 input
  - PHCxIN1 input

It is available to decide overflow, underflow and compare interrupt by the status register and to make two phase pulse as a trigger signal of the capture in 16-bit timer.

## 14.2 Differences in the Specifications

TMPM341FDXBG/FYXBG has four channel two-phase pulse input counters.

Each channel (PHCNT0 to PHCNT3) operates independently and the channel in the same way except for the differences in their specification as shown in Table 14-1.

| Specification | External | TMRB capture register |                      |                      |  |  |  |  |
|---------------|----------|-----------------------|----------------------|----------------------|--|--|--|--|
| channel       | signals  | PHCxIN0↑<br>PHCxIN1↑  | PHCxIN0↑<br>PHCxIN0↓ | PHCxIN1↑<br>PHCxIN1↓ |  |  |  |  |
| PHCNT0        | PHC0IN0  | TB2CP0                | TB2CP0               | TB3CP0               |  |  |  |  |
|               | PHC0IN1  | TB2CP1                | TB2CP1               | TB3CP1               |  |  |  |  |
| PHCNT1        | PHC1IN0  | TB4CP0                | TB4CP0               | TB5CP0               |  |  |  |  |
|               | PHC1IN1  | TB4CP1                | TB4CP1               | TB5CP1               |  |  |  |  |
| PHCNT2        | PHC2IN0  | TB6CP0                | TB6CP0               | TB7CP0               |  |  |  |  |
|               | PHC2IN1  | TB6CP1                | TB6CP1               | TB7CP1               |  |  |  |  |
| PHCNT3        | PHC3IN0  | TB8CP0                | TB8CP0               | TB9CP0               |  |  |  |  |
|               | PHC3IN1  | TB8CP1                | TB8CP1               | TB9CP1               |  |  |  |  |

Table 14-1 Differences in the Specifications of PHCNT Modules

### 14.3 Configuration

Two-phase pulse input counter is made from up-and-down counter PHCxCNT, compare circuit and counter control circuit. The counting operation is controlled by the registers.



Figure 14-1 Two-phase Pulse Input Counter (PHCNTx) Block Diagram

### 14.4 Registers

### 14.4.1 Register List according to channel

The following table shows the register names and addresses of each channel.

| Channel x | Base Address |
|-----------|--------------|
| Channel0  | 0x400C_A000  |
| Channel1  | 0x400C_A100  |
| Channel2  | 0x400C_A200  |
| Channel3  | 0x400C_A300  |

| Register name (x=0~1)          | Address(Base+) |        |  |
|--------------------------------|----------------|--------|--|
| Timer RUN Register             | PHCxRUN        | 0x0000 |  |
| Timer Control Register         | PHCxCR         | 0x0004 |  |
| Timer Enable Register          | PHCxEN         | 0x0008 |  |
| Timer Status Register          | PHCxFLG        | 0x000C |  |
| Timer Compare Register 0       | PHCxCMP0       | 0x0010 |  |
| Timer Compare Register 1       | PHCxCMP1       | 0x0014 |  |
| Counter Read Register          | PHCxCNT        | 0x0018 |  |
| DMA request permitted register | PHCxDMA        | 0x001C |  |

Note:Do not modify timer control register or timer enable register when timer is operating. Modify them after two-phase pulse counter timer stops.

#### 14.4 Registers

|             | 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      | 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  | -  | -  | -  | -  | -  | -  | PHCCLR | PHCRUN |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0      |

# 14.4.2 PHCxRUN (Timer RUN Register)

| Bit  | Bit Symbol | Туре | Description                                                                                 |
|------|------------|------|---------------------------------------------------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                                                                  |
| 1    | PHCCLR     | R/W  | Clears up-and-down counter value of PHCxCNT register to 0x7FFF<br>0: Don't care<br>1: Clear |
| 0    | PHCRUN     | R/W  | Controls up-and-down counter PHCxCNT counting operation<br>0: Stop<br>1: Active             |

|             | 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   | 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  | -  | -  | EVRYINT | CMP1EN | CMP0EN | NFOFF | PHO | CMD |
| After reset | 0  | 0  | 0       | 0      | 0      | 0     | 0   | 0   |

# 14.4.3 PHCxCR (Timer Control Register)

| Bit  | Bit Symbol | Туре | Description                                                                             |
|------|------------|------|-----------------------------------------------------------------------------------------|
| 31-6 | -          | R    | Read as 0.                                                                              |
| 5    | EVRYINT    | R/W  | Interrupt at every count                                                                |
|      |            |      | 0 : Disable                                                                             |
|      |            |      | 1 : Enable                                                                              |
|      |            |      | Enables to prohibit interrupt at every counting operation when using compare interrupt. |
| 4    | CMP1EN     | R/W  | Compare interrupt 1                                                                     |
|      |            |      | 0 : Disable                                                                             |
|      |            |      | 1 : Enable                                                                              |
|      |            |      | Interrupt is generated when up-and-down counter PHCxCNT matches compare register 1.     |
| 3    | CMP0EN     | R/W  | Compare interrupt 0                                                                     |
|      |            |      | 0 : Disable                                                                             |
|      |            |      | 1 : Enable                                                                              |
|      |            |      | Interrupt is generated when up-and-down counter PHCxCNT matches compare register 0.     |
| 2    | NFOFF      | R/W  | Noise filter                                                                            |
|      |            |      | 0 : ON                                                                                  |
|      |            |      | 1 : OFF                                                                                 |
|      |            |      | Controls noise cancellation. Noise filter value is 20ns (typ.).                         |
| 1-0  | PHCMD[1:0] | R/W  | Sets operation mode                                                                     |
|      |            |      | 00: Normal mode                                                                         |
|      |            |      | 01: Quadruple mode                                                                      |
|      |            |      | 10: Multiplied by two mode (PHCxIN0 input)                                              |
|      |            |      | 11: Multiplied by two mode (PHCxIN1 input)                                              |

Note: To change mode when two-phase input counter operates is prohibited.

14.4 Registers

|             | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | PHCEN |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     |

# 14.4.4 PHCxEN (Timer Enable Register)

| Bit  | Bit Symbol | Туре | Description                                                                                                                             |
|------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31-1 | -          | R    | Read as 0.                                                                                                                              |
| 0    | PHCEN      | R/W  | PHCNT operation                                                                                                                         |
|      |            |      | 0: Disable                                                                                                                              |
|      |            |      | 1: Enable                                                                                                                               |
|      |            |      | Specified the PHCNT operation.                                                                                                          |
|      |            |      | To use the PHCNT operation, set <phcen> = "1".</phcen>                                                                                  |
|      |            |      | When the operation is disabled, no clock is supplied to the other registers in the PHCNT module. This can reduce the power consumption. |
|      |            |      | If the PHCNT operation is executed and then disabled, the setting will be maintained in each 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    | 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  | -  | -  | -  | -  | UDF | OVF | CMP1 | CMP0 |
| After reset | 0  | 0  | 0  | 0  | 0   | 0   | 0    | 0    |

### 14.4.5 PHCxFLG (Timer Status Register)

| Bit  | Bit Symbol | Туре | Description                                        |
|------|------------|------|----------------------------------------------------|
| 31-4 | -          | R    | Read as 0.                                         |
| 3    | UDF        | R/W  | underflow interrupt                                |
|      |            |      | 0: not occurs                                      |
|      |            |      | 1: occurs                                          |
|      |            |      | Underflow interrupt of up-and-down counter         |
| 2    | OVF        | R/W  | overflow interrupt                                 |
|      |            |      | 0: not occurs                                      |
|      |            |      | 1: occurs                                          |
|      |            |      | Overflow interrupt of up-and-down counter          |
| 1    | CMP1       | R/W  | Compare 1 match interrupt                          |
|      |            |      | 0: not occurs                                      |
|      |            |      | 1: occurs                                          |
|      |            |      | Match interrupt with compare register 1 (PHCxCMP1) |
| 0    | CMP0       | R/W  | Compare 0 match interrupt                          |
|      |            |      | 0: not occurs                                      |
|      |            |      | 1: occurs                                          |
|      |            |      | Match interrupt with compare register (PHCxCMP0)   |

Note: The flag is cleared by writing "1" to each bit. Because each flag is not cleared automatically, initialize before using them.

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11   | 10 | 9  | 8  |
| bit symbol  |    |    |    | PHC | CMP0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3    | 2  | 1  | 0  |
| bit symbol  |    |    |    | PHC | CMP0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  |

# 14.4.6 PHCxCMP0 (Timer Compare Register 0)

| Bit   | Bit Symbol | Туре | Description        |
|-------|------------|------|--------------------|
| 31-16 | -          | R    | Read as 0.         |
| 15-0  | PHCCMP0    | R/W  | Sets compare value |
|       | [15:0]     |      | 0x0000 to 0xFFFF   |

# 14.4.7 PHCxCMP1(Timer Compare 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  | -  | -  | -  | -   | -    | -  | -  | -  |
| After reset | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  |
|             | 15 | 14 | 13 | 12  | 11   | 10 | 9  | 8  |
| bit symbol  |    |    |    | PHC | CMP1 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3    | 2  | 1  | 0  |
| bit symbol  |    |    |    | PHC | CMP1 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  |

| Bit   | Bit Symbol        | Туре | Description                            |
|-------|-------------------|------|----------------------------------------|
| 31-16 | -                 | R    | Read as 0.                             |
| 15-0  | PHCCMP1<br>[15:0] | R/W  | Sets compare value<br>0x0000 to 0xFFFF |

|             | 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  | 0  |
|             | 15 | 14     | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |        |    | PHC | CNT |    |    | -  |
| After reset | 0  | 1      | 1  | 1   | 1   | 1  | 1  | 1  |
|             | 7  | 6      | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    | PHCCNT |    |     |     |    |    |    |
| After reset | 1  | 1      | 1  | 1   | 1   | 1  | 1  | 1  |

## 14.4.8 PHCxCNT (Timer Read Register)

| Bit   | Bit Symbol   | Туре | Description                            |
|-------|--------------|------|----------------------------------------|
| 31-16 | -            | R    | Read as 0.                             |
| 15-0  | PHCCNT[15:0] | R    | Data read from the up-and-down counter |

Note:Pulse is counted not synchronized with MCU operation clock. Because there is a possibility that data is read while rewriting, depending on the timing, reading out twice is recommended. In this case if the data is different read out data again.

Note: When PHCxRUN register is "0" it is initialized.

14.4 Registers

|             | 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  | 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  | -  | -  | -  | -  | -  | PHCDMA2 | -  | -  |
| After reset | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  |

### 14.4.9 PHCxDMA (DMA request permitted register)

| Bit  | Bit Symbol | Туре | Description                                                                 |
|------|------------|------|-----------------------------------------------------------------------------|
| 31-3 | -          | R    | Read as 0.                                                                  |
| 2    | PHCDMA2    | R/W  | Controls DMA request permitted                                              |
|      |            |      | 0: Disable                                                                  |
|      |            |      | 1: Enable                                                                   |
|      |            |      | Controls DMA request permitted for every interrupt of up-and-down counting. |
| 1-0  | -          | R/W  | Write "0".                                                                  |

Note: When interrupt request is disabled, DMA request is not occurred even if DMA request is enabled.

### 14.5 Operation in Each Mode

The channel in the same way except for the differences in their specification as shown in Table 14-1.

#### 14.5.1 Count operation mode

The count operation mode is selected normal mode, quadruple mode or multiplied by two mode by the PHCxCR<PHCMD[1:0]>.

The up-and-down counter is increment or decremented by one depending on the state transition of the two- phase pulse that is input through PHCxIN0 and PHCxIN1 and has phase difference.

PHCNT has two compare registers, an interrupt is occurred when the up-and-down counter matches a compare register. And an interrupt is occurred at every counting.

The state transition of the two-phase pulse is shown as below.

| PHCxIN1 | PHCxIN0 | State |
|---------|---------|-------|
| 0       | 0       | 0     |
| 0       | 1       | 1     |
| 1       | 0       | 2     |
| 1       | 1       | 3     |

Table 14-2 The state of the two-phase input in normal mode and quadruple mode

The count operation of each mode is described below.

1. Normal mode

In normal mode, the up-and-down counter is increment or decrement when the state transition of the two-phase pulse changes at fourth count.

To avoid the miss counting, up-and-down counter is not increment or decrement until the set state is input after the clear state is input.

#### • Count up

When "2" is input at the previous clock and the current state is "3", the up-and-down counter is increment.

When "3" is input at the previous clock and the current state is "2", it is the clear state.

When "3" is input at the previous clock and the current state is "1", it is the set state.



Figure 14-2 Count up in normal mode

• Count down

When "1" is input at the previous clock and the current state is "3", the up-and-down counter is decrement.

When "3" is input at the previous clock and the current state is "1", it is the clear state. When "3" is input at the previous clock and the current state is "2", it is the set state.





#### 2. Quadruple mode

In quadruple mode, the up-and-down counter is increment or decrement when the state transition of the two-phase pulse changes once.

Count up

When "3" is input at the previous clock and the current state is "1", the up-and-down counter is increment.

When "1" is input at the previous clock and the current state is "0", the up-and-down counter is increment.

When "0" is input at the previous clock and the current state is "2", the up-and-down counter is increment.

When "2" is input at the previous clock and the current state is "3", the up-and-down counter is increment.



Figure 14-4 Count up in quadruple mode

• Count down

When "3" is input at the previous clock and the current state is "2", the up-and-down counter is decrement.

When "2" is input at the previous clock and the current state is "0", the up-and-down counter is decrement.

When "0" is input at the previous clock and the current state is "1", the up-and-down counter is decrement.

When "1" is input at the previous clock and the current state is "3", the up-and-down counter is decrement.

- 14. Two-phase pulse input counter (PHCNT)
- 14.5 Operation in Each Mode



Figure 14-5 Count down in quadruple mode

3. Multiplied by two mode

In multiplied by two mode, the up-and-down counter is increment when the state transition of either PHCxIN0 or PHCxIN1 changes once.

Count up

When "0" is input at the previous clock and the current state is "1", the up-and-down counter is increment.

When "1" is input at the previous clock and the current state is "0", the up-and-down counter is increment.



Cout up at every changing state

### Figure 14-6 Count up in multiplied by two mode

• Count down

In this mode, there is not count down state.

#### 14.5.2 Interrupt

The PHCNTx interrupt is enabled using the interrupt controller (NVIC).

1. Interrupt every count

INTPHEVRYx is occurred by increment or decrement.

In the interrupt service routine, it is possible to check for occurrences of an overflow and an underflow. If PHCxFLG<OVF> is "1", an overflow is occurred. If <UDF> is "1", an underflow is occurred. This register is cleared after it is written to "1".

2. Compare interrupt

INTPHTx0/1 is occurred by match up-and-down counter and compare register 0/1.

In the interrupt service routine, it is possible to check the register which is matched. If PHCxFLG<CMP0> is "1", the up-and-down counter matches a compare register 0. If <CMP1> is "1", the up-and-down counter matches a compare register 1. This register is cleared after it is written to "1".

### 14.5.3 Up-and-down counter

When the two-phase input count is started (PHCxRUN<PHCRUN> = "1"), the up-and-down counter value is counted from 0x7FFF which is an initial value. And the up-and-down counter value is initialized to 0x7FFF, when the PHCxRUN<PHCCLR> is set to "1".

If a counter overflow occurs, the counter returns to 0x0000. If a counter underflow occurs, the counter returns to 0xFFFF. After that, the counter continues the counting operation.

Therefore, overflow and underflow can be checked by reading the counter value and the status flag PHCxFLG after an interrupt is occurred.

Note: The reading the up-and-down counter should be read in a interrupt service routine of INTPHEVRYx.



Figure 14-7 Up count interrupt timing in Normal mode

# TOSHIBA

# 15. High Resolution 16-bit Timer/PPG Outputs (TMRD)

### 15.1 Outline

TMRD consists of two timer units (TMRD0 and TMRD1) and two clock setting circuits (prescalers) for supplying clocks to these timer units. The functions are as follows.

- 16-bit interval timer
- 16-bit programmable pulse generation (PPG)

16-bit interval timer has the following two modes.

- Timer mode that TMRD0 and TMRD1 operate independently.
- Interlock timer mode that can start TMRD0 and TMRD1 at the same time.

16-bit programmable pulse generation has the following two modes.

- · PPG mode that TMRD0 and TMRD1 independently output preprogrammed pulses.
- PPG mode that can change the phase releations between the pilse output by TMRD0 and that output by TMRD1 in the range from -180 degree to +180 degree.

TMRD consists of the clock setting circuit and two unit timers.

Figure 15-1 shows the clock setting and Figure 15-2 shows the block diagram of the timer unit.

In the following explanation of this section, "x" indicates a channel number.

# 15.2 Block Diagram



Figure 15-1 TMRD Clock Diagram





#### 15.2.1 Prescaler clock

TMRDCLK[1:0] is a prescaler clock to get the TMRD to work. After setting the input clock for the PLL circuit to the register CGPWMGEAR[5:4], the prescaler clock TMRDCLK[1:0] selects the source clock. The prescaler clock TMRD0 is set into the clock setting register TD0MOD[3:0] in the TMRD block, TMRD1 is set into the clock setting register TD1MOD[3:0].

Note: The maximum operating frequency is able to be provided to the TMRD is 160MHz. The configuration must not exceed this value.

#### 15.2.2 Timer unit (TMRD0, TMRD1)

As shown in the Figure 15-2, the timer unit (TMRD0) consists of the counter (UC0), six comparators (CP0m, m =0 to 5) and two waveform generating circuits (0 and 1). The other timer unit (TMRD1) consists of the counter (UC1), five comparators (CP1m, m=0 to 4) and two waveform generating circuits (2 and 3).

1. Counters (UC0/UC1)

UC0 and UC1 are the 16-bit binary counters which are counted up by the clocks (TMRDCLK0/ TMRDCLK1) output from the clock setting unit. These binary counters operate as free-run counters according to the values set in the registers TD0MOD<TDCLE>/TD1MOD<TDCLE>, or operate as the counters which are zero cleared if they match the value of the counter CP00 and the counter CP10. However, in interlock PPG mode, the counter UC1 operate as a counter that is zero cleared when the value of the UC1 matches that of the comparator CP05, not the value of the comparator CP10.

| UC0 : | TD0MOD <tdcle> = 0</tdcle> | Free-run counter                                                                                      |
|-------|----------------------------|-------------------------------------------------------------------------------------------------------|
|       | TD0MOD <tdcle> = 1</tdcle> | A counter that is zero cleared when the values of the binary counter UC0 and the counter CP00 match.  |
| UC1 : | TD1MOD <tdcle> = 0</tdcle> | Free-run counter                                                                                      |
|       | TD1MOD <tdcle> = 1</tdcle> | A counter that is zero cleared when the value of the binary counter UC1 matches that of CP10 or CP05. |

The binary counter UC0 and UC1 control the start and stop of the counters using the control signal TD0RUN and TD1RUN.

- UC0 :
   TD0RUN<TDRUN>= 0 :
   Counter Stop. Zero cleared.

   TD0RUN<TDRUN> = 1 :
   Operation of the counter starts.

   UC1 :
   TD1RUN<TDRUN> = 0 :
   Counter Stop. Zero cleared.

   TD1RUN<TDRUN> = 1 :
   Operation of the counter starts.
  - 2. Comparators (CPxm : x=0,1, x=0 : m=0 to 5, x=1 : m=0 to 4)

As shown in the Figure 15-3, comparators (CPxm) consist of a 16-bit width timer register (TDxRGm), 16-bit width compae register (TDxCPm) and a circuit to detect a match between the output value of the counter UCx and the values set in the TDxCPm (CPRGm[15:0]).

These comparators have a double-buffer scheme, which consists of TDxRGm and TDxCPm, and a path to write data to TDxCPm is selected according to the value of the register TDxCR<TDRDE>.

| TDxCR <tdrde> = 0 :</tdrde> | A value written to the TDxRGm is written to the TDxCPm at the same time.                                                                                                                          |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | However, since the register TDxCPm is a read-only register, direct write to this address with specified address is not possible. (The initial value can be set into the TDxCPm at random timing.) |
| TDxCR <tdrde> = 1 :</tdrde> | If the condition is that the update enable flag TDBCRx <tdsft> = 1, a value of the TDxRGm is written into the TDxCPm at the timing shown below.</tdsft>                                           |
| Update timing TMRD0 :       | At the timing of a detection signal output when the value matches the CP00.                                                                                                                       |
| TMRD1 :                     | At the timing of a detection signal output when the value matches the CP10.                                                                                                                       |
|                             | However, in the interlock PPG mode, at the timing of a detection signal output when the value matches the CP05.                                                                                   |

Figure 15-4 shows the waveform of the timing for writing a value of the TDxRGm to the TDxCPm when TDxCR<TDRDE> = 1.









3. Waveform generating circuit

The waveform generating circuits are pulse output circuits. They generate a leading edge signal at the timing a match is respectively detected for CP01/CP03/CP11/CP13, and a trailing edge signal at the timing a match is respectively detected for CP02/CP04/CP12/CP14. The polarity (rising/falling) of leading edge and trailing edge can be set into the register TD0MOD<TDIV[1:0]> and the register TD1MOD<TDIV[1:0]>.

### 15.3 Registers

### 15.3.1 Register list according to channel

The following table shows the register names and addresses of each channel.

| Channel x | Base Address |
|-----------|--------------|
| Channel0  | 0x4005_8000  |
| Channel1  | 0x4005_8100  |

| Register name(               | (x=0 to 1) |         | Address(Base+) |
|------------------------------|------------|---------|----------------|
| Timer RUN register           | TDxRUN     |         | 0x0000         |
| Timer Control register       | TDxCR      |         | 0x0004         |
| Timer Enable register        | TD0EN      | (Note1) | 0x0050         |
| Timer Configuration register | TD0CONF    | (Note1) | 0x0054         |
| Timer Mode register          | TDxMOD     |         | 0x0008         |
| Update flag set register     | TDxBCR     |         | 0x000C         |
| DMA request enable register  | TDxDMA     |         | 0x0010         |
| Timer register 0             | TDxRG0     |         | 0x0014         |
| Timer register 1             | TDxRG1     |         | 0x0018         |
| Timer register 2             | TDxRG2     |         | 0x001C         |
| Timer register 3             | TDxRG3     |         | 0x0020         |
| Timer register 4             | TDxRG4     |         | 0x0024         |
| Timer register 5             | TD0RG5     | (Note1) | 0x0028         |
| Compare register 0           | TDxCP0     |         | 0x002C         |
| Compare register 1           | TDxCP1     |         | 0x0030         |
| Compare register 2           | TDxCP2     |         | 0x0034         |
| Compare register 3           | TDxCP3     |         | 0x0038         |
| Compare register 4           | TDxCP4     |         | 0x003C         |
| Compare register 5           | TD0CP5     | (Note1) | 0x0040         |
| Reserved                     | -          |         | 0x0060         |

Base Address = 0x400F\_3000

| Register name              | Address(Base+) |        |
|----------------------------|----------------|--------|
| Timer clock setup register | CGPWMGEAR      | 0x0014 |

Note: Access to the "Reserved" area is prohibited.

Note:Access the registers by using word reads and word writes. Note 1: These registers do not have channel 1. 15.3 Registers

|             |    |    |     |      | ·  |    |    |           |
|-------------|----|----|-----|------|----|----|----|-----------|
|             | 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  | 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  | -  | -  | PWM | GEAR | -  | -  | -  | TMRDCLKEN |
| After reset | 0  | 0  | 1   | 1    | 0  | 0  | 0  | 0         |

### 15.3.2 CGPWMGEAR (Timer clock setup register)

| Bit  | Bit Symbol       | Туре | Function                                                                                                          |
|------|------------------|------|-------------------------------------------------------------------------------------------------------------------|
| 31-6 | -                | R    | Read as 0.                                                                                                        |
| 5-4  | PWMGEAR<br>[1:0] | R/W  | Select a source clock to input in the TMRD block.<br>00 : fpll<br>01 : fpll / 2<br>10 : fpll / 4<br>11 : Reserved |
| 3-1  | -                | R    | Read as 0.                                                                                                        |
| 0    | TMRDCLKEN        | R/W  | Disable or enable TMRDCLK to be provided to the TMRD.<br>0 : Stop (OFF)<br>1 : Operation (ON)                     |

Note:Clocks cannot be selected and provided at the same time. To use TMRD, select a source clock at <PWMGEAR[1:0]> in the condition that a clock is disabled<TMRDCLKEN>="0". Then, Set "1" to <TMRDCLKEN> to start providing a clock.

Note: If you try to change the setting of <PWMGEAR1:0>, set the TMRD first (<TMRDCLKEN>="0">.

|             | 31                 | 30 | 29     | 28 | 27 | 26 | 25 | 24 |
|-------------|--------------------|----|--------|----|----|----|----|----|
| bit symbol  | ol                 |    | -      | -  | -  | -  | -  | -  |
| 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  | 0  |
|             | 7                  |    | 5      | 4  | 3  | 2  | 1  | 0  |
| bit symbol  | symbol TDEN1 TDEN0 |    | TDHALT | -  | -  | -  | -  | -  |
| After reset | set 0 0            |    | 0      | 0  | 0  | 0  | 0  | 0  |

# 15.3.3 TD0EN (Timer Enable register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                           |
|------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                                         |
| 7    | TDEN1      | R/W  | Clock input to the TMRD1 is configured (ON/OFF).<br>0: Stop (OFF)<br>1: Operation (ON)                                                                             |
| 6    | TDEN0      | R/W  | Clock input to the TMRD0 is configured (ON/OFF).<br>0: Stop (OFF)<br>1: Operation (ON)                                                                             |
| 5    | TDHALT     | R/W  | Settings for the operation if a HALT instruction is executed during debugging.<br>0: Stop (Only an up counter stops)<br>1: Operation (An up counter does not stop) |
| 4-0  | -          | R    | Read as 0.                                                                                                                                                         |

15.3 Registers

|             | 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   | 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  | TDI2TD1 | TDI2TD0 | -  | -  | -  | TMRDMOD |     |    |
| After reset | 0       | 0       | 0  | 0  | 0  | 0       | 0 0 |    |

# 15.3.4 TD0CONF (Timer Configuration register)

| Bit  | Bit Symbol       | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -                | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7    | TDI2TD1          | R/W  | TMRD1 operation settings (ON/OFF) during the IDLE mode.<br>0: Stop (OFF)<br>1: Operation (ON)                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6    | TDI2TD0          | R/W  | TMRD0 operation settings (ON/OFF) during the IDLE mode.<br>0: Stop (OFF)<br>1: Operation (ON)                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5-3  | -                | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2-0  | TMRDMOD<br>[2:0] | R/W  | Operation mode settings for TMRD1 and TMRD0.<br>000 : TMRD0: Timer mode, TMRD1: timer mode<br>001 : TMRD0: Timer mode, TMRD1: PPG mode<br>010 : TMRD0: PPG mode, TMRD1: Timer mode<br>011 : TMRD0: PPG mode, TMRD1: PPG mode<br>100 : Timer mode that allows TMRD0 and TMRD1 to start simultaneously.<br>101 : Setting is prohibited.<br>110 : Setting is prohibited.<br>111 : Interlock PPG mode that allows TMRD0 and TMRD1 to operate in tandem.<br>(Phase relationships between pulse generated by TMRD1 and TMRD0 can be changed.) |

Note: In the condition of <TMRDMOD[2:0]>="111", TMRDCLK0 and TMRDCLK1 cannot be configured respectively; TMRDCLK1 and TMRDCLK0 have the same frequencies.

|             | 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  | 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  | TDIV1 | TDIV0 | -  | TDCLE | TDCLK |    |    |    |
| After reset | 0     | 0     | 0  | 0     | 0     | 0  | 0  | 0  |

# 15.3.5 TD0MOD (Timer mode register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                 |
|------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                               |
| 7    | TDIV1      | R/W  | Initial settings of leading edge/trailing edge of a signal a1                                                                            |
|      |            |      | 0: Rises when a value set in the CP03 matches a value in the counter, and falls when a value in the CP04 matches a value in the counter. |
|      |            |      | 1: Falls when a value set in the CP03 matches a value in the counter, and rises when a value in the CP04 matches a value in the counter. |
| 6    | TDIV0      | R/W  | Initial settings of leading edge/trailing edge of a signal a0                                                                            |
|      |            |      | 0: Rises when a value set in the CP01 matches a value in the counter, and falls when a value in the CP02 matches a value in the counter. |
|      |            |      | 1: Falls when a value set in the CP01 matches a value in the counter, and rises when a value in the CP02 matches a value in the counter. |
| 5    | -          | R    | Read as 0.                                                                                                                               |
| 4    | TDCLE      | R/W  | Selects the COUNTER0 (UC0) operation when the match signal of CP00 is generated.                                                         |
|      |            |      | 0: Operate as a free-run counter even if a match is detected.                                                                            |
|      |            |      | 1: Zero cleared if a match is detected.                                                                                                  |
| 3-0  | TDCLK[3:0] | R/W  | Selects a prescaler of TMRD0 (a frequency of TMRDCLK0).                                                                                  |
|      |            |      | 0000: ftmrd                                                                                                                              |
|      |            |      | 1000: ftmrd/2                                                                                                                            |
|      |            |      | 1001: ftmrd/4                                                                                                                            |
|      |            |      | 1010: ftmrd/8                                                                                                                            |
|      |            |      | 1011: ftmrd/16                                                                                                                           |
|      |            |      | Settings other than those shown above are prohibited.                                                                                    |

Note: In the PPG mode, the setting of <TDCLE>="0" becomes invalid. (Not operate as a free-run counter.)

15.3 Registers

|             | 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  | 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  | TDIV1 | TDIV0 | -  | TDCLE | TDCLK |    |    |    |  |
| After reset | 0     | 0     | 0  | 0     | 0     | 0  | 0  | 0  |  |

## 15.3.6 TD1MOD (Timer mode register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                 |
|------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                               |
| 7    | TDIV1      | R/W  | Initial settings of leading edge/trailing edge of a signal b1                                                                            |
|      |            |      | 0: Rises when a value set in the CP13 matches a value in the counter, and falls when a value in the CP14 matches a value in the counter. |
|      |            |      | 1: Falls when a value set in the CP13 matches a value in the counter, and rises when a value in the CP14 matches a value in the counter. |
| 6    | TDIV0      | R/W  | Initial settings of leading edge/trailing edge of a signal b0                                                                            |
|      |            |      | 0: Rises when a value set in the CP11 matches a value in the counter, and falls when a value in the CP12 matches a value in the counter. |
|      |            |      | 1: Falls when a value set in the CP11 matches a value in the counter, and rises when a value in the CP12 matches a value in the counter. |
| 5    | -          | R    | Read as 0.                                                                                                                               |
| 4    | TDCLE      | R/W  | Selects the COUNTER1 (UC1) operation when the match signal of CP10 is generated.                                                         |
|      |            |      | 0: Operate as a free-run counter even if a match is detected.                                                                            |
|      |            |      | 1: Zero cleared if a match is detected.                                                                                                  |
| 3-0  | TDCLK[3:0] | R/W  | Selects a prescaler of TMRD1 (a frequency of TMRDCLK1).                                                                                  |
|      |            |      | 0000: ftmrd                                                                                                                              |
|      |            |      | 1000: ftmrd/2                                                                                                                            |
|      |            |      | 1001: ftmrd/4                                                                                                                            |
|      |            |      | 1010: ftmrd/8                                                                                                                            |
|      |            |      | 1011: ftmrd/16                                                                                                                           |
|      |            |      | Settings other than those shown above are prohibited.                                                                                    |

Note: In the PPG mode, the setting of <TDCLE>="0" becomes invalid. (Not operate as a free-run counter.) Also in the interlock PPG mode, the settings of <TDCLE> bit become invalid.

Note: In the interlock PPG mode, the values set in the TD0MOD are selected as the values for <TDCLK[3: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  | -  | -  | -  | -  | -  | -     | -  | -   |
| 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  | 0   |
|             | 7  | 6  | 5  | 4  | 3  | 2     | 1  | 0   |
| bit symbol  | -  | -  | -  | -  | -  | TDRDE | TD | ISO |
| After reset | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0   |

# 15.3.7 TD0CR (Timer control register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                 |
|------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3 | -          | R    | Read as 0.                                                                                                                                                                               |
| 2    | TDRDE      | R/W  | Sets a write path to the compare register (TD0CPm) of the TMRD0. (m = 0, 1, 2, 3, 4, 5)                                                                                                  |
|      |            |      | 0: Directly written to the compare register by CPU instructions.                                                                                                                         |
|      |            |      | At the time when data is written into the timer register (TD0RGm), the same value is written to the                                                                                      |
|      |            |      | corresponding compare register (TD0CPm) simultaneously. In this case, it is not neccesary for an enable flag to update of TD0BCR <tdsft> to set to "1".</tdsft>                          |
|      |            |      | 1: Write via the timer register (TD0RGm) of the TMRD0.                                                                                                                                   |
|      |            |      | TD0BCR <tdfst>="1" is required.</tdfst>                                                                                                                                                  |
|      |            |      | In the timer mode:                                                                                                                                                                       |
|      |            |      | TD0MOD <tdcle>="0": A value in the compare register (TD0CPm) is updated to the value of the timer</tdcle>                                                                                |
|      |            |      | register (TD0RGm) when the COUNTER0 (UC0) overflows.                                                                                                                                     |
|      |            |      | TD0MOD <tdcle>="1": A value in the compare register (TD0CPm) is updated to the value of the timer</tdcle>                                                                                |
|      |            |      | register (TD0RGm) when the value set in the comparator 00 (CP00) matches the                                                                                                             |
|      |            |      | value in the counter.                                                                                                                                                                    |
|      |            |      | In the PPG mode or the interlock PPG mode:                                                                                                                                               |
|      |            |      | When the value set in the comparator 00 (CP00) matches the value in the counter, the value in the com-<br>pare register (TD0CPm) is updated to the value in the timer register (TD0RGm). |
| 1-0  | TDISO[1:0] | R/W  | Selects the interrupt factor of INTTD0CMP0.                                                                                                                                              |
|      |            |      | 00: No interrupt factor.                                                                                                                                                                 |
|      |            |      | 01: A match signal from CP00                                                                                                                                                             |
|      |            |      | 10: A match signal from CP05.                                                                                                                                                            |
|      |            |      | 11: Overflow of COUNTER0 (UC0). (In the PPG mode, this setting is invalid as an interrupt factor.)                                                                                       |

15.3 Registers

|             | 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  | 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  | -  | -  | -  | -  | -  | TDRDE | TD | ISO |
| After reset | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0   |

# 15.3.8 TD1CR (Timer control register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                        |
|------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3 | -          | R    | Read as 0.                                                                                                                                                      |
| 2    | TDRDE      | R/W  | Sets a write path to the compare register (TD1CPm) of the TMRD1. (m = 0, 1, 2, 3, 4)<br>0: Directly written to the compare register by CPU instructions.        |
|      |            |      | At the time when data is written into the timer register (TD1RGm), the same value is written to the                                                             |
|      |            |      | corresponding compare register (TD1CPm) simultaneously. In this case, it is not neccesary for an enable flag to update of TD1BCR <tdsft> to set to "1".</tdsft> |
|      |            |      | 1: Write via the timer register (TD1RGm) of the TMRD1.                                                                                                          |
|      |            |      | TD1BCR <tdfst>="1" is required.</tdfst>                                                                                                                         |
|      |            |      | In the timer mode:                                                                                                                                              |
|      |            |      | TD1MOD <tdcle>="0": A value in the compare register (TD1CPm) is updated to the value of the timer</tdcle>                                                       |
|      |            |      | register (TD1RGm) when the COUNTER1 (UC1) overflows.                                                                                                            |
|      |            |      | TD0MOD <tdcle>="1": A value in the compare register (TD1CPm) is updated to the value of the timer</tdcle>                                                       |
|      |            |      | register (TD1RGm) when the value set in the comparator 10 (CP10) matches the                                                                                    |
|      |            |      | value in the counter.                                                                                                                                           |
|      |            |      | In the PPG mode or the interlock PPG mode:                                                                                                                      |
|      |            |      | In the PPG mode, when the value set in the comparator 10 (CP10) matches the value in the counter,                                                               |
|      |            |      | the value in the compare register (TD1CPm) is updated to the value of the timer register (TD1RGm).                                                              |
|      |            |      | In the interlock mode, the value set in the comparator 05 (CP05) matches the value in the compare register,                                                     |
|      |            |      | the value of the compare register (TD1CPm) is updated to the value of the timer register (TD1RGm).                                                              |
| 0    | TDISO[1:0] | R/W  | Selects the interrupt factor of INTTD1CMP0.                                                                                                                     |
|      |            |      | 00: No interrupt factor.                                                                                                                                        |
|      |            |      | 01: CP10 match signal (Invalid as an interrupt factor in the interlock PPG mode)                                                                                |
|      |            |      | 10: No interrupt factor.                                                                                                                                        |
|      |            |      | 11: Overflow of COUNTER1 (UC1). (In the PPG mode, this setting is invalid as an interrupt factor.)                                                              |

Note: In the interlock PPG mode, the values set in the TD0CR are selected as the values for <TDRDE>.

|             | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | TDRUN |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     |

## 15.3.9 TDxRUN (Timer run register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                        |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                                                                                                                      |
| 1    | -          | W    | Always write 0.                                                                                                                                 |
| 0    | TDRUN      | W    | Controls the count operation of TMRDx.<br>0: Stops the count operation of TMRDx.<br>(Stops the operation of COUNTERx (UCx) and zero clears it.) |
|      |            |      | 1: Starts the count operation of TMRDx.<br>(Starts the operation of COUNTERx (UCx) (count up).)                                                 |

Note:As for TD1RUN<TDRUN>, the settings become invalid in both the interlock timer mode and interlock PPG mode, and starts operation in tandem with COUNTER0 (UC0).

15.3 Registers

|             | 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      | 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  | -  | -  | -  | -  | -  | -  | PHSCHG | TDSFT |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0     |

## 15.3.10 TD0BCR (Update flag setting register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                               |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                                                                                                                                                                                                             |
| 1    | PHSCHG     | R/W  | Sets the phase relation (delay/fast) of the phase B to the phase A.<br>0: Delay or same phase<br>1: Fast or same phase                                                                                                                 |
| 0    | TDSFT      | W    | An enable flag to update the compare register with the value of the timer register TMRD0. When the data in the compare register is updated, an update enable flag bit <tdsft> is cleared.<br/>0: Invalid<br/>1: Update enabled</tdsft> |

Note:For the update timing of <TDSFT>, please refer to the section writing about TD0CR<TDRDE>.

Note:<PHSCHG> is valid only in the interlock PPG mode. (The output of the phase A and the phase B cannot be switched in the timer mode, the interlock timer mode and the PPG mode.)

|             | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | TDSFT |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     |

## 15.3.11 TD1BCR (Update flag setting register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                               |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                                                                                                                                                                                                             |
| 1    | -          | R/W  | Always write 0.                                                                                                                                                                                                                        |
| 0    | TDSFT      | W    | An enable flag to update the compare register with the value of the timer register TMRD1. When the data in the compare register is updated, an update enable flag bit <tdsft> is cleared.<br/>0: Invalid<br/>1: Update enabled</tdsft> |

Note:For the update timing of <TDSFT>, please refer to the section writing about TD1CR<TDRDE>.

Note: In the interlock PPG mode, when TD0BCR<TDSFT> is written to "1", TD1BCR<TDSFT> is set to "1" at the same time. Do not write to this register. And this bit is zero cleared when a match of compare register 05 (CP05) is detected.

| 15.3 Registers |  |
|----------------|--|
|----------------|--|

|             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    |
|-------------|----|----|----|----|----|----|----|-------|
|             | 51 |    | 29 | 20 | 21 | 20 | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | DMAEN |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     |

# 15.3.12 TDxDMA (DMA request enable register)

| Bit  | Bit Symbol | Туре | Function                                                                                                           |
|------|------------|------|--------------------------------------------------------------------------------------------------------------------|
| 31-5 | -          | R    | Read as 0.                                                                                                         |
| 4-1  | -          | R/W  | Always write 0.                                                                                                    |
| 0    | DMAEN      | R/W  | Sets the DMA request enable/disable. (INTTDxCMP0 is a factor to generate a DMArequest.)<br>1: Enable<br>0: Disable |

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    | -  | TDI | RG0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | TDI | RG0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

# 15.3.13 TDxRG0 (Timer register 0)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                    |
|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                  |
| 15-0  | TDRG0[15:0] | R/W  | The timer register TDxRG0 is double-buffered with the compare register TDxCP0. The setting of the com-<br>pare register is performed on the timer register. |

## 15.3.14 TDxCP0 (Timer compare 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  | -  | -  | -  | -   | -   | -  | -  | -  |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | CPI | RG0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | CPI | RG0 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

| Bit   | Bit Symbol  | Туре | Function                                                                                                       |
|-------|-------------|------|----------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                     |
| 15-0  | CPRG0[15:0] | R    | Frequency cycle setting register: The minimum setting value is 0x0001 and the maximum setting value is 0xFFFF. |
|       |             |      | In the 16-bit interval timer: Sets the match timing of CPx0 or sets the timer frequency.                       |
|       |             |      | In the 16-bit PPG: Sets the frequency of the pulse output. However, in the interlock PPG mode, TD1CP0 is       |
|       |             |      | not used as a frequency cycle setting register.                                                                |

15.3 Registers

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | TDI | RG1 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | TDI | RG1 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

# 15.3.15 TDxRG1 (Timer register 1)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                    |
|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                  |
| 15-0  | TDRG1[15:0] | R/W  | The timer register TDxRG1 is double-buffered with the compare register TDxCP1. The setting of the com-<br>pare register is performed on the timer register. |

## 15.3.16 TDxCP1 (Timer compare 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  | -  | -  | -  | -   | -   | -  | -  | -  |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | CPI | RG1 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | CPI | RG1 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

| Bit   | Bit Symbol  | Туре | Function                                                                                |  |  |  |
|-------|-------------|------|-----------------------------------------------------------------------------------------|--|--|--|
| 31-16 | -           | R    | Read as 0.                                                                              |  |  |  |
| 15-0  | CPRG1[15:0] | R    | ning setting register:                                                                  |  |  |  |
|       |             |      | In the 16-bit interval timer: Sets a timing to generate an interrupt signal INTTDxCMP1. |  |  |  |
|       |             |      | In the 16-bit PPG: Sets a timing of a leading edge of a signal a0/b0.                   |  |  |  |

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | TDI | RG2 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | TDI | RG2 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

# 15.3.17 TDxRG2 (Timer register 2)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                    |
|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                  |
| 15-0  | TDRG2[15:0] | R/W  | The timer register TDxRG2 is double-buffered with the compare register TDxCP2. The setting of the com-<br>pare register is performed on the timer register. |

## 15.3.18 TDxCP2 (Timer compare 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  | 0  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | CPI | RG2 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | CPI | RG2 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

| Bit   | Bit Symbol  | Туре | Function                                                                                |
|-------|-------------|------|-----------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                              |
| 15-0  | CPRG2[15:0] | R    | Timing setting register:                                                                |
|       |             |      | In the 16-bit interval timer: Sets a timing to generate an interrupt signal INTTDxCMP2. |
|       |             |      | In the 16-bit PPG: Sets a timing of a trailing edge of a signal a0/b0.                  |

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | TDI | RG3 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | TDI | RG3 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

# 15.3.19 TDxRG3 (Timer register 3)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                    |
|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                  |
| 15-0  | TDRG3[15:0] | R/W  | The timer register TDxRG3 is double-buffered with the compare register TDxCP3. The setting of the com-<br>pare register is performed on the timer register. |

## 15.3.20 TDxCP3 (Timer compare 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  | -  | -  | -  | -   | -   | -  | -  | -  |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | CPI | RG3 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | CPI | RG3 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

| Bit   | Bit Symbol  | Туре | Function                                                                                |
|-------|-------------|------|-----------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                              |
| 15-0  | CPRG3[15:0] | R    | Timing setting register:                                                                |
|       |             |      | In the 16-bit interval timer: Sets a timing to generate an interrupt signal INTTDxCMP3. |
|       |             |      | In the 16-bit PPG: Sets a timing of a leading edge of a signal a1/b1.                   |

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    | -  | TDI | RG4 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | TDI | RG4 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

# 15.3.21 TDxRG4 (Timer register 4)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                    |
|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                  |
| 15-0  | TDRG4[15:0] | R/W  | The timer register TDxRG4 is double-buffered with the compare register TDxCP4. The setting of the com-<br>pare register is performed on the timer register. |

## 15.3.22 TDxCP4 (Timer compare 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  | -  | -  | -  | -   | -   | -  | -  | -  |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | CPI | RG4 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | CPI | RG4 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                                                      |
|-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                                                    |
| 15-0  | CPRG4[15:0] | R    | Timing setting register:<br>In the 16-bit interval timer: Sets a timing to generate an interrupt signal INTTDxCMP4.<br>In the 16-bit PPG: Sets a timing of a trailing edge of a signal a1/b1. |

15.3 Registers

|             | 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  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | TDI | RG5 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | TDI | RG5 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

# 15.3.23 TD0RG5 (Timer register 5)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                    |
|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                  |
| 15-0  | TDRG5[15:0] | R/W  | The timer register TD0RG5 is double-buffered with the compare register TD0CP5. The setting of the com-<br>pare register is performed on the timer register. |

## 15.3.24 TD0CP5 (Timer compare 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  | -  | -  | -  | -   | -   | -  | -  | -  |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  |
| bit symbol  |    |    |    | CPI | RG5 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| bit symbol  |    |    |    | CPI | RG5 |    |    |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                                                                                       |
|-------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -           | R    | Read as 0.                                                                                                                                                                                                                     |
| 15-0  | CPRG5[15:0] | R    | Register to set timing and width of phase shift:<br>In the 16-bit interval timer: Sets a match timing of the CP05.<br>In the 16-bit PPG: Sets the width of phase shift in the interlock PPG mode.<br>(Invalid in the PPG mode) |

### 15.4 Operation mode

Modes of the TMRD can be set into the register TD0CONF<TMRDMOD[2:0]>. The correlation between the setting value of the register and operation modes of the timer units will be found in the chapter of the register. The operations of the modes are described below.

Hereinafter, numbers in the names of circuit elements in timer units and registers are collectively described as "x" and "m". e.g. CPxm, UCx, TDxRGm and TDxCPm.

In this document, unless otherwise noted, x = 0,1. When x = 0, m = 0 to 5, when x = 1, m = 0 to 4.

### 15.4.1 16-bit interval timer

#### 15.4.1.1 Timer mode

In timer mode, the timer TMRD0 and the timer TMRD1 operate independently. Since the operation of the timer TMRD0 is the same as the timer TMRD1, this section describes the TMRD0 only.

If the value of the register TD0MOD<TDCLE> is "0", the counter UC0 operates as a free-run counter, which starts counting up from 0x0000, and returns to 0x0000 when it counts up to 0xFFFF. It generates an overflow interrupt (UC00VF) if the count value becomes 0xFFFF.

If the value of the register TD0MOD<TDCLE> is "1", the counter UC0 starts counting up from 0x0000, and returns to 0x0000 if the count value matches the value set in the compare register (TD0CP0) of the comparator. The timer cycle is configured by the comparator CP00.

In either case, each comparator (CPxm) generates a timer interrupt if the count value of the UC0 matches the value set in the each compare register (TD0CPm).

#### 15.4.1.2 Interlock timer (synchronization start) mode

This mode is a timer mode that can start the timer TMRD0 and TMRD1 at the same time. The two counters UC0 and UC1 are started simultaneously by setting the register TD0RUN<TDRUN> to "1". In this mode, the values set in the register TD1RUN<TDRUN> are ignored for starting and stopping the timers. However, the timer cycle of the timer TMRD0 and TMRD1 can be respectively set.

#### 15.4.1.3 Timer interrupt

Table 15-1 shows the relation of timer interrupt signals and factors.

Interrupt factors of INTTD0CMP0 is configured by a value of the register TD0CR<TDISO[1:0]>, and INTTD1CMP0 is configured by a value of the register TD1CR<TDISO[1:0]>.

| Table 15-1 Timer mode interrupts and factors. |
|-----------------------------------------------|
|-----------------------------------------------|

|            | Interrupts                             | Factors                                      |  |  |
|------------|----------------------------------------|----------------------------------------------|--|--|
|            |                                        |                                              |  |  |
|            | TD0CR <tdiso[1:0]> = "00"</tdiso[1:0]> | No factors                                   |  |  |
| INTTD0CMP0 | TD0CR <tdiso[1:0]> = "01"</tdiso[1:0]> | A match detected by the comparator 00 (CP00) |  |  |
|            | TD0CR <tdiso[1:0]> = "10"</tdiso[1:0]> | A match detected by the comparator 05(CP05)  |  |  |
|            | TD0CR <tdiso[1:0]> = "11"</tdiso[1:0]> | Overflow of the counter 0(UC0).              |  |  |
| INTTD0CMP1 |                                        | A match detected by the comparator 01(CP01)  |  |  |
| INTTD0CMP2 |                                        | A match detected by the comparator 02(CP02)  |  |  |
| INTTD0CMP3 |                                        | A match detected by the comparator 03(CP03)  |  |  |
| INTTD0CMP4 |                                        | A match detected by the comparator 04(CP04)  |  |  |
|            | TD1CR <tdiso[1:0]> = "00"</tdiso[1:0]> | No factors                                   |  |  |
|            | TD1CR <tdiso[1:0]> = "01"</tdiso[1:0]> | A match detected by the comparator 10(CP10)  |  |  |
| INTTD1CMP0 | TD1CR <tdiso[1:0]> = "10"</tdiso[1:0]> | No factors                                   |  |  |
|            | TD1CR <tdiso[1:0]> = "11"</tdiso[1:0]> | Overflow of the counter 1 (UC1)              |  |  |
| INTTD1CMP1 |                                        | A match detected by the comparator 11(CP11)  |  |  |
| INTTD1CMP2 |                                        | A match detected by the comparator 12(CP12)  |  |  |
| INTTD1CMP3 |                                        | A match detected by the comparator 13(CP13)  |  |  |
| INTTD1CMP4 |                                        | A match detected by the comparator 14(CP14)  |  |  |

Note: In 16-bit programmable pulse generation output mode, interrupt factors do not occur in the below conditions.

- Overflow interrupt factors in the counter UC0 and UC1.
- The factor that the detection of a match between the counter and the comparator CP10 in inter-lock PPG mode.

#### 15.4.1.4 Registger configuration process in timer mode

#### (1) Process to start up

- (1-1) Timer mode
  - Follow the following steps to configure the register settings before starting the timer mode.
  - a. Select a clock to be provided
    - 1. Select a clock to be provided to the TMRD and set it to the register CGPWMGEAR<PWMGEAR[1:0]>.
    - 2. Set the register CGPWMGEAR<TMRDCLKEN> to "1" to enable providing a clock to the TMRD. Be sure to set the <TMRDCLKEN> after setting the value of <PWMGEAR[1:0]>.
  - b. Select operation modes of timer units
    - 1. Set the timer unit to be used in the timer mode to the register TD0CONF<TMRDMOD[2:0]>. Simultaneuosly, set the operation status of the timer unit used in the IDLE mode to <TDI2TD1> and <TDI2TD0> of the same register TD0CONF.
  - c. Select clocks to be used in the timer units (TMRD0/TMRD1).
    - 1. Set "1" to the bit <TDEN1> and <TDEN0> of the register TD0EN which disables and enables a clock signal to be provided to the timer unists. (It's not necessary to configure timer units which don't need to be enabled.)
    - 2. Select a clock to be used in timer units and set it to the register TDxMOD<TDCLK[3:0]>.
    - Simultaneously, set the operation status of the counters used in in the timer mode to the register TDxMOD<TDCLE>.
  - d. Initial settings of timer registers and compare rgisters
    - 1. Set "0" to <TDRDE> of the register TDxCR to write to the compare register in the direct write mode. (It's a mode that the same data is written to the corresponding compare register when data is written to the timer register.) Set an interrupt factor of the INTTDxCMPm into the register TDxCR<TDISO[1:0]>.
    - Set a required value to timer register (TDxRGm).
       In the mode which condition is TDxCR<TDRDE> = "0", an operation to set "1" to the register TDxBCR<TDSFT> and an update timing signal are not required.
  - e. Start the timer mode
    - 1. Set "1" to <TDRDE> of the register TDnCR to enable writing data through the timer register to the compare register. (The value of the timer register is written into the corresponding timer register at the predefined update time in this mode.)
    - 2. Start the timer mode by setting "1" to <TDRUN> of the register TDxRUN.
- (1-2) Interlock timer mode

Follow the following steps to configure the register settings before starting the interlock timer mode.

- a. Select a clock to be provided
  - 1. Select a clock to be provided to the TMRD and set it to the register CGPWMGEAR<PWMGEAR[1:0]>.
  - Set the register CGPWMGEAR<TMRDCLKEN> to "1" to enable providing a clock to the TMRD. Be sure to set the <TMRDCLKEN> after setting the value of <PWMGEAR[1:0]>.
- b. Select operation modes of timer units
  - 1. Set the timer unit to be used in the timer mode to the register TD0CONF<TMRDMOD[2:0]>. Simultaneuosly, set the operation status of the timer unit used in the IDLE mode to <TDI2TD1> and <TDI2TD0> of the same register TD0CONF.
- c. Select clocks to be used in the timer units (TMRD0/TMRD1).
  - 1. Set "1" to both bits of <TDEN1> and <TDEN0> in the register TD0EN. The register TD0EN enables and disables providing clocks to the two timer units. (Be sure to set both <TDEN1> and <TDEN0>.)
  - 2. Select a clock to be used in timer units and set it to the register TDxMOD<TDCLK[3:0]>.
  - Simultaneously, set the operation status of the counters used in in the timer mode to the register TDxMOD<TDCLE>.
- d. Initial settings of timer registers and compare rgisters
  - 1. Set "0" to <TDRDE> of the register TDxCR to write to the compare register in the direct write mode. (It's a mode that the same data is written to the corresponding compare register when data is written to the timer register.) Set an interrupt factor of the INTTDxCMPm into the register TDxCR<TDISO[1:0]>.
  - Set a required value to timer register (TDxRGm).
     In the mode which condition is TDxCR<TDRDE> = 0, an operation to set "1" to the register TDxBCR<TDSFT> and an update timing signal are not required.
- e. Start the timer mode
  - 1. Set "1" to <TDRDE> of the register TDnCR to enable writing data through the timer register to the compare register. (The value of the timer register is written into the corresponding timer register at the predefined update time in this mode.)
  - 2. Set "1" to <TDRUN> of the register TD0RUN, start two timer units at the same time. Since the mode is a interlock timer mode, settings to the register TD1RUN<TDRUN> is not required.

#### (2) Configuration after starting the timer modes

(2-1) Timer mode and interlock timer mode

To set the register after starting the timer mode, make settings in the following procedures.

a. Update values of timer registers and compare registers

- 1. Set an arbitrary value to timer register (TDxRGm) corresponding to the compare register to be updated.
- 2. After the above setting is done, set "1" to register TDxBCR<TDSFT> which is corresponding to the timer unit to be updated.

With the above settings, a value in a timer register is set in the corresponding compare register at the predefined update timing. (See Figure 15-4)

Note: Registers which can be configured when the timer is running are the following three registers: (TDxRGm), (TDxBCR) and (TDxRUN). Other registers must be configured when the timer is being stopped.

#### 15.4.1.5 Setting range of compare registers

The setting range of the compare registers in 16-bit interval timer mode is shown in the Table 15-2.

| Timor Unit | Compare  | 16-bit interval timer               |                                          |  |  |  |
|------------|----------|-------------------------------------|------------------------------------------|--|--|--|
| Timer Unit | register | <tdcle> = "0"</tdcle>               | <tdcle> = "1"</tdcle>                    |  |  |  |
|            | TD0CP0   | 0x0000 ≤ CPRG0[15:0] ≤ 0xFFFF       | 0x0001 ≤ CPRG0[15:0] ≤ 0xFFFF            |  |  |  |
|            | TD0CP1   | 0x0000 ≤ CPRG1[15:0] ≤ 0xFFFF       | $0x0000 \le CPRG1[15:0] \le CPRG0[15:0]$ |  |  |  |
| TMRD0      | TD0CP2   | $0x0000 \le CPRG2[15:0] \le 0xFFFF$ | $0x0000 \le CPRG2[15:0] \le CPRG0[15:0]$ |  |  |  |
| TIVIRDU    | TD0CP3   | 0x0000 ≤ CPRG3[15:0] ≤ 0xFFFF       | 0x0000 ≤ CPRG3[15:0] ≤ CPRG0[15:0]       |  |  |  |
|            | TD0CP4   | $0x0000 \le CPRG4[15:0] \le 0xFFFF$ | $0x0000 \le CPRG4[15:0] \le CPRG0[15:0]$ |  |  |  |
|            | TD0CP5   | $0x0000 \le CPRG5[15:0] \le 0xFFFF$ | $0x0000 \le CPRG5[15:0] \le CPRG0[15:0]$ |  |  |  |
|            | TD1CP0   | 0x0000 ≤ CPRG0[15:0] ≤ 0xFFFF       | 0x0001 ≤ CPRG0[15:0] ≤ 0xFFFF            |  |  |  |
|            | TD1CP1   | 0x0000 ≤ CPRG1[15:0] ≤ 0xFFFF       | 0x0000 ≤ CPRG1[15:0] ≤ CPRG0[15:0]       |  |  |  |
| TMRD1      | TD1CP2   | $0x0000 \le CPRG2[15:0] \le 0xFFFF$ | $0x0000 \le CPRG2[15:0] \le CPRG0[15:0]$ |  |  |  |
|            | TD1CP3   | 0x0000 ≤ CPRG3[15:0] ≤ 0xFFFF       | $0x0000 \le CPRG3[15:0] \le CPRG0[15:0]$ |  |  |  |
|            | TD1CP4   | $0x0000 \le CPRG4[15:0] \le 0xFFFF$ | $0x0000 \le CPRG4[15:0] \le CPRG0[15:0]$ |  |  |  |

Table 15-2 Setting range of the compare registers in 16-bit interval timer mode

If the frequency of TMRDCLK is f<sub>CLK</sub>, a timer cycle Tx can be obtained using the following equation :

- 1. If  $\langle TDCLE \rangle = 0$ ,  $Tx = (1/f_{CLK}) \times 2^{16}$
- 2. If <TDCLE> = 1, Tx =  $(1/f_{CLK}) \times (TDxCP0 < CPRG0[15:0]> + 1)$

### 15.4.2 16-bit programmable pulse generation output

#### 15.4.2.1 PPG mode

In PPG (Programmable Pulse Generator) mode, TMRD0 and TMRD1 operate independently, and these timers can output a pulse with a programmable frequency and a duty cycle.

Pulse output of TMRD0: a0, a1, Pulse output of TMRD1: b0, b1

#### (1) Cycle of a pulse generation (PPG) output

The cycle of pulse ouput (a0/a1) of TMRD0 is configured with the value of the compare register TD0CP0<CPRG0[15:0]> of CP00. As shown in the Figure 15-5, UC0 operates, like a timer mode, as a counter which is zero cleared when a match signal is output by CP00.



### Figure 15-5 The cycle of a square-wave output in PPG mode

The cycle of a pulse output (b0/b1) of TMRD1 is also configured by the value of the compare register (TD1CP0<CPRG0[15:0]>) of CP10.

#### (2) Duty cycle of a pulse generation (PPG) output

As for TMRD0, a leading edge of the pulse output a0 is generated when a match signal of CP01 is detected and a trailing edge is generated when a match signal of CP02 is detected, as shown in the Figure 15-6. These leading edge and trailing edge are generated the pulse outputs.

Equally, a leading edge of the pulse output a1 is generated when a match signal of CP03 is detected and a trailing edge is generated when a match signal of CP04 is detected. These leading edge and trailing edge are generated the pulse outputs.

Square-wave output a0

154

Operation mode

#### Figure 15-6 Square-wave output in PPG mode (when square-wave output is a a0)

Figure 15-6 shows that a leading edge is a rising waveform and a trailing edge is a falling waveform. Switching the waveforms is possible by setting the register TD0MOD<TDIV[1:0]>; a leading edge is to be a falling waveform and a trailing edge is to be a rising waveform.

As for TMRD1, a leading edge of a pulse output b0 is generated by detecting a match signal of CP11, and a trailing edge is generated by detecting a match signal of CP12. A leading edge of a pulse output b1 is generated by detecting a match signal of CP13, and a trailing edge is generated by detecting a match signal of CP14.

Also in PPG mode, the control signal PHSCHGSW of SW0/SW1/SW2/SW3 is fixed to "0". Signals from TMRD0 are output only through SW0 and SW1. Signals from TMRD1 are output only through SW2 and SW3. The description is shown in "Figure 15-2 TMRD Unit Block Diagram".

#### (3) Start timing of pulse generation (PPG) output

Pulse generation (PPG) output starts by writing "1" to the register TDxRUN<TDRUN>. Figure 15-7 shows that the arbitrary pulse can be generated from the first cycle even a leading edge is set to rise/fall as the operation starts. Although the figure below shows the case of a0, a1 and b0/b1 are the same. The figure below shows the timing in the condition  $\langle CPRG1[15:0] \rangle = "0"$ .



(1) If a leading edge is specified as a rising waveform



(2) If a leading edge is specified as a falling waveform

Figure 15-7 Timing Chart at the start of operation (when square-wave output is a0)

#### (4) Configuration of the register in PPG mode

(4-1) Process to start up PPG mode

Register settings to start up PPG mode are made in the following steps.

a. Select a clock to be provided

- 1. Select a clock to be provided to the TMRD and set it to the register CGPWMGEAR<PWMGEAR[1:0]>.
- 2. Set the register CGPWMGEAR<TMRDCLKEN> to "1" to enable providing a clock to the TMRD. Be sure to set the <TMRDCLKEN> after setting the value of <PWMGEAR[1:0]>.
- b. Select operation modes of timer units
  - Set the timer unit to be used in the PPG mode to the register TD0CONF<TMRDMOD[2:0]>. Simultaneuosly, set the operation status of the timer unit used in the IDLE mode to <TDI2TD1> and <TDI2TD0> of the same register TD0CONF.
- c. Select clocks to be used in the timer units (TMRD0/TMRD1).
  - 1. Set "1" to the bit <TDEN1> and <TDEN0> of the register TD0EN which disables and enables a clock signal to be provided to the timer unists. (It's not necessary to configure timer units which don't need to be enabled.)
  - Select a clock to be used in timer units and set it to the register TDxMOD<TDCLK[3:0]>.
     At the same time, configure <TDIV[1:0]> in the same register which specify the leading edge and trailing edge of the pulse output.
- d. Initial settings of timer registers and compare rgisters
  - 1. Set "0" to <TDRDE> of the register TDxCR to write to the compare register in the direct write mode. (It's a mode that the same data is written to the corresponding compare register when data is written to the timer register.)
  - Set a required value to timer register (TDxRGm).
     In the mode that <TDRDE> of the register TDxCR is set to "0", neither the operation to set "1" to <TDSFT> of the register TDxBCR nor an update timing signal.
- e. Start the PPG mode
  - 1. Set "1" to <TDRDE> of the register TDnCR to enable writing data through the timer register to the compare register. (The value of the timer register is written into the corresponding timer register at the predefined update time in this mode.)
  - 2. Start the PPG mode by setting "1" to <TDRUN> of the register TDxRUN.

#### (4-2) Process after starting the PPG mode

To set the register after starting the PPG mode, make settings in the following procedures.

a. Update values of timer registers and compare registers

- 1. Set an arbitrary value to timer register (TDxRGm) corresponding to the compare register to be updated.
- 2. After the above setting is done, set "1" to register TDxBCR<TDSFT> which is corresponding to the timer unit to be updated.

With the above settings, a value in a timer register is set in the corresponding compare register at the predefined update timing. (See Figure 15-4)

b. Stops the pulse generation output.

1. To stop a pulse output from timer units, set "0" to <TDRUN> of the register TDxRUN.

Note: Registers which can be configured when the PPG is running are the following three registers: (TDxRGm), (TDxBCR) and (TDxRUN). Other registers must be configured when the timer is being stopped.

#### 15.4.2.2 Interlock PPG mode

In this mode, the phase relation between a pulse (a0/a1) output by TMRD0 and a pulse (b0/b1) output by TMRD1 can be dynamically specified in the following range: -180 degree  $< \theta < +180$  degree.

However, the phase relation between a0 and b0 and that between a1 and b1 are the same.

#### (1) Operation Outline

In this mode, the phase relation between the phase-A output which is output by SW0/SW1 and the phase-B output which is output by SW2/SW3 can be dynamically specified in the following range: -180 degree  $< \theta < +180$  degree. However, the phase relation between the phase-A0 output and the phase-B0 output and that between the phase-A1 output and the phase-B1 output are the same values.

A pair of the phase-A0 and the phase-B0 and the other pair of the phase-A1 and the phase-B1 output operate the same unless otherwise stated. The following explanation is presented taking the phase-A0 and the phase-B0 as the operation outline of the phase relation. Refer to the Figure 15-8.

Figure 15-8 is a simplified block diagram of the timer unit in Figure 15-2.



#### Figure 15-8 Interlock PPG Configuration diagram (In case of phase A0 and phase B0)

In the Figure 15-8, CP05 operates as a phase shifter (delay generator) which can delay the pulse output b0 in the following range (relative to the pulse output a0):

Phase 0 degree  $\leq \theta < 180$  degree

To delay the phase of the phase-B0 output to the phase-A0 output, switch SW0/SW2 using an output change signal (PHSCHGSW) to satisfy the following condition:

Phase-A0 output = a0, phase-B0 output = b0

To set the phase-B0 output as the same phase or faster than the phase-A0 output, switch SW0/ SW2 using an output change signal (PHSCHGSW) to satisfy the following condition:

Phase-A0 output = b0, phase-B0 output = a0

Unlike the PPG mode, a phase shifter can be achieved by setting the counter UC1 to "0" when a match signal of CP05 is detected, not that of CP10.

#### (2) Operation Details

The mode is changed to PPG mode by setting "111" to TD0CONF<TMRDMOD[2:0]>, and the counter UC1 operates as a counter which is zero cleared when a match of CP05 of TMRD0 is detected, not a match of CP10. After this, TMRDCLK0 and TMRDCLK1 cannot be configured respectively, the same frequencies are set to TMRDCLK1 and TMRDCLK0. Therefore, the pulse b0 is output later than the pulse a0 for the corresponding period to the setting value of TD0CP5<CPRG5[15:0]> in the compare register CP05. The phase relation is shown in the Figure 15-9. As seen in the Figure 15-9, the phase of the pulse a0 is the same phase or faster than the phase of the pulse b0.

Operation mode

154



Figure 15-9 Phase relation between square-wave a0 and b0

The cycles of the pulse a0 and b0 are depending on the setting value of the compare register TD0CP0<CPRG0[15:0]> of CP00. Thus, the phase shift (delay) ( $\theta$ ) can be calculated by using the formula:

 $\theta = 360 \text{ degree} \times (\langle CPRG5[15:0] \rangle \div (\langle CPRG0[15:0] \rangle + 1 \rangle))$ 

Also the condition of this operation mode is set to 0 degree  $\le \theta < 180$ , the setting range of <CPRG5 [15:0]> is  $0x0000 \le$ CPRG5[15:0] < (CPRG0[15:0]  $\div 2$ ).

As with PPG mode, duties of the pulse a0 and b0 are specified by the comparator CP01, CP02 and CP11, CP12.

(2-1) Setting the phase of the phase-A0 faster or the same as the phase of the phase B0

To set the phase of the phase-A0 faster or the same as the phase of the phase B0, PHSCHGSW of SW0/SW2 needs to set in the following condition:

Phase-A0 output = pulse a0, phase-B0 output = pulse b0

Settings of PHSCHGSW will hereinafter be described.



# Figure 15-10 In case that the phase of phase-A0 is set faster than the phase-B0 (phase-A0 output = square-wave a0, phase-B0 output = square-wave b0)

(2-2) Delaying the phase of the phase-A0 to that of the phase-B0

To delay the phase of the phase-A0 output to that of the phase-B0 output, or to set he phase of the phase-A0 output the same as that of the phase-B0 output, PHSCHGSW of SW0/SW2 needs to set in the following condition:

Phase-A0 output = pulse b0, phase-B0 output = pulse a0

Figure 15-11 shows the waveform chart.

15.4 Operation mode



# Figure 15-11 In case that the phase of phase-A0 delay to the phase-B0 (phase-A0 output = square-wave b0, phase-B0 output = square-wave a0)

(2-3) Switching output SW (SW0/SW1/SW2/SW3)

The control of SW0/SW1/SW2/SW3 is done by the settings of the register TD0BCR<PHSCHG>. However, SW0/SW1/SW2/SW3 can not be respectively controlled.

The phase relation of the phase-B to the phase-A can be set by the register TD0BCR<PHSCHG>.

| TD0BCR <phschg> = "0" :</phschg> | Delay or same phase                                          |
|----------------------------------|--------------------------------------------------------------|
|                                  | (Phase-A output = pulse a0/a1, phase-B output = pulse b0/b1) |
| TD0BCR <phschg> = "1" :</phschg> | Fast or same phase                                           |
|                                  | (Phase-A output = pulse b0/b1, phase-B output = pulse a0/a1) |

However, the bit operation of these registers is valid only in interlock PPG mode. The bit operation is ignored in PPG mode, and the condition in PPG mode is always as follows:

Phase-A output = pulse a0/a1, phase-B output = pulse b0/b1.





Figure 15-12 shows the switching time waveform of SW(SW0 through SW3). The signal PHSCHGSW for switching SW changes depending on the value of the register TD0BCR<PHSCHG> when a match signal of CP00 is detected or TD0RUN<TDRUN>="1" in the condition the update enable flag TDBCRx<TDSFT> is "1". The signal PHSCHGSW switches SW to fulfill the following conditions:

PHSCHGSW = "0" : Phase-A output = pulse a0/a1, phase-B output = pulse b0/b1

PHSCHGSW = "1" : Phase-A output = pulse b0/b1, phase-B = pulse a0/a1

Figure 15-13 shows an example of waveform when PHSCHGSW changes from "0" to "1".





#### (2-4) Counter 1 overflow processing

Since the range of phase shift is 0 degree  $\le \theta < 180$ , the range from CP05 match detection to the next match detection could be  $0.5T \le T\theta < 1.5T$ , if the cycle of the phase A and the phase B output is T. Therefore, depending to the value of the cycle T, the counter 1 (UC1) may overflow. In this mode, if the value of the UC1 counter exceeds 0xFFFF, overflow processing stops the counting up operation and maintains the value of 0xFFFF until the next CP05 match is detected.

#### (2-5) Start timing of interlock PPG mode

The output of the interlock PPG starts by writing "1" to  $\langle TDRUN \rangle$  of the register TD0RUN. As shown in the Figure 15-14, arbitrary waveform output can be generated from the first cycle even if the leading edge is set to rises/falls concomitantly with the start. The figure shows the case in the following condition: TDxCP1 $\langle CPRG1[15:0] \rangle =$  "0".

15.4

Operation mode



(1) Leading edge is set to be generated at the rising point of phase outputs



(2) Leading edge is set to be generated at the falling point of phase outputs

Figure 15-14 Timing chart at start up

- (3) Configuration of the register in interlock PPG mode
  - (3-1) Register setting priority in interlock PPG mode

Since TMRD0 operates as a maser and TMRD1 operates a slave in this mode, the setting of the TMRD0 has priority over the setting of the TMRD1 for some bits. Table 15-3 shows those bits.

| TMRD0 register                   | TMRD1 register                   |
|----------------------------------|----------------------------------|
| TD0MOD <tdclk[3:0]></tdclk[3:0]> | TD1MOD <tdclk[3:0]></tdclk[3:0]> |

Therefore, TMRD1 registers of the above registers do not need to be configured in this mode. If these registers are configured, the values are ignored but please note that these values remain in the registers. For example, <TDRUN> of the register TD1RUN is set to "1", TMRD1 restarts after this mode stops. Set "0" to <TDRUN> of the register TD1RUN.

TD1CR<TDRDE>

TD1RUN<TDRUN>

(3-2) Process to start up the interlock PPG mode

Register settings to start up the interlock PPG mode are made in the following steps.

TD0CR<TDRDE>

TD0RUN<TDRUN>

a. Select a clock to be provided

2.

- 1. Select a clock to be provided to the TMRD and set it to the register CGPWMGEAR<PWMGEAR[1:0]>.
  - Set the register CGPWMGEAR<TMRDCLKEN> to "1" to enable providing a clock to the TMRD. Be sure to set the <TMRDCLKEN> after setting the value of <PWMGEAR[1:0]>.
- b. Select operation modes of timer units
  - Since timer units operate in the interlock PPG mode, set "111" to <TMRDMOD[2:0]> of the register TD0CONF. Simultaneuosly, set the operation status of the timer unit used in the IDLE mode to <TDI2TD1> and <TDI2TD0> of the same register TD0CONF.
- c. Select clocks to be used in the timer units (TMRD0/TMRD1).
  - 1. Set "1" to the bit <TDEN1> and <TDEN0> of the register TD0EN which disables and enables a clock signal to be provided to the timer unists. (Both <TDEN1> and <TDEN0> must be set to "1".)
  - Select a clock to be used in timer units and set it to the register TD0MOD<TDCLK[3:0]>.
     At the same time, configure <TDIV[1:0]> in the same register which specify the polar of the leading edge and trailing edge of a0 and a1.
  - 3. Configure TD1MOD<TDIV[1:0]> which specify the polar of the leading edge and trailing edge of b0 and b1.
- d. Initial settings of timer registers and compare rgisters
  - 1. Set "0" to <TDRDE> of the register TDxCR to write to the compare register in the direct write mode. (It's a mode that the same data is written to the corresponding compare register when data is written to the timer register.)
  - Set a required value to timer register (TDxRGm).
     In the mode which condition is TDxCR<TDRDE> = 0, an operation to set "1" to the register TDxBCR<TDSFT> and an update timing signal are not required.
- e. Initialization of phase relation (delay/fast) between the phase A and the phase B
  - 1. Sets the phase relation between the phase A and the phase B, delay or fast, to the register TD0BCR<PHSCHG>. It's not necessary to set "1" to TD0BCR<TDSFT>.
- f. Start the interlock PPG mode
  - 1. Set "1" to <TDRDE> of the register TDnCR to enable writing data through the timer register to the compare register. (The value of the timer register is written into the corresponding timer register at the predefined update time in this mode.)
  - 2. Start the PPG mode by setting "1" to <TDRUN> of the register TD0RUN.

(3-3) Process after starting the interlock PPG mode

To set the register after starting the interlock PPG mode, make settings in the following procedures.

a. Update values of timer registers and compare registers

- 1. Set an arbitrary value to timer register (TDxRGm) corresponding to the compare register to be updated. However, the value in TD1RG0 does not affect this mode.
- 2. If you change the phase relation between the phase A and the phase B (delay/fast) after above setting, change the setting value of TD0BCR<PHSCHG> and set "1" to TD0BCR<TDSFT> simultaneuosly. Do not set "1" to TD1BCR<TDSFT>.

With the above settings, a value in a timer register is set in the corresponding compare register at the predefined update timing. (See Figure 15-4)

b. Stops the pulse generation output.

- 1. To stop a pulse output from timer units, set "0" to <TDRUN> of the register TDxRUN.
  - Note: Registers which can be configured when the PPG is running are the following three registers: (TDxRGm), (TDxBCR) and (TDxRUN). Other registers must be configured when the timer is being stopped.
  - (3-4) Notes on switching output SW in the interlock PPG mode

In the interlock PPGmode, a trailing edge of pulse b0/b1 can be configured in a moment exceeding the cycle of COUNTER0(UC0). If you change output SW, the phase from delay to fast or fast to delay, special attention is required.

Hereinafter, it's described that waveform of the phase A and B when the output SW is switched in both cases; trailing edge of a pulse b0/b1 is in the UC0 cycle and out of the UC0 cycle.

The term "UC0 cycle" means the period that the counter value changes from "0" to "0".

(3-4.1) When the trailing edge of the pulse b0/b1 is in the UC0 cycle

As shown in Figure 15-15, please note the following if you try to change the status of the phase A from fast state to delay state when the phase relation between A0 and B0 is in the condition that the trailing edge is in the UC0 cycle. As shown in Figure 15-16, switch the SW at predefined match detection timing of CP00, and change the conditions that the phase A0 output = pulse a0 and the phase B0 output = pulse b0 to the condition that the phase A0 output = pulse b0 and the phase B0 output = pulse a0. The output SW is switched without generating outlier waveform since the signal level of the pulse a0 and b0 are the same when the output SW is switched.

# TOSHIBA



Figure 15-15 Waveform before and after switching the phase status (output SW) between delay and fast (Trailing edge of the squarewave b0 is in the range of the UC0 cycle)



### Figure 15-16 Waveform before and after switching the output SW0 (Trailing edge of the squarewave b0 is in the range of the UC0 cycle)

Switching the phase A0 status from faster than the phase B0 output to delay is previously described. The vice versa is also true; outlier waveform is not generated when switching the phase A0 status from delay to faster than the phase B0. The case of the phase A1 and the phase B1 is the same.

(3-4.2) When the trailing edge of the pulse b0/b1 exceeds the UC0 cycle

As shown in the Figure 15-17, please note the following if you try to change the status of the phase A from fast state to delay state when the phase relation between A0 and B0 is in the condi-

tion that the trailing edge exceeds the UC0 cycle. As shown in the Figure 15-18, switch the SW0 at predefined match detection timing of CP00, and change the conditions that the phase A0 output = pulse a0 and the phase B0 output = pulse b0 to the condition that the phase A0 output = pulse b0 and the phase B0 output = pulse a0. As shown in the Figure 15-18, a pulse-type waveform is generated at this time.

And also a pulse-type waveform is generated when switching the phase A0 status from delay to faster than the phase B0, and in the case of the phase A1 and B1 as well.



Figure 15-17 Waveform before and after switching the phase delay (output SW) (Trailing edge of the squarewave b0 exceeds the UC0 cycle)



Figure 15-18 Waveform before and after switching the phase delay (output SW0) (Trailing edge of the squarewave b0 exceeds the UC0 cycle)

Switching the phase A0 status from faster than the phase B0 output to delay is previously described. The vice versa is also true; a pulse-type wavefoem is generated as shown in the Figure 15-18 when switching the phase A0 status from delay to faster than the phase B0. The case of the phase A1 and the phase B1 is the same.

If the pulse-type waveform generated when switching the phase between the delay state and the fast dtate affects the system, it's preventable through the coordination phase before switching the phases.

#### 15.4.2.3 The setting range of compare register

The setting range of the compare register when 16-bit programmable pulse output is shown in the Table 15-4.

| Timerallait | Compare  | 16-bit programmable pulse generation    |                                                                |  |  |  |
|-------------|----------|-----------------------------------------|----------------------------------------------------------------|--|--|--|
| Timer Unit  | register | PPG                                     | Interlock PPG                                                  |  |  |  |
|             | TD0CP0   | $0x0001 \le CPRG0[15:0] \le 0xFFFF$     | $0x0001 \le CPRG0[15:0] \le 0xFFFF$                            |  |  |  |
|             | TD0CP1   | 0x0000 ≤ CPRG1[15:0] < CPRG2[15:0]      | 0x0000 ≤ CPRG1[15:0] < CPRG2[15:0]                             |  |  |  |
|             | TD0CP2   | CPRG1[15:0] < CPRG2[15:0] ≤ CPRG0[15:0] | CPRG1[15:0] < CPRG2[15:0] ≤ CPRG0[15:0]                        |  |  |  |
| TMRD0       | TD0CP3   | 0x0000 ≤ CPRG3[15:0] < CPRG4[15:0]      | 0x0000 ≤ CPRG3[15:0] < CPRG4[15:0]                             |  |  |  |
|             | TD0CP4   | CPRG3[15:0] < CPRG4[15:0] ≤ CPRG0[15:0] | $CPRG3[15:0] < CPRG4[15:0] \le CPRG0[15:0]$                    |  |  |  |
|             | TD0CP5   | don't care                              | $0x0000 \le CPRG5[15:0] \le (CPRG0[15:0] \div 2)$              |  |  |  |
|             | TD1CP0   | $0x0001 \le CPRG0[15:0] \le 0xFFFF$     | don't care                                                     |  |  |  |
|             | TD1CP1   | 0x0000 ≤ CPRG1[15:0] < CPRG2[15:0]      | 0x0000 ≤ CPRG1[15:0] < CPRG2[15:0]                             |  |  |  |
| TMRD1       | TD1CP2   | CPRG1[15:0] < CPRG2[15:0] ≤ CPRG0[15:0] | CPRG1[15:0] < CPRG2[15:0] ≤ TD0CP0 <cprg0[15:0]></cprg0[15:0]> |  |  |  |
|             | TD1CP3   | 0x0000 ≤ CPRG3[15:0] < CPRG4[15:0]      | 0x0000 ≤ CPRG3[15:0] < CPRG4[15:0]                             |  |  |  |
|             | TD1CP4   | CPRG3[15:0] < CPRG4[15:0] ≤ CPRG0[15:0] | CPRG3[15:0] < CPRG4[15:0] ≤ TD0CP0 <cprg0[15:0]></cprg0[15:0]> |  |  |  |

Table 15-4 Setting range of the compare register when 16-bit programmable pulse is output

The cycle Tx of pulse output, when the frequency of TMRDCLK is  $f_{CLK}x$ , can be obtained by the following formulas.

(1) In the case of PPG mode, x = 0,1  $Tx = (1/f_{CLK}x) \times (TDxCP0 < CPRG0[15:0] > + 1)$ (2) In the case of Interlock PPG mode  $T = (1/f_{CLK}0) \times (TD0CP0 < CPRG0[15:0] > + 1)$ 

The duty of the pulse output when the frequency of TMRDCLK0 is  $f_{CLK0}$  can be obtained by the following formula. (in the case of a0)

p : q = {CPRG2[15:0] - CPRG1[15:0]} : {(CPRG0[15:0]+1) - CPRG2[15:0] + CPRG1[15:0]}



- 15. High Resolution 16-bit Timer/PPG Outputs (TMRD)
- 15.4 Operation mode

# TOSHIBA

# 16. Serial Channel (SIO/UART)

## 16.1 Overview

This device has two mode 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 given in the following.

- Transfer Clock
  - Dividing by the prescaler, from the peripheral clock ( $\varphi$ T0) frequency into 1/2, 1/8, 1/32, 1/128.
  - Make it possible to divide from the prescaler output clock frequency into 1-16.
  - Make it possible to divide from the prescaler output clock frequency into 1, N+m/16 (N=2-15, m=1-15), 16. (only UART mode)
  - The usable system clock (only UART mode).
- Double Buffer /FIFO

The usable double buffer function, and the usable FIFO buffers of transmit and receive in all for maximum 4-byte.

- I/O Interface Mode
  - Transfer Mode: the half duplex (transmit/receive), the full duplex
  - Clock: Output (fixed rising edge) /Input (selectable rising/falling edge)
  - Make it possible to specify the interval time of continuous transmission.
- UART Mode
  - Data length: 7 bits, 8bits, 9bits
  - Add parity bit (to be against 9bits data length)
  - Serial links to use wake-up function
  - Handshaking function with CTS pin

In the following explanation, "x" represents channel number.

## 16.2 Difference in the Specifications of SIO Modules

TMPM341FDXBG/FYXBG has five SIO channels.

Each channel functions independently. The used pins, interrupt, DMA request and UART source clock in each channel are collected in the following.

|           | Pin name |     |                | Interrupt         |                    |             |                      |
|-----------|----------|-----|----------------|-------------------|--------------------|-------------|----------------------|
|           | TXD      | RXD | CTSx/<br>SCLKx | Receive Interrupt | Transmit Interrupt | DMA request | UART source<br>clock |
| Channel 0 | PE0      | PE1 | PE2            | INTRX0            | INTTX0             | Support     | TB8OUT               |
| Channel 1 | PC0      | PC1 | PC2            | INTRX1            | INTTX1             | -           | TB8OUT               |
| Channel 2 | PC4      | PC5 | PC6            | INTRX2            | INTTX2             | Support     | TB8OUT               |
| Channel 3 | PG4      | PG5 | PG6            | INTRX3            | INTTX3             | -           | TB9OUT               |
| Channel 4 | PH0      | PH1 | PH2            | INTRX4            | INTTX4             | Support     | TB9OUT               |

## 16.3 Configuration

Figure 16-1 shows SIO block diagram.



Figure 16-1 SIO Block Diagram

# TOSHIBA

## 16.4 Registers Description

## 16.4.1 Registers List in Each Channel

The each channel registers and addresses are shown below.

| Channel x | Base Address |  |  |
|-----------|--------------|--|--|
| Channel0  | 0x400E_1000  |  |  |
| Channel1  | 0x400E_1100  |  |  |
| Channel2  | 0x400E_1200  |  |  |
| Channel3  | 0x400E_1300  |  |  |
| Channel4  | 0x400E_1400  |  |  |

| Register name (x=0 to                  | o 4)     | 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          |  |
| DMA request enable register (note2)    | SCxDMA   | 0x0034          |  |

Note 1: Do not modify any control register when data is being transmitted or received. Note 2: Channel 1 and channel 3 do not have this register.

#### 16.4 Registers Description

|             | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | SIOE |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    |

# 16.4.2 SCxEN (Enable Register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                              |
|------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31-1 | -          | R    | Read as 0.                                                                                                                            |
| 0    | SIOE       | R/W  | SIO operation                                                                                                                         |
|      |            |      | 0: Disabled                                                                                                                           |
|      |            |      | 1: Enabled                                                                                                                            |
|      |            |      | Specified 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: When DMA transfer is used by SIO transmit or receive, SIO operation should be enabled after a software reset by SCxMOD2<[1:0]>.

# 16.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  | 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  | 0  |
|             | 7  | 6  | 5  | 4  | 3    | 2  | 1  | 0  |
| bit symbol  |    |    |    | TB | / RB |    |    |    |
| -           |    |    |    |    |      | 0  | 0  | 0  |

| Bit  | Bit Symbol            | Туре | Function                            |  |  |  |
|------|-----------------------|------|-------------------------------------|--|--|--|
| 31-8 | -                     | R    | Read as 0.                          |  |  |  |
| 7-0  | TB[7:0] / RB<br>[7:0] | R/W  | [write] TB : Transmit buffer / FIFO |  |  |  |
|      | [7.0]                 |      | [read] RB : Receive buffer / FIFO   |  |  |  |

## 16.4 Registers Description

|             | 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     | 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  | RB8 | EVEN | PE | OERR | PERR | FERR | SCLKS | IOC |
| After reset | 0   | 0    | 0  | 0    | 0    | 0    | 0     | 0   |

# 16.4.4 SCxCR (Control Register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7    | RB8        | R    | Receive data bit 8 (For UART)<br>9th bit of the received data in the 9 bits UART mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6    | EVEN       | R/W  | Parity (For UART)<br>0: Odd<br>1: Even<br>Selects even or odd parity.<br>"0" : odd parity, "1" : even parity.<br>The parity bit may be used only in the 7- or 8-bit UART mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5    | PE         | R/W  | Add parity (For UART)<br>0: Disabled<br>1: Enabled<br>Controls enabling/ disabling parity.<br>The parity bit may be used only in the 7- or 8-bit UART mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4    | OERR       | R    | Overrun error flag (Note)<br>0: Normal operation<br>1: Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3    | PERR       | R    | Parity / Under-run error flag (Note)<br>0: Normal operation<br>1: Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2    | FERR       | R    | Framing error flag (Note)<br>0: Normal operation<br>1: Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1    | SCLKS      | R/W  | Selects input clock edge for data transmission and reception. (For I/O Interface)<br>0: TXD pin output the data per 1 bit from transmit buffer by falling edge of the register SCLK.<br>RXD pin output the data per 1 bit from receive buffer per 1 bit by risingg edge of the register SCLK.<br>In this case, the SCLK starts from high level.<br>1: TXD pin output the data per 1 bit from transmit buffer by rising edge of the register SCLK.<br>RXD pin output the data per 1 bit from transmit buffer by rising edge of the register SCLK.<br>RXD pin output the data per 1 bit from receive buffer by falling edge of the register SCLK.<br>In this case, the SCLK starts from low level. |
| 0    | IOC        | R/W  | Selecting clock (For I/O Interface)<br>0: Baud rate generator<br>1: SCLK pin input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Note: Any error flag (OERR, PERR, FERR) is cleared to "0" when read.

|             | 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  | 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  | TB8 | CTSE | RXE | WU | SM |    | SC |    |
| After reset | 0   | 0    | 0   | 0  | 0  | 0  | 0  | 0  |

# 16.4.5 SCxMOD0 (Mode Control Register 0)

| Bit  | Bit Symbol | Туре | 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 (Note)                                                                                |
|      |            |      | 0: Disabled                                                                                           |
|      |            |      | 1: Enabled                                                                                            |
| 4    | WU         | R/W  | Wake-up function (For UART)                                                                           |
|      |            |      | 0: Disabled                                                                                           |
|      |            |      | 1: Enabled                                                                                            |
|      |            |      | This function is available only at 9-bit UART mode. In other mode, this function has no meaning.      |
|      |            |      | In it is Enabled, Interrupt only when RB9 = "1" at 9-bit UART mode.                                   |
| 3-2  | SM[1:0]    | R/W  | Specifies transfer mode.                                                                              |
|      |            |      | 00: I/O interface mode                                                                                |
|      |            |      | 01: 7-bit length UART mode                                                                            |
|      |            |      | 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 TBxOUT (Note1)                                                                              |
|      |            |      | 01: Baud rate generator                                                                               |
|      |            |      | 10: Internal clock fsys                                                                               |
|      |            |      | 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: When setting to the <SC[1:0]>="00", the clock source is different according to the channel. (SIO channel0, channel1 and channel2: TB8OUT, SIO channel3 and channel4: TB9OUT)

Note:With <RXE> set to "0", set each mode register (SCxMOD0, SCxMOD1 and SCxMOD2). Then set <RXE> to "1".

Note: Do not stop the receive operation (by setting SCxMOD0<RXE> = "0") when data is being received.

## 16.4 Registers Description

|             | 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  | 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  | I2SC | FD | FDPX |    |    | SINT |    |    |
| After reset | 0    | 0  | 0    | 0  | 0  | 0    | 0  | 0  |

# 16.4.6 SCxMOD1 (Mode Control Register 1)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7    | I2SC       | R/W  | IDLE<br>0: Stop<br>1: Operate<br>Specifies the IDLE mode operation.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6-5  | FDPX[1:0]  | R/W  | Transfer mode setting<br>00: Transfer prohibited<br>01: Half duplex (Receive)<br>10: Half duplex (Transmit)<br>11: Full duplex<br>Configures the transfer mode in the I/O interface mode. Also configures the FIFO if it is enabled.<br>In the UART mode, it is used only to specify the FIFO configuration.                                                                                                                                                                   |
| 4    | TXE        | R/W  | Transmit control (Note2)<br>0 :Disabled<br>1: Enabled<br>This bit enables transmission and is valid for all the transfer modes.                                                                                                                                                                                                                                                                                                                                                |
| 3-1  | SINT[2:0]  | R/W  | Interval time of continuous transmission (For I/O interface)<br>000: None<br>001: 1SCLK<br>010: 2SCLK<br>011: 4SCLK<br>100: 8SCLK<br>101: 16SCLK<br>101: 16SCLK<br>111: 64SCLK<br>111: 64SCLK<br>This parameter is valid only for the I/O interface mode when SCLK pin output is selected. In other modes,<br>this function has no meaning.<br>Specifies the interval time of continuous transmission when double buffering or FIFO is enabled in the I/O in-<br>terface mode. |
| 0    | -          | R/W  | Write a "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Note 1: Specify the all mode 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: When SIO is transferred in the full duplex mode, transfer can not be used by SIO transmit or receive.

|             | 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     | 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     | 0     | 0    | 0     | 0  |

# 16.4.7 SCxMOD2 (Mode Control Register 2)

| Bit  | Bit Symbol | Туре |                                                                         |                                                                                                                                                                                                        | Function                                                                                  |              |  |  |  |  |  |
|------|------------|------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------|--|--|--|--|--|
| 31-8 | -          | R    | Read as 0.                                                              |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
| 7    | ТВЕМР      | R    | Transmit buffer empty                                                   | y flag.                                                                                                                                                                                                |                                                                                           |              |  |  |  |  |  |
|      |            |      | 0: Full                                                                 |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | 1: Empty                                                                |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | , s                                                                     | 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 noved to the transmit shift register and the double buffers are empty, this bit is set to "1". |                                                                                           |              |  |  |  |  |  |
|      |            |      | Writing data again to                                                   | the double buffe                                                                                                                                                                                       | rs sets this bit to "0".                                                                  |              |  |  |  |  |  |
| 6    | RBFLL      | R    | Receive buffer full fla                                                 | ıg.                                                                                                                                                                                                    |                                                                                           |              |  |  |  |  |  |
|      |            |      | 0: Empty                                                                |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | 1: Full                                                                 |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | This is a flag to show                                                  |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      |                                                                         | d and received data is moved from the receive shi to "1" while reading this bit changes it to "0".                                                                                                     | ft register to the re-                                                                    |              |  |  |  |  |  |
|      |            |      | If double buffering is                                                  | If double buffering is disabled, this flag is insignificant.                                                                                                                                           |                                                                                           |              |  |  |  |  |  |
| 5    | TXRUN      | R    | 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.</tbemp></txrun> |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | <txrun></txrun>                                                         | <tbemp></tbemp>                                                                                                                                                                                        | Status                                                                                    |              |  |  |  |  |  |
|      |            |      | 1                                                                       | -                                                                                                                                                                                                      | Transmission in progress                                                                  |              |  |  |  |  |  |
|      |            |      | 0                                                                       | 1                                                                                                                                                                                                      | Transmission completed                                                                    |              |  |  |  |  |  |
|      |            |      | 0                                                                       | 0                                                                                                                                                                                                      | Wait state with data in Transmit buffer                                                   |              |  |  |  |  |  |
| 4    | SBLEN      | R/W  | STOP bit (for UART)                                                     |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | 0 : 1-bit                                                               |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | 1 : 2-bit                                                               |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      |                                                                         | •                                                                                                                                                                                                      | on stop bit in the UART mode.                                                             |              |  |  |  |  |  |
|      |            |      | On the receive side,                                                    | the decision is m                                                                                                                                                                                      | ade using only a single bit regardless of the <sbl< td=""><td>EN&gt; setting.</td></sbl<> | EN> setting. |  |  |  |  |  |
| 3    | DRCHG      | R/W  | Setting transfer direct                                                 | tion                                                                                                                                                                                                   |                                                                                           |              |  |  |  |  |  |
|      |            |      | 0: LSB first                                                            |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      | 1: MSB first                                                            |                                                                                                                                                                                                        |                                                                                           |              |  |  |  |  |  |
|      |            |      |                                                                         |                                                                                                                                                                                                        | in the I/O interface mode.                                                                |              |  |  |  |  |  |
|      |            |      | In the UART mode, s                                                     | set this bit to LSB                                                                                                                                                                                    | first.                                                                                    |              |  |  |  |  |  |

| Bit | Bit Symbol | Туре |                                                           | Function                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|-----|------------|------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 2   | WBUF       | R/W  | put modes) and recei<br>UART mode.<br>When receiving data | <ul> <li>Disabled</li> <li>Enabled</li> <li>This parameter enables or disables the transmit/receive double buffers to transmit (in both SCLK output/in-<br/>out modes) and receive (in SCLK output mode) data in the I/O interface mode and to transmit data in the</li> </ul> |  |  |  |  |  |  |
| 1-0 | SWRST[1:0] | R/W  |                                                           | Software reset<br>Overwriting "01" in place of "10" generates a software reset. When this software reset is executed, the follow-<br>ing bits are initialized and the transmit/receive circuit, the transmit circuit and the FIFO become initial state                         |  |  |  |  |  |  |
|     |            |      | Register                                                  | Bit                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|     |            |      | SCxMOD0                                                   | RXE                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|     |            |      | SCxMOD1                                                   | TXE                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|     |            |      | SCxMOD2                                                   | TBEMP, RBFLL, TXRUN                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|     |            |      | SCxCR OERR, PERR, FERR                                    |                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|     |            |      | SCxDMA<br>(note2)                                         | DMAEN1, DMAEN0                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |

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.

# 16.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     |    | -      |    | -  |     |    | -  |    |
|-------------|----|--------|----|----|-----|----|----|----|
|             | 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  | 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  | -  | BRADDE | BR | CK | BRS |    |    |    |
| After reset | 0  | 0      | 0  | 0  | 0   | 0  | 0  | 0  |

| Bit  | Bit Symbol | Туре | Function                                                                                                                              |
|------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                            |
| 7    | -          | R/W  | Write "0".                                                                                                                            |
| 6    | BRADDE     | R/W  | N + (16 - K)/16 divider function (For UART)<br>0: disabled<br>1: enabled<br>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.<br>00: φT1<br>01: φT4<br>10: φT16<br>11: φT64                                          |
| 3-0  | BRS[3:0]   | R/W  | Division ratio "N"<br>0000: 16<br>0001: 1<br>0010: 2<br><br>1111: 15                                                                  |

Page 415

#### 16.4 Registers Description

|             | 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  | 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  | -  | -  | -  | -  |    | BI | RK |    |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

SCxBRADD

| Bit  | Bit Symbol | Туре | Function                                                                                                                      |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | -          | R    | Read as 0.                                                                                                                    |
| 3-0  | BRK[3:0]   | R/W  | Specify K for the "N + (16 - K)/16" division (For UART)<br>0000: Prohibited<br>0001: K = 1<br>0010: K = 2<br><br>1111: K = 15 |

Table 16-2 lists the settings of baud rate generator division ratio.

## Table 16-2 Setting division ratio

|                | <bradde> = "0"</bradde> | <bradde> = "1" (Note1)<br/>(Only UART mode)</bradde> |  |  |
|----------------|-------------------------|------------------------------------------------------|--|--|
| <brs></brs>    | Specify "               | V" (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)/ 16" division function in the UART mode.
- 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.

|             | 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       | 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  | -  | -  | -  | RFST | TFIE | RFIE | RXTXCNT | CNFG |
| After reset | 0  | 0  | 0  | 0    | 0    | 0    | 0       | 0    |

# 16.4.9 SCxFCNF (FIFO Configuration Register)

| Bit  | Bit Symbol | Туре |                                                                                                      | Function                                                                                                            |                                                                                  |  |  |  |  |  |
|------|------------|------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|--|--|--|--|
| 31-8 | -          | R    | Read as 0                                                                                            |                                                                                                                     |                                                                                  |  |  |  |  |  |
| 7-5  | -          | R/W  | Be sure to write "000                                                                                | )"                                                                                                                  |                                                                                  |  |  |  |  |  |
| 4    | RFST       | R/W  | Bytes used in RX FI                                                                                  | Bytes used in RX FIFO                                                                                               |                                                                                  |  |  |  |  |  |
|      |            |      | 0:Maximum                                                                                            | Maximum                                                                                                             |                                                                                  |  |  |  |  |  |
|      |            |      | 1:Same as FILL leve                                                                                  | Same as FILL level of RX FIFO                                                                                       |                                                                                  |  |  |  |  |  |
|      |            |      |                                                                                                      | /hen RX FIFO is enabled, the number of RX FIFO bytes to be used is selected (Note1)                                 |                                                                                  |  |  |  |  |  |
|      |            |      |                                                                                                      | nber of bytes of the FIFO configured (see                                                                           | ,                                                                                |  |  |  |  |  |
|      |            |      | 1: Same as the fill le                                                                               | evel for receive interrupt generation specified                                                                     | fied by SCxRFC <ril[1:0]></ril[1:0]>                                             |  |  |  |  |  |
| 3    | TFIE       | R/W  | TX interrupt for TX F                                                                                | IFO                                                                                                                 |                                                                                  |  |  |  |  |  |
|      |            |      | 0: Disabled                                                                                          |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | 1:Enabled                                                                                            |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      |                                                                                                      | abled, transmit interrupts are enabled or                                                                           | disabled by this parameter.                                                      |  |  |  |  |  |
| 2    | RFIE       | R/W  | RX interrupt for RX I                                                                                | -IFO                                                                                                                |                                                                                  |  |  |  |  |  |
|      |            |      | 0: Disabled<br>1:Enabled                                                                             |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      |                                                                                                      | abled receive interrupts are enabled or                                                                             | disabled by this parameter                                                       |  |  |  |  |  |
| 1    | RXTXCNT    | R/W  |                                                                                                      | When RX FIFO is enabled, receive interrupts are enabled or disabled by this parameter. Automatic disable of RXE/TXE |                                                                                  |  |  |  |  |  |
| ·    |            | 1011 | 0: None                                                                                              |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | 1: Auto disabled                                                                                     |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | Controls automatic d                                                                                 | isabling of transmission and reception.                                                                             |                                                                                  |  |  |  |  |  |
|      |            |      | Setting "1" enables t                                                                                | o operate as follows                                                                                                |                                                                                  |  |  |  |  |  |
|      |            |      | Half duplex RX                                                                                       | When receive shift register, the receive<br>SCxMOD0 <rxe> is automatically set to</rxe>                             |                                                                                  |  |  |  |  |  |
|      |            |      | Half duplex TX                                                                                       | When the TX FIFO, the transmit buffer SCxMOD1 <txe> is automatically set to</txe>                                   | and the transmit shift register is empty, o "0" to inhibit further transmission. |  |  |  |  |  |
|      |            |      | Full duplex                                                                                          | When either of the above two condition<br>ly set to "0" to inhibit further transmission                             | is is satisfied, TXE/RXE are automatical-<br>on and reception.                   |  |  |  |  |  |
| 0    | CNFG       | R/W  | Enables FIFO.                                                                                        |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | 0: Disabled                                                                                          |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | 1: Enabled                                                                                           |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | If enabled, the SCxMOD1 <fdpx[1:0]> setting automatically configures FIFO as follows:</fdpx[1:0]>    |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | (The type of TX/RX can be specified in the mode control register 1 SCxMOD1 <fdpx[1:0]>).</fdpx[1:0]> |                                                                                                                     |                                                                                  |  |  |  |  |  |
|      |            |      | Half duplex RX                                                                                       | RX FIFO 4byte                                                                                                       |                                                                                  |  |  |  |  |  |
|      |            |      | Half duplex TX                                                                                       | TX FIFO 4byte                                                                                                       |                                                                                  |  |  |  |  |  |
|      |            |      | Full duplex                                                                                          | RX FIFO 2byte + TX FIFO 2byte                                                                                       |                                                                                  |  |  |  |  |  |

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.

16.4 Registers Description

|             | 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  | 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  | RFCS | RFIS | -  | -  | -  | -  | R  | IL |
| After reset | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  |

# 16.4.10 SCxRFC (RX FIFO Configuration Register)

| Bit  | Bit Symbol | Туре |                         |                                                                                                                   |                       | Function |  |  |  |
|------|------------|------|-------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------|----------|--|--|--|
| 31-8 | -          | R    | Read as 0.              | Read as 0.                                                                                                        |                       |          |  |  |  |
| 7    | RFCS       | w    | RX FIFO cle             | X FIFO clear (Note)                                                                                               |                       |          |  |  |  |
|      |            |      | 1: Clear                | Clear                                                                                                             |                       |          |  |  |  |
|      |            |      | Setting "1" o           | tting "1" clears RX FIFO and "0" is always read.                                                                  |                       |          |  |  |  |
| 6    | RFIS       | R/W  | Select interr           | upt generation cor                                                                                                | ndition               |          |  |  |  |
|      |            |      | 0: when the             | data reaches to the                                                                                               | he specified fill lev | el.      |  |  |  |
|      |            |      | 1: when the ta is read. | 1: when the data reaches to the specified fill level or the data exceeds the specified fill level at the time da- |                       |          |  |  |  |
| 5-2  | -          | R    | Read as 0.              |                                                                                                                   |                       |          |  |  |  |
| 1-0  | RIL[1:0]   | R/W  | FIFO fill leve          | el to generate RX                                                                                                 | interrupts            |          |  |  |  |
|      |            |      |                         | Half duplex                                                                                                       | Full duplex           |          |  |  |  |
|      |            |      | 00                      | 4byte                                                                                                             | 2byte                 |          |  |  |  |
|      |            |      | 01                      | 01 1byte 1byte                                                                                                    |                       |          |  |  |  |
|      |            |      | 10                      | 10 2byte 2byte                                                                                                    |                       |          |  |  |  |
|      |            |      | 11                      | 3byte                                                                                                             | 1byte                 |          |  |  |  |

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").

|             | 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  | 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  | TFCS | TFIS | -  | -  | -  | -  | Т  | IL |
| After reset | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  |

# 16.4.11 SCxTFC (TX FIFO Configuration Register) (Note2)

| Bit  | Bit Symbol | Туре |                |                                                                                                                                                                |                    | Function                         |  |  |  |  |
|------|------------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------------------------|--|--|--|--|
| 31-8 | -          | R    | Read as 0.     | Read as 0.                                                                                                                                                     |                    |                                  |  |  |  |  |
| 7    | TFCS       | W    | TX FIFO cle    | K FIFO clear (Note 1)                                                                                                                                          |                    |                                  |  |  |  |  |
|      |            |      | 1: Clears T    | Clears TX FIFO.                                                                                                                                                |                    |                                  |  |  |  |  |
|      |            |      | Setting "1" of | tting "1" clears TX FIFO and "0" is always read.                                                                                                               |                    |                                  |  |  |  |  |
| 6    | TFIS       | R/W  | Selects inte   | rrupt generation co                                                                                                                                            | ondition.          |                                  |  |  |  |  |
|      |            |      | 0: An interru  | upt is generated wi                                                                                                                                            | hen the data reacl | hes to the specified fill level. |  |  |  |  |
|      |            |      |                | : 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 new data is read. |                    |                                  |  |  |  |  |
| 5-2  | -          | R    | Read as 0.     |                                                                                                                                                                |                    |                                  |  |  |  |  |
| 1-0  | TIL[1:0]   | R/W  | Selects FIF    | O fill level.                                                                                                                                                  |                    |                                  |  |  |  |  |
|      |            |      |                | Other than full duplex                                                                                                                                         | Full duplex        |                                  |  |  |  |  |
|      |            |      | 00             | Empty                                                                                                                                                          | Empty              |                                  |  |  |  |  |
|      |            |      | 01             | 01 1 byte 1 byte                                                                                                                                               |                    |                                  |  |  |  |  |
|      |            |      | 10             | 10 2 byte Empty                                                                                                                                                |                    |                                  |  |  |  |  |
|      |            |      | 11             | 3 byte                                                                                                                                                         | 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 started by the WFI (Wait For Interrupt) instruction.

## 16.4 Registers Description

# 16.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  | -   | -  | -  | -  | -  | -  | -    | -  |
| 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    | 0  |
|             | 7   | 6  | 5  | 4  | 3  | 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)<br>0: Not generated<br>1: Generated                                              |
| 6-3  | -          | R    | Read as 0.                                                                                              |
| 2-0  | RLVL[2:0]  | R    | Status of RX FIFO fill level.<br>000: Empty<br>001: 1 byte<br>010: 2 byte<br>011: 3 byte<br>100: 4 byte |

Note: The <ROR> bit is cleared to "0" when receive data is read from the SCxBUF 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  | 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  | TUR | -  | -  | -  | -  | TLVL |    |    |
| After reset | 1   | 0  | 0  | 0  | 0  | 0    | 0  | 0  |

# 16.4.13 SCxTST (TX FIFO Status Register)

| Bit  | Bit Symbol | Туре | Function                                                                                                |  |
|------|------------|------|---------------------------------------------------------------------------------------------------------|--|
| 31-8 | -          | R    | Read as 0.                                                                                              |  |
| 7    | TUR        | R    | X FIFO under run (Note)<br>: Not generated<br>: Generated.                                              |  |
| 6-3  | -          | R    | Read as 0.                                                                                              |  |
| 2-0  | TLVL[2:0]  | R    | Status of TX FIFO fill level.<br>000: Empty<br>001: 1 byte<br>010: 2 byte<br>011: 3 byte<br>100: 4 byte |  |

Note: The <TUR> bit is cleared to "0" when transmit data is written to the SCxBUF register.

#### 16.4 Registers Description

|             | 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      | 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  | -  | -  | -  | -  | -  | -  | DMAEN1 | DMAEN0 |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0      |

## 16.4.14 SCxDMA (DMA request enable register)

| Bit  | Bit Symbol | Туре | Function                                                                                            |  |
|------|------------|------|-----------------------------------------------------------------------------------------------------|--|
| 31-2 | -          | R    | Read as 0.                                                                                          |  |
| 1    | DMAEN1     | R/W  | Enable DMA request. DMA request is generated by receive interrupt INTRX.<br>D: disable<br>1: enable |  |
| 0    | DMAEN0     | R/W  | Enable DMA request. DMA request is generated by receive interrupt INTTX.<br>0: disable<br>1: enable |  |

Note 1: When DMA request is generated during DMA transfer is being, it is not kept and nesting. Note 2: Channel 1 and channel 3 do not support DMA request.

# 16.5 Operation in Each Mode

Table 16-3 shows the modes and data formats.

## Table 16-3 Mode and Data format

| Mode   | Mode type                                                      | Data length | Transfer direction  | Specifies<br>whether to use<br>parity bits. | STOP bit length (transmit) |  |
|--------|----------------------------------------------------------------|-------------|---------------------|---------------------------------------------|----------------------------|--|
| Mode 0 | Synchronous communication<br>mode 8 bit<br>(IO interface mode) |             | LSB first/MSB first | -                                           | -                          |  |
| Mode 1 | Asynchronous communica-                                        | 7 bit       |                     | 0                                           |                            |  |
| Mode 2 | tion mode                                                      | 8 bit       | LSB first           | 0                                           | 1 bit or 2 bit             |  |
| Mode 3 | (UART mode)                                                    | 9 bit       |                     | ×                                           |                            |  |

Mode 0 is a 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 use parity bits 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 wakeup 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.

# 16.6 Data Format

## 16.6.1 Data Format List

Figure 16-2 shows data format.





## 16.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 <EVEN> bit of SCxCR selects either even or odd parity.

## 16.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 and SCxMOD<TB8> in the 8-bit UART mode.

The <PE> and <EVEN> settings must be completed before data is written to the transmit buffer.

## 16.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.

## 16.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.

# 16.7 Clock Control

## 16.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  $\Phi$ 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] > = "11".

Table 16-4 (operation frequency 40MHz), Table 16-5 (operation frequency 32MHz) show the resolution of the input clock to the baud rate generator.

Table 16-4 Clock Resolution to the Baud Rate Generator fc = 40 MHz

| peripheral clock                        | Clock gear                                  | Prescaler clock se-                           |                             | Prescaler output             | clock resolution              |                               |
|-----------------------------------------|---------------------------------------------|-----------------------------------------------|-----------------------------|------------------------------|-------------------------------|-------------------------------|
| selection<br>CGSYSCR<br><fpsel></fpsel> | 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.05 µs)             | fc/2³ (0.2 µs)               | fc/2⁵ (0.8 μs)                | fc/2 <sup>7</sup> (3.2 µs)    |
|                                         |                                             | 001 (fperiph/2)                               | fc/2 <sup>2</sup> (0.1 µs)  | fc/24 (0.4 µs)               | fc/2 <sup>6</sup> (1.6 µs)    | fc/2 <sup>8</sup> (6.4 µs)    |
|                                         | 000 (fr)                                    | 010 (fperiph/4)                               | fc/23 (0.2 µs)              | fc/2 <sup>5</sup> (0.8 µs)   | fc/2 <sup>7</sup> (3.2 μs)    | fc/2 <sup>9</sup> (12.8 µs)   |
|                                         | 000 (fc)                                    | 011 (fperiph/8)                               | fc/24 (0.4 µs)              | fc/2 <sup>6</sup> (1.6 μs)   | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 100 (fperiph/16)                              | fc/2 <sup>5</sup> (0.8 μs)  | fc/2 <sup>7</sup> (3.2 µs)   | fc/2 <sup>9</sup> (12.8 μs)   | fc/2 <sup>11</sup> (51.2 µs)  |
|                                         |                                             | 101 (fperiph/32)                              | fc/2 <sup>6</sup> (1.6 µs)  | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>12</sup> (102.4 µs) |
|                                         |                                             | 000 (fperiph/1)                               | fc/2 <sup>2</sup> (0.1 µs)  | fc/24 (0.4 µs)               | fc/2 <sup>6</sup> (1.6 µs)    | fc/2 <sup>8</sup> (6.4 µs)    |
|                                         | 100 (fc/2)                                  | 001 (fperiph/2)                               | fc/23 (0.2 µs)              | fc/2 <sup>5</sup> (0.8 μs)   | fc/2 <sup>7</sup> (3.2 μs)    | fc/2 <sup>9</sup> (12.8 μs)   |
|                                         |                                             | 010 (fperiph/4)                               | fc/24 (0.4 µs)              | fc/2 <sup>6</sup> (1.6 μs)   | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 011 (fperiph/8)                               | fc/2 <sup>5</sup> (0.8 µs)  | fc/2 <sup>7</sup> (3.2 µs)   | fc/2 <sup>9</sup> (12.8 µs)   | fc/2 <sup>11</sup> (51.2 µs)  |
|                                         |                                             | 100 (fperiph/16)                              | fc/26 (1.6 µs)              | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>12</sup> (102.4 µs) |
| 0 (()                                   |                                             | 101 (fperiph/32)                              | fc/27 (3.2 µs)              | fc/2 <sup>9</sup> (12.8 µs)  | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>13</sup> (204.8 µs) |
| 0 (fgear)                               |                                             | 000 (fperiph/1)                               | fc/23 (0.2 µs)              | fc/2 <sup>5</sup> (0.8 μs)   | fc/2 <sup>7</sup> (3.2 μs)    | fc/2º (12.8 µs)               |
|                                         |                                             | 001 (fperiph/2)                               | fc/24 (0.4 µs)              | fc/2 <sup>6</sup> (1.6 μs)   | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 010 (fperiph/4)                               | fc/2⁵ (0.8 µs)              | fc/2 <sup>7</sup> (3.2 μs)   | fc/2 <sup>9</sup> (12.8 µs)   | fc/2 <sup>11</sup> (51.2 µs)  |
|                                         | 101 (fc/4)                                  | 011 (fperiph/8)                               | fc/26 (1.6 µs)              | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>12</sup> (102.4 µs) |
|                                         |                                             | 100 (fperiph/16)                              | fc/27 (3.2 µs)              | fc/2 <sup>9</sup> (12.8 µs)  | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>13</sup> (204.8 µs) |
|                                         |                                             | 101 (fperiph/32)                              | fc/28 (6.4 µs)              | fc/2 <sup>10</sup> (25.6 µs) | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>14</sup> (409.6 µs) |
|                                         |                                             | 000 (fperiph/1)                               | fc/24 (0.4 µs)              | fc/2 <sup>6</sup> (1.6 μs)   | fc/2 <sup>8</sup> (6.4 µs)    | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 001 (fperiph/2)                               | fc/2 <sup>5</sup> (0.8 µs)  | fc/2 <sup>7</sup> (3.2 μs)   | fc/2 <sup>9</sup> (12.8 µs)   | fc/2 <sup>11</sup> (51.2 µs)  |
|                                         | 440. (5. 10)                                | 010 (fperiph/4)                               | fc/2 <sup>6</sup> (1.6 µs)  | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  | fc/2 <sup>12</sup> (102.4 µs) |
|                                         | 110 (fc/8)                                  | 011 (fperiph/8)                               | fc/27 (3.2 µs)              | fc/2 <sup>9</sup> (12.8 µs)  | fc/2 <sup>11</sup> (51.2 µs)  | fc/2 <sup>13</sup> (204.8 µs) |
|                                         |                                             | 100 (fperiph/16)                              | fc/2 <sup>8</sup> (6.4 µs)  | fc/2 <sup>10</sup> (25.6 µs) | fc/2 <sup>12</sup> (102.4 µs) | fc/2 <sup>14</sup> (409.6 µs) |
|                                         |                                             | 101 (fperiph/32)                              | fc/2 <sup>9</sup> (12.8 µs) | fc/2 <sup>11</sup> (51.2 μs) | fc/2 <sup>13</sup> (204.8 µs) | fc/2 <sup>15</sup> (819.2 µs) |

# TOSHIBA

| peripheral clock                        | Clock gear                                  | Prescaler clock se-                           |                            | Prescaler output           | clock resolution             |                               |
|-----------------------------------------|---------------------------------------------|-----------------------------------------------|----------------------------|----------------------------|------------------------------|-------------------------------|
| selection<br>CGSYSCR<br><fpsel></fpsel> | value<br>CGSYSCR<br><gear[2:0]></gear[2:0]> | lection<br>CGSYSCR<br><prck[2:0]></prck[2:0]> | φT1                        | φΤ4                        | φΤ16                         | φΤ64                          |
|                                         |                                             | 000 (fperiph/1)                               | fc/2¹ (0.05 μs)            | fc/2³ (0.2 µs)             | fc/2 <sup>5</sup> (0.8 µs)   | fc/2 <sup>7</sup> (3.2 µs)    |
|                                         |                                             | 001 (fperiph/2)                               | fc/2² (0.1 µs)             | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   | fc/28 (6.4 µs)                |
|                                         | 000 (fr)                                    | 010 (fperiph/4)                               | fc/23 (0.2 µs)             | fc/2 <sup>5</sup> (0.8 µs) | fc/2 <sup>7</sup> (3.2 µs)   | fc/2º (12.8 µs)               |
|                                         | 000 (fc)                                    | 011 (fperiph/8)                               | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 100 (fperiph/16)                              | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (3.2 µs) | fc/2 <sup>9</sup> (12.8 μs)  | fc/2 <sup>11</sup> (51.2 µs)  |
|                                         |                                             | 101 (fperiph/32)                              | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs) | fc/2 <sup>10</sup> (25.6 µs) | fc/212 (102.4 µs)             |
|                                         |                                             | 000 (fperiph/1)                               | -                          | fc/2 <sup>3</sup> (0.2 µs) | fc/2 <sup>5</sup> (0.8 µs)   | fc/27 (3.2 µs)                |
|                                         |                                             | 001 (fperiph/2)                               | fc/2 <sup>2</sup> (0.1 µs) | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   | fc/28 (6.4 µs)                |
|                                         | 400 (5-10)                                  | 010 (fperiph/4)                               | fc/23 (0.2 µs)             | fc/2 <sup>5</sup> (0.8 µs) | fc/2 <sup>7</sup> (3.2 µs)   | fc/2 <sup>9</sup> (12.8 µs)   |
|                                         | 100 (fc/2)                                  | 011 (fperiph/8)                               | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 100 (fperiph/16)                              | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (3.2 µs) | fc/2º (12.8 µs)              | fc/2 <sup>11</sup> (51.2 µs)  |
| 4 (5-)                                  |                                             | 101 (fperiph/32)                              | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs) | fc/2 <sup>10</sup> (25.6 µs) | fc/212 (102.4 µs)             |
| 1 (fc)                                  |                                             | 000 (fperiph/1)                               | -                          | fc/2 <sup>3</sup> (0.2 µs) | fc/2 <sup>5</sup> (0.8 µs)   | fc/27 (3.2 µs)                |
|                                         |                                             | 001 (fperiph/2)                               | -                          | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   | fc/2 <sup>8</sup> (6.4 µs)    |
|                                         | 101 (5.11)                                  | 010 (fperiph/4)                               | fc/23 (0.2 µs)             | fc/2 <sup>5</sup> (0.8 µs) | fc/2 <sup>7</sup> (3.2 µs)   | fc/2º (12.8 µs)               |
|                                         | 101 (fc/4)                                  | 011 (fperiph/8)                               | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 100 (fperiph/16)                              | fc/2 <sup>5</sup> (0.8 µs) | fc/2 <sup>7</sup> (3.2 µs) | fc/2 <sup>9</sup> (12.8 µs)  | fc/2 <sup>11</sup> (51.2 µs)  |
|                                         |                                             | 101 (fperiph/32)                              | fc/2 <sup>6</sup> (1.6 µs) | fc/2 <sup>8</sup> (6.4 µs) | fc/2 <sup>10</sup> (25.6 µs) | fc/2 <sup>12</sup> (102.4 µs) |
|                                         |                                             | 000 (fperiph/1)                               | -                          | -                          | fc/2 <sup>5</sup> (0.8 µs)   | fc/27 (3.2 µs)                |
|                                         |                                             | 001 (fperiph/2)                               | -                          | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 µs)   | fc/28 (6.4 µs)                |
|                                         | 110 (fa/9)                                  | 010 (fperiph/4)                               | -                          | fc/2⁵ (0.8 µs)             | fc/2 <sup>7</sup> (3.2 µs)   | fc/2 <sup>9</sup> (12.8 µs)   |
|                                         | 110 (fc/8)                                  | 011 (fperiph/8)                               | fc/24 (0.4 µs)             | fc/2 <sup>6</sup> (1.6 μs) | fc/2 <sup>8</sup> (6.4 µs)   | fc/2 <sup>10</sup> (25.6 µs)  |
|                                         |                                             | 100 (fperiph/16)                              | fc/2 <sup>5</sup> (0.8 μs) | fc/2 <sup>7</sup> (3.2 µs) | fc/2 <sup>9</sup> (12.8 µs)  | fc/2 <sup>11</sup> (51.2 µs)  |
|                                         |                                             | 101 (fperiph/32)                              | fc/2 <sup>6</sup> (1.6 μs) | fc/2 <sup>8</sup> (6.4 μs) | fc/2 <sup>10</sup> (25.6 µs) | fc/2 <sup>12</sup> (102.4 µs) |

## Table 16-4 Clock Resolution to the Baud Rate Generator fc = 40 MHz

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 dashes in the above table indicate that the setting is prohibited.

| peripheral clock                        | Clock gear      | Prescaler clock se-                           |                              | Prescaler output             | clock resolution              |                               |
|-----------------------------------------|-----------------|-----------------------------------------------|------------------------------|------------------------------|-------------------------------|-------------------------------|
| selection<br>CGSYSCR<br><fpsel></fpsel> | CGSYSCR CGSYSCR | 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⁵ (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/2 <sup>8</sup> (8.0 µs)    |
|                                         | 000 (6-)        | 010 (fperiph/4)                               | fc/2 <sup>3</sup> (0.25 µs)  | fc/2⁵ (1.0 μs)               | fc/2 <sup>7</sup> (4.0 µs)    | fc/2º (16.0 µs)               |
|                                         | 000 (fc)        | 011 (fperiph/8)                               | fc/24 (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 <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/21 (0.0625 µs)            | fc/24 (0.5 µs)               | fc/2 <sup>6</sup> (2.0 µs)    | fc/2 <sup>8</sup> (8.0 µs)    |
|                                         | 400 (5-10)      | 001 (fperiph/2)                               | fc/23 (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)   |
|                                         |                 | 010 (fperiph/4)                               | fc/24 (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 (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)               | fc/211 (64.0 µs)              |
|                                         |                 | 100 (fperiph/16)                              | 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) |
| 0 (facar)                               |                 | 101 (fperiph/32)                              | fc/27 (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 (fgear)                               |                 | 000 (fperiph/1)                               | fc/21 (0.0625 µ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)   |
|                                         |                 | 001 (fperiph/2)                               | fc/24 (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)  |
|                                         | 404 (5-(4)      | 010 (fperiph/4)                               | fc/2 <sup>5</sup> (1.0 µs)   | fc/2 <sup>7</sup> (4.0 µs)   | fc/2º (16.0 µs)               | fc/211 (64.0 µs)              |
|                                         | 101 (fc/4)      | 011 (fperiph/8)                               | 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) |
|                                         |                 | 100 (fperiph/16)                              | fc/27 (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/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) |
| -                                       |                 | 000 (fperiph/1)                               | fc/21 (0.0625 µs)            | fc/2 <sup>6</sup> (2.0 µs)   | fc/2 <sup>8</sup> (8.0 µs)    | fc/210 (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 (fo/9)      | 010 (fperiph/4)                               | 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) |
|                                         | 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)  | 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º (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 16-5 Clock Resolution to the Baud Rate Generator fc = 32 MHz

# TOSHIBA

| peripheral clock                        | Clock gear                                  | Prescaler clock se-                           |                             | Prescaler output           | clock resolution             |                               |
|-----------------------------------------|---------------------------------------------|-----------------------------------------------|-----------------------------|----------------------------|------------------------------|-------------------------------|
| selection<br>CGSYSCR<br><fpsel></fpsel> | 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³ (0.25 µs)            | fc/2⁵ (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/2 <sup>6</sup> (2.0 µs)   | fc/2 <sup>8</sup> (8.0 µs)    |
|                                         | 000 (fr)                                    | 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/24 (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⁵ (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³ (0.25 µs)            | fc/2⁵ (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/2 <sup>6</sup> (2.0 µs)   | fc/2 <sup>8</sup> (8.0 µs)    |
|                                         | 100 (fc/2)                                  | 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)   |
|                                         |                                             | 011 (fperiph/8)                               | fc/24 (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⁵ (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)  |
| 4 (5-)                                  |                                             | 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) |
| 1 (fc)                                  |                                             | 000 (fperiph/1)                               | -                           | fc/2³ (0.25 µs)            | fc/2⁵ (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/2 <sup>8</sup> (8.0 µs)    |
|                                         | 101 (5-14)                                  | 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/24 (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/27 (4.0 µs)             | fc/2º (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⁵ (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/2 <sup>8</sup> (8.0 µs)    |
|                                         | 110 (fa/9)                                  | 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/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) |

## Table 16-5 Clock Resolution to the Baud Rate Generator fc = 32 MHz

Note 1: The prescaler output clock  $\varphi$ Tn must be selected so that the relationship " $\varphi$ Tn  $\leq$  fsys / 2" is satisfied (so that  $\varphi$ Tn is slower than fsys / 2).

Note 2: Do not change the clock gear while SIO is operating.

Note 3: The dashes in the above table indicate that the setting is prohibited.

Note 1:

Note 2:

Note 3:

## 16.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.

## 16.7.2.1 Baud Rate Generator

The baud rate generator generates transmit and receive clocks to determine the serial channel transfer rate.

#### (1) Baud 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<br>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.

16.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 16-6 shows clock selection in I/O interface mode.

## Table 16-6 Clock Selection in I/O Interface Mode

| Mode<br>SCxMOD0 <sm></sm> | Input/Output<br>selection<br>SCxCR <ioc></ioc> | Clock edge selection<br>SCxCR <sclks></sclks> | Clock of use                                         |
|---------------------------|------------------------------------------------|-----------------------------------------------|------------------------------------------------------|
|                           | SCLK output                                    | Set to "0".<br>(Fixed to the rising edge)     | Divided by 2 of the baud rate gen-<br>erator output. |
| I/O interface mode        | 0011/11/11                                     | 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.

- <u>Clock/mode control block settings</u>
  - fc = 40 MHz
  - fgear = 40MHz (CGSYSCR<GEAR[2:0]> = "000" : fc selected)
  - $\phi$ 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.

- <u>SIO settings (if double buffer is not used)</u>
  - Clock (SCxBRCR<BRCK[1:0]> = "00" :  $\varphi$ 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 baud rate is less than  $54 \div 6 = 9$  Mbps.

• If double buffer is not used

- SCLK cycle > 8/fsys

The highest baud rate is less than  $54 \div 8 = 6.75$  Mbps.

## (2) Transfer clock in the UART mode

Table 16-7 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.

| Mode<br>SCxMOD0 <sm></sm> | Clock selection<br>SCxMOD0 <sc></sc> |
|---------------------------|--------------------------------------|
|                           | Timer output                         |
|                           | Baud rate generator                  |
| UART Mode                 | fsys                                 |
|                           | SCLK input                           |

Table 16-7 Clock Selection in UART Mode

The examples of baud rate in each clock settings.

- If the baud rate generator is used
  - fc = 40MHz
  - fgear = 40MHz (CGSYSCR<GEAR[2:0]> = "000" : fc selected)
  - $\phi T0 = 40 MHz (CGSYSCR < PRCK[2:0] > = "000" : 1 division ratio)$
  - Clock =  $\Phi$ T1 = 20MHz (SCxBRCR<BRCK[1:0]> = "00" :  $\varphi$ T1 selected)

The highest baud rate is 1.25Mbps because 20MHz is divided by 16.

Table 16-8 shows examples of baud rate when the baud rate generator is used with the following clock settings.

- fc = 9.8304 MHz
- fgear = 9.8304MHz (CGSYSCR<GEAR[2:0]> = "000" : fc selected)
- $\phi$ T0 = 4.9152MHz (CGSYSCR<PRCK[2:0]> = "001" : 2 division ratio)

#### Table 16-8 Example of UART Mode Baud Rate (Using the Baud Rate Generator)

| fc [MHz] | Division ratio N<br>(SCxBRCR <brs>)</brs> | φT1<br>(fc/4) | φT4<br>(fc/16) | φT16<br>(fc/64) | φT64<br>(fc/256) |
|----------|-------------------------------------------|---------------|----------------|-----------------|------------------|
| 9.830400 | 2                                         | 76.800        | 19.200         | 4.800           | 1.200            |
|          | 4                                         | 38.400        | 9.600          | 2.400           | 0.600            |
|          | 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  $54 \div 2 \div 16 = 1.68$  Mbps.

• If fsys is used

Since the highest value of fsys is 54MHz, the highest baud rate is  $54 \div 16 = 3.37$ 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 TBxRG0 match. The SIOCLK clock frequency is "Setting value of TBxRG0  $\times$  2".

Baud rates can be obtained by using the following formula.

#### Baud rate calculation

•



Table 16-9 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)
- φT0 = 16MHz / 4.9152MHz / 4MHz (CGSYSCR<PRCK[2:0]> = "001" : 2 division ratio)
- Timer count clock = 4MHz / 1.2287MHz / 1MHz (TBxMOD<TBCLK[1:0]> = "01" : φT1 selected)

| fc     |                                                             |                                                                                                                                                                                                                                                                           |  |  |
|--------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 32MHz  | 9.8304MHz                                                   | 8MHz                                                                                                                                                                                                                                                                      |  |  |
| 250    | 76.8                                                        | 62.5                                                                                                                                                                                                                                                                      |  |  |
| 125    | 38.4                                                        | 31.25                                                                                                                                                                                                                                                                     |  |  |
| -      | 25.6                                                        | -                                                                                                                                                                                                                                                                         |  |  |
| 62.5   | 19.2                                                        | 15.625                                                                                                                                                                                                                                                                    |  |  |
| 50     | 15.36                                                       | 12.5                                                                                                                                                                                                                                                                      |  |  |
| -      | 12.8                                                        | -                                                                                                                                                                                                                                                                         |  |  |
| 31.25  | 9.6                                                         | -                                                                                                                                                                                                                                                                         |  |  |
| 25     | 7.68                                                        | 6.25                                                                                                                                                                                                                                                                      |  |  |
| 15.625 | 4.8                                                         | -                                                                                                                                                                                                                                                                         |  |  |
| 12.5   | 3.84                                                        | 3.125                                                                                                                                                                                                                                                                     |  |  |
|        | 250<br>125<br>-<br>62.5<br>50<br>-<br>31.25<br>25<br>15.625 | 32MHz         9.8304MHz           250         76.8           125         38.4           -         25.6           62.5         19.2           50         15.36           -         12.8           31.25         9.6           25         7.68           15.625         4.8 |  |  |

Unit : kbps

# 16.8 Transmit/Receive Buffer and FIFO

## 16.8.1 Configuration

Figure 16-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 16-3 The Configuration of Buffer and FIFO

## 16.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 16-10 shows correlation between modes and buffers.

| Mada          | SCxMOD2 <wbuf></wbuf> |        |        |
|---------------|-----------------------|--------|--------|
| Mode          | "0"                   | "1"    |        |
| UART          | Transmit              | Single | Double |
|               | Receive               | Double | Double |
| I/O interface | Transmit              | Single | Double |
| (SCLK input)  | Receive               | Double | Double |
| I/O interface | Transmit              | Single | Double |
| (SCLK output) | Receive               | Single | Double |

Table 16-10 Mode and buffer Composition

## 16.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]>.

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 16-11 shows correlation between modes and FIFO.

|                | 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   |  |

# 16.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".

## 16.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 meanings in each mode.

These flags are cleared to "0" after reading the SCxCR register.

| Mode                           | Flag          |                                                         |               |  |  |
|--------------------------------|---------------|---------------------------------------------------------|---------------|--|--|
| Mode                           | <oerr></oerr> | <perr></perr>                                           | <ferr></ferr> |  |  |
| UART                           | Overrun error | Parity error                                            | Framing error |  |  |
| I/O Interface<br>(SCLK input)  | 0             | Underrun error<br>(When using double buffer<br>or FIFO) | <b>F</b> ( )  |  |  |
|                                | 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    |  |  |

## 16.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.

## 16.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 under-run flag.

## 16.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.

# TOSHIBA

## 16.11 Receive

## 16.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.

## 16.11.2 Receive Control Unit

## 16.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.

## 16.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.

## 16.11.3 Receive Operation

## 16.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 INTRXx 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.





## 16.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 following describes configurations and operations in the half duplex RX mode.

| 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-<br>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 operation is finished.

In this above condition, if the continuous reception after reaching the fill level is enabled, and it is possible to receive a data continuously with and reading the data in the FIFO.



Figure 16-5 Receive FIFO Operation

## 16.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. So, 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 is restarted.

## (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 is restarted.

## (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 received buffer and SCLK output is restarted.

And if SCxFCNF<RXTXCNT> is set to "1", SCLK stops and receive operation stops with clearing SCxMOD0<RXE> bit too.

#### 16.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>.

### 16.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."

#### 16.11.3.6 Overrun Error

When FIFO is disabled, the overrun error is occurred and set overrun flag without completing data read before receiving the next data. When overrun error is occurred, 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 content 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.

## 16.12 Transmission

## 16.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.





## 16.12.2 Transmission Control

## 16.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.

## 16.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.

## 16.12.3 Transmit Operation

#### 16.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 16-7 Operation of Transmission Buffer (Double-buffer is enabled)

## 16.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 (SCxFCNF<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     | : Transfer mode is set to half duplex.                                                                 |
|----------------------|--------------------------------------------------------------------------------------------------------|
| SCxFCNF[4:0] = 11011 | : 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 generation fill level. |
| SCxTFC[1:0] = 00     | : Sets the interrupt generation fill level to "0".                                                     |
| SCxTFC[7:6] = 11     | : Clears receive FIFO and sets the condition of interrupt generation.                                  |

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 by writing transmit data.

| Transmit FIFO fourth stage | DATA 5 |        |        |     |              |        |        |
|----------------------------|--------|--------|--------|-----|--------------|--------|--------|
| Third stage                | DATA 4 | DATA 5 |        |     |              |        |        |
| Second stage               | DATA 3 | DATA 4 | DATA S | 5   |              |        |        |
| First stage                | DATA 2 | DATA 3 | DATA 4 | 4   | DATA 5       |        |        |
|                            |        | 1      |        |     |              | 1      |        |
| Transmit buffer            | DATA 1 | DATA 2 | DATA   | 3   | DATA 4       | DATA 5 |        |
|                            |        |        | ,      |     | $\downarrow$ | ↓      |        |
| Transmit shift register    | [      | DATA 1 | DATA 2 | DAT | ʿA 3 [       | DATA 4 | DATA 5 |
|                            |        |        |        |     |              |        |        |
| SCxMOD1 <txe></txe>        |        |        |        |     |              |        |        |
|                            |        |        |        |     |              |        |        |
| SCxMOD2 <tbemp></tbemp>    |        | П      | Г      | 1   |              |        |        |
|                            |        |        |        |     |              |        |        |
| Transmit interrupt(INTTXx) |        |        |        |     |              |        |        |
|                            |        |        |        |     |              |        |        |

#### 16.12.3.3 I/O interface Mode/Transmission by SCLK Output

If SCLK is set to generate clock 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

TOSHIBA

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.

#### 16.12.3.4 Under-run 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.

Note: Before switching the I/O interface SCLK output mode to other modes, read the SCxCR register and clear the underrun flag.

### 16.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 the  $\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 "H" during transmission, the next data transmission is suspended after the current transmission is completed. (2) Data transmission starts on the first falling edge of the TXDCLK clock after CTS is set to "L".

Although no  $\overline{\text{RTS}}$  pin is provided, a handshake control function can easily implemented by assigning one bit of the port for the  $\overline{\text{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 16-8 Handshake Function



Figure 16-9 CTS Signal timing

## 16.14 Interrupt/Error Generation Timing

### 16.14.1 RX Interrupts

Figure 16-10 shows the data flow of receive operation and the route of read.



Figure 16-10 Receive Buffer/FIFO Configuration Diagram

### 16.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 as follows.

| Buffer<br>Configurations | UART modes                              | IO interface modes                                                                                                                                                                                                                                    |
|--------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Single Buffer            | -                                       | <ul> <li>Immediately after the raising / falling edge of the last SCLK<br/>(Rising or falling is determined according to SCxCR<sclks> setting.)</sclks></li> </ul>                                                                                    |
| Double Buffer            | Around the center of the first stop bit | <ul> <li>Immediately after the raising / falling edge of the last SCLK<br/>(Rising or falling is determined according to SCxCR<sclks> setting.)</sclks></li> <li>On data transfer from the shift register to the buffer by reading buffer.</li> </ul> |

Note: Interrupts are not generated when an overrun error is occurred.

### 16.14.1.2 FIFO

In use of FIFO, receive interrupt is generated on the condition that the following either operation and SCxRFC<RFIS > setting are established.

- Reception completion of all bits of one frame.
- · Reading FIFO

Interrupt conditions are decided by the SCxRFC<RFIS> settings as described in Table 16-12.

### Table 16-12 Receive Interrupt conditions in use of FIFO

| SCxRFC <rfis></rfis> | Interrupt conditions                                                                                  |
|----------------------|-------------------------------------------------------------------------------------------------------|
| "0"                  | "The fill level of FIFO" is equal to "the fill level of FIFO interruption generation."                |
| "1"                  | "The fill level of FIFO" is greater than or equal to "the fill level of FIFO intrruption generation." |

### 16.14.2 TX interrupts

Figure 16-11 shows the data flow of transmit operation and the route of read.



Figure 16-11 Transmit Buffer/FIFO Configuration Diagram

### 16.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<br>Configurations | UART modes                                                                    | IO interface modes                                                                                                                             |  |  |  |  |
|--------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Single Buffer            | Just before the stop bit is sent                                              | Immediately after the raising / falling edge of the last SCLK<br>(Rising or falling is determined according to SCxCR <sclks> setting.)</sclks> |  |  |  |  |
| Double Buffer            | When a data is moved from the transmit 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.

### 16.14.2.2 FIFO

In use of FIFO, transmit interrupt is generated on the condition that the following either operation and SCxTFC<TFIS> setting are established.

- Transmittion completion of all bits of one frame.
- Writing FIFO

Interrupt conditions are decided by the SCxTFC<TFIS> settings as described in Table 16-13.

Table 16-13 Transmit Interrupt conditions in use of FIFO

| SCxTFC <tfis></tfis> | Interrupt conditions                                                                                        |
|----------------------|-------------------------------------------------------------------------------------------------------------|
| "0"                  | "The fill level of FIFO" is equal to "the fill level of FIFO interruption generation."                      |
| "1"                  | "The fill level of FIFO" is smaller than or equal to "the fill level of FIFO interruption genera-<br>tion." |

### 16.14.3 Error Generation

### 16.14.3.1 UART Mode

| modes                          | 9 bits        | 7 bits<br>8 bits<br>7 bits+ Parity<br>8 bits + Parity |  |  |
|--------------------------------|---------------|-------------------------------------------------------|--|--|
| Framing Error<br>Overrun Error | Around the ce | enter of stop bit                                     |  |  |
| Parity Error                   | -             | Around the center of parity bit                       |  |  |

### 16.14.3.2 IO 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.<br>(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.

## 16.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.

### 16.16 DMA request

DMA request to DMAC is generated at the timing of UART/SIO interrupt request (INTRX0, INTTX0, INTRX2, INTRX2, INTRX4, INTTX4). When DMA transfer is used, set SCxDMA (x=0, 2, 4).

### 16.17 Operation in Each Mode

### 16.17.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.

### 16.17.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.





### (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 16-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.



TBEMP

PERR

(Functions to detect under-run errors)

<WBUF> = "1" (if double buffering is enabled and there is no data in buffer2)

Figure 16-13 Transmit Operation in the I/O Interface Mode (SCLK Input Mode)

### 16.17.1.2 Receive

### (1) SCLK Output Mode

The SCLK output can be started by setting the receive enable bit SCxMOD0<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.



<WBUF> = "1" (if double buffering is enabled and data cannot be read from buffer)

Figure 16-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 INTRx receive interrupt is generated each time received data is moved to the receive buffer.







#### 16.17.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.

## <u>TOSHIBA</u>



Figure 16-16 Transmit/Receive Operation in the I/O Interface Mode (SCLK Output Mode)

#### (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 16-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 16-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.

## TOSHIBA

| Receive data read timing      |                                                                                                                                         |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Transmit data<br>write timing |                                                                                                                                         |
| SCLK input                    |                                                                                                                                         |
| TXD                           | bit 0 bit 1 bit 5 bit 6 bit 7 bit 0 bit 1                                                                                               |
| RXD                           | $\underbrace{X \text{ bit 0 } X \text{ bit 1 } X}_{\text{bit 5 } X \text{ bit 6 } X \text{ bit 7 } X \text{ bit 0 } X \text{ bit 1 } X$ |
| (INTTXx interrupt reque       | <u></u>                                                                                                                                 |
| (INTRXx interrupt reque       | [                                                                                                                                       |
|                               | <wbuf> = "0" (if double buffering is disabled)</wbuf>                                                                                   |
| Receive data<br>read timing   |                                                                                                                                         |
| Transmit data<br>write timing |                                                                                                                                         |
| SCLK input                    |                                                                                                                                         |
|                               |                                                                                                                                         |
| TXD                           | bit 0 X bit 1 X bit 5 X bit 6 X bit 7 X bit 0 X bit 1 X                                                                                 |
| RXD                           | bit 0 bit 1 1 bit 5 bit 6 bit 7 bit 0 bit 1                                                                                             |
| (INTTXx interrupt reque       | est)                                                                                                                                    |
| (INTRXx interrupt reque       | est)                                                                                                                                    |
|                               | <wbuf> = "1" (if double buffering is enabled with no errors)</wbuf>                                                                     |
| Receive data read timing      | Л                                                                                                                                       |
| Transmit data write timing    |                                                                                                                                         |
| SCLK input                    |                                                                                                                                         |
|                               |                                                                                                                                         |
| TXD                           | bit 0 X bit 1 X bit 5 X bit 6 X bit 7 X bit 0 X bit 1 X                                                                                 |
| RXD                           |                                                                                                                                         |
| (INTTXx interrupt reque       | est) [                                                                                                                                  |
| (INTRXx interrupt reque       | est)                                                                                                                                    |
| PERR(Under-run errors         | s)                                                                                                                                      |
|                               | <wbuf> = "1" (if double buffering is enabled with error generation)</wbuf>                                                              |

Figure 16-17 Transmit/Receive Operation in the I/O Interface Mode (SCLK Input Mode)

### 16.17.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.

|                          | bit 0<br>Transm | 1<br>nission | <mark>∑ 2</mark><br>n dire | ction  | 3 X<br>(Trans | 4<br>missic | 5<br>on rate              | ₹<br>e of b | <u></u>       | ven<br>arity stop<br>= 9.8304 MHz) |
|--------------------------|-----------------|--------------|----------------------------|--------|---------------|-------------|---------------------------|-------------|---------------|------------------------------------|
| Clocking condi-<br>tions | . н             | ligh-sp      | clock<br>eed cl<br>er cloc | ock ge | ar:           | X1          | gh-spe<br>(fc)<br>eriph/2 |             | )<br>oh = fsy | ys)                                |
|                          |                 | 7            | 6                          | 5      | 4             | 3           | 2                         | 1           | 0             |                                    |
| SCxMOD0                  | ←               | х            | 0                          | -      | 0             | 0           | 1                         | 0           | 1             | Set 7-bit UART mode                |
| SCxCR                    | $\leftarrow$    | х            | 1                          | 1      | х             | х           | х                         | 0           | 0             | Even parity enabled                |
| SCxBRCR                  | $\leftarrow$    | 0            | 0                          | 1      | 0             | 0           | 1                         | 0           | 0             | Set 2400bps                        |
| SCxBUF                   | ←               | *            | *                          | *      | *             | *           | *                         | *           | *             | Set transmit data                  |
| x : don't care - :       | no cha          | ange         |                            |        |               |             |                           |             |               |                                    |

### 16.17.3 Mode 2 (8-bit UART mode)

The 8-bit UART mode can be selected by setting SCxMOD0 $\leq$ SM[1:0]> to "10." In this mode, parity bits can be added and parity enable/disable is controlled using SCxCR $\leq$ PE>. If  $\leq$ PE> = "1" (enabled), either even or odd parity can be selected using SCxCR $\leq$ 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 | inge |   |   |   |   |   |   |   |                     |

### 16.17.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>.

### 16.17.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 16-18 Serial Links to Use Wake-up Function

### 16.17.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".

$$\frac{1}{2 \times 3 \times 4 \times 5 \times 6 \times 7} \text{bit } 8 \text{stop}$$

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.

## TOSHIBA

## 17. Synchronous Serial Port (SSP)

## 17.1 Overview

This LSI contains the SSP (Synchronous Serial Port) with 1 channel. This channel has the following features.

| Communica           | tion protocol        | <ul> <li>Three types of synchronous serial ports including the SPI</li> <li>Motorola SPI (SPI) frame format</li> <li>TI synchronous (SSI) frame format</li> <li>National Microwire (Microwire) frame format</li> </ul> |  |  |  |  |
|---------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Operatio            | 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                                                                                                                                                                                                           |  |  |  |  |
| Interru             | pt type              | Transmit interrupt<br>Receive interrupt<br>Receive overrun interrupt<br>Time-out interrupt                                                                                                                             |  |  |  |  |
| Communication and   | In master mode       | fsys / 2 (max. 20Mbps)                                                                                                                                                                                                 |  |  |  |  |
| Communication speed | In slave mode (Note) | fsys / 12 (max. 4.5Mbps)                                                                                                                                                                                               |  |  |  |  |
| DI                  | MA                   | Supported                                                                                                                                                                                                              |  |  |  |  |
| Internal te         | est function         | The internal loopback test mode is available.                                                                                                                                                                          |  |  |  |  |
| Contr               | rol pin              | SPCLK,SPFSS,SPDO,SPDI                                                                                                                                                                                                  |  |  |  |  |

Note:Set a clock prescaler to  $\underline{SSPCR0 < SCR[7:0] > = 0x00}$ ,  $\underline{SSPCPSR < CPSDVSR[7:0] > = 0x02}$ , when slave mode is selected.

## 17.2 Block Diagram



Figure 17-1 SSP block diagram

## 17.3 Register

### 17.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                                                    | -              | 0x0028 to 0x0FFC           |

Note 1: These registers in the above table allows to access only word (32 bits) basis.

Note 2: Access to the "Reserved" area is prohibited.

|             | 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        | 10        | 9         | 8         |
| bit symbol  |           | -         |           | S         | CR        |           |           |           |
| After Reset | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | SPH       | SPO       | Fi        | FRF       |           | D         | SS        |           |
| After Reset | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

## 17.3.2 SSPCR0(Control register 0)

| Bit   | Bit Symbol | Туре | Description                                                                                                                               |  |  |  |  |  |  |
|-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 31-16 | -          | W    | Write as "0".                                                                                                                             |  |  |  |  |  |  |
| 15-8  | SCR[7:0]   | R/W  | or serial clock rate setting.<br>arameter : 0x00 to 0xFF.                                                                                 |  |  |  |  |  |  |
|       |            |      | Bits to generate the SSP transmit bit rate and receive bit rate.<br>This bit rate can be obtained by the following equation.              |  |  |  |  |  |  |
|       |            |      | Bit rate = $f_{svs}$ / ( <cpsdvsr> × (1+ <scr>))</scr></cpsdvsr>                                                                          |  |  |  |  |  |  |
|       |            |      | 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> |  |  |  |  |  |  |
| 7     | SPH        | R/W  | SPCLK phase:                                                                                                                              |  |  |  |  |  |  |
|       |            |      | 0 : Captures data at the 1st clock edge.                                                                                                  |  |  |  |  |  |  |
|       |            |      | 1 : Captures data at the 2nd clock edge.                                                                                                  |  |  |  |  |  |  |
| 6     | SPO        | R/W  | This is applicable to Motorola SPI frame format only. Refer to Section "Motorola SPI frame format"                                        |  |  |  |  |  |  |
| 0     | SPO        | R/W  | SPCLK polarity:<br>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 op-<br>eration 1001: 10 bits data                                                                               |  |  |  |  |  |  |
|       |            |      | 0010: Reserved, undefined op-<br>eration 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                                                                                                      |  |  |  |  |  |  |

|             | 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        | 10        | 9         | 8         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After Reset | Undefined |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | -         | -         | -         | -         | SOD       | MS        | SSE       | LBM       |
| After Reset | Undefined | Undefined | Undefined | Undefined | 0         | 0         | 0         | 0         |

## 17.3.3 SSPCR1(Control register1)

| Bit  | Bit Symbol | Туре | Description                                                                                                                                                    |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | -          | W    | Write as "0".                                                                                                                                                  |
| 3    | SOD        | R/W  | Slave mode SPDO output control:<br>0: Enable<br>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)<br>0: Device configured as a master.<br>1: Device configured as a slave.                                                      |
| 1    | SSE        | R/W  | SSP enable/disable<br>0: Disable<br>1: Enable                                                                                                                  |
| 0    | LBM        | R/W  | Loop back mode<br>0: Normal serial port operation enabled.<br>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.

:<SSE>=1

1) Set to slave mode

:<MS>=1

- 2) Set transmit data in FIFO :<DATA>=0x\*\*\*\*
- 3) Set SSP to Enable.

## 17.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  | -         | -         | -         | -         | -         | -         | -         | -         |
| 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         | 1         | 0         |
| bit symbol  |           |           |           | DA        | TA        |           |           |           |
| After Reset | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

| Bit   | Bit Symbol | Туре | Description                                                                                                                                                                                                               |
|-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

## 17.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  | -         | -         | -         | -         | -         | -         | -         | -         |
| 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  | -         | -         | -         | BSY       | RFF       | RNE       | TNF       | TFE       |
| After Reset | Undefined | Undefined | Undefined | 0         | 0         | 0         | 1         | 1         |

| Bit  | Bit Symbol | Туре | Description                                                                                                                      |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------|
| 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<br/>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.                                                                                                       |

## 17.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  | -         | -         | -         | -         | -         | -         | -         | -         |
| 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  |           |           |           | CPSI      | OVSR      |           |           |           |
| After Reset | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

| Bit  | Bit Symbol   | Туре | Description                                                                                                                                                                                                                   |
|------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -            | W    | Write as "0".                                                                                                                                                                                                                 |
| 7-0  | CPSDVSR[7:0] | R/W  | Clock prescale divisor:<br>Set an even number from 2 to 254.<br>Clock prescale divisor: Must be an even number from 2 to 254, depending on the frequency of fsys. The<br>least significant bit always returns zero when read. |

|             | 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        | 10        | 9         | 8         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After Reset | Undefined |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | -         | -         | -         | -         | TXIM      | RXIM      | RTIM      | RORIM     |
| After Reset | Undefined | Undefined | Undefined | Undefined | 0         | 0         | 0         | 0         |

## 17.3.7 SSPIMSC (Interrupt enable/disable register)

| Bit  | Bit Symbol | Туре | Description                                                                                                                                  |
|------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | -          | W    | Write as "0".                                                                                                                                |
| 3    | ТХІМ       | 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 peri-<br>od and data is not read. |
| 0    | RORIM      | R/W  | Receive overrun interrupt enable:                                                                                                            |
|      |            |      | 0: Disable                                                                                                                                   |
|      |            |      | 1: Enable                                                                                                                                    |
|      |            |      | Enable or disable a conditioal interrupt to indicate that data was written when the receive FIFO was in the full condition.                  |

17.3 Register

| 17.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  | -         | -         | -         | -         | -         | -         | -         | -         |
| 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  | -         | -         | -         | -         | TXRIS     | RXRIS     | RTRIS     | RORRIS    |
| After Reset | Undefined | Undefined | Undefined | Undefined | 1         | 0         | 0         | 0         |

| Bit  | Bit Symbol | Туре | Description                                                                             |
|------|------------|------|-----------------------------------------------------------------------------------------|
| 31-4 | -          | W    | Write as "0".                                                                           |
| 3    | TXRIS      | R    | Pre-enable transmit interrupt flag:<br>0: Interrupt not present<br>1: Interrupt present |
| 2    | RXRIS      | R    | Pre-enable receive interrupt flag:<br>0: Interrupt not present<br>1: Interrupt present  |
| 1    | RTRIS      | R    | Pre-enable timeout interrupt flag:<br>0: Interrupt not present<br>1: Interrupt present  |
| 0    | RORRIS     | R    | Pre-enable overrun interrupt flag:<br>0: Interrupt not present<br>1: Interrupt present  |

25

\_

Undefined

24

-

Undefined

After Reset

Undefined

|            |    |    |    | pr otatuo . | egiotoi) |    |  |
|------------|----|----|----|-------------|----------|----|--|
|            | 31 | 30 | 29 | 28          | 27       | 26 |  |
| bit symbol | -  | -  | -  | -           | -        | -  |  |

Undefined

## 17.3.9 SSPMIS (Post-enable interrupt status register)

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  | -         | -         | -         | -         | TXMIS     | RXMIS     | RTMIS     | RORMIS    |
| After Reset | Undefined | Undefined | Undefined | Undefined | 0         | 0         | 0         | 0         |
|             |           |           |           |           |           |           |           |           |
|             |           |           |           |           |           |           |           |           |

Undefined

Undefined

Undefined

| Bit  | Bit Symbol | Туре | Description                                                                              |  |  |  |
|------|------------|------|------------------------------------------------------------------------------------------|--|--|--|
| 31-4 | -          | W    | Write as "0".                                                                            |  |  |  |
| 3    | TXMIS      | R    | st-enable transmit interrupt flag:<br>Interrupt not present<br>Interrupt present         |  |  |  |
| 2    | RXMIS      | R    | Post-enable receive interrupt flag:<br>0: Interrupt not present<br>1: Interrupt present  |  |  |  |
| 1    | RTMIS      | R    | Post-enable time-out interrupt flag:<br>0: Interrupt not present<br>1: Interrupt present |  |  |  |
| 0    | RORMIS     | R    | Post-enable overrun interrupt flag:<br>0: Interrupt not present<br>1: Interrupt present  |  |  |  |

|             | 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        | 10        | 9         | 8         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After Reset | Undefined |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | -         | -         | -         | -         | -         | -         | RTIC      | RORIC     |
| After Reset | Undefined |

## 17.3.10 SSPICR (Interrupt clear register)

| Bit  | Bit Symbol | Туре | Description                                                  |
|------|------------|------|--------------------------------------------------------------|
| 31-2 | -          | W    | Write as "0".                                                |
| 1    | RTIC       | W    | Clear the time-out interrupt flag:<br>0: Invalid<br>1: Clear |
| 0    | RORIC      | W    | Clear the overrun interrupt flag:<br>0: Invalid<br>1: Clear  |

## 17.3.11 SSPDMACR (DMA control 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        | 10        | 9         | 8         |
| bit symbol  | -         | -         | -         | -         | -         | -         | -         | -         |
| After Reset | Undefined |
|             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| bit symbol  | -         | -         | -         | -         | -         | -         | TXDMAE    | RXDMAE    |
| After Reset | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | 0         | 0         |

| Bit  | Bit Symbol | Туре | Description                                         |
|------|------------|------|-----------------------------------------------------|
| 31-2 | -          | W    | Write as "0".                                       |
| 1    | TXDMAE     | R/W  | Transmit FIFO DMA control:<br>0:Disable<br>1:Enable |
| 0    | RXDMAE     | R/W  | Transmit FIFO DMA control:<br>0:Disable<br>1:Enable |

### 17.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.

### 17.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.

Bitrate = fsys / (<CPSDVSR>×(1+<SCR>))



### 17.4.2 Transmit FIFO

This is a 16-bit wide, 8-layered transmit FIFO buffer, which is shared in master and slave modes.

### 17.4.3 Receive FIFO

This is a 16-bit wide 8-layered receive FIFO buffer, which is shared in master and slave modes.

### 17.4.4 Interrupt generation logic

The High active 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 (includ-<br>ing half) of the entire capacity.<br>(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 (includ-<br>ing half) the entire capacity.<br>(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 pe-<br>riod.                                                                               |
| 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  $\langle SSE \rangle = "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.

## TOSHIBA



#### 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.

### 17.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.

|                 | Burst length                                       |   |  |  |
|-----------------|----------------------------------------------------|---|--|--|
| Watermark level | Transmit (number of empty locations) led locations |   |  |  |
| 1/2             | 4                                                  | 4 |  |  |

## 17.5 SSP operation

### 17.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

### 17.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.

### 17.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}/2$ 

 $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 20Mbps.

## 17.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 "17.6.1" to "17.6.3" for details of each frame format.

#### 17.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 17-2 SSI frame format (transmission/reception during single transfer)



Figure 17-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.

### 17.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 17-4 SPI frame format (single transfer, <SPO>="0" & <SPH>="0")



Figure 17-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.

#### 17.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 17-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 17-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.

17. Synchronous Serial Port (SSP)

#### 17.6 Frame Format

# 18. Serial Bus Interface (I2C/SIO)

The TMPM341FDXBG/FYXBG contains 2 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 18-1 Port settings for using serial bus interface

| channel | Operating<br>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 :PG1<br>SDA0 :PG0            | PGFR1[1:0] = 11             | PGCR[1:0] = 11                                              | PGIE[1:0] = 11                                              | PGOD[1:0] = 11                                |
| SBI0    | SIO mode          | SCK0 :PG2<br>SI0 :PG1<br>SO0 :PG0 | PGFR1[2:0] = 111            | PGCR[2:0] = 101(SCK0 output)<br>PGCR[2:0] = 001(SCK0 input) | PGIE[2:0] = 010(SCK0 output)<br>PGIE[2:0] = 110(SCK0 input) | PGOD[2:0] = xxx                               |
|         | I2C<br>bus mode   | SCL1 :PD1<br>SDA1 :PD0            | PDFR1[1:0] = 11             | PDCR[1:0] = 11                                              | PDIE[1:0] = 11                                              | PDOD[1:0] = 11                                |
| SBI1    | SIO mode          | SCK1 :PD2<br>SI1 :PD1<br>SO1 :PD0 | PDFR1[2:0] = 111            | PDCR[2:0] = 101(SCK1 output)<br>PDCR[2:0] = 001(SCK1 input) | PDIE[2:0] = 010(SCK1 output)<br>PDIE[2:0] = 110(SCK1 input) | PDOD[2:0] = xxx                               |

Note:x: Don't care

18.1 Configuration

# 18.1 Configuration

The configuration is shown in Figure 18-1.



Figure 18-1 (I2C/SIO) Block Interface

### 18.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 "18.4 Control Registers in the I2C Bus Mode" and "18.7 Control register of SIO mode".

### 18.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  |

| Register name(x=0,1,)    | 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) | 00040  |
| Status register          | SBIxSR (reading)  | 0x0010 |
| Baud rate register 0     | SBIxBR0           | 0x0014 |

18.3 I2C Bus Mode Data Format

Figure 18-2 shows the data formats used in the I2C bus mode.



Figure 18-2 I2C Bus Mode Data Formats

# 18.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.

# 18.4.1 SBIxCR0(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  | -     | -  | -  | -  | -  | -  | -  | -  |
| 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  | 0  |
|             | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| bit symbol  | SBIEN | -  | -  | -  | -  | -  | -  | -  |
| After reset | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | SBIEN      | R/W  | Serial bus interface operation<br>0:Disable<br>1:Enable<br>To use the serial bus interface, enable this bit first.<br>For the first time in case of setting to enable, the relevant SBI registers can be read or written.<br>Since all clocks except SBIxCR0 stop if this bit is disabled, power consumption can be reduced by disabling<br>this bit.<br>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.

|             | 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    | 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  |    | BC |    | ACK | -  | SCK2 | SCK1 | SCK0 /<br>SWRMON |
| After reset | 0  | 0  | 0  | 0   | 1  | 0    | 0    | 1(Note3)         |

# 18.4.2 SBIxCR1(Control register 1)

| Bit  | Bit Symbol | Туре |                                                                                                                                                                                                                               |                                                      |                                                                                                   |                                                                                    | Function                                          |                                                                  |                      |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------------|----------------------|
| 31-8 | -          | R    | Read a                                                                                                                                                                                                                        | Read as 0.                                           |                                                                                                   |                                                                                    |                                                   |                                                                  |                      |
| 7-5  | BC[2:0]    | R/W  | Select t                                                                                                                                                                                                                      | Select the number of bits per transfer (Note 1)      |                                                                                                   |                                                                                    |                                                   |                                                                  |                      |
|      |            |      |                                                                                                                                                                                                                               |                                                      | When <a< td=""><td>CK&gt; = 0</td><td>When <a< td=""><td>CK&gt; = 1</td><td>]</td></a<></td></a<> | CK> = 0                                                                            | When <a< td=""><td>CK&gt; = 1</td><td>]</td></a<> | CK> = 1                                                          | ]                    |
|      |            |      |                                                                                                                                                                                                                               | <bc></bc>                                            | Number of<br>clock cycles                                                                         | Data<br>length                                                                     | Number of<br>clock cycles                         | Data<br>length                                                   |                      |
|      |            |      | Ī                                                                                                                                                                                                                             | 000                                                  | 8                                                                                                 | 8                                                                                  | 9                                                 | 8                                                                |                      |
|      |            |      |                                                                                                                                                                                                                               | 001                                                  | 1                                                                                                 | 1                                                                                  | 2                                                 | 1                                                                |                      |
|      |            |      | Ī                                                                                                                                                                                                                             | 010                                                  | 2                                                                                                 | 2                                                                                  | 3                                                 | 2                                                                |                      |
|      |            |      |                                                                                                                                                                                                                               | 011                                                  | 3                                                                                                 | 3                                                                                  | 4                                                 | 3                                                                | -                    |
|      |            |      |                                                                                                                                                                                                                               | 100                                                  | 4                                                                                                 | 4                                                                                  | 5                                                 | 4                                                                | -                    |
|      |            |      |                                                                                                                                                                                                                               | 101                                                  | 5                                                                                                 | 5                                                                                  | 6                                                 | 5                                                                |                      |
|      |            |      |                                                                                                                                                                                                                               | 110                                                  | 6                                                                                                 | 6                                                                                  | 7                                                 | 6                                                                |                      |
|      |            |      |                                                                                                                                                                                                                               | 111                                                  | 7                                                                                                 | 7                                                                                  | 8                                                 | 7                                                                |                      |
|      |            |      | Master mode<br>0: Acknowledgement clock pulse is not generated.<br>1: Acknowledgement clock pulse is generated.<br>Slave mode<br>0: Acknowledgement clock pulse is not counted.<br>1: Acknowledgement clock pulse is counted. |                                                      |                                                                                                   |                                                                                    |                                                   |                                                                  |                      |
| 3    | -          | R    | Read a                                                                                                                                                                                                                        | s 1.                                                 |                                                                                                   |                                                                                    |                                                   |                                                                  |                      |
| 2-1  | SCK[2:1]   | R/W  | Select i                                                                                                                                                                                                                      | nternal SCL o                                        | output clock fre                                                                                  | quency (Note                                                                       | : 2).                                             |                                                                  |                      |
| 0    | SCK[0]     | w    |                                                                                                                                                                                                                               | 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111 | n = 5<br>n = 6<br>n = 7<br>n = 8<br>n = 9<br>n = 10<br>n = 11                                     | 385 kHz<br>294 kHz<br>200 kHz<br>122 kHz<br>68 kHz<br>36 kHz<br>19 kHz<br>reserved |                                                   | n Clock: fsys<br>(<br>gear : fc/1<br>ency = $\frac{fsys}{2^n+7}$ | = 40MHz )<br>72 [Hz] |
|      | SWRMON     | R    | 0:Softw                                                                                                                                                                                                                       | are reset ope                                        | DN>: Software<br>ration is in prog<br>ration is not in                                            | gress.                                                                             | monitor                                           |                                                                  |                      |

# TOSHIBA

- 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 "18.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 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.

#### 18.4 Control Registers in the I2C Bus Mode

# 18.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  | -   | -   | -  | -   | -  | -   | -  | -   |
| 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  | 0   |
|             | 7   | 6   | 5  | 4   | 3  | 2   | 1  | 0   |
| bit symbol  | MST | TRX | BB | 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: I2C bus mode                                       |
|      | ļ          |      | 11: Reserved                                           |
| 1-0  | SWRST[1:0] | w    | Software reset generation                              |
|      |            |      | Write "10" followed by "01" to generate a reset.       |

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.

# TOSHIBA

# 18.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   | 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  | MST | TRX | BB | 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    | BB         | R    | I2C bus state monitor                                        |
|      |            |      | 0: Free                                                      |
|      |            |      | 1: Busy                                                      |
| 4    | PIN        | R    | INTSBIx 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"                                      |

|             | 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  | 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  | -  | I2SBI | -  | -  | -  | -  | -  | -  |
| After reset | 1  | 0     | 1  | 1  | 1  | 1  | 1  | 0  |

# 18.4.5 SBIxBR0(Serial bus interface baud rate register 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<br>0: Stop<br>1: Operate |
| 5-1  | -          | R    | Read as 1.                                          |
| 0    | -          | R/W  | Be sure to write "0".                               |

### 18.4.6 SBIxDBR (Serial bus interface 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  | -  | -  | -  | -  | -  | -  | -  | -  |
| 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  | 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 /<br>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, readmodify-write instructions, such as bit manipulation, cannot be used.

|             | 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  | 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  |    |    |    | SA |    |    |    | ALS |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   |

# 18.4.7 SBIxI2CAR (I2Cbus address register)

| 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.<br>0: Recognize its slave address.<br>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.)

### 18.5 Control in the I2C Bus Mode

#### 18.5.1 Serial Clock

#### 18.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 18-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.

#### 18.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 18-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.

#### 18.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 acknowledgment 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.

#### 18.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.

#### 18.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 address-ing 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.

#### 18.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  $\langle SBIM[1:0] \rangle$  to "10". Also, ensure that the bus is free before switching the operating mode to the port mode.

#### 18.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.

#### 18.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  $\langle MST \rangle$  to "0" configures the SBI as a slave device.  $\langle MST \rangle$  is cleared to "0" by the hardware when it detects the stop condition on the bus or the arbitration lost.

### 18.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.





When  $\langle BB \rangle$  is "1", writing "1" to  $\langle MST, TRX, PIN \rangle$  and "0" to  $\langle BB \rangle$  causes the SBI to start a sequence for generating the stop condition on the bus. The contents of  $\langle MST, TRX, BB, PIN \rangle$  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 18-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).

#### 18.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  $\langle BC \rangle$  and  $\langle ACK \rangle$  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 SBIxI2CAR<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<sub>LOW</sub> 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).

### 18.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.

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.





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 18-8 Example of Master B Lost Arbitration (D7A = D7B, D6A = D6B)

#### 18.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  $\langle ALS \rangle$  is "1",  $\langle AAS \rangle$  is set to "1" when the first data word has been received.  $\langle AAS \rangle$  is cleared to "0" when data is written to or read from SBIxDBR.

### 18.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.

#### 18.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.

#### 18.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.

### 18.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.

#### 18.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. 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.

# 18.6 Data Transfer Procedure in the I2C Bus Model2C

#### 18.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  $\langle SA[6:0] \rangle$  and an address recognition mode at  $\langle ALS \rangle$ . ( $\langle ALS \rangle$  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   | ←            | 0 | 0 | 0 | Х | 0 | Х | Х | х | Specifies ACK and SCL clock.                               |
| SBIxI2CAR | $\leftarrow$ | Х | Х | Х | Х | Х | Х | Х | х | Specifies a slave address and an address recognition mode. |
| SBIxCR2   | ←            | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Configures the SBI as a slave receiver.                    |

Note:X; Don't care

### 18.6.2 Generating the Start Condition and a Slave Address

#### 18.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 ( $\langle BB \rangle = "0"$ ). Then, write "1" to SBIxCR1 $\langle ACK \rangle$  to select the acknowledgment mode. Write to SBIxDBR a slave address and a direction bit to be transmitted.

When  $\langle BB \rangle = "0"$ , writing "1111" to SBIxCR2 $\langle MST, TRX, BB, PIN \rangle$  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.

#### Settings in main routine

|         |     | 7    | 6       | 5      | 4       | 3       | 2      | 1 | 0 |                                                    |
|---------|-----|------|---------|--------|---------|---------|--------|---|---|----------------------------------------------------|
| Reg.    | ←   | SBI  | xSR     |        |         |         |        |   |   |                                                    |
| Reg.    | ←   | Reg  | g.e0    | x20    |         |         |        |   |   |                                                    |
| if Reg. | ¥   | 0x0  | 0       |        |         |         |        |   |   | Ensures that the bus is free.                      |
| Then    |     |      |         |        |         |         |        |   |   |                                                    |
| SBIxCR1 | ←   | х    | х       | х      | 1       | 0       | х      | х | х | Selects the acknowledgement mode.                  |
| SBIxDBR | ←   | х    | х       | х      | х       | х       | х      | х | х | Specifies the desired slave address and direction. |
| SBIxCR2 | ←   | 1    | 1       | 1      | 1       | 1       | 0      | 0 | 0 | Generates the start condition.                     |
|         | Exa | mple | of IN   | TSBI   | ) inter | rrupt i | routin | е |   |                                                    |
|         |     | Cle  | ars th  | e inte | errupt  | reque   | est.   |   |   |                                                    |
|         |     | Pro  | cessii  | ng     |         |         |        |   |   |                                                    |
|         |     | Enc  | l of in | terrup | ot      |         |        |   |   |                                                    |
|         |     |      |         |        |         |         |        |   |   |                                                    |

#### 18.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 18-9 Generation of the Start Condition and a Slave Address

#### 18.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.

#### 18.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. Specifies the number of bits to be transmitted and SBIxCR1 х ххх 0 Х Х Х specify whether ACK is required. SBIxDBR Х Writes the transmit data. Х Х Х Х Х Х Х End of interrupt processing.

Note: X; Don't care





#### (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 18-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 18-12 Terminating Data Transmission in the Master Receiver Mode

Example: When receiving N data word

INTSBIx interrupt (after data transmission) 7 6 5 4 3 2 1 0 Sets the number of bits of data to be received and SBIxCR1 Х Х х 0 Х Х Х Х specify whether ACK is required. Reg. SBIxDBR Reads dummy data. ← End of interrupt INTSBIx interrupt (first to (N-2)th data reception) 6 5 4 3 2 1 0 7 SBIxDBR Reads the first to (N-2)th data words. Reg. End of interrupt INTSBIx interrupt ((N-1)th data reception) 0 7 6 5 4 3 2 1 SBIxCR1 Х Х Х 0 0 х х х Disables generation of acknowledgement clock. Reg. SBIxDBR Reads the (N-1)th data word. ← End of interrupt INTSBIx interrupt (Nth data reception) 7 6 5 3 2 0 4 1 SBIxCR1 0 0 0 0 Х Х Disables generation of acknowledgement clock. 1 Х Reg. SBIxDBR Reads the Nth data word. ← End of interrupt INTSBlx interrupt (after completing data reception)

Processing to generate the stop condition. End of interrupt Terminates the data transmission.

#### 18.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  $\langle$ PIN $\rangle$  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 18-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 = 0Then go to other processing. if AAS = 0 Then go to other processing. SBIxCR1 ← х Х х 1 0 Х Х Х Sets the number of bits to be transmitted. SBIxDBR х х х Х Sets the transmit data Х Х х х

Note:X; Don't care

Table 18-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<br>was being transmitted and the SBI received a slave<br>address with the direction bit "1" transmitted by an-<br>other 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 comple-<br>ted 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-<br>call address transmitted by another master. |                                                                                                                                                                                                                                                                                                                                                                 |
| 0           |           | 0           | 0           | Arbitration Lost is detected while a slave address<br>or a data word is being transmitted, and the trans-<br>fer is terminated.                                                                              | Read the SBIxDBR (a dummy read) to set <pin><br/>to 1, or write "1" to <pin>.</pin></pin>                                                                                                                                                                                                                                                                       |
|             | 0         | 1           | 1/0         | In the slave receiver mode, the SBI received either<br>a slave address with the direction bit "0" or a general-<br>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>                                                                                                                                                                                                                                                         |

#### 18.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 18-13 Generating the Stop Condition

#### 18.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 "18.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>=

# TOSHIBA

"1" is confirmed by following the restart procedure. To check the status of the SCL line, read the port.

| -> |                                                                                                                                                                                               |       | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                                                  |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---|---|---|---|---|---|---|---|------------------------------------------------------------------|
|    | SBIxCR2                                                                                                                                                                                       | ←     | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Releases the bus.                                                |
|    | if SBIxSR <bb< td=""><td>&gt; ≠ 0</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>Checks that the SCL pin is released.</td></bb<>                             | > ≠ 0 |   |   |   |   |   |   |   |   | Checks that the SCL pin is released.                             |
|    | Then                                                                                                                                                                                          |       |   |   |   |   |   |   |   |   |                                                                  |
|    | if SBIxSR <lr< td=""><td>B&gt; ≠</td><td>1</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>Checks that no other device is pulling the SCL pin to the "Low".</td></lr<> | B> ≠  | 1 |   |   |   |   |   |   |   | Checks that no other device is pulling the SCL pin to the "Low". |
|    | Then                                                                                                                                                                                          |       |   |   |   |   |   |   |   |   |                                                                  |
|    | 4.7 µs Wait                                                                                                                                                                                   |       |   |   |   |   |   |   |   |   |                                                                  |
|    | SBIxCR1                                                                                                                                                                                       | ←     | х | х | х | 1 | 0 | Х | Х | х | Selects the acknowledgment mode.                                 |
|    | SBIxDBR                                                                                                                                                                                       | ←     | х | х | х | х | х | х | х | х | Sets the desired slave address and direction.                    |
|    | SBIxCR2                                                                                                                                                                                       | ←     | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | Generates the start condition.                                   |

Note:X; Don't care



Figure 18-14 Timing Chart of Generating a Restart

# 18.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.

# 18.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  | 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  | 0  |
|             | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| bit symbol  | SBIEN | -  | -  | -  | -  | -  | -  | -  |
| After reset | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                             |
|------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                           |
| 7    | SBIEN      | R/W  | Serial bus interface operation.<br>0:Disable<br>1: Enable<br>Enable this bit before using the serial bus interface.<br>If this bit is disabled, power consumption can be reduced because all clocks except SBIxCR0 stop.<br>If the serial bus interface operation is enabled and then disabled, the settings will be maintained in each<br>register. |
| 6-0  | -          | R    | Read as 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  | -    | -      | -    | -  | -  | -   | -  | -         |
| 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  | 0         |
|             | 7    | 6      | 5    | 4  | 3  | 2   | 1  | 0         |
| bit symbol  | SIOS | SIOINH | SIOM |    | -  | SCK |    |           |
| After reset | 0    | 0      | 0    | 0  | 1  | 0   | 0  | 0(Note 1) |

# 18.7.2 SBIxCR1(Control register 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                                                      |  |  |  |  |  |  |  |
|      |            |      | 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 2.5 MHz                                                         |  |  |  |  |  |  |  |
|      |            |      | 001 n = 4 1.25 MHz                                                        |  |  |  |  |  |  |  |
|      |            |      | 010 n = 5 625 kHz                                                         |  |  |  |  |  |  |  |
|      |            |      | 011 n = 6 313 kHz (System clock: fsys                                     |  |  |  |  |  |  |  |
|      |            |      | 100 n = 7 156 kHz } Clock gear: fc/1                                      |  |  |  |  |  |  |  |
|      |            |      | 101 n = 8 78 kHz $\left( Frequency = \frac{fsys/2}{2^n} [Hz] \right)$     |  |  |  |  |  |  |  |
|      |            |      | 110 n = 9 39 kHz                                                          |  |  |  |  |  |  |  |
|      |            |      | 111 – 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.

18.7 Control register of SIO mode

|             | 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  | 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  | DB |    |    |    |    |    |    |    |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

# 18.7.3 SBIxDBR (Data buffer register)

| Bit  | Bit Symbol | Туре | Function      |
|------|------------|------|---------------|
| 31-8 | -          | R    | Read as 0.    |
| 7-0  | DB[7:0]    | R    | Receive data  |
|      |            | W    | 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 SBIxDBR has independent buffers for writing and reading, a written data cannot be read. Thus, readmodify-write instructions, such as bit manipulation, cannot be used.

## 18.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  | -         | -         | -         | -         | -  | -   | -         | -         |
| 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         | 0         |
|             | 7         | 6         | 5         | 4         | 3  | 2   | 1         | 0         |
| bit symbol  | -         | -         | -         | -         | SE | BIM | -         | -         |
| 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)<br>00: Port mode<br>01: SIO mode<br>10: I2Cbus mode<br>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.

## 18.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         | 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  | -         | -         | -         | -         | SIOF | SEF | -         | -         |
| 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    | ead as 1.(Note 1)                                                 |  |  |  |  |  |  |  |  |  |
| 3    | SIOF       | R    | serial transfer status monitor.<br>: Completed<br>: In progress   |  |  |  |  |  |  |  |  |  |
| 2    | SEF        | R    | Shift operation status monitor<br>0: Completed.<br>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.

|             | 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  | 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  | -  | I2SBI | -  | -  | -  | -  | -  | -  |
| After reset | 1  | 0     | 1  | 1  | 1  | 1  | 1  | 0  |

# 18.7.6 SBIxBR0 (Baud rate register 0)

| Bit  | Bit Symbol | Туре | Function                                         |
|------|------------|------|--------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                       |
| 7    | -          | R    | Read as 1.                                       |
| 6    | I2SBI      | R/W  | Operation in IDLE mode.<br>0: Stop<br>1: Operate |
| 5-1  | -          | R    | Read as 1.                                       |
| 0    | -          | R/W  | Make sure to write "0".                          |

### 18.8 Control in SIO mode

#### 18.8.1 Serial Clock

#### 18.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.

|                         | Automa<br>                                                                                    | atic wait<br>──▶                                                                         |   |
|-------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---|
| SCKx pin output         |                                                                                               |                                                                                          | • |
| SOx pin output          | a <sub>0</sub> Xa <sub>1</sub> Xa <sub>2</sub> a <sub>5</sub> Xa <sub>6</sub> Xa <sub>7</sub> | $\chi_{b_0}\chi_{b_1}$ $b_4\chi_{b_5}\chi_{b_6}\chi_{b_7}\chi_{c_0}\chi_{c_1}\chi_{c_2}$ | - |
| Write the transmit data | a                                                                                             | b C                                                                                      | - |



#### (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 18-16 Maximum Transfer Frequency of External Clock Input

#### 18.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 input/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).





SBIxCR1<SIOM[1:0]>.

Transfer Modes

#### 18.8.2.1 8-bit transmit mode

Set the control register to the transmit mode and write the transmit data to SBIxDBR.

The transmit mode, the receive mode or the transmit/receive mode can be selected by programming

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.

|            |       | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                            |
|------------|-------|----|---|---|---|---|---|---|---|----------------------------|
| SBIxCR1    | ←     | 0  | 1 | 0 | 0 | 0 | х | х | х | Selects the transmit mode. |
|            |       |    |   |   |   |   |   |   |   |                            |
| SBIxDBR    | ←     | Х  | Х | Х | Х | Х | Х | Х | Х | Writes the transmit data.  |
| SBIxCR1    | ←     | 1  | 0 | 0 | 0 | 0 | Х | Х | Х | Starts transmission.       |
|            |       |    |   |   |   |   |   |   |   |                            |
| INTSBIx in | terru | pt |   |   |   |   |   |   |   |                            |
| SBIxDBR    | ←     | х  | х | х | х | х | х | Х | Х | Writes the transmit data.  |

18.8.2

18.8 Control in SIO mode





Example: Example of programming (external clock) to terminate transmission by <SIO>



#### 18.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.

|             |          | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                           |
|-------------|----------|----|---|---|---|---|---|---|---|---------------------------|
| SBIxCR1     | ←        | 0  | 1 | 1 | 1 | 0 | х | х | х | Selects the receive mode. |
|             |          |    |   |   |   |   |   |   |   |                           |
| SBIxCR1     | <i>←</i> | 1  | 0 | 1 | 1 | 0 | х | х | х | Starts reception.         |
| INTSBIx int | terru    | pt |   |   |   |   |   |   |   |                           |

Reg. ←

SBIxDBR

Reads the received data



Figure 18-19 Receive Mode (Example: Internal Clock)

#### 18.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 8bit 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.



## Figure 18-20 Transmit/Receive Mode (Example: Internal Clock)

|             |      | 7   | 6    | 5 | 4 | 3 | 2 | 1 | 0 |                                |
|-------------|------|-----|------|---|---|---|---|---|---|--------------------------------|
| SBIxCR1     | ←    | 0   | 1    | 1 | 0 | 0 | х | х | х | Selects the transmit mode.     |
|             |      |     |      |   |   |   |   |   |   |                                |
| SBIxDBR     | ←    | х   | Х    | Х | Х | Х | Х | Х | Х | Writes the transmit data.      |
| SBIxCR1     | ←    | 1   | 0    | 1 | 0 | 0 | х | Х | х | Starts reception/transmission. |
|             |      |     |      |   |   |   |   |   |   |                                |
| INTSBIx int | erru | pt  |      |   |   |   |   |   |   |                                |
| Reg.        | ←    | SBI | xDBR | 2 |   |   |   |   |   | Reads the received data.       |
| SBIxDBR     | ←    | х   | х    | х | х | х | х | х | х | Writes the transmit data.      |
|             |      |     |      |   |   |   |   |   |   |                                |

#### 18.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 18-21 Data retention time of the last bit at the end of transmission

# TOSHIBA

# 19. Analog/Digital Converter (ADC)

# 19.1 Outline

TMPM341FDXBG/FYXBG contains a 12-bit, sequential-conversion analog/digital converter (ADC) with 15 analog input channels.

These 15 analog input channels (pins AIN00 through AIN14) are also used as input/output ports.

The 12-bit AD converter has the following features:

- · Starting normal AD conversion and highest-priority AD conversion
  - Software activation
  - Activation with the 16-bit timer (TMRB)
  - Hardware activation with an external trigger input ( $\overline{\text{ADTRG}}$  pin)
- AD conversion
  - Fixed-channel singlel conversion mode
  - Channel scan single conversion mode
  - Fixed-channel repeat conversion mode
  - Channnel scan repeat conversion mode
- Highest-priority AD conversion
- · Normal AD conversion completion interrupt and highest-priority AD conversion completion interrupt
- Normal AD conversion and highest-priority AD conversion have the following status flags.

A flag indicating the AD conversion result data is valid, <ADRxRF>, and a flag indicating theAD conversion result data is overwritten, <OVRx>

Normal AD conversion completion flag and highest-priority AD conversion completion flag

Normal AD conversion busy flag and highest-priority AD conversion busy flag

AD Monitor Function

When the AD monitor function is enabled, an interrupt is generated if any comparison result is matched.

- AD conversion clock can be contorolled from 1/fc to 1/16fc.
- When AD conversion is completed, two types of DMA requests are supported.
- Standby mode is supported.
- Output switching monitor function

This is the function that monitors output switching operation of general input-output ports, which is also used as analog input channels (pins AIN00 througe AIN14), during AD conversion. This monitor function is used to suggest the possibility that output switching operation during AD conversion affects conversion accuracy.

## 19.2 Configuration

Figure 19-1 shows the block diagram of the AD converter.



Figure 19-1 AD Converter Block Diagram

## 19.3 Registers

### 19.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 ADMOD7). The result of AD conversion is stored in 15 AD conversion result registers, ADREG00 through ADREG14. The highest-priority conversion result is stored in the register ADREGSP.

|                                         |          | Base Address = 0x4005_000 |
|-----------------------------------------|----------|---------------------------|
| 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                    |
| Mode Control Register 6                 | ADMOD6   | 0x001C                    |
| Mode Control Register 7                 | ADMOD7   | 0x0020                    |
| Monitor Function Control Register 0     | ADCMPCR0 | 0x0024                    |
| Monitor Function Control Register 1     | ADCMPCR1 | 0x0028                    |
| Conversion Result Comparison Register 0 | ADCMP0   | 0x002C                    |
| Conversion Result Comparison Register 1 | ADCMP1   | 0x0030                    |
| Conversion Result Register 0            | ADREG00  | 0x0034                    |
| Conversion Result Register 1            | ADREG01  | 0x0038                    |
| Conversion Result Register 2            | ADREG02  | 0x003C                    |
| Conversion Result Register 3            | ADREG03  | 0x0040                    |
| Conversion Result Register 4            | ADREG04  | 0x0044                    |
| Conversion Result Register 5            | ADREG05  | 0x0048                    |
| Conversion Result Register 6            | ADREG06  | 0x004C                    |
| Conversion Result Register 7            | ADREG07  | 0x0050                    |
| Conversion Result Register 8            | ADREG08  | 0x0054                    |
| Conversion Result Register 9            | ADREG09  | 0x0058                    |
| Conversion Result Register 10           | ADREG10  | 0x005C                    |
| Conversion Result Register 11           | ADREG11  | 0x0060                    |
| Conversion Result Register 12           | ADREG12  | 0x0064                    |
| Conversion Result Register 13           | ADREG13  | 0x0068                    |
| Conversion Result Register 14           | ADREG14  | 0x006C                    |
| Reserved                                | -        | 0x0070                    |
| Conversion Result Register SP           | ADREGSP  | 0x0074                    |
| Reserved                                | -        | 0x0F00                    |
| Reserved                                | -        | 0x0F04                    |
| Reserved                                | -        | 0x0F08                    |

Note: Access to the "Reserved" area is prohibited.

|             | 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  | 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  | ADSH - ADCLK |    |    |    |    |    |    |    |
| After reset | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 1  |

## 19.3.2 ADCLK (Conversion Clock Setting Register)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                              |
|------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | -          | R    | Read as 0.                                                                                                                                                                                                            |
| 7-4  | ADSH[3:0]  | R/W  | Select the AD sample hold time.<br>0000: 40 × <adclk><br/>0001: 50 × <adclk><br/>0010: 60 × <adclk><br/>0011: 70 × <adclk><br/>0100: 110 × <adclk><br/>0101 to 1111: Reserved</adclk></adclk></adclk></adclk></adclk> |
| 3    | -          | R    | Read as 0.                                                                                                                                                                                                            |
| 2-0  | ADCLK[2:0] | R/W  | Select the AD prescaler clock.<br>000: fc<br>001: fc/2<br>010: fc/4<br>011: fc/8<br>100 to 111: Reserved                                                                                                              |

Note:Specify ADCLK in range 4MHz ≤ ADCLK ≤ 40MHz. For example, when fosc = 13.5MHz and PLL = 16 multiplying, fc comes to 54MHz. In such case, set ADCLK<ADCLK[2:0]> to a value other than "000".

Note:Do not change the setting of <ADCLK > except when AD convertsion is suspended and AD-MOD1<VREFON>="0".



Figure 19-2 AD conversion clock (ADCLK)

# TOSHIBA

A clock count required for conversion is 40 clocks at the minimum.

Examples of sample hold time and conversion time as shown as below.

| <adclk[2:0]></adclk[2:0]> |                         | Co       | nversion time (Tcc | onv)     |
|---------------------------|-------------------------|----------|--------------------|----------|
| Setting                   | <adsh[3:0]></adsh[3:0]> | fc=32MHz | fc=40MHz           | fc=54MHz |
|                           | 40 × ADCLK              | 1.25 µs  | 1.00 µs            | -        |
|                           | 50 × ADCLK              | 1.56 µs  | 1.25 µs            | -        |
| 000 (fc)                  | 60 × ADCLK              | 1.88 µs  | 1.50 µs            | -        |
|                           | 70 × ADCLK              | 2.19 µs  | 1.75 µs            | -        |
|                           | 110 × ADCLK             | 3.44 µs  | 2.75 µs            | -        |
|                           | 40 × ADCLK              | 2.50 µs  | 2.00 µs            | 1.48 µs  |
|                           | 50 × ADCLK              | 3.13 µs  | 2.50 µs            | 1.85 µs  |
| 001 (fc/2)                | 60 × ADCLK              | 3.75 µs  | 3.00 µs            | 2.22 µs  |
|                           | 70 × ADCLK              | 4.38 µs  | 3.50 µs            | 2.59 µs  |
|                           | 110 × ADCLK             | 6.88 µs  | 5.50 µs            | 4.07 µs  |
|                           | 40 × ADCLK              | 5.00 µs  | 4.00 µs            | 2.96 µs  |
|                           | 50 × ADCLK              | 6.25 µs  | 5.00 µs            | 3.70 µs  |
| 010 (fc/4)                | 60 × ADCLK              | 7.50 µs  | 6.00 µs            | 4.44 µs  |
|                           | 70 × ADCLK              | 8.75 µs  | 7.00 µs            | 5.19 µs  |
|                           | 110 × ADCLK             | -        | -                  | 8.15 µs  |
|                           | 40 × ADCLK              | 10.0 µs  | 8.00 µs            | 5.93 µs  |
|                           | 50 × ADCLK              | -        | 10.0 µs            | 7.41 µs  |
| 011 (fc/8)                | 60 × ADCLK              | -        | -                  | 8.89 µs  |
|                           | 70 × ADCLK              | -        | -                  | -        |
|                           | 110 × ADCLK             | -        | -                  | _        |

Note: Do not change the setting of the AD conversion clock during AD conversion.

Note:Setting the element indicated by "-" in the above table is prohibited. Specify <ADCLK> setting in the 1µs to 10µs range.

|             | 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     | 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  | -  | -  | -  | -  | -  | -  | HPADS | ADS |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0   |

## 19.3.3 ADMOD0 (Mode Control Register 0)

| Bit  | Bit Symbol | Туре | Function                                                                                                |
|------|------------|------|---------------------------------------------------------------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                                                                              |
| 1    | HPADS      | W    | Activate highest-priority AD conversion<br>0: Don't care<br>1: Start conversion<br>"0" is always read.  |
| 0    | ADS        | W    | Activate normal (software) AD conversion<br>0: Don't care<br>1: Start conversion<br>"0" is always read. |

Note: In use ADC, write "1" to ADMOD1<VREFON> first, and then start AD conversion or external trigger by setting ADMOD0<ADS> or <HPADS>.

Note: When both highest-priority AD conversion <HPADS> and normal AD conversion (software) are enabled and they are selected as ADTRG (external trigger input), highest-priority AD conversion is activated as a priority and normal AD conversion is not activated.

|             | 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     | 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  | VREFON | I2AD | RCUT | -  | HPADHWS | HPADHWE | ADHWS | ADHWE |
| After reset | 0      | 0    | 0    | 0  | 0       | 0       | 0     | 0     |

## 19.3.4 ADMOD1 (Mode Control Register 1)

| Bit  | Bit Symbol | Туре | Function                                                                                                                                |  |  |  |
|------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31-8 | -          | R    | Read as 0.                                                                                                                              |  |  |  |
| 7    | VREFON     | R/W  | VREF application control (Note1 and Note2)<br>0: OFF<br>1: ON                                                                           |  |  |  |
| 6    | I2AD       | R/W  | Specify operation mode in IDLE mode<br>0: Stop<br>1: Operation                                                                          |  |  |  |
| 5    | RCUT       | R/W  | Control AVREFH-AVREFL reference current<br>0: Apply the current only in conversion.<br>1: Apply the current at any time except in RESET |  |  |  |
| 4    | -          | R    | Read as 0.                                                                                                                              |  |  |  |
| 3    | HPADHWS    | R/W  | Select hardware activation source of highest-priority AD conversion<br>0: External trigger<br>1: Match with timer register 0 (TB4RG0)   |  |  |  |
| 2    | HPADHWE    | R/W  | Activate highest-priority AD conversion triggered by hardware factors (External trigger or TB4RG0)<br>0: Disable<br>1: Enable           |  |  |  |
| 1    | ADHWS      | R/W  | Select hardware activation source of normal AD conversion (Note3)<br>0: External trigger<br>1: Match with timer register 0 (TB5RG0)     |  |  |  |
| 0    | ADHWE      | R/W  | Activate normal AD conversion triggered by hardware factors (External trigger or TB5RG0)<br>0: Disable<br>1: Enable                     |  |  |  |

- Note 1: In use AD conversion, write "1" to the ADMOD1<VREFON> bit, wait for 3µs during which time the internal reference voltage should stabilize, and then start AD conversion or external trigger by setting AD-MOD0<ADS> or <HPADS> to "1".
- Note 2: Set <VREFON> to "0" to go into standby mode upon completion of AD conversion.
- Note 3: The external trigger cannot be used for H/W activation of normal AD conversion when it is used for H/W activation of highest-priority AD conversion.
  - Note: If it is necessary to reduce a power current with 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 into standby mode.

- 1. In the case of putting into IDLE mode with ADMOD1<I2AD> = "0".
- 2. In the case of putting into STOP1/STOP2 mode.

|             | 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  | 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  | HPADCH ADCH |    |    |    |    |    |    |    |
| After reset | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

## 19.3.5 ADMOD2 (Mode Control Register 2)

| Bit  | Bit Symbol  | Туре | Function                                                                                                |
|------|-------------|------|---------------------------------------------------------------------------------------------------------|
| 31-8 | -           | R    | Read as 0.                                                                                              |
| 7-4  | HPADCH[3:0] | R/W  | Select analog input channels in highest-priority AD conversion. "1111" is prohibited. (See Table 19-1.) |
| 3-0  | ADCH[3:0]   | R/W  | Select analog input channels in normal AD conversion. "1111" is prohibited. (See Table 19-1.)           |

#### Table 19-1 Selection of input channels in normal AD conversion or highest-priority AD conversion

| <hpadch[3:0]></hpadch[3:0]> | Analog input channels<br>in highest-priority AD conver-<br>sion | <adch[3:0]></adch[3:0]> | Analog input channels<br>in normal AD conversion |
|-----------------------------|-----------------------------------------------------------------|-------------------------|--------------------------------------------------|
| 0000                        | AIN00                                                           | 0000                    | AIN00                                            |
| 0001                        | AIN01                                                           | 0001                    | AIN01                                            |
| 0010                        | AIN02                                                           | 0010                    | AIN02                                            |
| 0011                        | AIN03                                                           | 0011                    | AIN03                                            |
| 0100                        | AIN04                                                           | 0100                    | AIN04                                            |
| 0101                        | AIN05                                                           | 0101                    | AIN05                                            |
| 0110                        | AIN06                                                           | 0110                    | AIN06                                            |
| 0111                        | AIN07                                                           | 0111                    | AIN07                                            |
| 1000                        | AIN08                                                           | 1000                    | AIN08                                            |
| 1001                        | AIN09                                                           | 1001                    | AIN09                                            |
| 1010                        | AIN10                                                           | 1010                    | AIN10                                            |
| 1011                        | AIN11                                                           | 1011                    | AIN11                                            |
| 1100                        | AIN12                                                           | 1100                    | AIN12                                            |
| 1101                        | AIN13                                                           | 1101                    | AIN13                                            |
| 1110                        | AIN14                                                           | 1110                    | AIN14                                            |

|             | 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      | 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  | -  |    | ITM | -  | -  | -  | REPEAT | SCAN |
| After reset | 0  | 0  | 0   | 0  | 0  | 0  | 0      | 0    |

## 19.3.6 ADMOD3 (Mode Control Register 3)

| Bit  | Bit Symbol | Туре | Function                                                                        |
|------|------------|------|---------------------------------------------------------------------------------|
| 31-7 | -          | R    | Read as 0.                                                                      |
| 6-4  | ITM[2:0]   | R/W  | Specify interrupt in fixed channel repeat conversion mode. See Table 19-2.      |
| 3-2  | -          | R    | Read as 0.                                                                      |
| 1    | REPEAT     | R/W  | Specify repeat mode<br>0 : Single conversion mode<br>1 : Repeat conversion mode |
| 0    | SCAN       | R/W  | Specify scan mode<br>0 : Fixed channel mode<br>1 : Channel scan mode            |

# Table 19-2 AD conversion interrupt specification in fixed channel repeat conversion mode

| <itm[2:0]></itm[2:0]> | Fixed channel repeat conversion mode<br><scan> = "0", <repeat> = "1"</repeat></scan> |
|-----------------------|--------------------------------------------------------------------------------------|
| 000                   | Generate in interrupt once every single conversion.                                  |
| 001                   | Generate interrupt once every 2 conversions.                                         |
| 010                   | Generate interrupt once every 3 conversions.                                         |
| 011                   | Generate interrupt once every 4 conversions.                                         |
| 100                   | Generate interrupt once every 5 conversions.                                         |
| 101                   | Generate interrupt once every 6 conversions.                                         |
| 110                   | Generate interrupt once every 7 conversions.                                         |
| 111                   | Generate interrupt once every 8 conversions.                                         |

Note:<ITM[2:0]> is valid only when it's specified in the fixed channel repeat mode, <REPEAT>="1" and <SCAN>="0".

Note: When repeat conversion is aborted during repeat conversion (in <REPEAT>=1, fixed channel mode or channel scan mode), <REPEAT> is "0" cleared. In such case, do not change the setting except <RE-PEAT> bit.

|             | 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  | 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  |    | SCAN | IAREA |    | SCANSTA |    |    |    |  |
| After reset | 0  | 0    | 0     | 0  | 0       | 0  | 0  | 0  |  |

## 19.3.7 ADMOD4 (Mode Control Register 4)

| Bit  | Bit Symbol        | Туре | Function                                                        |  |  |  |  |
|------|-------------------|------|-----------------------------------------------------------------|--|--|--|--|
| 31-8 | -                 | R    | Read as 0.                                                      |  |  |  |  |
| 7-4  | SCANAREA<br>[3:0] | R/W  | Range of channel scan. ("1111" is prohibited.)                  |  |  |  |  |
| 3-0  | SCANSTA[3:0]      | R/W  | Select the start channel to be scanned. ("1111" is prohibited.) |  |  |  |  |

To specify channel scan single mode, set ADMOD3<SCAN> to "1" and <REPEAT> to "0". And, to specify channel scan repeat mode, set ADMOD3<SCAN> to "1" and <REPEAT> to "1".

At first, select the start channel to be scanned. Then select the number of channels to be scanned, starting on the specified start channel.

For example, when ADMOD4<SCANSTA> is set to "0001"(AIN01) and <SCANAREA> is set to "0010" (3ch scan), three channels from AIN01 to AIN03 are scanned.

The following shows the range of assignable value to <SCANAREA> in relation to setting of <SCANSTA>.

| <scansta[3:0]></scansta[3:0]> | The start<br>channel to be<br>scanned | <scanarea[3:0]></scanarea[3:0]> | The range of as-<br>signable channel<br>scan value |
|-------------------------------|---------------------------------------|---------------------------------|----------------------------------------------------|
| 0000                          | (AIN00)                               | 0000 to 1110                    | (1ch to 15ch)                                      |
| 0001                          | (AIN01)                               | 0000 to 1101                    | (1ch to 14ch)                                      |
| 0010                          | (AIN02)                               | 0000 to 1100                    | (1ch to 13ch)                                      |
| 0011                          | (AIN03)                               | 0000 to 1011                    | (1ch to 12ch)                                      |
| 0100                          | (AIN04)                               | 0000 to 1010                    | (1ch to 11ch)                                      |
| 0101                          | (AIN05)                               | 0000 to 1001                    | (1ch to 10ch)                                      |
| 0110                          | (AIN06)                               | 0000 to 1000                    | (1ch to 9ch)                                       |
| 0111                          | (AIN07)                               | 0000 to 0111                    | (1ch to 8ch)                                       |
| 1000                          | (AIN08)                               | 0000 to 0110                    | (1ch to 7ch)                                       |
| 1001                          | (AIN09)                               | 0000 to 0101                    | (1ch to 6ch)                                       |
| 1010                          | (AIN10)                               | 0000 to 0100                    | (1ch to 5ch)                                       |
| 1011                          | (AIN11)                               | 0000 to 0011                    | (1chto 4ch)                                        |
| 1100                          | (AIN12)                               | 0000 to 0010                    | (1ch to 3ch)                                       |
| 1101                          | (AIN13)                               | 0000 to 0001                    | (1ch to 2ch)                                       |
| 1110                          | (AIN14)                               | 0000                            | (1ch)                                              |

Table 19-3 The range of assignable channel scan value

#### 19.3 Registers

Note: In case of a setting other than listed above, AD conversion is not activated even if ADMOD0 register is set to activate AD conversion.

|             | 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    | 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  | -  | -  | -  | -  | HPEOCF | HPADBF | EOCF | ADBF |
| After reset | 0  | 0  | 0  | 0  | 0      | 0      | 0    | 0    |

## 19.3.8 ADMOD5 (Mode Control Register 5)

| Bit  | Bit Symbol | Туре | Function                                                                                                 |  |  |  |  |  |
|------|------------|------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31-4 | -          | R    | Read as 0.                                                                                               |  |  |  |  |  |
| 3    | HPEOCF     | R    | Highest-priority AD conversion completion flag (Note1)<br>b: Before or during conversion<br>: Completion |  |  |  |  |  |
| 2    | HPADBF     | R    | Highest-priority AD conversion BUSY flag<br>0: During conversion halts<br>1: During conversion           |  |  |  |  |  |
| 1    | EOCF       | R    | Normal AD conversion completion flag (Note1)<br>0: Before or during conversion<br>1: Completion          |  |  |  |  |  |
| 0    | ADBF       | R    | Normal AD conversion BUSY flag<br>0: During conversion halts<br>1: During conversion                     |  |  |  |  |  |

Note 1: Both <EOCF> and <HPEOCF> flags are "0" cleared by reading the ADMOD5 register.

- Note: If it is necessary to reduce a power current with 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 into standby mode.
  - 1. In the case of putting into IDLE mode with ADMOD1<I2AD> = "0".
  - 2. In the case of putting into STOP1/STOP2 mode.

|             | 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     | 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  | -  | -  | -  | -  | -  | -  | ADRST |    |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0  |

## 19.3.9 ADMOD6 (Mode Control Register 6)

| Bit  | Bit Symbol | Туре | Function                                                                         |
|------|------------|------|----------------------------------------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                                                       |
| 1-0  | ADRST[1:0] | W    | Overwriting 10 with 01 allows ADC to be software reset.                          |
|      |            |      | A software reset initializes all the registers except for ADCLK <adclk>.</adclk> |

Note:When DMA transmission is executed by using AD conversion completion interrupt, software reset AD-MOD6 <ADRST> first, and then operate DMAC(DMA request standby state) and configure (activate) the ADC.

Note: When executing the software reset, the bit of ADMOD1<VREFON> would be "1" is a valid.

Note: Initialization takes 3µs in case of the software reset.

|             | 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               | 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  | -  | -  | -  | -  | -  | -  | INTADHPD-<br>MA | INTADDMA |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0        |

# 19.3.10 ADMOD7 (Mode Control Register7)

| Bit  | Bit Symbol | Туре | Function                                                                                                          |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------|
| 31-4 | -          | R    | Read as 0.                                                                                                        |
| 3-2  | -          | R/W  | Always write "0".                                                                                                 |
| 1    | INTADHPDMA | R/W  | Specify Highest-priority AD conversion DMA activation factor. (Triggered by INTADHP)<br>0 : Disable<br>1 : Enable |
| 0    | INTADDMA   | RW   | Specify normal AD conversion DMA activation factor. (Triggered by INTAD<br>0 : Disable<br>1 : Enable              |

|             | 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    | 0  |  |
|             | 15     | 14 | 13       | 12     | 11    | 10  | 9    | 8  |  |
| bit symbol  | -      | -  | -        | -      |       | CMP | CNT0 |    |  |
| After reset | 0      | 0  | 0        | 0      | 0     | 0   | 0    | 0  |  |
|             | 7      | 6  | 5        | 4      | 3     | 2   | 1    | 0  |  |
| bit symbol  | CMP0EN | -  | CMPCOND0 | ADBIG0 | AINS0 |     |      |    |  |
| After reset | 0      | 0  | 0        | 0      | 0     | 0   | 0    | 0  |  |

# 19.3.11 ADCMPCR0 (Monitor Control Register 0)

| Bit   | Bit Symbol   | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|-------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31-12 | -            | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| 11-8  | CMPCNT0[3:0] | R/W  | Number of comparison until the judgment is confirmed.An interrupt is generated when the number of the counts is achieved, .0000 : 1 time count0110 : 7 times count1100 : 13 times count0001 : 2 times count0111 : 8 times count1101 : 3 times count1000 : 9 times count1110 : 15 times count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|       |              |      | 0011 : 4 times count         1001 : 10 times count         1111 : 16 times count           0100 : 5 times count         1010 : 11 times count         1011 : 12 times count           0101 : 6 times count         1011 : 12 times count         1011 : 12 times count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 7     | CMP0EN       | R/W  | AD monitor function 0<br>0: Disable<br>1: Enable<br>Setting the condition <cmp0en>="0" (disabled) clears the number of counts.</cmp0en>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| 6     | -            | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| 5     | CMPCOND0     | R/W  | Set the count condition for determination.<br>0: Continuous method<br>1: Cumulative method<br>In the continuous method, if conditions set to <adbig0> goes on and the counting number reaches the number set to <cmpcnt0>, an AD monitor function interrupt (INTADM0) is generated. Even after reaching the counting number, AD monitor function interrupts (INTADM0) keep being generated as long as the condition matches. If the condition is different from that set to <adbig0>, the value of the counter is cleared.<br/>In the cumulative method, AD monitor function interrupts (INTADM0) are generated and clears the count numbers when the condition set to <adbigo> piles up and reaches the counting number set to <cmpcnt0>.</cmpcnt0></adbigo></adbig0></cmpcnt0></adbig0> |  |  |  |  |  |
| 4     | ADBIG0       | R/W  | Even if a value is different from that is set to <adbigo>, the value of the counter is held<br/>Set the determination for small and large.<br/>0: Larger than comparision register<br/>1: Smaller than comparision register<br/>Everytime when the AD conversion set to <ains0[3:0]> is completed, compare the size of conversion re-<br/>sults. If the result matches the settings of <adbigo>, the counter is incremented.</adbigo></ains0[3:0]></adbigo>                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| 3-0   | AINS0[3:0]   | R/W  | Set analog inputs as a target for comparison.           0000 : AIN00         0101 : AIN05         1010 : AIN10           0001 : AIN01         0110 : AIN06         1011 : AIN11           0010 : AIN02         0111 : AIN07         1100 : AIN12           0011 : AIN03         1000 : AIN08         1101 : AIN13           0100 : AIN04         1001 : AIN09         1110 : AIN14                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |

Note: AD monitor function is used the fixed repeat mode and the scan repeat mode.

|             | 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    | 0  |
|             | 15     | 14 | 13       | 12     | 11    | 10  | 9    | 8  |
| bit symbol  | -      | -  | -        | -      |       | CMP | CNT1 |    |
| After reset | 0      | 0  | 0        | 0      | 0     | 0   | 0    | 0  |
|             | 7      | 6  | 5        | 4      | 3     | 2   | 1    | 0  |
| bit symbol  | CMP1EN | -  | CMPCOND1 | ADBIG1 | AINS1 |     |      |    |
| After reset | 0      | 0  | 0        | 0      | 0     | 0   | 0    | 0  |

# 19.3.12 ADCMPCR1 (AD Monitor Control Register 1)

| Bit   | Bit Symbol   | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|-------|--------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31-12 | -            | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 11-8  | CMPCNT1[3:0] | R/W  | Number of comparison until the judgment is confirmed.An interrupt is generated when the number of the counts is achieved, .0000 : 1 time count0110 : 7 times count1100 : 13 times count0001 : 2 times count0111 : 8 times count1101 : 14 times count0010 : 3 times count1001 : 10 times count1001 : 10 times count1111 : 16 times count                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|       |              |      | 0100 : 5 times count 1010 : 11 times count<br>0101 : 6 times count 1011 : 12 times count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 7     | CMP1EN       | R/W  | AD monitor function 1<br>0: Disable<br>1: Enable<br>Setting the condition <cmp1en>="0" (disabled) clears the number of counts.</cmp1en>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| 6     | -            | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 5     | CMPCOND1     | R/W  | Set the count condition for determination.<br>0: Continuous method<br>1: Cumulative method<br>In the continuous method, if conditions set to <adbig1> goes on and the counting number reaches the num-<br/>ber set to <cmpcnt1>, an AD monitor function interrupt (INTADM1) is generated. Even after reaching the<br/>counting number, AD monitor function interrupts (INTADM1) keep being generated as long as the condi-<br/>tion matches. If the condition is different from that set to <adbig1>, the value of the counter is cleared.<br/>In the cumulative method, AD monitor function interrupts (INTADM1) are generated and clears the count num-<br/>bers when the condition set to <adbig1> piles up and reaches the counting number set to <cmpcnt1>.</cmpcnt1></adbig1></adbig1></cmpcnt1></adbig1> |  |  |  |  |  |
| 4     | ADBIG1       | R/W  | Even if a value is different from that is set to <adbig1>, the value of the counter is held.<br/>Set the determination for small and large.<br/>0: Larger than comparision register<br/>1: Smaller than comparision register<br/>Everytime when the AD conversion set to <ains1[3:0]> is completed, compare the size of conversion re-<br/>sults. If the result matches the settings of <adbig1>, the counter is incremented.</adbig1></ains1[3:0]></adbig1>                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 3-0   | REGS1[3:0]   | R/W  | Set analog inputs as a target for comparison.           0000 : AIN00         0101 : AIN05         1010 : AIN10           0001 : AIN01         0110 : AIN06         1011 : AIN11           0010 : AIN02         0111 : AIN07         1100 : AIN12           0011 : AIN03         1000 : AIN08         1101 : AIN13           0100 : AIN04         1001 : AIN09         1110 : AIN14                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |

Note: AD monitor function is used the fixed repeat mode and the scan repeat mode.

|             | 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   | 0  |
|             | 15     | 14 | 13 | 12 | 11 | 10  | 9   | 8  |
| bit symbol  | -      | -  | -  | -  |    | AD0 | CMP |    |
| After reset | 0      | 0  | 0  | 0  | 0  | 0   | 0   | 0  |
|             | 7      | 6  | 5  | 4  | 3  | 2   | 1   | 0  |
| bit symbol  | AD0CMP |    |    |    |    |     |     |    |
| After reset | 0      | 0  | 0  | 0  | 0  | 0   | 0   | 0  |

## 19.3.13 ADCMP0 (AD Conversion Result Comparison Register 0)

| Bit   | Bit Symbol   | Туре | Function                                                                     |  |  |  |
|-------|--------------|------|------------------------------------------------------------------------------|--|--|--|
| 31-12 | -            | R    | Read as 0.                                                                   |  |  |  |
| 11-0  | AD0CMP[11:0] | R/W  | Sets a value to be compared with the value of the conversion result register |  |  |  |

Note:To write values into this register, the AD monitor function 0 must be disabled (ADCMPCR0<CMP0EN> ="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  | -  | -  | -  | -   | -   | -   | -   | -  |
| After reset | 0  | 0  | 0  | 0   | 0   | 0   | 0   | 0  |
|             | 15 | 14 | 13 | 12  | 11  | 10  | 9   | 8  |
| bit symbol  | -  | -  | -  | -   |     | AD1 | CMP |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0   | 0   | 0  |
|             | 7  | 6  | 5  | 4   | 3   | 2   | 1   | 0  |
| bit symbol  |    |    |    | AD1 | CMP |     |     |    |
| After reset | 0  | 0  | 0  | 0   | 0   | 0   | 0   | 0  |

## 19.3.14 ADCMP1 (AD Conversion Result Comparison Register 1)

| Bit   | Bit Symbol   | Туре | Function                                                                     |  |  |  |  |
|-------|--------------|------|------------------------------------------------------------------------------|--|--|--|--|
| 31-12 | -            | R    | Read as 0.                                                                   |  |  |  |  |
| 11-0  | AD1CMP[11:0] | R/W  | Sets a value to be compared with the value of the conversion result register |  |  |  |  |

Note:To write values into this register, the AD monitor function 1 must be disabled (ADCMPCR1<CMP1EN> ="0").

## 19.3.15 ADREG00 to ADREG14 (Normal Conversion Result Register 00 to 14)

|             | 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  | 0  |
|             | 15 | 14      | 13     | 12   | 11 | 10 | 9  | 8  |
| bit symbol  | -  | ADPOSWF | ADOVRF | ADRF |    | A  | DR |    |
| After reset | 0  | 0       | 0      | 0    | 0  | 0  | 0  | 0  |
|             | 7  | 6       | 5      | 4    | 3  | 2  | 1  | 0  |
| bit symbol  |    |         |        | A    | DR |    |    |    |
| After reset | 0  | 0       | 0      | 0    | 0  | 0  | 0  | 0  |

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                          |
|-------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-15 | -          | R    | Read as 0.                                                                                                                                                                        |
| 14    | ADPOSWF    | R    | The output switching flag of AIN port.                                                                                                                                            |
|       |            |      | 0: Without switching                                                                                                                                                              |
|       |            |      | 1: With switching                                                                                                                                                                 |
|       |            |      |                                                                                                                                                                                   |
|       |            |      | When PxDATA register of general input-output port which is also used as AIN changes during AD conversion, the port output switching flag, <adposwf>, is set to "1".</adposwf>     |
|       |            |      | In this case, when PxCR register corresponding to the changed bit is "1", there is a possibility that the out-<br>put switching during AD conversion affects conversion accuracy. |
|       |            |      | This bit is "0" cleared when registers, ADREG00 through ADREG14, are read.                                                                                                        |
| 13    | ADOVRF     | R    | Overrun flag                                                                                                                                                                      |
|       |            |      | 0: Not generated.                                                                                                                                                                 |
|       |            |      | 1: Generated.                                                                                                                                                                     |
|       |            |      | If the conversion result is overwritten before reading (ADREGx), this bit is set to "1".                                                                                          |
|       |            |      | This bit is "0" cleared when ADREGx registers are read.                                                                                                                           |
| 12    | ADRF       | R    | AD conversion result storage flag                                                                                                                                                 |
|       |            |      | 0: Conversion result is not stored                                                                                                                                                |
|       |            |      | 1: Conversion result is stored.                                                                                                                                                   |
|       |            |      | If the conversion result is stored, this bit is set to "1".                                                                                                                       |
|       |            |      | This bit is "0" cleared when the conversion result of ADREGx registers are read.                                                                                                  |
| 11-0  | ADR[11:0]  | R    | 12-bits AD conversion result                                                                                                                                                      |
|       |            |      | Conversion result is stored. The previous conversion result is read while in AD conversion.                                                                                       |

Note:Do not do the output switching during AD conversion, when other analog / input-output ports are used as output port.

|             | 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   | 0  |
|             | 15 | 14        | 13     | 12       | 11  | 10  | 9   | 8  |
| bit symbol  | -  | SPADPOSWF | SPOVRA | SPADRARF |     | ADI | RSP |    |
| After reset | 0  | 0         | 0      | 0        | 0   | 0   | 0   | 0  |
|             | 7  | 6         | 5      | 4        | 3   | 2   | 1   | 0  |
| bit symbol  |    |           |        | ADI      | RSP |     |     |    |
| After reset | 0  | 0         | 0      | 0        | 0   | 0   | 0   | 0  |

## 19.3.16 ADREGSP (Highest-priority Conversion Result Register)

| Bit   | Bit Symbol  | Туре | Function                                                                                                                                                                               |
|-------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-15 | -           | R    | Read as 0.                                                                                                                                                                             |
| 14    | ADPOSWFSP   | R    | The output switching flag of AIN port.                                                                                                                                                 |
|       |             |      | 0: Without switching                                                                                                                                                                   |
|       |             |      | 1: With switching                                                                                                                                                                      |
|       |             |      | When PxDATA register of general input-output port which is also used as AIN changes during AD conver-<br>sion, the port output switching flag, <adposwfsp>, is set to "1".</adposwfsp> |
|       |             |      | In this case, when PxCR register corresponding to the changed bit is "1", there is a possibility that the out-<br>put switching during AD conversion affects conversion accuracy.      |
|       |             |      | This bit is "0" cleared when registers, ADREGx is read.                                                                                                                                |
| 13    | ADOVRFSP    | R    | Overrun flag                                                                                                                                                                           |
|       |             |      | 0: Not generated                                                                                                                                                                       |
|       |             |      | 1: Generated                                                                                                                                                                           |
|       |             |      | If the highest-priority AD conversion result is overwritten before reading <adrsp>, "1" is set.</adrsp>                                                                                |
|       |             |      | This bit is "0" cleared when ADREGSP register is read.                                                                                                                                 |
| 12    | ADRFSP      | R    | Highest-priority AD conversion result storage flag                                                                                                                                     |
|       |             |      | 0: Conversion result is not stored.                                                                                                                                                    |
|       |             |      | 1: Conversion result is stored.                                                                                                                                                        |
|       |             |      | If the highest-priority conversion result is stored, this bit is set to "1".                                                                                                           |
|       |             |      | This bit is "0" cleared when ADREGSP conversion result is read.                                                                                                                        |
| 11-0  | ADRSP[11:0] | R    | Highest-priority 12-bits AD conversion result                                                                                                                                          |
|       |             |      | Highest-priority conversion result is stored. The previous conversion result is read while in AD conversion.                                                                           |

Note:Do not do the output switching during AD conversion, when other analog / input-output ports are used as output port.

## 19.4 Description of Operations

### 19.4.1 Analog Reference Voltage

The "High" level of the analog reference voltage shall be applied to the AVRFEH pin, and the "Low" shall be applied to the AVREFL 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<RCUT> bit, a switched-on state of AVREFH – AVREFL can be turned into a switched -off state.

#### 19.4.2 AD Conversion Mode

Two types of AD conversion are supported: normal AD conversion and highest-priority AD conversion.

#### 19.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 ADMOD3<REPEAT, SCAN>.

- Fixed channel single conversion mode
- Channel scan single conversion mode
- · Fixed channel repeat conversion mode
- Channel scan repeat conversion mode

#### (1) Fixed channel single conversion mode

If ADMOD3<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 by ADMOD2 <ADCH>. After AD conversion is completed, ADMOD5<EOCF> is set to "1", ADMOD5<ADBF> is cleared to "0", and the AD conversion completion interrupt request (INTAD) is generated. <EOCF> is cleared to "0" upon read.

#### (2) Channel scan single conversion mode

If ADMOD3 <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 the scan channel area selected by ADMOD4 <SCANAREA> from the start channel selected by ADMOD4 <SCANSTA>. After AD scan conversion is completed, ADMOD5<EOCF> is set to "1", ADMOD5<ADBF> is cleared to "0", and the conversion completion interrupt request (INTAD) is generated. <EOCF> is cleared to "0" upon read.

#### (3) Fixed channel repeat conversion mode

If ADMOD3<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 by ADMOD2 <ADCH>. After AD conversion is completed, ADMOD5<EOCF> is set to "1". ADMOD5<ADBF> 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 ADMOD3<ITM> to an appropriate setting. <EOCF> is set with the same timing as this interrupt INTAD is generated. <EOCF> is cleared to "0" upon read.

#### (4) Channel scan repeat conversion mode

If ADMOD3<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 the scan channel area selected by AD-MOD4 <SCANAREA> from the start channel selected by ADMOD4 <SCANSTA>. Each time one AD scan conversion is completed, ADMOD5 <EOCF> is set to "1", and the conversion completion interrupt request (INTAD) is generated. ADMOD5 <ADBF> is not cleared to "0" and remains at "1". <EOCF> is cleared to "0" upon read.

#### 19.4.2.2 Highest-priority AD conversion

By interrupting ongoing normal AD conversion, highest-priority AD conversion can be performed.

The fixed-channel single conversion is automatically selected, irrespective of the ADMOD3 <RE-PEAT, SCAN> setting. When conditions to start operation are met, a conversion is performed just once for a channel selected by ADMOD2<HPADCH>. When conversion is completed, the highest-priority AD conversion completion interrupt (INTADHP) is generated, and ADMOD5 <HPEOCF> showing the completion of AD conversion is set to "1". <HPADBF> returns to "0". <HOEOCF> flag is cleared to "0" upon read.

Highest-priority AD conversion activated while highest-priority AD conversion is under way is ignored.

### 19.4.3 AD Monitor Function

This is a function for setting the channel fixed repeat mode and the scan repeat mode.

Setting "1" to both ADCMPCR0<CMP0EN> and ADCMPCR1<CMP1EN> enables the AD monitor function. The monitor function can also be enabled for both registers at the same time.

Here is an example, taking the ADCMPCR0.

Configure the following settings: analog input as a target for comparison to the <AINS0[3:0]> of the ADCMPCR0 register, large/small determination to the <ADBIG0>, counting conditions for determination to the <CMPCOND0> and the number of counts in determination to the <CMPCNT0[3:0]>.

Once AD conversion starts, everytime when one single conversion completes, large/small determination is performed. If the result of the conversion matches the settings stored in the <ADBIG0>, increment the judgment counter.

There are two conditions of judgment: continuous method and cumulative method. In the continuous method, if conditions set to the <ADBIG0> goes on and the counting number reaches the numbers set to <CMPCNT0 [3:0]>, an AD monitor interrupt (INTADM0) is generated and clears the counter value. Even if the values are different from that is set to the <ADBIG0>, the value of the counter is cleared. In the cumulative method, AD monitor function interrupts (INTADM0) are generated when conditions set to the <ADBIG0> pile up and reache the counting number set to the <CMPCNT0[3:0]>. The counter values are held even the condition is different from that is set to the <ADBIG0>. If values of the conversion result storage register set to the ADCMPCR0 are the same as the values of a register as a comparison target, the count is not incremented. AD monitor function interrupt (INTADM0) is not generated. (neither ADCMPCR1 is) This comparison is performed everytime when a result is stored to the conversion result storage register, and an interrupt (INTADM0) occurs when a condition matches. Since the storage register used as AD monitor function is not usually read using software, registers correspond to overrun flags, from ADREG00 to 14<ADOVRF>, and conversion result storage flags, from ADREG00 to 14<ADRF>, are always set to "1". Thus, do not use those flags of the conversion result storage register when you use the AD monitor function.

- 1. Set the AIN00 input as fixed cnnel repeat conversion. Compare values of the AD conversion result storage register (0x0888) to judge.
  - ADMOD3=0x0002 : fixed channel repeat conversion Note: Disable the AD conversion completion interrupt (INTAD).
  - ADCMPCR0 =0x0280 : Target channel for comparison: AIN00, large/small determination: larger than the comparison register, count condition for determination: continuous method, AD monitor function: enabled, counting number of large/small determination: three counts
  - ADCMP0=0x0888 : AD conversion resule storage register (conaprison value 0x0888)



#### Figure 19-3 AD monitor function (Fixed channel repeat and Continuous method)

- 2. Set AIN00 input as fixed channel repeat conversion. Cmpare values of the AD conversion result comparison register (0x0888).
  - ADMOD3=0x0002 : fixed channel repeat conversion Note: AD conversion completion interrupt (INTAD) is disabled.
  - ADCMPCR0 =0x02A0 : target channel for comparison: AIN00, large/small determination: larger than the comparison register, count condition for determination: cumulative method, AD monitor function: enabled, counting number of large/small determination: three counts.
  - ADCMP0=0x0888: AD conversion result comparison register (comparison value 0x0888)

# <u>TOSHIBA</u>





## 19.4.4 Selecting the Input Channel

After reset, ADMOD3 <REPEAT, SCAN> is initialized to "00" and ADMOD2 <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 (ADMOD3<SCAN> = "0")

One channel is selected from analog input pins AIN00 through AIN14 by setting AD-MOD2 <ADCH> to an appropriate setting

• If the analog input channel is used in a scan state (ADMOD3<SCAN> = "1")

The channel to be started can be specified by setting ADMOD4 <SCANSTA>. And, the number of channels to be scanned can be specified by setting ADMOD4 <SCANAREA>.

2. Highest-priority AD conversion mode

One channel is selected from analog input pins from AIN00 through AIN14 by setting AD-MOD2<HPADCH> to an appropriate setting. If highest-priority AD conversion has been activated during normal AD conversion, ongoing normal AD conversion is suspended, and restarts normal AD conversion after highest-priority AD conversion is completed.

## 19.4.5 AD Conversion Details

#### 19.4.5.1 Starting AD Conversion

Two types of A/D conversion are supported: normal AD conversion and top-priority AD conversion. Normal AD conversion is activated by setting ADMOD0<ADS> to "1". Highest-priority AD conversion is activated by setting ADMOD0<HPADS> 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 ADMOD3 <REPEAT, SCAN> to an appropriate setting. For highest-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-MOD1<ADHWS>, and highest-priority AD conversion can be activated using the HW activation source selected by ADMOD1<HPADHWS>. If bits of <ADHWS> and <HPADHWS> are "0", normal and highestpriority AD conversions are activated in response to the input of a falling edge through the ADTRG pin. If these bits are "1", normal AD conversion is activated in response to TB5RG0 generated by the 16-bit timer channel 5, and highest-priority AD conversion is activated in response to TB4RG0 generated by the 16bit timer channel 4.

To permit H/W activation, set ADMOD1 <ADHWE> to "1" for normal AD conversion and set AD-MOD1<HPADHWE> to "1" for highest-priority AD conversion.

Software activation is still valid even after H/W activation has been permitted.

Note: When an external trigger is used for the HW activation source of a highest-priority AD conversion, an external trigger cannot be set for activating normal AD conversion H/W start.

#### 19.4.5.2 AD Conversion

When normal AD conversion starts, the AD conversion Busy flag (ADMOD5 <ADBF>) showing that AD conversion is under way is set to "1".

When highest-priority AD conversion starts, the highest-priority AD conversion Busy flag (ADMOD5 <HPADBF>) showing that AD conversion is under way is set to "1".

At that time, the value of the Busy flag ADMOD5<ADBF> for normal AD conversion before the start of highest-priority AD conversion is retained.

The value of the conversion completion flag ADMOD5 <EOCF> for normal AD conversion before the start of highest-priority AD conversion is retained.

Note: Normal AD conversion must not be activated when highest-priority AD conversion is under way. If activated when highest-priority AD conversion is under way, the highest-priority AD conversion completion flag cannot be set, and the flag for previous normal A/D conversion cannot be cleared.

#### 19.4.5.3 Highest-priority AD conversion requests during normal AD conversion

If highest-priority AD conversion has been activated during normal AD conversion, ongoing normal AD conversion is suspended, and restarts normal AD conversion after highest-priority AD conversion is completed.

If ADMOD0<HPADS> is set to "1" during normal AD conversion, ongoing normal AD conversion is suspended, and the highest-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 highest-priority AD conversion is stored in the storage register ADREGSP, normal AD conversion is resumed.

If H/W activation of highest-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 highest-priority AD conversion (fixed-channel single conversion) starts for a channel designated by ADMOD2<HPADCH>. After the result of this highest-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 AIN00 through AIN03 and if <HPADS> is set to "1" during AIN02 conversion, AIN02 conversion is suspended, and conversion is performed for a channel designated by <HPADCH> (AIN11 in the case shown below). After the result of conversion is stored in ADREGSP, channel repeat conversion is resumed, starting from AIN02.

| Highest-priority AD has been activated |     |     |     |      |     |     |     |  |
|----------------------------------------|-----|-----|-----|------|-----|-----|-----|--|
|                                        | (   |     |     |      |     |     |     |  |
| Conversion Ch                          | Ch0 | Ch1 | Ch2 | Ch11 | Ch2 | Ch3 | Ch0 |  |

#### 19.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 conversion mode), write "0" to ADMOD3<REPEAT>. When ongoing AD conversion is completed, the repeat conversion mode terminates, and ADMOD5<ADBF> is set to "0".

#### 19.4.5.5 Reactivating normal AD conversion

If ADMOD0 <ADS> is set to "1" during normal AD conversion, normal AD conversion is reactivated. Ongoing normal AD conversion is suspended at the time that it is reactivated. At that time, the normal AD conversion Busy flag ADMOD5 <ADBF>, the normal AD conversion completion flag ADMOD5 <EOCF> and the storage result flag ADREGm <ADOVRF>, <ADRF> are cleared to "0". (m=00-14)

If H/W activation of normal 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. Ongoing normal AD conversion is suspended at the time that it is reactivated. At that time, the normal AD conversion Busy flag ADMOD5 <ADBF>, the normal AD conversion completion flag ADMOD5 <EOCF> and the storage result flag ADREGm <ADOVRF>, <ADRF> are cleared to "0". (m=00-14)

#### 19.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, and two registers change: the register ADMOD5<EOCF> which indicates the completion of AD conversion and the register AD-MOD5<ADBF>. The timing that interrupt request is generated and the timing that conversion result register <EOCF> <ADBF> changes vary according to a mode selected.

In mode other than fixed-channel repeat conversion mode, conversion results are stored in AD conversion result registers (ADREG00 through ADREG14) corresponding to a channel.

In fixed-channel repeat conversion mode, the conversion results are sequentially stored in storage registers ADREG00 through ADREG14. 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 ADREG00. If interrupt setting on <ITM> is set to be generated each time 8 AD conversions are completed, the conversion results are sequentially stored in ADREG00 through ADREG07.

Interrupt requests, flag changes and conversion result registers in each mode are as shown below.

· Fixed-channel single conversion mode

After AD conversion is completed, ADMOD5 <EOCF> is set to "1", ADMOD5 <ADBF> is cleared to "0", and the interrupt request INTAD 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, ADMOD5 <EOCF> is set to "1", AD-MOD5 <ADBF> is cleared 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

ADMOD5 <ADBF> is not cleared to "0". It remains at "1". The timing with which the interrupt request INTAD is generated can be selected by setting ADMOD3<ITM> to an appropriate setting. ADMOD5 <EOCF> is set with the same timing as this interrupt INTAD is generated.

a. One conversion

With ADMOD2 <ADCH[3:0]> set to "0000" (AIN00) and ADMOD3 <ITM[2:0]> set to "000", 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 ADREG00. After the conversion result is stored, <EOCF> is set to "1".

b. 8 conversions

With ADMOD2 <ADCH[3:0]> set to "1110" (AIN14) and ADMOD3 <ITM[2:0]> set to "111", an interrupt request is generated each time 8 AD conversions are completed. In this case, the conversion results are sequentially stored in the storage register ADREG00 through ADREG07. After the conversion result is stored in ADREG07, <EOCF> is set to "1", and the storage of subsequent conversion results starts from ADREG00.

<u>Channel scan repeat conversion mode</u>

Each time one AD conversion is completed, ADMOD5<EOCF> is set to "1" and an interrupt request INTAD is generated. ADMOD5<ADBF> is not cleared to "0". It remains at "1".

If ADMOD4 <SCANSTA[3:0]> is set to "0001" (AIN01) and ADMOD4 <SCANAREA [7:4]> is set to "1110" (14Ch scan), each time one AD conversion is completed, AD-MOD5 <EOCF> is set to "1" and an interrupt request INTAD is generated. ADMOD5 <ADBF> is not cleared to "0" and remains at "1".

AD conversion results are stored in a AD conversion result register corresponding to a channel.

#### (2) Highest-priority AD conversion completion

After the highest-priority AD conversion is completed, the highest-priority AD conversion completion interrupt (INTADHP) is generated, and ADMOD5<HPEOCF> which indicates the completion of highest-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, ADMOD5 <EOCF> 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 word access. If  $\langle ADOVRF \rangle = "0"$ ,  $\langle ADRF \rangle = "1"$  and  $\langle ADPOSWF \rangle = "0"$ , a correct conversion result has been obtained.

#### (4) DMA request

After the normal AD conversion completion interrupt (INTAD) or the highest-priority AD conversion completion interrupt (INTADHP) is generated, DMA request is issued. DMA request after any interrupt is generated can be set to "disable" or "enable" by setting ADMOD7 register to an appropriate setting. A DMA request is issued in 2 system clocks (fsys) after AD conversion completion interrupt (INTAD or INTADHP) is generated.

#### 19.4.5.7 Interrupt generation timings and AD conversion result storage register

Table 19-4 shows a relation in the following three items: AD conversion modes, interrupt generation timings and flag operations. Table 19-5 shows a relation between analog channel inputs and AD conversion result registers.

| Table 10 1 Deletione in | annuaraian madaa  | interrupt concretion | timings and flag sporations |
|-------------------------|-------------------|----------------------|-----------------------------|
| Table 19-4 Relations in | conversion modes. | interruot deneration | timings and flag operations |
|                         |                   |                      |                             |

|                   | Scan/repeat mode setting<br>(ADMOD3)       Conversion mode <repeat> <scan> <itm[2:0]></itm[2:0]></scan></repeat> |   |                                       | ٩)                                          | DMOD5)                                         |                                                                 |                                                              |                                                                  |                                              |   |
|-------------------|------------------------------------------------------------------------------------------------------------------|---|---------------------------------------|---------------------------------------------|------------------------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------|----------------------------------------------|---|
| Conv              |                                                                                                                  |   | > <scan> <itm[2:0]></itm[2:0]></scan> |                                             | Interrupt<br>generation timing                 | <eocf>/<br/><hpeocf><br/>set timing<br/>(Note1)</hpeocf></eocf> | <adbf><br/>(After the<br/>interrupt is<br/>generated)</adbf> | <adbfhp><br/>(After the<br/>interrupt is<br/>generated)</adbfhp> |                                              |   |
|                   | Fixed-channel single conversion                                                                                  | 0 | 0                                     | -                                           | After generation is completed.                 | After generation is completed.                                  | 0                                                            | -                                                                |                                              |   |
|                   |                                                                                                                  |   |                                       | 000                                         | Each time one conversion is completed.         | After one conver-<br>sion is completed.                         | 1                                                            | -                                                                |                                              |   |
|                   |                                                                                                                  |   |                                       | 001                                         | Each time 2 con-<br>version is com-<br>pleted. | After 2 conver-<br>sions are comple-<br>ted.                    | 1                                                            | -                                                                |                                              |   |
|                   |                                                                                                                  | 1 | 0                                     | 010                                         | Each time 3 con-<br>version is com-<br>pleted. | After 3 conver-<br>sions are comple-<br>ted.                    | 1                                                            | -                                                                |                                              |   |
| Fixed-channel     | Fixed-channel                                                                                                    |   |                                       | 0                                           | 011                                            | Each time 4 con-<br>version is com-<br>pleted.                  | After 4 conver-<br>sions are comple-<br>ted.                 | 1                                                                | -                                            |   |
| Normal conversion |                                                                                                                  |   |                                       |                                             | 100                                            | Each time 5 con-<br>version is com-<br>pleted.                  | After 5 conver-<br>sions are comple-<br>ted.                 | 1                                                                | -                                            |   |
|                   |                                                                                                                  |   |                                       | 101                                         | Each time 6 con-<br>version is com-<br>pleted. | After 6 conver-<br>sions are comple-<br>ted.                    | 1                                                            | -                                                                |                                              |   |
|                   |                                                                                                                  |   |                                       |                                             |                                                |                                                                 | 110                                                          | Each time 7 con-<br>version is com-<br>pleted.                   | After 7 conver-<br>sions are comple-<br>ted. | 1 |
|                   |                                                                                                                  |   |                                       | 111                                         | Each time 8 con-<br>version is com-<br>pleted. | After 8 conver-<br>sions are comple-<br>ted.                    | 1                                                            | -                                                                |                                              |   |
|                   | Channel scan<br>single conversion                                                                                | 1 | -                                     | After scan con-<br>version<br>is completed. | After scan conver-<br>sion is completed.       | 0                                                               | -                                                            |                                                                  |                                              |   |
|                   | Channel scan<br>repeat conversion                                                                                | 1 | 1                                     | -                                           | After one scan<br>conversion is<br>completed.  | After one scan con-<br>version is comple-<br>ted.               | 1                                                            | -                                                                |                                              |   |
| Highest-p         | riority conversion                                                                                               | _ | _                                     | -                                           | After generation is completed.                 | Conversion com-<br>pletion                                      | _                                                            | 0                                                                |                                              |   |

Note 1: ADMOD5 <EOCF> and <HPEOCF> are cleared upon read.

Note: In repeat mode, ADMOD5 <ADBF> is not cleared to "0" even if any interrupt is generated. To suspend the repeat operation, ADMOD5 <ADBF> is cleared to "0" after ADMOD3 <REPEAT> is written "0" and AD conversion is completed.

| Fixed-channel single mode |                  | Fixed-channel repeat mode |                               |                    |  |  |
|---------------------------|------------------|---------------------------|-------------------------------|--------------------|--|--|
| Channel                   | Storage register |                           | ADMOD3 <itm[2:0]></itm[2:0]>  | Storage register   |  |  |
| AIN00                     | ADREG00          | 000                       | Interrupt by each time AD/C   | ADREG00            |  |  |
| AIN01                     | ADREG01          | 001                       | Interrupt by each time 2 AD/C | ADREG00 to ADREG01 |  |  |
| AIN02                     | ADREG02          | 010                       | Interrupt by each time 3 AD/C | ADREG00 to ADREG02 |  |  |
| AIN03                     | ADREG03          | 011                       | Interrupt by each time 4 AD/C | ADREG00 to ADREG03 |  |  |
| AIN04                     | ADREG04          | 100                       | Interrupt by each time 5 AD/C | ADREG00 to ADREG04 |  |  |
| AIN05                     | ADREG05          | 101                       | Interrupt by each time 6 AD/C | ADREG00 to ADREG05 |  |  |
| AIN06                     | ADREG06          | 110                       | Interrupt by each time 7 AD/C | ADREG00 to ADREG06 |  |  |
| AIN07                     | ADREG07          | 111                       | Interrupt by each time 8 AD/C | ADREG00 to ADREG07 |  |  |
| AIN08                     | ADREG08          |                           |                               |                    |  |  |
| AIN09                     | ADREG09          |                           |                               |                    |  |  |
| AIN10                     | ADREG10          |                           |                               |                    |  |  |
| AIN11                     | ADREG11          |                           |                               |                    |  |  |
| AIN12                     | ADREG12          |                           |                               |                    |  |  |
| AIN13                     | ADREG13          |                           |                               |                    |  |  |
| AIN14                     | ADREG14          |                           |                               |                    |  |  |

| Table 19-5 Relations b | etween analog channel | inputs and AD conversi | on result registers |
|------------------------|-----------------------|------------------------|---------------------|
|------------------------|-----------------------|------------------------|---------------------|

| Chan                                            | nel scan single mode / repeat m                       | ode               |
|-------------------------------------------------|-------------------------------------------------------|-------------------|
| (ex. ADREG                                      | 03 to depend on the scan chan                         | nel range.)       |
| ADMOD4 <scansta><br/>(Starts channel)</scansta> | ADMOD4 <scanarea><br/>(Scan channel range)</scanarea> | Storage register  |
| AIN00                                           | 15 channels                                           | ADREG00 to ADRE14 |
| AIN01                                           | 14 channels                                           | ADREG01 to ADRE14 |
| AIN02                                           | 13 channels                                           | ADREG02 to ADRE14 |
| AIN03                                           | 12 channels                                           | ADREG03 to ADRE14 |
| AIN04                                           | 11 channels                                           | ADREG04 to ADRE14 |
| AIN05                                           | 10 channels                                           | ADREG05 to ADRE14 |
| AIN06                                           | 9 channels                                            | ADREG06 to ADRE14 |
| AIN07                                           | 8 channels                                            | ADREG07 to ADRE14 |
| AIN08                                           | 7 channels                                            | ADREG08 to ADRE14 |
| AIN09                                           | 6channels                                             | ADREG09 to ADRE14 |
| AIN10                                           | 5 channels                                            | ADREG10 to ADRE14 |
| AIN11                                           | 4 channels                                            | ADREG11 to ADRE14 |
| AIN12                                           | 3 channels                                            | ADREG12 to ADRE14 |
| AIN13                                           | 2 channels                                            | ADREG13 to ADRE14 |
| AIN14                                           | 1 channels                                            | ADREG14           |

Note: When the range of channel scan is set to out of the assignable value in channel scan mode, the AD conversion can not be activated even if ADMOD0 is set to activate AD conversion.

#### Notes on designing for AD converter inputs

<Input impedance>

The factors shown below need to be taken into consideration when designing impedance from signal sources other than this product. -- Calculating formula of allowable value of external impedance --

AIN pin external impedance: R<sub>EXAIN</sub> < Tscyc  $\div$  (ADCLK × C<sub>ADC</sub> × In (2<sup>14</sup>)) - R<sub>AIN</sub>

| MCU information                             | Symbol           | Min | Тур | Max  | Unit  |
|---------------------------------------------|------------------|-----|-----|------|-------|
| A/DC clock frequency                        | ADCLK            | 4   | -   | 40   | MHz   |
| Total AIN input capacity in MCU             | C <sub>ADC</sub> | -   | -   | 12.2 | pF    |
| AIN resistance in MCU                       | R <sub>AIN</sub> | -   | -   | 1    | kΩ    |
| Cycle number in the sample hold pe-<br>riod | Тѕсус            | 10  | -   | 80   | Cycle |

R<sub>EXAIN</sub> maximum value list ( ADCLK = 40MHz )

| Тсѕус | R <sub>EXAIN</sub> | Unit |  |
|-------|--------------------|------|--|
| 10    | 1.1                | kΩ   |  |
| 20    | 3.2                | kΩ   |  |
| 30    | 5.3                | kΩ   |  |
| 40    | 7.5                | kΩ   |  |
| 80    | 15.9               | kΩ   |  |

< Addition of stabilizing capacity >

If high-speed AD conversion is required and the sample hold period cannot meet the conditions of calculating formula of allowable values of external impedance, add stabilizing capacity to the AIN pin. The additional capacity depends on external circuit board. Although the capacity to add is different from the final board set, add the capacity from about  $0.1\mu$ F to  $1\mu$ F, appropriate amount for your circuit board. Set the capacity to be added next to the AIN pin.

< Adjustment of sample hold period>

By setting the sample hold period long, you can stabilize the input voltage of the conversion target (analog input pin) and can reduce the error of input voltage.

#### Cautions for use AD converter

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 cy 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.

# TOSHIBA

# 20. Digital/Analog Converter (DAC)

TMPM341FDXBG/FYXBG contains a digital/analog converter (DAC) with 2 channels.

## 20.1 Features

- A high-resolution, 10-bit D/A converter is built in.
- Built in full range buffer amplifier.
- Built in power down function.

## 20.2 Block Diagram



Figure 20-1 DAC Block Diagram

## 20.3 Registers

## 20.3.1 Register List

| Channel x | Base Address |
|-----------|--------------|
| Channel0  | 0x4005_4000  |
| Channel1  | 0x4005_5000  |

| Register name (x=0~1) | Address(Base+) |        |
|-----------------------|----------------|--------|
| Control register      | DAxCTL         | 0x0000 |
| Output register       | DAxREG         | 0x0004 |
| Reserved              | -              | 0x0010 |
| Reserved              | -              | 0x0030 |

Note: Access to the "reserved" areas is prohibited.

## 20.3.2 DAxCTL(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      | 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  | -  | -  | -  | -  | -  | -  | VREFON | OP |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  |

| Bit  | Bit Symbol | Туре | Function                                                                                                                                                                                                                                              |
|------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | -          | R    | Read as 0.                                                                                                                                                                                                                                            |
| 1    | VREFON     | R/W  | VREF control<br>0: VREF off<br>1: VREF on                                                                                                                                                                                                             |
|      |            |      | When the setting value is "1", connect an external pin of AVREFH to D/A converter circuit.                                                                                                                                                            |
| 0    | OP         | R/W  | DAC operation control<br>0: Disable<br>1: Enable<br>When setting value is "1", DAx pin is output the voltage that specified by the output register DAxREG.<br>When setting value is "0", the operation stops and the output pin DAx goes into High-Z. |

## 20.3.3 DAxREG(Output 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  | 0  |
|             | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  |
| bit symbol  | -   | -  | -  | -  | -  | -  | D/ | AC |
| After reset | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
|             | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| bit symbol  | DAC |    |    |    |    |    |    |    |
| After reset | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                            |
|-------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10 | -          | R    | Read as 0.                                                                                                                                                          |
| 9-0   | DAC[9:0]   | R/W  | Conversion value setting<br>Configures analog voltage output level for outputting to output pin. The calculation is follow.<br>DAx = DAC × (AVREFH - AVREFL) / 1024 |

## 20.4 Operational Description

## 20.4.1 Setting method

Set the control register DAxCTL<OP><VREFON> to "11" and write an output CODE to the output register DAxREG so that an output voltage specified for that CODE generates at the output pin DAx.

### 20.4.2 Low power consumption mode

By setting DAxCTL<VREFON> to "0", internal VREF can be cut and so VREF level equals to AVREFL and a consumption current can be reduced. In the same way, by setting DAxCTL<OP> to "0", the DA conversion stops and DAx output goes into High-Z, thus the amplifier is power-down.

When transition to low power consumption mode, set DAxCTL<OP><VREFON>="00" first and execute the instruction to enter the standby mode.

## 21. Flash Memory Operation

This section describes the hardware configuration and operation of the flash memory.

## 21.1 Flash Memory

## 21.1.1 Features

#### 1. Memory capacity

The TMPM341FDXBG/FYXBG devices contain flash memory. The memory sizes and configurations of each device are shown in the table below.

#### 2. Write/erase time

Writing is executed per page. The TMPM341FDXBG contains 128 words and the TMPM341FYXBG contains 64 words in a page.

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.

| Draduat Nama | Memory Size | Block Configuration |       |       |       | # of Words  | Write Time | Erase   |
|--------------|-------------|---------------------|-------|-------|-------|-------------|------------|---------|
| Product Name |             | 128 KB              | 64 KB | 32 KB | 16 KB | # OI VVOIUS | while time | Time    |
| TMPM341FDXBG | 512 KB      | 3                   | 1     | 2     | -     | 128         | 4 00       | 0.4     |
| TMPM341FYXBG | 256 KB      | -                   | 3     | 1     | 2     | 64          | 1.28 sec   | 0.4 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 the user.

#### 3. Programming method

There are two types of the onboard programming mode for the user to program (rewrite) the device while it is mounted on the user's board:

- The onboard programming mode
- a. User boot mode

The user'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.

#### 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 the 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                                                                                               |  |
|-----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|
| <ul> <li>Automatic programming</li> <li>Automatic chip erase</li> <li>Automatic block erase</li> <li>Data polling/toggle bit</li> </ul> | <modified> Block protect (only software protection is supported)<br/><deleted> Erase resume - suspend function</deleted></modified> |  |

#### 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.

## 21.1.2 Block Diagram of the Flash Memory Section



## Figure 21-1 Block Diagram of the Flash Memory Section

## 21.2 Operation Mode

This device has three operation modes including the mode not to use the internal flash memory.

| 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 card, are defined. The former is referred to as "normal mode" and the latter "user boot mode.                                                                                                                                                 |
| User boot mode   | The user can uniquely configure the system to switch between these two modes. For ex-<br>ample, the user can freely design the system such that the normal mode is selected<br>when the port "A0" is set to "1" and the user boot mode is selected when it is set to<br>"0." The user should prepare a routine as part of the application program to make the de-<br>cision 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.           |

#### Table 21-1 Operation Modes

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 card.

Either the Single Chip or Single Boot operation mode can be selected by externally setting the level of the  $\overline{\text{BOOT}}$  (PF0) pin while the device is in reset status.

| Table 21-2 Operation | Mode Setting |
|----------------------|--------------|
|----------------------|--------------|

| One metion mode  | Pin               |            |  |
|------------------|-------------------|------------|--|
| Operation mode   | RESET             | BOOT (PF0) |  |
| Single chip mode | $0 \rightarrow 1$ | 1          |  |
| Single boot mode | $0 \rightarrow 1$ | 0          |  |





## 21.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  $\overrightarrow{\text{RESET}}$  input is held at "0" for a minimum duration of 12 system clocks (0.3 µs with 40MHz operation; the "1/1" clock gear mode is applied after reset).

- Note 1: Regarding cold-reset of devices with internal flash memory; for devices with internal flash memory, it is necessary to apply "0" to the RESET inputs upon power on for a minimum duration of 1.0 milli-seconds regardless of the operating frequency.
- Note 2: While flash automatic programming or deletion is in progress, at least 0.5 microseconds of reset period is required regardless of the system clock frequency. In this condition, it takes approx. 2 ms to enable reading after reset.

## 21.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 old application.

The condition to switch the modes needs to be set by using the I/O of TMPM341FDXBG/FYXBG 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 "21.3 On-board Programming of Flash Memory (Rewrite/Erase)".

#### 21.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 TMPM341FDXBG/FYXBG 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                                          |

opy routine: Code to cop TMPM341FI

TMPM341FDXBG/FYXBG flash memory to either the TMPM341FDXBG/FYXBG on-chip RAM or external memory device.



#### (2) Step-2

After  $\overline{\text{RESET}}$  is released, the reset procedure determines whether to put the TMPM341FDXBG/ FYXBG 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 disabled 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 TMPM341FDXBG/FYXBG on-chip RAM.



#### (4) Step-4

Jump program execution to the flash programming routine in the on-chip RAM to 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{\text{RESET}}$  to "0" to reset the TMPM341FDXBG/FYXBG. Upon reset, the on-chip flash memory is put in Normal mode. After  $\overline{\text{RESET}}$  is released, the CPU will start executing the new application program code.



21.2.2.2 (1-B) Method 2: Transferring a Programming Routine from an External Host

(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 TMPM341FDXBG/FYXBG 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

After  $\overline{\text{RESET}}$  is released, the reset procedure determines whether to put the TMPM341FDXBG/ FYXBG 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 disabled 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 TMPM341FDXBG/FYXBG on-chip RAM.



#### (4) Step-4

Jump program execution to the flash programming routine in the on-chip RAM to 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{\text{RESET}}$  to "0" low to reset the TMPM341FDXBG/FYXBG. Upon reset, the on-chip flash memory is put in Normal mode. After  $\overline{\text{RESET}}$  is released, the CPU will start executing the new application program code.



## 21.2.3 Single Boot Mode

In Single Boot mode, the flash memory can be re-programmed by using a program contained in the TMPM341FDXBG/FYXBG 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 0 of the SIO (SIO0) of the TMPM341FDXBG/FYXBG is connected to an external host controller. Via this serial link, a programming routine is downloaded from the host controller to the TMPM341FDXBG/FYXBG 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 SIO0 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 are executed in Normal mode.

Once re-programming is complete, it is recommended to protect relevant flash blocks from accidental corruption during subsequent Single-Chip (Normal mode) operations.

#### 21.2.3.1 (2-A) Using the Program in the On-Chip Boot ROM

#### (1) Step-1

The flash block containing the older version of the program code need not be erased before executing the programming routine. Since a programming routine and programming data are transferred via the SIO (SIO0), the SIO0 must be connected to a host controller. Prepare a programming routine (a) on the host controller.



#### (2) Step-2

Set the  $\overline{\text{RESET}}$  pin to "1" to cancel the reset of the TMPM341FDXBG/FYXBG when the  $\overline{\text{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 SIO0 is first 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 was correct, the boot program downloads, via the SIO0, the programming routine (a) from the host controller into the on-chip RAM of the TMPM341FDXBG/FYXBG. The programming routine must be stored in the range from 0x2000\_0400 to the end address of RAM.



#### (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 SIO0 channel as for the programming routine. However, once the programming routine has begun to execute, 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 leading from the host to the target board. Turn on the power again so that the TMPM341FDXBG/ FYXBG re-boots in Single-Chip (Normal) mode to execute the new program.



## 21.2.4 Configuration for Single Boot Mode

To execute the on-board programming, boot the TMPM341FDXBG/FYXBG with Single Boot mode following the configuration shown below.

> $\overline{\text{BOOT}}(\text{PF0}) = 0$  $\overline{\text{RESET}} = 0 \rightarrow 1$

Set the  $\overline{\text{RESET}}$  input to "0", and set the each  $\overline{\text{BOOT}}$  (PF0) pins to values shown above, and then release RE-SET (high).

### 21.2.5 Memory Map

Figure 21-3 and Figure 21-4 show 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<br>(Single Chip/ Single Boot Mode)         | RAM Address                |
|--------------|------------|----------|----------------------------------------------------------|----------------------------|
| TMPM341FDXBG | 512 KB     |          | 0x0000_0000 to 0x0007_FFFF<br>0x3F80_0000 to 0x3F87_FFFF |                            |
| TMPM341FYXBG | 256 KB     | 32 KB    | 0x0000_0000 to 0x0003_FFFF<br>0x3F80_0000 to 0x3F83_FFFF | 0x2000_0000 to 0x2000_7FFF |



Figure 21-3 Memory Maps for TMPM341FDXBG



Figure 21-4 Memory Maps for TMPM341FYXBG

## 21.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 0

Serial transfer mode : UART (asynchronous), half -duplex, LSB first

Data length : 8 bit

Parity bits : None

STOP bits : 1 bit

Baud rate : Arbitrary baud rate

I/O interface mode

Communication channel : SIO channel 0

Serial transfer mode : I/O interface mode, full -duplex, LSB first

Synchronization clock (SCLK0) : Input mode

Handshaking signal : PE4 configured as an output mode

Baud rate : Arbitrary baud rate

#### Table 21-3 Required Pin Connections

| Pins                  |             | Interface                         |                    |  |
|-----------------------|-------------|-----------------------------------|--------------------|--|
|                       |             | UART                              | I/O Interface Mode |  |
|                       | MODE        | Connect with Pull                 | -down resistance   |  |
|                       | INTLV       | Connect with Pull                 | -down resistance   |  |
| Made esting his       | FTEST3      | fixed to open                     |                    |  |
| Mode-setting pin      | BSC         | Connect                           | to GND             |  |
|                       | ENDIAN      | Connect with Pull-down resistance |                    |  |
|                       | BOOT (PF0)  | 0                                 | 0                  |  |
| Reset pin             | RESET       | 0                                 | 0                  |  |
|                       | TXD0 (PE0)  | 0                                 | 0                  |  |
| Communication<br>pins | RXD0 (PE1)  | 0                                 | 0                  |  |
|                       | SCLK0 (PE2) | ×                                 | o (Input mode)     |  |
|                       | PE4         | ×                                 | o (Output mode)    |  |
|                       |             | x . unused                        |                    |  |

o : used

× : unused

## 21.2.7 Data Transfer Format

Table 21-4 and Table 21-6 to Table 21-7 illustrate the operation commands and data transfer formats at each operation mode. In conjunction with this section, refer to "21.2.10 Operation of Boot Program".

Table 21-4 Single Boot Mode Commands

| Code | Command                       |
|------|-------------------------------|
| 0x10 | RAM transfer                  |
| 0x40 | Chip and protection bit erase |

## 21.2.8 Restrictions on internal memories

Single Boot Mode places restrictions on the internal RAM and ROM as shown in Table 21-5.

Table 21-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 pass-<br>words. Storing program in these addresses is not recommendable.<br>TMPM341FDXBG: 0x3F87_FFF0 to 0x3F87_FFFF<br>TMPM341FYXBG: 0x3F83_FFF0 to 0x3F83_FFFF |

## 21.2.9 Transfer Format for Single Boot Mode commands

The following tables shows the transfer format for each Single Boot Mode command. Use this section in conjunction with Chapter "21.2.10 Operation of Boot Program".

#### 21.2.9.1 RAM Transfer

#### Table 21-6 Transfer Format for the RAM Transfer Command

|          | Byte              | Data Transferred from the Controller<br>to the TMPM341FDXBG/FYXBG                                                          | Baud rate                     | Data Transferred from the TMPM341FDXBG/<br>FYXBG to the Controller                                                                                                                                                          |
|----------|-------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Boot ROM | 1 byte            | Serial operation mode and baud rate<br>For UART mode : 0x86<br>For I/O Interface mode : 0x30                               | Desired baud<br>rate (Note 1) | -                                                                                                                                                                                                                           |
|          | 2 byte            | -                                                                                                                          |                               | ACK for the serial operation mode byte<br>• For UART mode<br>-Normal acknowledge : 0x86<br>(The boot program aborts if the baud rate can<br>not be set correctly.)<br>• For I/O Interface mode<br>-Normal acknowledge :0x30 |
|          | 3 byte            | Command code (0x10)                                                                                                        | -                             | -                                                                                                                                                                                                                           |
|          | 4 byte            | -                                                                                                                          |                               | ACK for the command code byte (Note 2)<br>-Normal acknowledge : 0x10<br>-Negative acknowledge : 0xX1<br>-Communication error : 0xX8                                                                                         |
|          | 5 byte to 16 byte | Password sequence (12 bytes)<br>TMPM341FDXBG:<br>0x3F87_FFF4 to 0x3F87_FFFF<br>TMPM341FYXBG:<br>0x3F83_FFF4 to 0x3F83_FFFF |                               | -                                                                                                                                                                                                                           |
|          | 17 byte           | Check SUM value for bytes 5 - 16                                                                                           |                               | -                                                                                                                                                                                                                           |
|          | 18 byte           | -                                                                                                                          |                               | ACK for the checksum byte (Note 2)<br>-Normal acknowledge : 0x10<br>-Negative acknowledge : 0xX1<br>-Communication error : 0xX8                                                                                             |
|          | 19 byte           | RAM storage start address 31 to 24                                                                                         |                               | -                                                                                                                                                                                                                           |
|          | 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 byte count 15 to 8                                                                                             |                               | -                                                                                                                                                                                                                           |
|          | 24 byte           | RAM storage byte count 7 to 0                                                                                              |                               | -                                                                                                                                                                                                                           |
|          | 25 byte           | Check SUM value for bytes 19 to 24                                                                                         |                               | -                                                                                                                                                                                                                           |
|          | 26 byte           | -                                                                                                                          |                               | ACK for the checksum byte (Note 2)<br>-Normal acknowledge : 0x10<br>-Negative acknowledge : 0xX1<br>-Communication error : 0xX8                                                                                             |
|          | 27 byte to m byte | RAM storage data                                                                                                           | -                             | -                                                                                                                                                                                                                           |
|          | m + 1 byte        | Checksum value for bytes 27 to m                                                                                           | -                             | -                                                                                                                                                                                                                           |
|          | m + 2 byte        | -                                                                                                                          |                               | ACK for the checksum byte (Note 2)<br>-Normal acknowledge : 0x10<br>-Negative acknowledge : 0xX1<br>-Communication error : 0xX8                                                                                             |
| RAM      | m + 3 byte        | -                                                                                                                          | 1                             | 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.

#### 21.2.9.2 Chip Erase and Protect Bit Erase

| Table 21-7 | Transfer | Format for | r the C | Chin and | Protection | <b>Bit Erase</b> | Command |
|------------|----------|------------|---------|----------|------------|------------------|---------|
|            | Transier | i umat iu  |         | Jinp and | TOLECTION  |                  | Command |

|          | Byte             | Data Transferred from the Controller<br>to the TMPM341FDXBG/FYXBG                                                                                                                                                                                                                                                                                                 | Baud rate                     | Data Transferred from the TMPM341FDXBG/<br>FYXBG to the Controller                                                                                                                                                           |
|----------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Boot ROM | 1 byte           | Serial operation mode and baud rate<br>For UART mode : 0x86<br>For I/O Interface mode : 0x30                                                                                                                                                                                                                                                                      | Desired baud<br>rate (Note 1) | -                                                                                                                                                                                                                            |
|          | 2 byte           | -                                                                                                                                                                                                                                                                                                                                                                 |                               | ACK for the serial operation mode byte<br>• For UART mode<br>-Normal acknowledge : 0x86<br>• For I/O Interface mode<br>-Normal acknowledge : 0x30<br>(The boot program aborts if the baud rate can<br>not be set correctly.) |
|          | 3 byte           | Command code (0x40)                                                                                                                                                                                                                                                                                                                                               |                               | -                                                                                                                                                                                                                            |
|          | 4 byte           | -                                                                                                                                                                                                                                                                                                                                                                 |                               | ACK for the command code byte (Note 2)<br>-Normal acknowledge : 0x40<br>-Negative acknowledge : 0xX1<br>-Communication error : 0xX8                                                                                          |
|          | 5 byte to 16byte | TMPM341FDXBG:<br>In case of 0x3F87_FFF0 is not 0xFF<br>PASS WORD data (12bytes) is<br>0x3F87_FFF4 to 0x3F87_FFFF<br>In case of 0x3F87_FFF0 is 0xFF<br>DUMMY data (12bytes) is<br>0x3F87_FFF4 to 0x3F87_FFFF<br>TMPM341FYXBG:<br>In case of 0x3F83_FFF0 is not 0xFF<br>PASS WORD data (12bytes) is<br>0x3F83_FFF4 to 0x3F83_FFFF<br>In case of 0x3F83_FFFF is 0xFF |                               | -                                                                                                                                                                                                                            |
|          |                  | DUMMY data (12bytes) is<br>0x3F83_FFF4 to 0x3F83_FFFF                                                                                                                                                                                                                                                                                                             |                               |                                                                                                                                                                                                                              |
|          | 17 byte          | Checksum value for 5 byte to 16 byte                                                                                                                                                                                                                                                                                                                              | _                             | -                                                                                                                                                                                                                            |
|          | 18 byte          | -                                                                                                                                                                                                                                                                                                                                                                 |                               | ACK for the checksum byte (Note 2)<br>-Normal acknowledge : 0x10<br>-Negative acknowledge : 0xX1<br>-Communication error : 0xX8                                                                                              |
|          | 19 byte          | Erase enable command code (0x54)                                                                                                                                                                                                                                                                                                                                  |                               | -                                                                                                                                                                                                                            |
|          | 20 byte          | -                                                                                                                                                                                                                                                                                                                                                                 |                               | ACK for the command code byte (Note 2)<br>-Normal acknowledge : 0x54<br>-Negative acknowledge : 0xX1<br>-Communication error : 0xX8                                                                                          |
|          | 21 byte          | -                                                                                                                                                                                                                                                                                                                                                                 |                               | ACK for the erase command code byte<br>-Normal acknowledge : 0x4F<br>-Negative acknowledge : 0x4C                                                                                                                            |
|          | 22 byte          | (Wait for the next command code.)                                                                                                                                                                                                                                                                                                                                 | 7                             | -                                                                                                                                                                                                                            |

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.

## 21.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 a 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 \sim 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 21.3. Before initiating a transfer, the RAM Transfer command verifies a password sequence coming from the controller against that stored in the flash memory.

2. Chip and Protection Bit Erase command

This command erases the entire area of the flash memory automatically without verifying a password. 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 FCSEC-BIT <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.

This command can select whether a password is verified.

Note: If a password is set to 0xFF (erased data area), it is difficult to protect data securely due to an easyto-guess password. Even if Single Boot mode is not used, it is recommended to set a unique value as a password.

#### 21.2.10.1 RAM Transfer Command

See Table 21-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 "21.2.10.4 Determination of a Serial Operation Mode" described later. If it is determined as UART mode, the boot program then checks if the SIO0 is programmable to the baud rate at which the 1st byte was transferred. During the first-byte interval, the RXE bit in the SCOMOD register is cleared.
  - To communicate in UART mode

Send, from the controller to the target board, 0x86 in UART data format at the desired baud rate. If the serial operation mode is determined as UART, then the boot program checks if the SIO0 can be programmed to the baud rate at which the first byte was transferred. If that baud rate is not possible, the boot program aborts, disabling any subsequent communications.

• To communicate in I/O Interface mode

Send, from the controller to the target board, 0x30 in I/O Interface data format at 1/16 of the desired baud rate. Also send the 2nd byte at the same baud rate. Then send all subsequent bytes at a rate equal to the desired baud rate.

In I/O Interface mode, the CPU sees the serial receive pin as if it were a general input port in monitoring its logic transitions. If the baud rate of the incoming data is high or the chip's operating frequency is high, the CPU may not be able to keep up with the speed of logic transitions. To prevent such situations, the 1st and 2nd bytes must be transferred at 1/16 of the desired baud rate; then the boot program calculates 16 times that as the desired baud rate. When the serial operation mode is determined as I/O Interface mode, the SIO0 is configured for SCLK Input mode. Beginning with the third byte, 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 such thing as error acknowledge (bit 3, 0xX8).

- 2. The 2nd byte, transmitted from the target board to the controller, is an acknowledge response to the 1st byte. The boot program echoes back the first byte: 0x86 for UART mode and 0x30 for I/O Interface mode.
  - UART mode

If the SIO0 can be programmed to the baud rate at which the 1st byte was transferred, the boot program programs the SC0BRCR and sends back 0x86 to the controller as an acknowledge. If the SIO0 is not programmable at that baud rate, the boot program simply aborts with no error indication. Following the 1st byte, the controller should allow for a time-out period of five seconds. If it does not receive 0x86 within the allowed time-out period, the controller should give up the communication. The boot program sets the RXE bit in the SC0MOD0 register to enable reception ("1") before loading the SIO transmit buffer with 0x86.

· I/O Interface mode

The boot program programs the SC0MOD0 and SC0CR registers to configure the SIO0 in I/O Interface mode (clocked by the rising edge of SCLK0), writes 0x30 to the SC0BUF. Then, the SIO0 waits for the SCLK0 signal to come from the controller. Following the transmission of the 1st byte, 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 the desire baud rate. If the 2nd byte, which is from the target board to the controller, is 0x30, then the controller should take it as a go-ahead. The controller must then deliver the 3rd byte to the target board at a rate equal to the desired baud rate. The boot program sets the RXE bit in the SC0MOD register to enable reception before loading the SIO transmit buffer with 0x30.

- 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 was 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 21-4, the boot program echoes it back to the controller. When the RAM Transfer command was 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 a 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 and the smallest address in the designated area. If the password verification fails, the RAM Transfer routine sets the password error flag.

| Product name | Password area              |  |  |
|--------------|----------------------------|--|--|
| TMPM341FDXBG | 0x3F87_FFF4 to 0x3F87_FFFF |  |  |
| TMPM341FYXBG | 0x3F83_FFF4 to 0x3F83_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, drop the carries and take the two's complement of the total sum. Transmit this checksum value from the controller to the target board. The checksum calculation is described in details in a 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 bytes. If there was 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 SIO0 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 5th to 16th bytes must result in 0x00 (with the carry dropped). If it is not 0x00, one or more bytes of data has been corrupted. 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 RAM Transfer routine examines the result of the password verification. The following two cases are treated as a password error. In these cases, the RAM Transfer routine sends back 0x11 (bit 0) to the controller and returns to the state in which it waits for a command (i.e., the 3rd byte) again.

- 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.24 of the address and the 22nd byte corresponds to bits 7.0 of the 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.8 of the number of bytes to be transferred, and the 24th byte corresponds to bits 7.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, drop the carries and take the two's complement of the total sum. Transmit this checksum value from the controller to the target board. The checksum calculation is described in details in a later section "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 was 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 SIO0 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 25th bytes must result in 0x00 (with the carry dropped). If it is not 0x00, one or more bytes of data has been corrupted. 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 RAM storage start address 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 TMPM341FDXBG/FYXBG. Storage begins at the address specified by the 19th.22nd bytes and continues for the number of bytes specified by the 23rd.24th bytes.
- 13. The (m+1) th byte is a checksum value. To calculate the checksum value, add the 27th to mth bytes together, drop the carries and take the two's complement of the total sum. Transmit this checksum value from the controller to the target board. The checksum calculation is described in details in a later section "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 was 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 SIOO 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). If it is not 0x00, one or more bytes of data has been corrupted. 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 successful, 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 after a normal acknowledge response (0x10) is transfered.

### 21.2.10.2 Chip and Protection Bit Erase Command

See Table 21-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. From the Controller to the TMPM341FDXBG/FYXBG

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 the TMPM341FDXBG/FYXBG 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 21-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 acknowl-edge response are undefined - they hold the same values as the upper four bits of the previously issued command.

 The 5th byte to 16th byte, transmitted from the target board to the controller, differ according to the Chip Erase Enable/Disable area (TMPM341FDXBG: 0x3F87\_FFF0, TMPM341FYXBG: 0x3F83\_FFF0).

If (TMPM341FDXBG: 0x3F87\_FFF0, TMPM341FYXBG: 0x3F83\_FFF0) is not the same value as 0xFF, a delete password is required. The 5th byte from the 16th byte becomes password data (12bytes). The verification is started with the 5th byte to compare with the addresses in the flash memory shown in the table below. If the password verification fails, the password error flag is set.

| Product name | Password area              |
|--------------|----------------------------|
| TMPM341FDXBG | 0x3F87_FFF4 to 0x3F87_FFFF |
| TMPM341FYXBG | 0x3F83_FFF4 to 0x3F83_FFFF |

If (TMPM341FDXBG: 0x3F87\_FFF0, TMPM341FYXBG: 0x3F83\_FFF0) is 0xFF, a password is not required. The 5th byte from 16th byte becomes dummy data.

5. The 17th byte is a checksum value. To calculate the checksum value, perform 8-bit unsigned addition of transmits data (5th byte to 16th byte), drop the carries and take the two's complement of the total sum. Transmit this checksum value from the controller to the target board. The checksum calculation is described in details in a later section "Checksum Calculation". 6. The 18th byte, transmitted from the target board to the controller, is an acknowledge response to the 5th to 17th bytes. First, the Chip and Protection bit erase routine checks for a receive error in the 5th to 17th bytes. If there was a receive error, the boot program sends back 0x48 (bit 3) and returns to the state in which it for a command (i.e., the 3rd byte) again. Since the upper four bits of the transmitted data are the same as those of the previously issued command (i.e., 4). When the SIO0 is configured for I/O Interface mode, the Chip and Protection bit erase routine does not check for a receive error.

Next, the Chip and Protection bit erase routine performs the checksum operation to ensure data integrity. Adding the series of the 5th to 16th bytes must result in 0x00 (with the carry dropped). If it is not 0x00, one or more bytes of data have been corrupted. In case of a checksum error, the Chip and Protection bit erase routine sends back the ACK response data (0x41) to the controller and returns to the state in which it for a command (i.e., the 3rd byte) again.

Finally, the Chip and Protection bit erase routine examines the result of the password verification. The following two cases are treated as a password error. In these cases, the Chip and Protection bit erase routine sends back the ACK response error 0x41 (bit 0) to the controller and returns to the state in which it waits for a command (i.e., the 3rd byte) again.

- Irrespective of the result of the password comparison (from 5th byte to 16th byte), 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 Chip and Protection bit erase routine returns a normal acknowledge response (0x40) to the controller.

7. From the Controller to the Device

The 19th byte, transmitted from the target board to the controller, is the Chip Erase Enable command code (0x54).

#### 8. From the Device to the Controller

The 20th byte, transmitted from the target board to the controller, is an acknowledge response to the 19th 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 19th byte is equal to any of the command codes to enable erasing, the boot program echoes it back to the controller (normal ACK response data). In this case, the boot program echoes back a value of 0x54 and then branches to the Chip Erase routine. If the 19th byte is not a valid command, the boot program sends back ACK response data 0xX1 (bit 0) to the controller and returns to the state in which it waits for a command (the 3rd 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.

9. From the Device to the Controller

The 21st 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.

10. The 22nd byte of received data is the next command.

### 21.2.10.3 Acknowledge Responses

The boot program represents processing states with specific codes. Table 21-8 to Table 21-11 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. Bit 3 of the code indicates a receive error. Bit 0 indicates an invalid command error, a checksum error or a password error. Bit 1 and bit 2 are always "0". Receive error checking is not done in I/O Interface mode.

### Table 21-8 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: If the serial operation mode is determined as UART, the boot program checks if the SIO can be programmed to the baud rate at which the operation mode byte was transferred. If that baud rate is not possible, the boot program aborts, without sending back any response.

Table 21-9 ACK Response to the Command Byte

| Return Value       | Meaning                                                                     |
|--------------------|-----------------------------------------------------------------------------|
| 0xX8<br>(See Note) | A receive error occurred while getting a command code.                      |
| 0xX1<br>(See Note) | An undefined command code was received. (Reception was completed normally.) |
| 0x10               | The RAM Transfer 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 21-10 ACK Response to the Checksum Byte

| Return Value       | Meaning                                |  |  |
|--------------------|----------------------------------------|--|--|
| 0xX8<br>(See Note) | A receive error occurred.              |  |  |
| 0xX1<br>(See Note) | A checksum or password error occurred. |  |  |
| 0xX0<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. It is 1 (X ; RAM transfer command data [7:4] ) when password error occurs.

Table 21-11 ACK Response to Chip and Protection Bit Erase Byte

| Return Value | Meaning                                     |  |  |
|--------------|---------------------------------------------|--|--|
| 0x54         | The Erase enabling command was received.    |  |  |
| 0x4F         | The Erase command was completed.            |  |  |
| 0x4C         | The Erase command was abnormally completed. |  |  |

### 21.2.10.4 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 first 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 the desired baud rate. Figure 21-5 shows the waveforms for the first 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 21-6 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 each time a logic transition occurs in the first serial byte. Consequently, the calculated tAB, tAC and tAD intervals are bound 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 is more prone to 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 the desired baud rate.

The flowchart in Figure 21-6 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. Bear in mind that if the baud rate is too high or the timer operating frequency is too low, the timer resolution will be coarse, relative to the intervals between logic transitions. This becomes a problem due to inherent errors caused by the way in which timer counts are captured by software; consequently the boot program might not be able to determine the serial operation mode correctly. 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).



Figure 21-6 Serial Operation Mode Byte Reception Flowchart



## Figure 21-7 Serial Operation Mode Determination Flowchart

### 21.2.10.5 Password

Verification methods differ according to operation commands. The password area is common to all commands, as shown below. Password verification is performed even if the security is enabled.

|   | Product name | Password area              |
|---|--------------|----------------------------|
| Γ | TMPM341FDXBG | 0x3F87_FFF4 to 0x3F87_FFFF |
|   | TMPM341FYXBG | 0x3F83_FFF4 to 0x3F83_FFFF |

Note: If a password is set to 0xFF (erased data area), it is difficult to protect data securely due to an easyto-guess password. Even if Single Boot mode is not used, it is recommended to set a unique value as a password.

### (1) RAM Transfer command

After an operation command code echoes back (0x10), the boot program verifies a data at password area (12 bytes).

If all these address locations contain the same bytes of data other than 0xFF, a password area error occurs as shown in Figure 21-8. 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.

The password sequence received from the controller (5th to 16th bytes) 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).





### (2) Flash Memory Chip Erase and Protect Bit Erase

The Chip erase enable/disable area specifies whether password verification is performed or not. The Chip erase enable/disable area is as shown below.

| Product      | The Chip erase enable/disable area |
|--------------|------------------------------------|
| TMPM341FDXBG | 0x3F87_FFF0                        |
| TMPM341FYXBG | 0x3F83_FFF0                        |

As shown in the Figure 21-9, if the data contained in the Chip erase enable/disable area is not 0xFF, password verification is executed. If all data in the password area is the same, it is determined as an error. The boot program returns an error acknowledge (0x41) in response to the check-sum byte (the 17th byte).

The password sequence received from the controller (5th to 16th bytes) 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 error acknowledges in response to the checksum byte (the 17th byte).



Figure 21-9 Password Area Verification Flowchart (2)

### 21.2.10.6 Checksum Calculation

The checksum byte for a series of bytes of data is calculated by adding the bytes together, dropping the carries, and taking the two's complement of the total sum. 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

Take the two's complement of the sum, and that is the checksum byte.

0 - 0xDB = 0x25

# 21.2.11 General Boot Program Flowchart

Figure 21-10 shows an overall flowchart of the boot program.





# 21.3 On-board Programming of Flash Memory (Rewrite/Erase)

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.

# 21.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.

| Major functions                                                                            | Description                                               |  |  |  |
|--------------------------------------------------------------------------------------------|-----------------------------------------------------------|--|--|--|
| Automatic page program                                                                     | Writes data automatically per page.                       |  |  |  |
| Automatic chip erase                                                                       | Erases 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 |                                                           |  |  |  |

### 21.3.1.1 Block Configuration



Figure 21-11 Block Configuration of Flash Memory (TMPM341FDXBG)

| User Boot Mode | Single Boot Mode | 9                  | Page Configuration |
|----------------|------------------|--------------------|--------------------|
| 0x0003_FFFF    | 0x3F83_FFFF      |                    | ])                 |
|                |                  | 64K bytes (BLOCK0) | 64 words × 256     |
| 0x0003_0000    | 0x3F83_0000      |                    | 1                  |
|                |                  | 64K bytes (BLOCK1) | ≻64 words×256      |
| 0x0002_0000    | 0x3F82_0000      |                    | 11                 |
|                |                  | 64K bytes (BLOCK2) | 64 words × 256     |
| 0x0001_0000    | 0x3F81_0000      |                    |                    |
|                |                  | 32K bytes (BLOCK3) | 64 words × 128     |
| 0x0000_8000    | 0x3F80_8000      |                    | 1                  |
| 0x0000_4000    | 0x3F80_4000      | 16K bytes (BLOCK5) | 64 words × 64      |
| 0x0000_0000    | 0x3F80_0000      | 16K bytes (BLOCK4) | ]}64 words×64      |

Figure 21-12 Block Configuration of Flash Memory (TMPM341FYXBG)

### 21.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 exceptions 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 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.

### (2) Command write

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, the operation to apply 32-bit data transmit command to the flash memory is called "bus write cycle." The bus write cycles are to be in 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 a command write operation is in accordance with a predefined specific sequence. 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, don't generate any interrupt (except debug exceptions when a debug port is connected). If such an operation is made, it can result in an unexpected read access to the flash memory and the command sequencer may not be able to correctly recognize the command. While it could cause an abnormal termination of the command sequence, it is also possible that the written command is incorrectly recognized.

- 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 that 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.

#### 21.3.1.3 Reset (Hardware reset)

A hardware reset is used to cancel the operational mode set by the command write operation when forcibly termination during automatic programming/ erasing or abnormal termination during 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  $\overrightarrow{\text{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 "21.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.

#### 21.3.1.4 Commands

#### (1) Automatic Page Programming

Writing to a flash memory device is to make "1" data cells to "0" data cells. Any "0" data cell cannot be changed to a "1" data cell. For making "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 TMPM341FDXBG/FYXBG contain 128 words in a page. A 128 word block is defined by a same [31:9] address and 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 times irrespective of the data cell value whether it is "1" or "0." 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 can 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. On and 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 a time). Be sure to use the 32-bit data transfer command in writing commands on and after the fourth bus cycle. In

this, any 32-bit data transfer commands shall not be placed across word boundary. On and 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 of the fourth bus write cycle to 0xFFFFFFF to command write the data.

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 normally terminating the automatic page writing process, FCFLCS<RDY/BSY> is set to "1" and 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 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 in bus write cycles on and 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 blocks 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 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 accepted 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 blocks 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 hard-ware 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 21-16 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 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 the status of FCFLCS <BLPRO> whether all <BLPRO> are set to "1" or not if FCSECBIT<FCSECBIT> is 0x1. Be sure to check the value of FCFLCS <BLPRO> before executing the automatic protection bit erase command. See the chapter "ROM protection" 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".While 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 appropriate.

• 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 21-17. 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".

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). On and 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 repetitively executed. For returning to the read mode, use the Read/reset command or hardware reset command.

### 21.3.1.5 Flash control/ status register

Base Address = 0x41FF\_F000

| Register name          | Address(Base+) |                  |  |
|------------------------|----------------|------------------|--|
| Reserved               | -              | 0x0000 to 0x000F |  |
| Security bit register  | FCSECBIT       | 0x0010           |  |
| Reserved               | -              | 0x0014 to 0x001F |  |
| Flash control register | FCFLCS         | 0x0020           |  |
| Reserved               | -              | 0x0024 to 0x0FFF |  |

Note: Access to the "Reserved" areas is prohibited.

|             | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | SECBIT |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1      |

### (1) FCSECBIT (Security bit register)

| 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 or releasing STOP2 mode of standby mode.

|             | 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  | -  | -  | BLPRO5  | BLPRO4  | BLPRO3  | BLPRO2  | BLPRO1  | BLPRO0  |
| After reset | 0  | 0  | (Note2) | (Note2) | (Note2) | (Note2) | (Note2) | (Note2) |
|             | 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  | -  | -  | -       | -       | -       | -       | -       | RDY/BSY |
| After reset | 0  | 0  | 0       | 0       | 0       | 0       | 0       | 1       |

## (2) FCFLCS (Flash control register)

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-22 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 21-16 | BLPRO5 to  | R    | Protection for Block5 to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | BLPRO0     |      | 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 it.                                                                                                                                                                                                                                                                        |
| 15-1  | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0     | RDY/BSY    | R    | Ready/Busy (Note 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |            |      | 0: automatic operating                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |            |      | 1:automatic 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 func-<br>tion bit for the CPU to monitor the function. When the flash memory is in automatic operation, it outputs<br>"0" to indicate that it is busy. When the automatic operation is terminated, it returns to the ready state and out-<br>puts "1" to accept the next command. If the automatic operation has failed, this bit maintains the "0" out-<br>put. 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 µ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.

### 21.3.1.6 List of Command Sequences

Table 21-13 shows the addresses 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 and the fourth bus cycle of the Read/reset 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 21-14 for the detail of the address bit configuration. Use a value of "Addr." in the Table 21-13 for the address [15:8] of the normal command in the Table 21-14.

Note: Always set "0" to the address bits [1:0] in the entire bus cycle.

|                                         | 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.                | Addr.            | Addr.                | Addr.            | Addr.                | Addr.                | Addr.             |
|                                         | Data                 | Data             | Data                 | Data             | Data                 | Data                 | Data              |
| Dead                                    | 0xXX                 | -                | -                    | -                | -                    | -                    | -                 |
| Read                                    | 0xF0                 | -                | -                    | -                | -                    | -                    | -                 |
| Read/Reset                              | 0x54XX               | 0xAAXX           | 0x54XX               | RA               | -                    | -                    | -                 |
| Read/Reset                              | 0xAA                 | 0x55             | 0xF0                 | RD               | -                    | -                    | -                 |
| ID-Read                                 | 0x54XX               | 0xAAXX           | 0x54XX               | IA               | 0xXX                 | -                    | -                 |
|                                         | 0xAA                 | 0x55             | 0x90                 | 0x00             | ID                   | -                    | -                 |
| Automatic page pro-<br>gramming         | 0x54XX               | 0xAAXX           | 0x54XX               | PA               | PA                   | PA                   | PA                |
|                                         | 0xAA                 | 0x55             | 0xA0                 | PD0              | PD1                  | PD2                  | PD3               |
| Automatic chip erase                    | 0x54XX               | 0xAAXX           | 0x54XX               | 0x54XX           | 0xAAXX               | 0x54XX               | -                 |
|                                         | 0xAA                 | 0x55             | 0x80                 | 0xAA             | 0x55                 | 0x10                 | -                 |
| Automatic block erase                   | 0x54XX               | 0xAAXX           | 0x54XX               | 0x54XX           | 0xAAXX               | BA                   | -                 |
| Automatic block erase                   | 0xAA                 | 0x55             | 0x80                 | 0xAA             | 0x55                 | 0x30                 | -                 |
| Automatic protection bit                | 0x54XX               | 0xAAXX           | 0x54XX               | 0x54XX           | 0xAAXX               | 0x54XX               | PBA               |
| Automatic protection bit<br>programming | 0xAA                 | 0x55             | 0x9A                 | 0xAA             | 0x55                 | 0x9A                 | 0x9A              |
| Automatic protection bit                | 0x54XX               | 0xAAXX           | 0x54XX               | 0x54XX           | 0xAAXX               | 0x54XX               | PBA               |
| erase                                   | 0xAA                 | 0x55             | 0x6A                 | 0xAA             | 0x55                 | 0x6A                 | 0x6A              |

Table 21-13 Flash Memory Access from the Internal CPU

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 the fourth bus cycle, enter data in the order of the address for a page.

- BA: Block address
- PBA: Protection bit address

### 21.3.1.7 Address bit configuration for bus write cycles

Table 21-14 is used in conjunction with Table 21-13 "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 21-14 Address Bit Configuration for Bus Write Cycles can be changed as necessary.

| Address | Addr    | Addr | Addr | Addr | Addr | Addr | Addr    | Addr | Addr | Addr | Addr  |
|---------|---------|------|------|------|------|------|---------|------|------|------|-------|
|         | [31:19] | [18] | [17] | [16] | [15] | [14] | [13:11] | [10] | [9]  | [8]  | [7:0] |

|                      | Normal bus write cycle address configuration                                  |                     |            |                                               |  |  |  |  |
|----------------------|-------------------------------------------------------------------------------|---------------------|------------|-----------------------------------------------|--|--|--|--|
| Normal com-<br>mands | Flash area                                                                    | "0" is recommended. |            | Command                                       |  |  |  |  |
|                      | IA: ID address (Set the fourth bus write cycle address for ID-Read operation) |                     |            |                                               |  |  |  |  |
| ID-READ              | Flash area                                                                    | "0" is recommended. | ID address | Addr[1:0]="0" (fixed), Others:0 (recommended) |  |  |  |  |

#### [TMPM341FDXBG]

|                                    |                                                                                                     | tion)                                        |  |                                                |                                                 |                                                 |  |  |  |
|------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------|--|------------------------------------------------|-------------------------------------------------|-------------------------------------------------|--|--|--|
| Block erase                        |                                                                                                     | Block selection<br>(Table 21-15)             |  | Addr[1:0]="0" (fixed) , Others:0 (recommended) |                                                 |                                                 |  |  |  |
|                                    | PA: Program page address (Set the fourth bus write cycle address for page programming operation)    |                                              |  |                                                |                                                 |                                                 |  |  |  |
| Automatic<br>page pro-<br>gramming | Page address     Addr[1:0]="0" (fixed       Others:0     (recommended)                              |                                              |  |                                                |                                                 |                                                 |  |  |  |
|                                    | PBA: Protection bit address (Set the seventh bus write cycle address for protection bit programming |                                              |  |                                                |                                                 |                                                 |  |  |  |
| Protection<br>bit program-<br>ming | Flash area                                                                                          | Protection bit<br>selection<br>(Table 21-16) |  | Fixed to "0".                                  | Protection bit<br>selection<br>(Table 21-16)    | Addr[1:0]="0" (fixed)<br>Others:0 (recommended) |  |  |  |
|                                    | PBA: Protection bit address (Set the seventh bus erase cycle address for protection bit erasure)    |                                              |  |                                                |                                                 |                                                 |  |  |  |
| Protection<br>bit erase            | Flash area                                                                                          | Protection bit<br>selection<br>(Table 21-17) |  | Fixed to "0".                                  | Addr[1:0]="0" (fixed)<br>Others:0 (recommended) |                                                 |  |  |  |

#### [TMPM341FYXBG]

| Block erase                        |                                                                                                     | Block selection<br>(Table 21-15              |     | Addr[1:0]="0" (fixed), Others:0 (recommended) |                                              |                                                    |  |  |  |
|------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------|-----|-----------------------------------------------|----------------------------------------------|----------------------------------------------------|--|--|--|
|                                    | PA: Program page address (Set the fourth bus write cycle address for page programming operation)    |                                              |     |                                               |                                              |                                                    |  |  |  |
| Automatic<br>page pro-<br>gramming | Page address     Addr[1:0]="0" (fixe       Others:0     (recommended)                               |                                              |     |                                               |                                              |                                                    |  |  |  |
|                                    | PBA: Protection bit address (Set the seventh bus write cycle address for protection bit programming |                                              |     |                                               |                                              |                                                    |  |  |  |
| Protection<br>bit program-<br>ming | Flash area                                                                                          | Protection bit<br>selection<br>(Table 21-16) | Fix | ed to "0".                                    | Protection bit<br>selection<br>(Table 21-16) | Addr[1:0]="0" (fixed)<br>Others:0<br>(recommended) |  |  |  |
|                                    | PBA: Protection bit address (Set the seventh bus erase cycle address for protection bit erasure)    |                                              |     |                                               |                                              |                                                    |  |  |  |
| Protection<br>bit erase            | Flash area                                                                                          | Protection bit<br>selection<br>(Table 21-17) |     | Fixed to "0".                                 |                                              | Addr[1:0]="0" (fixed)<br>Others:0<br>(recommended) |  |  |  |

# TOSHIBA

As block address, specify any address in the block to be erased.

Table 21-15 Block Address Table

| Block Address (User boot mode) Address (Single boot mode) Size (Kbyte) |
|------------------------------------------------------------------------|
|------------------------------------------------------------------------|

### [TMPM341FDXBG]

| 4 | 0x0000_0000 to 0x0000_7FFF | 0x3F80_0000 to 0x3F80_7FFF | 32  |
|---|----------------------------|----------------------------|-----|
| 5 | 0x0000_8000 to 0x0000_FFFF | 0x3F80_4000 to 0x3F80_FFFF | 32  |
| 3 | 0x0001_0000 to 0x0001_FFFF | 0x3F81_0000 to 0x3F81_FFFF | 64  |
| 2 | 0x0002_0000 to 0x0003_FFFF | 0x3F82_0000 to 0x3F83_FFFF | 128 |
| 1 | 0x0004_0000 to 0x0005_FFFF | 0x3F84_0000 to 0x3F85_FFFF | 128 |
| 0 | 0x0006_0000 to 0x0007_FFFF | 0x3F86_0000 to 0x3F87_FFFF | 128 |

#### [TMPM341FYXBG]

| 4 | 0x0000_0000 to 0x0000_3FFF | 0x3F80_0000 to 0x3F80_3FFF | 16 |
|---|----------------------------|----------------------------|----|
| 5 | 0x0000_4000 to 0x0000_7FFF | 0x3F80_4000 to 0x3F80_7FFF | 16 |
| 3 | 0x0000_8000 to 0x0000_FFFF | 0x3F80_8000 to 0x3F80_FFFF | 32 |
| 2 | 0x0001_0000 to 0x0001_FFFF | 0x3F81_0000 to 0x3F81_FFFF | 64 |
| 1 | 0x0002_0000 to 0x0002_FFFF | 0x3F82_0000 to 0x3F82_FFFF | 64 |
| 0 | 0x0003_0000 to 0x0003_FFFF | 0x3F83_0000 to 0x3F83_FFFF | 64 |

Note: As for the addresses from the first to the fifth bus cycles, specify the upper addresses of the blocks to be erased.

|       |                | The seventh bus write cycle address |                 |                    |                 |             |             |  |
|-------|----------------|-------------------------------------|-----------------|--------------------|-----------------|-------------|-------------|--|
| Block | Protection bit | Address<br>[18]                     | Address<br>[17] | Address<br>[16:11] | Address<br>[10] | Address [9] | Address [8] |  |

#### [TMPM341FDXBG]

| 1      |                       |   |   | i        | Ì |   | 1              |
|--------|-----------------------|---|---|----------|---|---|----------------|
| Block0 | <blpro[0]></blpro[0]> | 0 | 0 |          | 0 | 0 |                |
| Block1 | <blpro[1]></blpro[1]> | 0 | 0 |          | 0 | 1 |                |
| Block2 | <blpro[2]></blpro[2]> | 0 | 0 | Fixed to | 1 | 0 | "0" is rec-    |
| Block3 | <blpro[3]></blpro[3]> | 0 | 0 | "0".     | 1 | 1 | ommen-<br>ded. |
| Block4 | <blpro[4]></blpro[4]> | 0 | 1 |          | 0 | 0 |                |
| Block5 | <blpro[5]></blpro[5]> | 0 | 1 |          | 0 | 1 |                |

[TMPM341FYXBG]

| Block0 | <blpro[0]></blpro[0]> | 0 | 0 |               | 0 | 0 |
|--------|-----------------------|---|---|---------------|---|---|
| Block1 | <blpro[1]></blpro[1]> | 0 | 0 |               | 0 | 1 |
| Block2 | <blpro[2]></blpro[2]> | 0 | 0 | Fixed to #0#  | 1 | 0 |
| Block3 | <blpro[3]></blpro[3]> | 0 | 0 | Fixed to "0". | 1 | 1 |
| Block4 | <blpro[4]></blpro[4]> | 0 | 1 |               | 0 | 0 |
| Block5 | <blpro[5]></blpro[5]> | 0 | 1 |               | 0 | 1 |

### Table 21-17 Protection Bit Erase Address Table (TMPM341FD/FYXBG)

| Block       | Protection bit            | The seventh bus write cycle address [18:17] |             |  |  |
|-------------|---------------------------|---------------------------------------------|-------------|--|--|
|             |                           | Address[18]                                 | Address[17] |  |  |
| Block0 to 3 | <blpro[0:3]></blpro[0:3]> | 0                                           | 0           |  |  |
| Block4 to 5 | <blpro[4:5]></blpro[4:5]> | 0                                           | 1           |  |  |

Note: The protection bit erase command cannot erase by individual block.

Table 21-18 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      | 0x12 (TMPM341FDXBG)<br>0x13 (TMPM341FYXBG) | Macro code        |

### 21.3.1.8 Flowchart



Automatic Page Programming Command Sequence (Address/ Command)



# Figure 21-13 Automatic Programming

Note: Command sequence is executed by 0x54xx or 0x55xx.

#### 21. Flash Memory Operation

21.3 On-board Programming of Flash Memory (Rewrite/Erase)





Figure 21-14 Automatic Erase

Note: Command sequence is executed by 0x54xx or 0x55xx.

# 22. ROM protection

# 22.1 Outline

The TMPM341FDXBG/FYXBG 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.

# 22.2 Future

## 22.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[5:0]> bit. See the chapter "Flash" for programming details.

## 22.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"1".
- 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 22-1 shows details of the restrictions by the security function.

### Table 22-1 Restrictions by the security function

| Item                        | Details                                                                                                                                                                      |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1) ROM data readout         | Data can be read from CPU.                                                                                                                                                   |
| 2) Debug port               | Communication of JTAG/SW and trace are prohibited                                                                                                                            |
| 3) Command for flash memory | Writing a command to the flash memory is prohibited.<br>An attempt to erase the contents in the bits used for the write/<br>erase-protection erases all the protection bits. |

# 22.3 Register

|                        |               | Base Address = 0x41FF_F000 |  |  |  |  |
|------------------------|---------------|----------------------------|--|--|--|--|
| Register name          | Register name |                            |  |  |  |  |
| Reserved               | -             | 0x0000                     |  |  |  |  |
| Reserved               | -             | 0x0004                     |  |  |  |  |
| Security bit register  | FCSECBIT      | 0x0010                     |  |  |  |  |
| Flash control register | FCFLCS        | 0x0020                     |  |  |  |  |
| Reserved               | -             | 0x0024                     |  |  |  |  |
| Reserved               | -             | 0x0028                     |  |  |  |  |

Note: Access to the "Reserved" area is prohibited.

|             | 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  | -  | -  | BLPRO5  | BLPRO4  | BLPRO3  | BLPRO2  | BLPRO1  | BLPR00  |
| After reset | 0  | 0  | (Note2) | (Note2) | (Note2) | (Note2) | (Note2) | (Note2) |
|             | 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  | -  | -  | -       | -       | -       | -       | -       | RDY/BSY |
| After reset | 0  | 0  | 0       | 0       | 0       | 0       | 0       | 1       |

# 22.3.1 FCFLCS (Flash control register)

| Bit   | Bit Symbol | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-22 | -          | R    | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 21-16 | BLPRO5 to  | R    | Protection for Block5 to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | BLPRO0     |      | 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 it.                                                                                                                                                                                                                                                                        |
| 15-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 func-<br>tion bit for the CPU to monitor the function. When the flash memory is in automatic operation, it outputs<br>"0" to indicate that it is busy. When the automatic operation is terminated, it returns to the ready state and out-<br>puts "1" to accept the next command. If the automatic operation has failed, this bit maintains the "0" out-<br>put. 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.

|             | 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  | 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  | -  | -  | -  | -  | -  | -  | -  | SECBIT |
| After reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1      |

# 22.3.2 FCSECBIT(Security bit register)

| Bit  | Bit Symbol | Туре | ã@î\                                      |
|------|------------|------|-------------------------------------------|
| 31-1 | -          | R    | Read as 0.                                |
| 0    | SECBIT     | R/W  | Security bit<br>0: Disabled<br>1: Enabled |

Note: This register is initialized by cold reset and releasing STOP2 mode of the standby mode.

# 22.4 Writing and erasing

Writing and erasing protection bits are available with a single chip mode, single boot mode and writer mode.

## 22.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

## 22.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.

22. ROM protection

## 22.4 Writing and erasing

# 23. Debug Interface

# 23.1 Specification Overview

TMPM341FDXBG/FYXBG contains the Serial Wire JTAG Debug Port (SWJ-DP) unit for interfacing with the debugging tools and the Embedded Trace Macrocell<sup>TM</sup>(ETM) unit for instruction trace output. Trace data is output to the dedicated pins(TRACEDATA[3:0], SWV) for the debugging via the on-chip Trace Port Interface Unit (TPIU).

For details about SWJ-DP, ETM and TPIU, refer to "Cortex-M3 Technical Reference Manual" .

# 23.2 SWJ-DP

SWJ-DP supports the Serial Wire Debug Port (SWCLK, SWDIO) and the JTAG Debug Port (TDI, TDO, TMS, TCK, TRST).

# 23.3 ETM

ETM supports four data signal pins (TRACEDATA[3:0]), one clock signal pin (TRACECLK) and trace output from Serial Wire Viewer (SWV).

# 23.4 Pin Functions

The debug interface pins can also be used as general-purpose ports.

The PI6 and PI5 pins are shared between the JTAG debug port function and the Serial Wire Debug Port function. The PI7 pin is shared between the JTAG debug port function and the SWV trace output function.

| SWJ-DP      | General-             | JTA    | G Debug Function                                      | SW Debug Function |                               |  |
|-------------|----------------------|--------|-------------------------------------------------------|-------------------|-------------------------------|--|
| Pin Name    | purpose<br>Port Name | Ι/Ο    | Explanation                                           | Ι/Ο               | Explanation                   |  |
| TMS / SWDIO | PI6                  | Input  | JTAG Test Mode Selection I / O Serial Wire Data Ing   |                   | Serial Wire Data Input/Output |  |
| TCK / SWCLK | PI5                  | Input  | JTAG Test Check Input Serial Wire                     |                   | Serial Wire Clock             |  |
| TDO / SWV   | PI7                  | Output | JTAG Test Data Output (Output)(Note) (Serial Wire Vie |                   | (Serial Wire Viewer Output)   |  |
| TDI         | PI4                  | Input  | JTAG Test Data Input                                  | -                 | -                             |  |
| TRST        | PI3                  | Input  | JTAG Test RESET                                       | -                 | -                             |  |
| TRACECLK    | PI2                  | Output | TRACE Clock Output                                    |                   |                               |  |
| TRACEDATA0  | PI1                  | Output | TRACE DATA Output0                                    |                   |                               |  |
| TRACEDATA1  | PI0                  | Output | TRACE DATA Output1                                    |                   |                               |  |
| TRACEDATA2  | PH6                  | Output | TRACE DATA Output2                                    |                   |                               |  |
| TRACEDATA3  | PH5                  | Output | TRACE DATA Output3                                    |                   |                               |  |

Table 23-1 SWJ-DP,ETM Debug Functions

#### Note: When SWV function is enabled.

After reset, PI3, PI4, PI5, PI6 and PI7 pins are configured as debug port function pins. The functions of other debug interface pins need to be programmed as required.

When using a low power consumption mode, take note of the following points.

- Note 1: If PI6 and PI7 are configured as TMS/SWDIO and TDO/SWV, output continues to be enabled even in STOP1 mode regardless of the setting of the CGSTBYCR<DRVE> bit.
- Note 2: If PI5 is configured as a debug function pin, it prevents a low power consumption mode from being fully effective. Configure PI5 to function as a general-purpose port if the debug function is not used.

Table 23-2 summarizes the debug interface pin and related port settings after reset.

| Dether                  |                | Value of Related port settings 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) |  |
| Pl6                     | TMS/SWDIO      | 1                                          | 1               | 1                | 1                  | -                    |  |
| PI5                     | TCK/SWCLK      | 1                                          | 1               | 0                | -                  | 1                    |  |
| PI7                     | TDO/SWV        | 1                                          | 0               | 1                | 0                  | -                    |  |
| Pl4                     | TDI            | 1                                          | 1               | 0                | 1                  | -                    |  |
| PI3                     | TRST           | 1                                          | 1               | 0                | 1                  | -                    |  |
| PI2                     | TRACECLK       | 0                                          | 0               | 0                | 0                  | -                    |  |
| PI1                     | TRACEDATA0     | 0                                          | 0               | 0                | 0                  | -                    |  |
| P10                     | TRACEDATA1     | 0                                          | 0               | 0                | 0                  | -                    |  |
| PH6                     | TRACEDATA2     | 0                                          | 0               | 0                | 0                  | -                    |  |
| PH5                     | TRACEDATA3     | 0                                          | 0               | 0                | 0                  | -                    |  |

### Table 23-2 Debug Interface Pins and Related Port Settings after Reset

- : Don't care

# 23.5 Peripheral Functions in Halt Mode

When the Cortex-M3 core enters in the halt mode, the watchdog-timer (WDT) automatically stops. Other peripheral functions continue to operate.

# 23.6 Connection with a Debug Tool

## 23.6.1 About connection with 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.

Note 1: Ensure that to mesure the power-consumption with debug tool connected in STOP1/STOP2 mode is prohibitted.

### 23.6.2 Important points of using debug interface pins used as general-purpose ports

TMPM341FDXBG/FYXBG is prohibited from transmission with debug tools while reset caused by  $\overline{\text{RE-}}$  SET pin is effective. Therefore it cannot change to the debug mode.

The PI3, PI4, PI5, PI6 and PI7 ports are the debug interface pins after reset however if these pins are changed to the general-purpose port immediately after reset, the control from the debug tools are not accepted under some circumstances. When changing the settings, please pay attention to the status of debug interface pins.

|                             | Debug interface pins |     |              |                |                |                    |              |
|-----------------------------|----------------------|-----|--------------|----------------|----------------|--------------------|--------------|
|                             | TRST                 | TDI | TDO /<br>SWV | TCK /<br>SWCLK | TMS /<br>SWDIO | TRACE<br>DATA[3:0] | TRACE<br>CLK |
| JTAG+SW (After reset)       | 0                    | 0   | о            | о              | 0              | ×                  | ×            |
| JTAG+SW (without TRST)      | ×                    | 0   | ο            | о              | 0              | ×                  | ×            |
| JTAG+TRACE                  | 0                    | 0   | о            | о              | 0              | 0                  | 0            |
| SW                          | ×                    | ×   | ×            | 0              | 0              | ×                  | ×            |
| SW+SWV                      | ×                    | ×   | 0            | 0              | 0              | ×                  | ×            |
| Debugging function disabled | ×                    | ×   | ×            | ×              | ×              | ×                  | ×            |

### Table 23-3 Table of using debug interface pins

o : Enabled × : Disabled (Usable as general-purpose port)

# 24. JTAG Interface

## 24.1 Overview

The TMPM341FDXBG/FYXBG provides a boundary-scan interface that is compatible with Joint Test Action Group (JTAG) specifications and uses the industry-standard JTAG protocol (IEEE Standard 1149.1 • 1990 <Includes IEEE Standard 1449.1a • 1993>).

This chapter describes the JTAG interface, with the descriptions of boundary scan and the pins and signals used by the interface.

1. JTAG standard version

IEEE Standard 1149.1 • 1990 (Includes IEEE Standard 1149.1a • 1993)

2. JTAG instructions

Standard instructions (BYPASS, SAMPLE/PRELOAD, EXTEST)

HIGHZ instruction

CLAMP instruction

However, the SAMPLE/RELOAD instruction doesn't function because internal circuit reset starts as for TMPM341FDXBG/FYXBG while JTAG is operating.

3. IDCODE

Not available

- 4. Pins excluded from boundary scan register (BSR)
  - a. Oscillator circuit pins (X1, X2)
  - b. DAC pins (DA0, DA1)
  - c. JTAG control pins (BSC)
  - d. Power supply/GND pins (including AVREFH, AVREFL)
  - e. Monitor pins (FTEST3)
  - f. Control pins (RESET, MODE, INTLV)

Note: As for FP0 pin is always pull-up, the pin is output high-level while in HIGHZ instruction.

Note: Please note the input level to the analog input pins.

Note: The BSR of  $\overline{\text{NMI}}$  pin has not an output function.

Note: The BSR of ENDIAN pin has an input/output function.

# 24.2 Signal Summary and Connection Example

The JTAG interface signals are listed below.

| - TDI  | JTAG serial data input                                         |
|--------|----------------------------------------------------------------|
| - TDO  | JTAG serial data output                                        |
| - TMS  | JTAG test mode select                                          |
| - TCK  | JTAG serial clock input                                        |
| - TRST | JTAG test reset input                                          |
| - BSC  | ICE/JTAG test select input (compatible with the Enable signal) |
| - 830  | 0: ICE, 1: JTAG                                                |

The TMPM341FDXBG/FYXBG supports debugging by connecting the JTAG interface with a JTAG-compliant development tool.

For information about debugging, refer to the specification of the development tool used.



## Figure 24-1 Example of connection with a JTAG development tool

Note: In the case of not using JTAG Tool, fix the TRST pin to GND. In the case of using JTAG Tool, Once set the TRST pin to "Low" level to reset the JTAG circuits, and then translate to "High" level. Pull-up resistance is built in some JTAG Tools, the value of external pull-up resistance need to be considered according to the JTAG Tools.

| Mode Setting Pin (BSC) | Operation mode                                                                                                                                                                          |  |  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0                      | Set this pin to 0 except for Boundary Scan Mode.<br>The TMPM341FDXBG/FYXBG operates as regular Debug<br>Mode.<br>Note: Debugging is not available if the internal BOOT is run-<br>ning. |  |  |
| 1                      | The TMPM341FDXBG/FYXBG operates in Boundary Scan Mode.                                                                                                                                  |  |  |

### 24.3 What is Boundary Scan?

With the evolution of ever-denser integrated circuits (ICs), surface-mounted devices, double-sided component mounting on printed-circuit boards (PCBs), and set-in recesses, in-circuit tests that depend upon physical contact like the connection of the internal board and chip has become more and more difficult to use. The more ICs have become complex, the larger and more difficult the test program became.

As one of the solutions, boundary-scan circuits started to be developed. A boundary-scan circuit is a series of shift register cells placed between the pins and the internal circuitry of the IC to which the said pins are connected. Normally, these boundary-scan cells are bypassed; when the IC enters test mode, however, the scan cells can be directed by the test program to pass data along the shift register path and perform various diagnostic tests. To accomplish this, the tests use the five signals, TCK, TMS, TDI, TDO and  $\overline{\text{TRST}}$ .

The JTAG boundary-scan mechanism (hereinafter referred to as JTAG mechanism in the chapter) allows testing of the connections between the processor, the printed circuit board to which it is attached, and the other components on the circuit board.

The JTAG mechanism cannot test the processor alone.

### 24.4 JTAG Controller and Registers

The processor contains the following JTAG controller and registers.

- Instruction register
- Boundary scan register
- Bypass register
- Device identification register
- Test Access Port (TAP) controller

JTAG basically operates to monitor the TMS input signal with the TAP controller state machine. When the monitoring starts, the TAP controller determines the test functionality to be implemented. This includes both loading the JTAG instruction register (IR) and beginning a serial data scan through a data register (DR), as shown in Table 24-1. As the data is scanned, the state of the TMS pin signals each new data word and indicates the end of the data stream. The data register is selected according to the contents of the instruction register.

### 24.5 Instruction Register

The JTAG instruction register includes four shift register-based cells. This register is used to select the test to be performed and/or the test data register to be accessed. As listed in Table 24-1, this instruction codes select either the boundary scan register or the bypass register.

| Instruction code<br>(MSB to LSB) | Instruction    | Selected data register |
|----------------------------------|----------------|------------------------|
| 0000                             | EXTEST         | Boundary scan register |
| 0001                             | SAMPLE/PRELOAD | Boundary scan register |
| 0100 to 1110                     | Reserved       | Reserved               |
| 0010                             | HIGHZ          | Bypass register        |
| 0011                             | CLAMP          | Bypass register        |
| 1111                             | BYPASS         | Bypass register        |

Table 24-1 JTAG Instruction Register Bit Configuration

Figure 24-2 shows the format of the instruction register.



Figure 24-2 Instruction register

The instruction code is shifted out to the instruction register from the LSB.



Figure 24-3 Instruction Register Shift Direction

The bypass register is 1 bit wide. When the TAP controller is in the Shift-DR (bypass) state, the data on the TDI pin is shifted into the bypass register, and the bypass register output shifts to the data out on the TDO output pin.

In essence, the bypass register is an alternative route which allows bypassing of board-level devices in the serial boundary-scan chain, which are not required for a specific test. The logical location of the bypass register in the boundary-scan chain is shown in Figure 24-4.

Use of the bypass register speeds up access to the boundary scan register in the IC that remains active in the board-level test data path.



Figure 24-4 Bypass Register Operation

#### 24.6 Boundary Scan Register

The boundary scan register provides all the inputs and outputs of the TMPM341FDXBG/FYXBG processor except some analog outputs and control signals. The pins of the TMPM341FDXBG/FYXBG allow any pattern to be driven by scanning the data into the boundary scan register in the Shift-DR state. Incoming data to the processor is examined by enabling the boundary scan register and shifting the data when the BSR is in the Capture-DR state.

The boundary scan register is a single, 231-bit-wide, shift register-based path containing cells connected to the input and output pads on the TMPM341FDXBG/FYXBG.

The TDI input is loaded to the LSB of the boundary scan register. The MSB of the boundary scan register is shifted out on the TDO output.

#### 24.7 Test Access Port(TAP)

The Test Access Port (TAP) consists of the five signal pins:  $\overline{\text{TRST}}$ , TDI, TDO, TMS and TCK. These pins control a test by communicating the serial test data and instructions.

As Figure 24-5 shows, data is serially scanned into one of the three registers (instruction register, bypass register or boundary scan register) on the TDI pin, or it is scanned out from one of these three registers on the TDO pin.

The TMS input controls the state transitions of the main TAP controller state machine. The TCK input is a special test clock that allows serial JTAG data to be shifted synchronously, independent of any chip-specific or system clocks.



Figure 24-5 JTAG Test Access Port

Data on the TDI and TMS pins are sampled on the rising edge of the TCK input clock signal. Data on the TDO pin changes on the falling edge of the TCK clock signal.

#### 24.8 TAP Controller

The processor incorporates the 16-state TAP controller stipulated in the IEEE JTAG specification.

### 24.9 Resetting the TAP Controller

The TAP controller state machine can be put into the Reset state by the following method.

Assertion of the TRST signal input (low) resets the TAP controller. After the processor reset state is released, keep the TMS input signal asserted through five consecutive rising edges of TCK input. Keeping TMS asserted maintains the Reset state.

### 24.10 State Transitions of the TAP Controller

The state transition diagram of the TAP controller is shown in Figure 24-6. Each arrow between states is labeled with a 1 or 0, indicating the logic value of TMS that must be set up before the rising edge of TCK to cause the transition.



Figure 24-6 TAP Controller State Transition Diagram

The following paragraphs describe each of the controller states. The left column in Figure 24-6 is the data column, and the right column is the instruction column. The data column and instruction column reference the data register (DR) and the instruction register (IR), respectively.

Test-Logic-Reset

When the TAP controller is in the Reset state, the device identification register is selected by default. The MSB of the boundary scan register is cleared to 0 which disables the outputs.

The TAP controller remains in this state while TMS is high. If TMS is held low while the TAP controller is in this state, then the controller moves to the Run-Test/Idle state.

• Run-Test/Idle

In the Run-Test/Idle state, the IC is put in test mode only when certain instructions such as a built-in self test (BIST) instruction are present. For instructions that do not cause any activities in this state, all test data registers selected by the current instruction retain their previous states.

The TAP controller remains in this state while TMS is held low. When TMS is held high, the controller moves to the Select-DR-Scan state.

Select-DR-Scan

This is a temporary controller state. Here, the IC does not execute any specific functions.

If TMS is held low when the TAP controller is in this state, the controller moves to the Capture-DR state. If TMS is held high, the controller moves to the Select-IR-Scan state.

Select-IR-Scan

This is a temporary controller state. Here, the IC does not execute any specific functions.

If TMS is held low when the TAP controller is in this state, the controller moves to the Capture-IR state. IF TMS is held high, the controller returns to the Test-Logic-Reset state.

• Capture-DR

In this state, if the test data register selected by the current instruction has parallel inputs, then data is parallel-loaded into the shift portion of the data register. If the test data register does not have parallel inputs, or if data needs not be loaded into the selected data register, then the data register retains its previous state.

If TMS is held low when the TAP controller is in this state, the controller moves to the Shift-DR state. If TMS is held high, the controller moves to the Exit 1-DR state.

Shift-DR

In this controller state, the test data register connected between TDI and TDO shifts data out serially.

When the TAP controller is in this state, then it remains in the Shift-DR state if TMS is held low, or moves to the Exit 1-DR state if TMS is held high.

• Exit 1-DR

This is a temporary controller state.

If TMS is held low when the TAP controller is in this state, the controller moves to the Pause-DR state. If TMS is held high, the controller moves to the Update-DR state.

• Pause-DR

This state allows the shifting of the data register selected by the instruction register to be temporarily suspended. Both the instruction register and the data register retain their current states.

When the TAP controller is in this state, then it remains in the Pause-DR state if TMS is held low, or moves to the Exit 2-DR state.

• Exit 2-DR

This is a temporary controller state.

When the TAP controller is in this state, it returns to the Shift-DR state if TMS is held low, or moves on to the Update-DR state if TMS is held high.

• Update-DR

In this state, data is latched, on the rising edge of TCK, onto the parallel outputs of the data registers from the shift register path. The data held at the parallel output does not change while data is shifted in the associated shift register path.

When the TAP controller is in this state, it moves to either the Run-Test/Idle state if TMS is held low, or the Select-DR-Scan state if TMS is held high.

• Capture-IR

In this state, data is parallel-loaded into the instruction register. The data to be loaded is 0001. The Capture-IR state is used for testing the instruction register. Faults in the instruction register, if any, may be detected by shifting out the loaded data.

When the TAP controller is in this state, it moves to either the Shift-IR state if TMS is held low, or the Exit 1-IR state if TMS is high.

Shift-IR

In this state, the instruction register is connected between TDI and TDO and shifts the captured data toward its serial output on the rising edge of TCK.

When the TAP controller is in this state, it remains in the Shift-IR state if TMS is low, or moves to the Exit 1-IR state if TMS is high.

• Exit 1-IR

This is a temporary controller state.

When the TAP controller is in this state, it moves to either the Pause-IR state if TMS is held low, or the Update-IR state if TMS is held high.

Pause-IR

This state allows the shifting of the instruction register to be temporarily suspended. Both the instruction register and the data register retain their current states.

When the TAP controller is in this state, it remains in the Pause-IR state if TMS is held low, or moves to the Exit 2-IR state if TMS is held high.

• Exit 2-IR

This is a temporary controller state.

When the TAP controller is in this state, it moves to either the Shift-IR state if TMS is held low, or the Update-IR state if TMS is held high.

• Update-IR

This state allows the instruction previously shifted into the instruction register to be output in parallel on the rising edge of TCK. Then it becomes the current instruction, setting a new operational mode.

When the TAP controller is in this state, it moves to either the Run-Test/Idle state if TMS is low, or the Select-DR-Scan state if TMS is high.

# 24.11 Boundary Scan Order

The following table shows the boundary scan order with respect to the processor signals.

 $TDI \rightarrow 1 (PI2) \rightarrow 2(PI1) \rightarrow - \rightarrow 82(PH5) \rightarrow 83(PH6) \rightarrow TDO$ 

| No. | Pin<br>Name | No. | Pin<br>Name | No | Pin<br>Name | No | Pin<br>Name | No | Pin<br>Name |
|-----|-------------|-----|-------------|----|-------------|----|-------------|----|-------------|
|     | TDI         |     |             |    |             |    |             |    |             |
| 1   | Pl2         | 21  | PE4         | 41 | PB0         | 61 | PK4         | 81 | PH4         |
| 2   | PI1         | 22  | PE3         | 42 | PA7         | 62 | PK3         | 82 | PH5         |
| 3   | PI0         | 23  | PE2         | 43 | PA6         | 63 | PK2         | 83 | PH6         |
| 4   | PG5         | 24  | PE1         | 44 | PA5         | 64 | PK1         |    | TDO         |
| 5   | PG4         | 25  | PE0         | 45 | PA4         | 65 | PK0         |    |             |
| 6   | PG3         | 26  | PC7         | 46 | PA3         | 66 | PJ7         |    |             |
| 7   | PG2         | 27  | PC6         | 47 | PA2         | 67 | PJ6         |    |             |
| 8   | PG1         | 28  | PC5         | 48 | PA1         | 68 | PJ5         |    |             |
| 9   | PG0         | 29  | PC4         | 49 | PA0         | 69 | PJ4         |    |             |
| 10  | PD7         | 30  | PC3         | 50 | PF7         | 70 | PJ3         |    |             |
| 11  | PD6         | 31  | PC2         | 51 | PF6         | 71 | PJ2         |    |             |
| 12  | PD5         | 32  | PC1         | 52 | PF5         | 72 | PJ1         |    |             |
| 13  | PD4         | 33  | PC0         | 53 | PF4         | 73 | PJ0         |    |             |
| 14  | PD3         | 34  | PB7         | 54 | PF3         | 74 | PG7         |    |             |
| 15  | PD2         | 35  | PB6         | 55 | PF2         | 75 | PG6         |    |             |
| 16  | PD1         | 36  | PB5         | 56 | PF1         | 76 | PH2         |    |             |
| 17  | PD0         | 37  | PB4         | 57 | PF0         | 77 | PH1         |    |             |
| 18  | PE7         | 38  | PB3         | 58 | ENDIAN      | 78 | PH0         |    |             |
| 19  | PE6         | 39  | PB2         | 59 | PK6         | 79 | NMI         |    |             |
| 20  | PE5         | 40  | PB1         | 60 | PK5         | 80 | PH3         |    |             |

### 24.12 Instructions Supported by the JTAG Controller Cells

This section describes the instructions supported by the JTAG controller cells of the TMPM341FDXBG/FYXBG.

#### 1. EXTEST instruction

The EXTEST instruction is used for external interconnect tests. The EXTEST instruction permits BSR cells at output pins to shift out test patterns in the Update-DR state and those at input pins to capture test results in the Capture-DR state.

Typically, before EXTEST is executed, the initialization pattern is shifted into the boundary scan register using the SAMPLE/PRELOAD instruction. If the boundary scan register is not reset, indeterminate data will be transferred in the Update-DR state and bus conflicts between ICs may occur. Figure 24-7 shows data flow when the EXTEST instruction is selected.



Figure 24-7 Test Data Flow when the EXTEST Instruction is Selected

The following steps describe the basic test procedure of the external interconnect test.

- 1. Reset the TAP controller to the Test-Logic-Reset state.
- 2. Load the instruction register with the SAMPLE/PRELOAD instruction. This causes the boundary scan register to be connected between TDI and TDO.
- 3. Reset the boundary scan register by shifting certain data in.
- 4. Load the test pattern into the boundary scan register.
- 5. Load the instruction register with the EXTEST instruction.
- 6. Capture the data applied to the input pin into the boundary scan register.
- 7. Shift out the captured data while simultaneously shifting the next test pattern in.
- 8. Send out the test pattern in the boundary scan register at the output on the output pin.

Repeat steps 6 to 8 for each test pattern.

#### 2. SAMPLE/PRELOAD instruction

This instruction targets the boundary scan register between TDI and TDO. As its name implies, the SAM-PLE/PRELOAD instruction provides two functions.

SAMPLE allows the input and output pads of an IC to be monitored. While it does so, it does not disconnect the system logic from the IC pins. SAMPLE is executed in the Capture-DR state. It is mainly used to capture the values of the IC's I/O pins on the rising edge of TCK during normal operation. Figure 24-8 shows the flow of data for the SAMPLE phase of the SAMPLE/PRELOAD instruction.



Figure 24-8 Test Data Flow while the SAMPLE is Selected

PRELOAD allows the boundary scan register to be reset before any other instruction is selected. For example, prior to selection of the EXTEST instruction, PRELOAD is used to load reset data into the boundary scan register. PRELOAD permits data shifting of the boundary scan register without interfering with the normal operation of the system logic. Figure 24-9 shows the data flow for the PRELOAD phase of the SAMPLE/PRELOAD instruction.



Figure 24-9 Test Data Flow while PRELOAD is Selected

3. BYPASS instruction

This instruction targets the bypass register between JTDI and JTDO. The bypass register provides the shortest serial path that bypasses the IC (between JTDI and JTDO) when the test does not require control or monitoring of the IC. The BYPASS instruction does not cause interference in the normal operation of the on-chip system logic. Figure 24-10 shows the data flow through the bypass register when the BY-PASS instruction is selected.



Figure 24-10 Test Data Flow when the BYPASS Instruction is Selected

4. CLAMP instruction

The CLAMP instruction outputs the value that boundary scan register is programmed according to the PRELOAD instruction, and execute Bypass operation.

The CLAMP instruction selects the bypass register between TDI and TDO.

#### 5. HIGHZ instruction

The HIGHZ instruction disables the output of the internal logical circuits. When the HIGHZ instruction is executed, it places the 3-state output pins in the high-impedance state.

The HIGHZ instruction also selects the bypass register between TDI and TDO.

• Notes

This section describes the cautions of the JTAG boundary-scan operations specific to the processor.

- 1. As for a PF0 pin is always pull-up, whenever HIGHZ is ordered, High is output.
- 2. Please note the input level to the analog input pins.
- The JTAG circuit can be released from the reset state by either of the following two methods: Assert TRST, initialize the JTAG circuit, and then deassertion TRST.
   Supply the TCK signal for 5 or more clock pulses to TCK while pulling the TMS pin High.

# TOSHIBA

# 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$ . Feedback resistor and Damping resistor are shown with a typical value.

# 25.1 PA0 to 7,PB0 to 7



25.2 PC0 to 7,PD0 to 6,PE0 to 7,PF1 to 7,PG0 to 7,PH0 to 6,PI0 to 7



# 25.3 PJ0 to 7,PK0 to 7



25.4 PF0



## 25.5 DA0,DA1



# 25.6 X1,X2



# 25.7 RESET, NMI



### 25.8 BSC



# 25.9 MODE, INTLV, ENDIAN



# 25.10 FTEST3



# 25.11 AVREFH, AVREFL



# TOSHIBA

# 26. Electrical Characteristics

# 26.1 Absolute Maximum Ratings

| Para                 | meter                      | Symbol              | Rating            | Unit |
|----------------------|----------------------------|---------------------|-------------------|------|
|                      |                            | DVDD3A              | -0.3 to 3.9       |      |
| Quarkunskana         |                            | DVDD3B              | -0.3 to 3.9       | V    |
| Supply voltage       |                            | AVDD3               | -0.3 to 3.9       | V    |
|                      |                            | RVDD3               | -0.3 to 3.9       |      |
| Input voltage        |                            | V <sub>IN</sub>     | -0.3 to VDD + 0.3 | V    |
| Low-level            | Per pin                    | I <sub>OL</sub>     | 5                 |      |
| output current       | Total <sup>#1</sup>        | ΣI <sub>OL</sub>    | 50                |      |
| High-level           | Per pin                    | I <sub>OH</sub>     | -5                | mA   |
| output current       | Total #1                   | ΣI <sub>OH</sub>    | 50                |      |
| Power consumption    | (Ta = 85 °C)               | PD                  | 600               | mW   |
| Soldering temperatur | re(10 s)                   | T <sub>SOLDER</sub> | 260               | °C   |
| Storage temperature  |                            | T <sub>STG</sub>    | -40 to 125        | °C   |
| Operating Tempera-   | Except during Flash<br>W/E | T <sub>OPR</sub>    | -20 to 85         | °C   |
| ture                 | During Flash W/E           |                     | 0 to 70           |      |

#1 Each I/O supply voltage, DVDD3A and DVDD3B

Note: 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.

# 26.2 DC Electrical Characteristics (1/3)

Ta = −40 to 85 °C

|                           | Parameter                                   | Symbol                               | Co                                                                            | ndition                        | Min.       | Typ. (Note 1) | Max.         | Unit   |
|---------------------------|---------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------|--------------------------------|------------|---------------|--------------|--------|
| Supply volt-<br>age       | DVDD3A<br>DVDD3B<br>AVDD3<br>RVDD3          | DVDD3A<br>AVDD3<br>RVDD3<br>(Note 2) | f <sub>OSC</sub> = 8 to 27 M<br>fsys = 1 to 54 Mł                             |                                | 2.7        | -             | 3.6          | V      |
|                           | DVSSA = DVSSB = AVSS =<br>RVSS = DVSSC = 0V | DVDD3B                               |                                                                               |                                | 1.65       | _             | 3.6          | v      |
|                           | PA, PB, PC, PD, PE, PF                      | V <sub>IL1</sub>                     | 1.65 V ≤ DVDD3B ≤ 3.6 V                                                       |                                |            |               | 0.2 DVDD3B   |        |
| Low-level                 | PG, PH, PI, PJ, PK                          | V <sub>IL2</sub>                     | 2.7 V ≤ DVDD3A ≤ 3.6 V                                                        |                                |            |               | 0.2 DVDD3A   |        |
| input volt-<br>age        | RESET, NMI, MODE,<br>INTLV, BSC, ENDIAN     | V <sub>IL3</sub>                     | (Include 5 V tolerant pins)                                                   |                                | -0.3       | -             |              | V      |
|                           | X1                                          | V <sub>IL4</sub>                     | 2.7 V ≤ RVDD3 ≤ 3.6 V                                                         |                                |            |               | 0.2 RVDD3    |        |
|                           | PA, PB, PC, PD, PE, PF                      | V <sub>IH1</sub>                     | 1.65 V ≤ DVDD3B ≤ 3.6 V                                                       |                                | 0.8 DVDD3B |               | DVDD3B + 0.3 |        |
|                           |                                             | V <sub>IH2</sub>                     | $2.7 V \le DVDD3A \le 3.6 V$ $5 V$ tolerant pins $2.7 V \le DVDD3A \le 3.6 V$ |                                |            |               | DVDD3A + 0.3 |        |
| High-level<br>input volt- | PG, PH, PI, PJ, PK                          | V <sub>IH5</sub>                     |                                                                               |                                | 0.8 DVDD3A | -             | 5.5          | V      |
| age                       | RESET, NMI, MODE,<br>INTLV, BSC, ENDIAN     | V <sub>IH3</sub>                     |                                                                               |                                |            |               | DVDD3A + 0.3 |        |
|                           | X1                                          | V <sub>IH4</sub>                     | 2.7 V ≤ RVDD3 ≤ 3.6 V                                                         |                                | 0.8 RVDD3  |               | RVDD3 + 0.3  | 1      |
|                           |                                             |                                      | I <sub>OL</sub> = 2 mA                                                        | DVDD3A ≥ 2.7 V                 |            |               | 0.4          |        |
| Low-level out             | tput voltage                                | V <sub>OL</sub>                      | 10L - 2 11A                                                                   | DVDD3B ≥ 2.7 V                 | -          | -             | 0.4          | l v    |
|                           |                                             |                                      | $I_{OL} = 2 \text{ mA}$ DVDD3B $\geq 1.65 \text{ V}$                          |                                |            |               | 0.2          |        |
|                           |                                             |                                      | I <sub>OH</sub> = −2 mA DVDD3A ≥ 2.7 V 2.4                                    |                                |            |               |              |        |
| High-level ou             | tput voltage                                | V <sub>OH</sub>                      | I <sub>OH</sub> = −2 mA                                                       | DVDD3B ≥ 2.7 V                 | 2.4        | -             | -            | v      |
|                           |                                             |                                      | I <sub>OH</sub> = −0.5 mA                                                     | DVDD3B ≥ 1.65 V                | 1.5        |               |              |        |
| Input leakage             | e current                                   | I <sub>LI1</sub>                     | $0.0 \le V_{IN} \le DVDI$<br>$0.0 \le V_{IN} \le AVDI$                        |                                | -          | 0.02          | ±5           |        |
| Output leaka              | ge current                                  | I <sub>LO</sub>                      | $0.2 \le V_{IN} \le (DVDI)$<br>$0.2 \le V_{IN} \le AVDI$                      | D3A, DVDD3B) - 0.2<br>D3 - 0.2 | -          | 0.05          | ±10          | μA     |
| Pull-up resist            | er at Reset                                 | RRST                                 | DVDD3 = 2.7 V t                                                               | o 3.6 V                        | -          | 50            | 150          | kΩ     |
|                           |                                             | VTH1                                 | 2.7 V ≤ DVDD3A                                                                | , DVDD3B ≤ 3.6 V               | 0.3        | 0.6           |              |        |
| Hysteresis vo             | bitage                                      | VTH2                                 | 1.65 V ≤ DVDD3B ≤ 2.7 V                                                       |                                | 0.14       | 0.19          | -            | V      |
| Programmab                | le pull-up/pull-down resistor               | PKH                                  | DVDD3A, DVDD3B = 2.7 V to 3.6 V                                               |                                | -          | 50            | 150          | kΩ     |
| Voltage flucti            |                                             |                                      |                                                                               |                                | -          | -             | 23           | m)//uo |
|                           | on rate in the operation range              | VFS                                  | RVDD3 = DVDD3                                                                 |                                | -          | -             | 40           | mV/µs  |
| Pin capacitar             | nce (Except power supply pins)              | C <sub>IO</sub>                      | fc = 1 MHz                                                                    |                                | -          | -             | 10           | pF     |

Note 1: Ta = 25 °C, DVDD3A = DVDD3B = RVDD3 = AVDD3 = 3.3 V, unless otherwise noted. Note 2: The same voltage must be supplied to DVDD3A, AVDD3, and RVDD3.

Note:Ensure that all power suply source, including DVDD3B, is power-off and then power-on again when DVDD3A, RVDD3 and AVDD3 falls below 2.7V which is minimum operation voltage.



The fluctuation rate of both VRS(increasing voltage) and VFS(decreasing voltage) should measure the exact point about the specification.

# 26.3 DC Electrical Characteristics (2/3)

|                           |                    | i                                                                                                                                      | AVDD3 = F | RVDD3 = 2.7 V | to 3.6 V, Ta = · | -40 to 85 °( |  |  |  |
|---------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------|---------------|------------------|--------------|--|--|--|
| Parameter                 | Symbol             | Condition                                                                                                                              | Min.      | Тур.          | Max.             | Unit         |  |  |  |
|                           | I <sub>OL1</sub>   | Per pin<br>2.7 V ≤ DVDD3A ≤ 3.6 V<br><pi0 pi7,="" pj0="" pj7,="" pk0="" pk6="" to=""></pi0>                                            | -         | -             | 2                | mA           |  |  |  |
|                           | I <sub>OL2</sub>   | Per pin as 5V tolerant<br>2.7 V ≤ DVDD3A ≤ 3.6 V<br><pg0 pg7,="" ph0="" ph2="" to=""></pg0>                                            | -         | -             | 5                | mA           |  |  |  |
|                           | ΣI <sub>OL1</sub>  | Per group, PortG, 5V tolerant                                                                                                          | -         | -             | 20               |              |  |  |  |
|                           | ΣI <sub>OL2</sub>  | Per group, PH0 to PH2, 5V tolerant                                                                                                     | -         | -             | 10               |              |  |  |  |
|                           | ΣI <sub>OL3</sub>  | Per group, PH3 to PH6                                                                                                                  | -         | -             | 10               | 1.           |  |  |  |
|                           | ΣI <sub>OL4</sub>  | Per group, Port I                                                                                                                      | -         | -             | 10               | mA           |  |  |  |
|                           | ΣI <sub>OL5</sub>  | Per group, Port J                                                                                                                      | -         | -             | 10               |              |  |  |  |
| Low-level                 | Σl <sub>OL6</sub>  | Per group, Port K                                                                                                                      | -         | -             | 10               |              |  |  |  |
| output current            | I <sub>OL3</sub>   | Per pin<br>1.65 V ≤ DVDD3B ≤ 3.6 V<br><pa0 pa7,="" pb0="" pb7,="" pc0="" pc7,<br="" to="">PD0 to PD7, PE0 to PE7, PF0 to PF7&gt;</pa0> | -         | -             | 2                | mA           |  |  |  |
|                           | ΣI <sub>OL7</sub>  | Per group, Port A                                                                                                                      | -         | -             | 10               |              |  |  |  |
|                           | ΣI <sub>OL8</sub>  | Per group, Port B                                                                                                                      | -         | -             | 10               |              |  |  |  |
| -                         | Σl <sub>OL9</sub>  | Per group, Port C                                                                                                                      | -         | -             | 10               | ]            |  |  |  |
|                           | ΣI <sub>OL10</sub> | Per group, Port D                                                                                                                      | -         | -             | 10               | mA           |  |  |  |
|                           | ΣI <sub>OL11</sub> | Per group, Port E                                                                                                                      | -         | -             | 10               |              |  |  |  |
|                           | ΣI <sub>OL12</sub> | Per group, Port F                                                                                                                      | -         | _             | 10               | <u> </u>     |  |  |  |
|                           | ΣΙ <sub>ΟL</sub>   | Total, all Port                                                                                                                        | -         | -             | 35               | mA           |  |  |  |
|                           | I <sub>OH1</sub>   | Per pin<br>2.7 V ≤ DVDD3A, DVDD3B ≤ 3.6 V<br><pg0 pg7,="" ph0="" ph6,="" pi0="" pi7,<br="" to="">PJ0 to PJ7, PK0 to PK6&gt;</pg0>      | -         | _             | -2               | mA           |  |  |  |
|                           | ΣI <sub>OH1</sub>  | Per group, Port G                                                                                                                      | -         | -             | -10              |              |  |  |  |
|                           | ΣI <sub>OH2</sub>  | Per group, Port H                                                                                                                      | -         | -             | -10              |              |  |  |  |
|                           | ΣI <sub>OH3</sub>  | Per group, Port I                                                                                                                      | -         | -             | -10              | mA           |  |  |  |
|                           | ΣI <sub>OH4</sub>  | Per group, Port J                                                                                                                      | -         | -             | -10              |              |  |  |  |
|                           | ΣI <sub>OH5</sub>  | Per group, Port K                                                                                                                      | -         | _             | -10              |              |  |  |  |
| High-level output current | I <sub>OH2</sub>   | Per pin<br>1.65 V ≤ DVDD3B ≤ 3.6 V<br><pa0 pa7,="" pb0="" pb7,="" pc0="" pc7,<br="" to="">PD0 to PD7, PE0 to PE7, PF0 to PF7&gt;</pa0> | -         | -             | -2               | mA           |  |  |  |
|                           | ΣI <sub>OH6</sub>  | Per group, Port A                                                                                                                      | -         | -             | -10              |              |  |  |  |
|                           | ΣI <sub>OH7</sub>  | Per group, Port B                                                                                                                      | -         | -             | -10              |              |  |  |  |
|                           | ΣI <sub>OH8</sub>  | Per group, Port C                                                                                                                      | 1         |               |                  |              |  |  |  |
|                           | ΣI <sub>OH9</sub>  | Per group, Port D                                                                                                                      | -         | -             | -10              | mA           |  |  |  |
|                           | ΣI <sub>OH10</sub> | Per group, Port E                                                                                                                      | -         | -             | -10              |              |  |  |  |
|                           | ΣI <sub>OH11</sub> | Per group, Port F                                                                                                                      | -         | -             | -10              |              |  |  |  |
|                           | ΣΙ <sub>ΟΗ</sub>   | Total, all Port                                                                                                                        | -         | -             | -35              | mA           |  |  |  |

AVDD3 = RVDD3 = 2.7 V to 3.6 V, Ta = -40 to 85  $^{\circ}$ C

Note: The same voltage must be supplied to DVDD3A, AVDD3, and RVDD3.

Note: The total of port output current is accumulated each voltage supply.

# 26.4 DC Electrical Characteristics (3/3)

| Parameter               | Symbol | Condition     | Min. | Typ. (Note1) | Max. | Unit |
|-------------------------|--------|---------------|------|--------------|------|------|
| NORMAL (Note2) Gear 1/1 |        | form - E4 MUL | -    | 42           | 50   | mA   |
| IDLE (Note3)            | ססן    | fsys = 54 MHz | -    | 18           | 25   |      |
| NORMAL (Note2) Gear 1/1 |        | fsys = 40 MHz | -    | 33           | 42   |      |
| IDLE (Note3)            |        |               | -    | 14           | 20   |      |
| STOP1                   |        | -             | -    | 60           | 1000 |      |
| STOP2                   |        | -             | _    | 2.5          | 60   | μA   |

DVDD3A = DVDD3B = AVDD3 = RVDD3 = 2.7 V to 3.6 V, Ta = -40 to 85  $^{\circ}$ C

Note 1: Ta = 25 °C, DVDD3A = DVDD3B = AVDD3 = RVDD3 = 3.3 V, unless otherwise noted.

Note 2:  $I_{DD}$  NORMAL: Measured with the dhrystone ver. 2.1 operated in FLASH.

All functions operates excluding A/DC and D/AC

Note 3: I<sub>DD</sub> IDLE: Measured with all functions stopped. The currents flow through DVDD3A, DVDD3B, AVDD3 and RVDD3 are included.

# 26.5 12-bit ADC Electrical Characteristics

| Para                                                             | meter                  | Symbol                                           | Condition                               | Min.   | Тур. | EFL = OV, Ta =<br>Max | Unit |  |
|------------------------------------------------------------------|------------------------|--------------------------------------------------|-----------------------------------------|--------|------|-----------------------|------|--|
| Analog reference                                                 | e voltage(+)           | AVREFH                                           | -                                       | 2.7    | 3.3  | 3.6                   | V    |  |
| Analog input vol                                                 | tage                   | VAIN                                             | _                                       | AVREFL | -    | AVREFH                | V    |  |
| Power supply                                                     | AD conversion          |                                                  |                                         | -      | 2.0  | 2.5                   | mA   |  |
| current of ana-<br>log reference<br>voltage                      | Non-AD con-<br>version | IREF                                             | DVSSA = DVSSB = DVSSC =<br>AVSS         | -      | -    | 0.1                   | μΑ   |  |
| INL error                                                        | NL error               |                                                  |                                         | -      | ± 4  | -                     |      |  |
| DNL error<br>Zero-scale error<br>Full-scale error<br>Total error |                        |                                                  | AIN resistance $\leq 600 \Omega$        | -      | ± 2  | -                     |      |  |
|                                                                  |                        | <ul> <li>AIN load capacitance ≥ 30 pF</li> </ul> |                                         | -      | ± 3  | -                     |      |  |
|                                                                  |                        |                                                  | Conversion time $\ge 2.0 \ \mu s$       | -      | ± 4  | -                     |      |  |
|                                                                  |                        |                                                  |                                         | -      | ± 6  | -                     |      |  |
| INL error                                                        |                        |                                                  |                                         | -      | ± 4  | -                     |      |  |
| DNL error                                                        |                        |                                                  | AIN resistance $\leq 1 \text{ k}\Omega$ | -      | ± 2  | -                     |      |  |
| Zero-scale error                                                 |                        | -                                                | AIN load capacitance ≥ 0.1µF            | -      | ± 3  | -                     | LSB  |  |
| Full-scale error                                                 |                        |                                                  | Conversion time $\ge$ 1.0 µs            | -      | ± 4  | -                     |      |  |
| Total error                                                      |                        |                                                  |                                         | -      | ± 6  | -                     |      |  |
| INL error                                                        |                        |                                                  |                                         | -      | ± 4  | -                     |      |  |
| DNL error                                                        |                        |                                                  | AIN resistance ≤ 10 kΩ                  | -      | ± 2  | -                     |      |  |
| Zero-scale error<br>Full-scale error                             |                        | ] –                                              | AIN load capacitance ≥ 0.1µF            | -      | ± 3  | -                     |      |  |
|                                                                  |                        |                                                  | Conversion time $\geq$ T.B.D.           | -      | ± 4  | -                     | 1    |  |
| Total error                                                      | Total error            |                                                  |                                         | -      | ± 6  | -                     |      |  |
| Conversion time                                                  |                        | Tconv                                            | -                                       | 1.0    | -    | 10                    | μs   |  |

DVDD3A = DVDD3B = AVDD3 = RVDD3 = AVREFH = 2.7 V to 3.6 V AVSS = DVSSA = DVSSB = DVSSC = AVREFL = 0V, Ta = -40 to 85 °C

Note:1LSB = (AVREFH - AVREFL)/4096 [V]

Note: Peripheral functions are disable.

Note:An AVREFL of analog input voltage is a must for applying exact same voltage level between AVSS, DVSSA, DVSSB and DVSSC.

Note: The total error is a combination of actual values of zero-scale error, full-size error and INL error, and is the maximum difference between the actual values and the theoretical figure (quantum error is not included).

## 26.6 10-bit DAC Electrical Characteristics

| a                               |                                  |            | 4 - DV33B - D | VSSC - AVRE | FL = 0V, Ia = -4 | 01085 0     |      |
|---------------------------------|----------------------------------|------------|---------------|-------------|------------------|-------------|------|
| Parameter                       |                                  | Symbol     | Condition     | Min.        | Тур.             | Max         | Unit |
| Analog reference voltage(+)     |                                  | DAVREF     | -             | 2.7         | 3.3              | 3.6         | V    |
| Power supply<br>current of ana- | <vrefon>=1<br/>ch = 0,1</vrefon> | IDREF      | -             | -           | 4                | 10          | μA   |
| log reference<br>voltage        | <vrefon>=0</vrefon>              |            |               | -           | 0.3              | 1           |      |
| Settling time                   |                                  | Tset       | -             | -           | -                | 100         | μs   |
| Output current                  |                                  | IDA0, IDA1 | -             | -           | -                | ± 500       | μA   |
| Range of output voltage         |                                  | DA0, DA1   | -             | AVSS + 0.3  | -                | AVDD3 - 0.3 | V    |
| Full-scale error                |                                  | TERR       | -             | -           | ± 2              | ± 4         | LSB  |

$$\label{eq:dvdd3} \begin{split} \mathsf{DVDD3A} = 1.65 \ \mathsf{V} \ \text{to} \ 3.6 \ \mathsf{V}, \ \mathsf{DVDD3B} = \mathsf{AVDD3} = \mathsf{RVDD3} = \mathsf{AVREFH} = 2.7 \ \mathsf{V} \ \text{to} \ 3.6 \ \mathsf{V} \\ \mathsf{AVSS} = \mathsf{DVSSA} = \mathsf{DVSSB} = \mathsf{DVSSC} = \mathsf{AVREFL} = \mathsf{0V}, \ \mathsf{Ta} = -40 \ \mathsf{to} \ 85 \ ^\circ\mathsf{C} \end{split}$$

Note: 1LSB = (AVREFH - AVREFL)/1024 [V]

Note: IDREF current value is in the dual channel operation.

Note:No guarantee about relative accuracy in the dual channel operation.

Note:Load maximum capacitance of each DAx pin is 100pF.

Note: The total error is the output voltage error introduced in the theoretical output voltage ((AVREFH-AVREFL)/ 1024 × DAC).

#### 26.7 AC Electrical Characteristics

#### 26.7.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 \text{DVDD3A}, 0.8 \times \text{DVDD3B}$
- Output levels: Low =  $0.2 \times \text{DVDD3A}$ ,  $0.2 \times \text{DVDD3B}$
- Input levels: Refer to low-level input voltage and high-level input voltage in "DC Electrical Characteristics".
- Load capacity: CL = 30pF
- Ambient Temp.: Ta = -40 to 85 °C

#### 26.7.2 Serial Channel (SIO/UART)

#### 26.7.2.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.

| Demmeter                                        | Ourschal         | Equation                            | _   | 40             | MHz | 54 I             | MHz | Unit |
|-------------------------------------------------|------------------|-------------------------------------|-----|----------------|-----|------------------|-----|------|
| Parameter                                       | Symbol           | Min.                                | Max | Min.           | Max | Min.             | Max | Unit |
| SCLK Clock High width (input)                   | t <sub>SCH</sub> | 4x                                  | -   | 100            | -   | 74               | -   |      |
| SCLK Clock Low width (input)                    | t <sub>SCL</sub> | 4x                                  | -   | 100            | -   | 74               | -   |      |
| SCLK cycle                                      | t <sub>SCY</sub> | t <sub>SCH</sub> + t <sub>SCL</sub> | -   | 200            | -   | 148              | -   |      |
| Output Data ←<br>SCLK rise or fall (Note 1)     | toss             | t <sub>SCY</sub> /2 − 3x− 60        | -   | -35<br>(Note2) | -   | −41.5<br>(Note2) | -   |      |
| SCLK rise →<br>Output Data hold or fall (Note1) | toнs             | t <sub>SCY</sub> /2                 | -   | 100            | -   | 74               | -   | ns   |
| Valid Data input ←<br>SCLK rise or fall (Note1) | t <sub>SRD</sub> | x + 30                              | _   | 55             | -   | 48.5             | _   |      |
| SCLK rise →<br>Input Data hold or fall (Note1)  | t <sub>HSR</sub> | x + 30                              | _   | 55             | _   | 48.5             | -   |      |

#### (1) SCLK input mode

Note 1: SCLK rise or fall ... Measured relative to the programmed active edge of SCLK.

Note 2: Keep this value positive by adjusting SCLK cycle.

#### 26.7 AC Electrical Characteristics

#### (2) SCLK output mode

| Demmeter                                 | Querra ha a l    | Equation                 | 40  | MHz  | 54 I | Unit |     |      |
|------------------------------------------|------------------|--------------------------|-----|------|------|------|-----|------|
| Parameter                                | Symbol           | Min.                     | Max | Min. | Max  | Min. | Max | Unit |
| SCLK cycle (programmable)                | t <sub>SCY</sub> | 4x                       | -   | 100  | -    | 74   | -   |      |
| Output Data ← SCLK rise                  | t <sub>oss</sub> | t <sub>SCY</sub> /2 - 30 | -   | 20   | -    | 7    | -   |      |
| SCLK rise $\rightarrow$ Output Data hold | t <sub>OHS</sub> | t <sub>SCY</sub> /2 - 30 | -   | 20   | -    | 7    | -   | ns   |
| Valid Data Input ← SCLK rise             | t <sub>SRD</sub> | 45                       | -   | 45   | -    | 45   | -   |      |
| SCLK rise $\rightarrow$ Input Data hold  | t <sub>HSR</sub> | 0                        | -   | 0    | -    | 0    | -   |      |



#### 26.7.3 Serial Bus Interface (I2C/SIO)

#### 26.7.3.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.

| Deremeter                                                | Sumbol               | Equ     | ation | Standa | rd Mode | Fast | Mode | Unit |
|----------------------------------------------------------|----------------------|---------|-------|--------|---------|------|------|------|
| Parameter                                                | Symbol               | Min.    | Max   | Min.   | Max     | Min. | Max  | Unit |
| SCL clock frequency                                      | t <sub>SCL</sub>     | 0       | -     | 0      | 100     | 0    | 400  | kHz  |
| Hold time for START condition                            | t <sub>HD;</sub> STA | -       | -     | 4.0    | -       | 0.6  | -    | μs   |
| SCL Low width (Input) (Note 1)                           | t <sub>LOW</sub>     | -       | -     | 4.7    | -       | 1.3  | -    | μs   |
| SCL High width (Input) (Note 2)                          | t <sub>HIGH</sub>    | -       | -     | 4.0    | -       | 0.6  | -    | μs   |
| Setup time for a repeated START condition                | t <sub>SU; STA</sub> | (Note5) | -     | 4.7    | -       | 0.6  | -    | μs   |
| Data hold time (Input) (Note 3, 4)                       | t <sub>HD; DAT</sub> | -       | -     | 0.0    | -       | 0.0  | -    | μs   |
| Data setup time                                          | t <sub>SU; DAT</sub> | -       | -     | 250    | -       | 100  | -    | ns   |
| Setup time for a STOP condition                          | t <sub>su; sто</sub> | -       | -     | 4.0    | -       | 0.6  | -    | μs   |
| Bus free time between stop condition and start condition | t <sub>BUF</sub>     | (Note5) | -     | 4.7    | -       | 1.3  | -    | μs   |

Note 1: SCL clock Low width (output) =  $(2^{n-1} + 58)/x$ 

Note 2: SCL clock High width (output) = (2<sup>n-1</sup> + 12)/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 12x 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 6: The Philips I2C-bus specification instructs that if the power supply to a Fast-mode device is switched off, the SDA and SCL I/O pins must be floating so that they don't obstruct the bus lines. However, this SBI does not satisfy this requirement.



Note 5: Software -dependent

#### 26.7.3.2 Clock-Synchronous 8-Bit SIO 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.

# (1) SCK Input Mode (The electrical specifications below are for an SCK signal with a 50% duty cycle.)

| Deveryoter                              | Oumbal           | Equation                            | Equation |               | 40 MHz |                 | 54 MHz |      |
|-----------------------------------------|------------------|-------------------------------------|----------|---------------|--------|-----------------|--------|------|
| Parameter                               | Symbol           | Min.                                | Max      | Min.          | Max    | Min.            | Max    | Unit |
| SCK Clock High width (input)            | t <sub>SCH</sub> | 4x                                  | -        | 100           | -      | 74              | -      |      |
| SCK Clock Low width (input)             | t <sub>SCL</sub> | 4x                                  | -        | 100           | -      | 74              | -      |      |
| SCK cycle                               | t <sub>SCY</sub> | t <sub>SCH</sub> + t <sub>SCL</sub> | -        | 200           | -      | 148             | -      |      |
| Output Data ← SCK rise                  | toss             | t <sub>SCY</sub> /2 - 3x - 60       | -        | −35<br>(Note) | -      | −41.5<br>(Note) | -      | ns   |
| SCK rise $\rightarrow$ Output Data hold | t <sub>OHS</sub> | t <sub>SCY</sub> /2 + x             | -        | 125           | -      | 92.5            | -      | 1    |
| Valid Data input ← SCK rise             | t <sub>SRD</sub> | 30 - x                              | -        | 5             | -      | 11.5            | -      |      |
| SCK rise $\rightarrow$ Input Data hold  | t <sub>HSR</sub> | 2x + 30                             | -        | 80            | -      | 67              | -      |      |

Note: Keep this value positive by adjusting SCK cycle.

(2) SCK Output Mode (The electrical specifications below are for an SCK signal with a 50% duty cycle.)

| Deventer                                | Querrahad        | Equation                 |     | 40   | MHz | 54   | MHz | l la it |
|-----------------------------------------|------------------|--------------------------|-----|------|-----|------|-----|---------|
| Parameter                               | Symbol           | Min.                     | Max | Min. | Max | Min. | Max | Unit    |
| SCK cycle (programmable)                | t <sub>SCY</sub> | 16x                      | -   | 400  | -   | 296  | -   |         |
| Output Data ← SCK rise                  | toss             | t <sub>SCY</sub> /2 - 30 | -   | 170  | -   | 118  | -   |         |
| SCK rise $\rightarrow$ Output Data hold | tons             | t <sub>SCY</sub> /2 - 30 | -   | 170  | -   | 118  | -   | ns      |
| Valid Data input $\leftarrow$ SCK rise  | t <sub>SRD</sub> | x + 45                   | -   | 70   | -   | 63.5 | -   |         |
| SCK rise $\rightarrow$ Input Data hold  | t <sub>HSR</sub> | 0                        | -   | 0    | -   | 0    | -   |         |



# TOSHIBA

#### 26.7.4 Synchronous serial Interface (SSP)

#### 26.7.4.1 AC measurement conditions

The letter "T" used in the equations in the table represents the period of internal bus frequency (fsys).

- Output levels: High =  $0.7 \times \text{DVDD3A}$ , Low =  $0.3 \times \text{DVDD3A}$
- Input levels: High =  $0.9 \times \text{DVDD3A}$ , Low =  $0.1 \times \text{DVDD3A}$

Note: The "Equation" column in the table shows the specifications under the conditions DVDD3A = 2.7V to 3.6V.

| Parameter                                                      | Symbol                       | Equ                               | ation                 | fsys=40MHz      | fsys=54MHz      | Unit |
|----------------------------------------------------------------|------------------------------|-----------------------------------|-----------------------|-----------------|-----------------|------|
| Falameter                                                      | Symbol                       | Min.                              | Max                   | (m=2, n=12)     | (m=6, n=12)     | Unit |
| SPCLK Period (Master)                                          | Τ <sub>m</sub>               | (m)T<br>However more<br>than 50ns | -                     | 50              | 111             |      |
| SPCLK Period (Slave)                                           | Τs                           | (n)T                              | -                     | 300<br>(3.3MHz) | 222<br>(4.5MHz) |      |
| SPCLK rise up time                                             | tr                           | -                                 | 15                    | 15              | 15              |      |
| SPCLK fall down time                                           | t <sub>f</sub>               | -                                 | 15                    | 15              | 15              |      |
| Master mode: SPCLK low level pulse width                       | t <sub>WLM</sub>             | (m)T/2 - 15                       | -                     | 10              | 40.5            |      |
| Master mode: SPCLK high level pulse width                      | t <sub>WHM</sub>             | (m)T/2 - 15                       | -                     | 10              | 40.5            |      |
| Slave mode: SPCLK low level pulse width                        | t <sub>WLS</sub>             | (n)T/2 - 15                       | -                     | 135             | 96              |      |
| Slave mode: SPCLK high level pulse width                       | t <sub>WHS</sub>             | (n)T/2 - 15                       | -                     | 135             | 96              |      |
| Master mode:<br>SPCLK rise/fall to output data valid           | t <sub>ODSM</sub>            | -                                 | 15                    | 15              | 15              |      |
| Master mode:<br>SPCLK rise/fall to output data hold            | t <sub>ODHM</sub>            | (m)T/2 - 15                       | -                     | 10              | 40.5            |      |
| Master mode:<br>SPCLK rise/fall to input data valid delay time | t <sub>IDSM</sub>            | -                                 | -                     | 10              | 10              | ns   |
| Master mode:<br>SPCLK rise/fall to input data hold             | t <sub>IDHM</sub>            | T/2 + 5                           | -                     | 17.5            | 14.3            |      |
| Master mode:<br>SPFSS valid to SPCLK rise/fall                 | t <sub>OFSM</sub>            | (m)T - 15                         | (m)T + 15             | 35 to 65        | 96 to 126       |      |
| Slave mode:<br>SPCLK rise/fall to output data valid delay time | t <sub>ODSS</sub>            | _                                 | (3T) + 40             | 115             | 95.5            |      |
| Slave mode:<br>SPCLK rise/fall to output data hold             | t <sub>ODHS</sub><br>(Note1) | (n)T/2 + (2T)                     | -                     | 100             | 74              |      |
| Slave mode:<br>SPCLK rise/fall to input data valid delay time  | t <sub>IDSS</sub>            | -                                 | (n)T/2 + (3T) -<br>10 | 215             | 156.5           |      |
| Slave mode:<br>SPCLK rise/fall to input data hold              | tidhs                        | (3T) + 15                         | -                     | 90              | 70.5            |      |
| Slave mode:<br>SPFSS valid to SPCLK rise/fall                  | t <sub>OFSS</sub>            | (n)T + 15                         | -                     | 285             | 207             |      |

DVDD3B = 2.7V to 3.6V ( fsys  $\leq$  40MHz : m = 2, fsys > 40MHz : m = 6 )

26.7 AC Electrical Characteristics

|                                                                |                                         | Equ                               | ation                 | fsys=40MHz      | fsys=54MHz      |      |
|----------------------------------------------------------------|-----------------------------------------|-----------------------------------|-----------------------|-----------------|-----------------|------|
| Parameter                                                      | Symbol                                  | Min.                              | Max                   | (m=2, n=12)     | (m=6, n=12)     | Unit |
| SPCLK Period (Master)                                          | T <sub>m</sub>                          | (m)T<br>However more<br>than 50ns | -                     | 50              | 111             |      |
| SPCLK Period (Slave)                                           | Τs                                      | (n)T                              | _                     | 300<br>(3.3MHz) | 222<br>(4.5MHz) |      |
| SPCLK rise up time                                             | tr                                      | -                                 | 20                    | 20              | 20              |      |
| SPCLK fall down time                                           | t <sub>f</sub>                          | -                                 | 20                    | 20              | 20              |      |
| Master mode: SPCLK low level pulse width                       | t <sub>WLM</sub>                        | (m)T/2 - 20                       | -                     | 5               | 35.5            |      |
| Master mode: SPCLK high level pulse width                      | t <sub>WHM</sub>                        | (m)T/2 - 20                       | -                     | 5               | 35.5            |      |
| Slave mode: SPCLK low level pulse width                        | t <sub>WLS</sub>                        | (n)T/2 - 20                       | -                     | 130             | 91              |      |
| Slave mode: SPCLK high level pulse width                       | t <sub>WHS</sub>                        | (n)T/2 - 20                       | -                     | 130             | 91              |      |
| Master mode:<br>SPCLK rise/fall to output data valid           | t <sub>ODSM</sub>                       | -                                 | 20                    | 20              | 20              |      |
| Master mode:<br>SPCLK rise/fall to output data hold            | t <sub>ODHM</sub>                       | (m)T/2 - 20                       | -                     | 5               | 35.5            |      |
| Master mode:<br>SPCLK rise/fall to input data valid delay time | t <sub>IDSM</sub>                       | -                                 | -                     | 10              | 10              | ns   |
| Master mode:<br>SPCLK rise/fall to input data hold             | t <sub>IDHM</sub>                       | T/2 + 5                           | _                     | 17.5            | 14.3            |      |
| Master mode:<br>SPFSS valid to SPCLK rise/fall                 | t <sub>OFSM</sub>                       | (m)T - 15                         | (m)T + 25             | 35 to 75        | 96 to 136       |      |
| Slave mode:<br>SPCLK rise/fall to output data valid delay time | t <sub>ODSS</sub>                       | _                                 | (3T) + 55             | 130             | 110.5           |      |
| Slave mode:<br>SPCLK rise/fall to output data hold             | <sup>t</sup> <sub>ODHS</sub><br>(Note1) | (n)T/2 + (2T)                     | -                     | 100             | 74              |      |
| Slave mode:<br>SPCLK rise/fall to input data valid delay time  | t <sub>IDSS</sub>                       | -                                 | (n)T/2 + (3T) -<br>10 | 215             | 156.5           |      |
| Slave mode:<br>SPCLK rise/fall to input data hold              | t <sub>IDHS</sub>                       | (3T) + 15                         | -                     | 90              | 70.5            |      |
| Slave mode:<br>SPFSS valid to SPCLK rise/fall                  | t <sub>OFSS</sub>                       | (n)T + 15                         | _                     | 285             | 207             |      |

DVDD3B = 1.65V to 3.6V ( fsys  $\leq$  40MHz : m = 2, fsys > 40MHz : m = 6 )

Note: Baud rate clock is set under below condition

• <u>Master mode</u>

 $m = (\langle CPSDVSR \rangle \times (1 + \langle SCR \rangle)) = fsys/SPCLK$ 

<CPSDVR> is set only even number and "m" must set during  $65024 \geq m \geq 2$ 

• <u>Slave mode</u>

 $n = fsys/SPCLK \ (65024 \ge n \ge 12)$ 

# TOSHIBA

26.7.4.2 SSP SPI mode (Master)

- fsys  $\geq 2 \times$  SPxCLK (Max.)
- $fsys \ge 65204 \times SPxCLK$  (Min.)

(1) Master SSPCR0<SPH>=0 (Data is latched on the first edge.)



(2) Master SSPCR0<SPH>=1 (Data is latched on the second edge.)

26.7 AC Electrical Characteristics



26.7.4.3 SSP SPI mode (Slave)

- fsys  $\geq$  12 × SPCLK (Max.)
- fsys  $\geq$  65204 × SPCLK (Min.)

(3) Slave SSPCR0<SPH>=0 (Data is latched on the first edge.)



(4) Slave SSPCR0<SPH>=1 (Data is latched on the second edge.)

TOSHIBA



#### 26.7.5 Event Counter

In the table below, the letter x represents the TMRB operation clock cycle time which is identical to the fsys cycle time. It varies depending on the programming of the clock gear function.

| Parameter              | Symbol            | Equation |     | 40 MHz |     | 54 MHz |     | l la it |
|------------------------|-------------------|----------|-----|--------|-----|--------|-----|---------|
| Parameter              | Symbol            | Min.     | Max | Min.   | Max | Min.   | Max | Unit    |
| Clock Low pulse width  | t <sub>VCKL</sub> | 2x + 100 | -   | 150    | -   | 137    | -   | ns      |
| Clock High pulse width | t <sub>VCKH</sub> | 2x + 100 | -   | 150    | -   | 137    | -   | ns      |

#### 26.7.6 Capture

In the table below, the letter x represents the TMRB operation clock cycle time which is identical to the fsys cycle time. It varies depending on the programming of the clock gear function.

| Parameter        | Symbol           | Equation |     | 40 MHz |     | 54 MHz |     | Unit |
|------------------|------------------|----------|-----|--------|-----|--------|-----|------|
|                  |                  | Min.     | Max | Min.   | Max | Min.   | Max | Unit |
| Low pulse width  | t <sub>CPL</sub> | 2x + 100 | -   | 150    | -   | 137    | -   | ns   |
| High pulse width | t <sub>CPH</sub> | 2x + 100 | -   | 150    | -   | 137    | -   | ns   |

#### 26.7.7 External Interrupt

In the table below, the letter x represents the fsys cycle time.

1. Except STOP1 and STOP2 release interrupts

| Parameter                        | Symphol            | Equation |     | 40 MHz |     | 54 MHz |     | Linit |
|----------------------------------|--------------------|----------|-----|--------|-----|--------|-----|-------|
|                                  | Symbol             | Min.     | Max | Min.   | Max | Min.   | Max | Unit  |
| INT0 to B low level pulse width  | t <sub>INTAL</sub> | x + 100  | -   | 125    | -   | 118.5  | -   | ns    |
| INT0 to B high level pulse width | t <sub>INTAH</sub> | x + 100  | -   | 125    | -   | 118.5  | -   | ns    |

#### 2. STOP1 release interrupts

| Parameter                           | Symbol             | Min. | Max | Unit |
|-------------------------------------|--------------------|------|-----|------|
| MI, INT0 to B low level pulse width | t <sub>INTBL</sub> | 100  | -   | ns   |
| INT0 to B high level pulse width    | t <sub>INTBH</sub> | 100  | -   | ns   |

3. STOP2 release interrupts

| Parameter                        | Symbol             | Min. | Max | Unit |
|----------------------------------|--------------------|------|-----|------|
| NMI low level pulse width        | t <sub>INTCL</sub> | 500  | -   | μs   |
| INT0 to B high level pulse width | t <sub>INTCH</sub> | 500  | -   | μs   |

26.7.8 NMI

| Parameter                                     | Symbol             | Min. | Мах | Unit |
|-----------------------------------------------|--------------------|------|-----|------|
| $\overline{\text{NIM}}$ low level pulse width | t <sub>INTCL</sub> | 100  | -   | ns   |

### 26.7.9 SCOUT Pin AC Characteristic

| Deremeter              | Symbol           | Equation |     | 40 MHz |     | 54 MHz |     | 1.1:4 |
|------------------------|------------------|----------|-----|--------|-----|--------|-----|-------|
| Parameter              |                  | Min.     | Max | Min.   | Max | Min.   | Max | Unit  |
| High level pulse width | t <sub>SCH</sub> | 0.5T - 5 | -   | 7.5    | -   | 4.3    | -   | ns    |
| Low level pulse width  | t <sub>SCL</sub> | 0.5T - 5 | -   | 7.5    | -   | 4.3    | -   | ns    |

Note: In the above table, the letter T represents the cycle time of the SCOUT output clock.



### 26.7.10 Two-phase pulse input Pin AC Characteristic

| Parameter                            | Symbol            | Min. | Max | Unit |
|--------------------------------------|-------------------|------|-----|------|
| Two-phase pulse input cycle          | T <sub>dcyc</sub> | 2    | -   |      |
| Two-phase pulse input setup          | T <sub>abs</sub>  | 1    | -   |      |
| Two-phase pulse input hold           | T <sub>abh</sub>  | 1    | -   | μs   |
| Two-phase input Low/High pulse width | T <sub>pwlh</sub> | 1    | -   |      |



### 26.7.11 High resolution PPG output Pin AC Characteristic

| Parameter              | Symbol            | Equation |     | 40 MHz |     | 54 MHz |     | 11-14 |  |
|------------------------|-------------------|----------|-----|--------|-----|--------|-----|-------|--|
|                        |                   | Min.     | Max | Min.   | Max | Min.   | Max | Unit  |  |
| High level pulse width | t <sub>PPGH</sub> | 100      | -   | 100    | -   | 100    | -   |       |  |
| Low level pulse width  | t <sub>PPGL</sub> | 100      | -   | 100    | -   | 100    | -   | ns    |  |



### 26.7.12 ADTRG input Pin AC Characteristic

| Parameter                 | Symbol           | Equation    |     | 40MHz |     | 54MHz |     | 11.3 |  |
|---------------------------|------------------|-------------|-----|-------|-----|-------|-----|------|--|
|                           |                  | Min.        | Max | Min.  | Max | Min.  | Max | Unit |  |
| Low level pulse width     | T <sub>adl</sub> | fsys/2 + 20 | -   | 32.5  | -   | 29.3  | -   |      |  |
| High level pulse interval | T <sub>adh</sub> | fsys/2 + 20 | -   | 32.5  | -   | 29.3  | -   | ns   |  |

# TOSHIBA

#### 26.7.13 External bus interface AC Characteristic

26.7.13.1 AC measurement condition

- Output levels: High =  $0.7 \times \text{DVDD3A}$ ,  $0.7 \times \text{DVDD3B}$
- Output levels: Low =  $0.3 \times \text{DVDD3A}$ ,  $0.3 \times \text{DVDD3B}$

#### 26.7.13.2 Separate Bus mode

Conditional variable : RWS = 1, TW = 2, RWH = 1 and CSH =1

- RWS : Number of setup cycle insertion before  $\overline{RD}$ ,  $\overline{WR}$  asserted (TW = 0, 1, 2 or 4)
- TW : Number of internal wait insertion (TW = 0 to 15)
- RWH : Number of  $\overline{RD}$ ,  $\overline{WR}$  recovery cycle insertion (RWH = 0 to 6 or 8)
- CSH : Number of  $\overline{\text{CSx}}$  recovery cycle insertion (CSH = 0, 1, 2 or 4)

|                                                                           | DVDD3A = DVDD3B = 3.6V to 2.7 |                  |                 |      |       |      |       |      |
|---------------------------------------------------------------------------|-------------------------------|------------------|-----------------|------|-------|------|-------|------|
| Parameter                                                                 | Symbol                        | Equation         |                 |      | 40MHz |      | 54MHz |      |
|                                                                           |                               | Min.             | Max             | Min. | Max   | Min. | Max   | Unit |
| System clock period (x)                                                   | t <sub>SYS</sub>              | x                | -               | 25   | -     | 18.5 | -     |      |
| External bus clock (EXBCLK)                                               | t <sub>CYC</sub>              | x                | -               | 25   | -     | 18.5 | -     |      |
| A[23:0] valid to $\overline{\text{RD}}$ , $\overline{\text{WR}}$ asserted | t <sub>AC</sub>               | x (1+RWS)-10     | -               | 40   | -     | 27   | -     |      |
| A[23:0] hold after $\overline{RD}$ , $\overline{WR}$ negated              | t <sub>CAR</sub>              | x (1+RWH+CSH)-10 | -               | 65   | -     | 45.5 | -     |      |
| A[23:0] valid to D[15:0] data in                                          | t <sub>AD</sub>               | -                | x (1+RWS+TW)-35 | -    | 65    | -    | 39    |      |
| $\overline{\text{RD}}$ asserted to D[15:0] data in                        | t <sub>RD</sub>               | -                | x (1+TW)-30     | -    | 45    | -    | 25.5  |      |
| RD width low level                                                        | t <sub>RR</sub>               | x (1+TW)-12      | -               | 63   | -     | 43.5 | -     | ns   |
| D[15:0] hold after RD negated                                             | t <sub>HR</sub>               | x (1+RWH)−7      | -               | 43   | -     | 30   | -     |      |
| RD negated to next A[23:0] output                                         | t <sub>RAE</sub>              | x (1+RWH+CSH)-15 | -               | 60   | -     | 40.5 | -     |      |
| $\overline{\text{WR}}$ width low level                                    | t <sub>WW</sub>               | x (1+TW)−15      | -               | 60   | -     | 40.5 | -     |      |
| D[15:0] valid after $\overline{\text{WR}}$ negated                        | t <sub>DO</sub>               | -                | -               | -    | 20    | -    | 20    |      |
| D[15:0] valid to WR negated                                               | t <sub>DW</sub>               | x (1+TW)-15      | _               | 60   | -     | 40.5 | -     |      |
| D[15:0] hold after WR negated                                             | t <sub>WD</sub>               | x (1+RWH)−7      | _               | 43   | -     | 30   | -     |      |

#### 26.7 AC Electrical Characteristics

| Parameter                                                                 | Symbol           | Equation         |                 |      | 40MHz |      | 54MHz |      |
|---------------------------------------------------------------------------|------------------|------------------|-----------------|------|-------|------|-------|------|
|                                                                           |                  | Min.             | Max             | Min. | Max   | Min. | Мах   | Unit |
| System clock period (x)                                                   | tsys             | x                | -               | 25   | -     | 18.5 | -     |      |
| External bus clock (EXBCLK)                                               | t <sub>CYC</sub> | x                | -               | 25   | -     | 18.5 | -     |      |
| A[23:0] valid to $\overline{\text{RD}}$ , $\overline{\text{WR}}$ asserted | t <sub>AC</sub>  | x (1+RWS)-20     | -               | 30   | -     | 17   | -     |      |
| A[23:0] hold after $\overline{RD}$ , $\overline{WR}$ negated              | t <sub>CAR</sub> | x (1+RWH+CSH)-25 | -               | 50   | -     | 30.5 | -     |      |
| A[23:0] valid to D[15:0] data in                                          | t <sub>AD</sub>  | -                | x (1+RWS+TW)-45 | -    | 55    | -    | 29    |      |
| RD asserted to D[15:0] data in                                            | t <sub>RD</sub>  | -                | x (1+TW)−40     | -    | 35    | -    | 15.5  |      |
| RD width low level                                                        | t <sub>RR</sub>  | x (1+TW)-20      | -               | 55   | -     | 35.5 | -     | ns   |
| D[15:0] hold after RD negated                                             | t <sub>HR</sub>  | x (1+RWH)−15     | -               | 35   | -     | 22   | I     |      |
| RD negated to next A[23:0] output                                         | t <sub>RAE</sub> | x (1+RWH+CSH)-20 | -               | 55   | -     | 35.5 | -     |      |
| WR width low level                                                        | t <sub>WW</sub>  | x (1+TW)-20      | -               | 55   | -     | 35.5 | -     |      |
| D[15:0] valid after WR negated                                            | t <sub>DO</sub>  | -                | _               | -    | 25    | -    | 25    |      |
| D[15:0] valid to WR negated                                               | t <sub>DW</sub>  | x (1+TW)-20      | _               | 55   | -     | 35.5 | -     |      |
| D[15:0] hold after $\overline{WR}$ negated                                | t <sub>WD</sub>  | x (1+RWH)−15     | _               | 35   | -     | 22   | -     |      |

#### DVDD3A = 3.6V to 2.7V, DVDD3B = 3.6V to 1.65V

Read cycle timing ( minimum bus cycle )

(Neither Cycle expander, RD setup, Internal wait, CS recovery nor RD recovery function are used.)



Read cycle timing (1 bus cycle per 6 clock)

(RD setup, Internal wait, CS recovery and RD recovery function are set to 1 cycle though Cycle expander function is not used.)



Write cycle timing ( minimum bus cycle )

(Neither Cycle expander, WR setup, Internal wait, CS recovery nor WR recovery function are used.)



Write cycle timing (1 bus cycle per 6 clock)

(WR setup, Internal wait, CS recovery and WR recovery function are set to 1 cycle though Cycle expander function is not used.)



#### 26.7.13.3 Multiplex Bus mode

Conditional variable : ALE = 1, RWS = 1, TW = 2, RWH = 1 and CSH =1

- ALE : Number of ALE cycle insertion (ALE = 1 + n; n = 0, 1, 2 or 4)
- RWS : Number of setup cycle insertion before  $\overline{RD}$ ,  $\overline{WR}$  asserted (TW = 0, 1, 2 or 4)
- TW : Number of internal wait insertion (TW = 0 to 15)
- RWH : Number of  $\overline{RD}$ ,  $\overline{WR}$  recovery cycle insertion (RWH = 0 to 6 or 8)
- CSH : Number of  $\overline{\text{CSx}}$  recovery cycle insertion (CSH = 0, 1, 2 or 4)

|                                                                                                                               |                                      |                  |                     | DVDD3 | BA = DV | DD3B = | : 3.6V to | 2.7V |
|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------|---------------------|-------|---------|--------|-----------|------|
| Descentes                                                                                                                     | 0 set of                             | Ec               | uation              | 40    | MHz     | 54MHz  |           |      |
| Parameter                                                                                                                     | Symbol                               | Min.             | Max                 | Min.  | Max     | Min.   | Max       | Unit |
| System clock period (x)                                                                                                       | t <sub>SYS</sub>                     | x                | -                   | 25    | -       | 18.5   | -         |      |
| External bus clock (EXBCLK)                                                                                                   | t <sub>CYC</sub>                     | x                | -                   | 25    | -       | 18.5   | -         |      |
| A[23:0] valid to ALE low                                                                                                      | t <sub>AL</sub>                      | x (1+ALE)-15     | -                   | 35    | -       | 22     | -         |      |
| A[23:0] hold after ALE low                                                                                                    | t <sub>LA</sub>                      | x (1+RWS)-7      | -                   | 43    | -       | 30     | -         |      |
| ALE width high                                                                                                                | t <sub>LL</sub>                      | x (1+ALE)-15     | -                   | 35    | -       | 22     | -         |      |
| ALE low to $\overline{\text{RD}}$ or $\overline{\text{WR}}$ asserted                                                          | t <sub>LC</sub>                      | x (1+RWS)-7      | -                   | 43    | -       | 30     | -         |      |
| $\overline{\text{RD}}$ or $\overline{\text{WR}}$ negated to ALE high                                                          | t <sub>CL</sub>                      | x (1+RWH+CSH)-15 | -                   | 60    | -       | 40.5   | -         |      |
| A[15:0] valid to $\overline{RD}$ or $\overline{WR}$ asserted<br>A[23:16] valid to $\overline{RD}$ or $\overline{WR}$ asserted | t <sub>ACL</sub><br>t <sub>ACH</sub> | x (1+ALE+RWS)-15 | -                   | 60    | -       | 40.5   | -         |      |
| A[23:16] hold after $\overline{RD}$ or $\overline{WR}$ negated                                                                | t <sub>CAR</sub>                     | x (1+RWH+CSH)-15 | -                   | 60    | -       | 40.5   | -         | ns   |
| A[15:0] valid to D[15:0] data in<br>A[23:16] valid to D[15:0] data in                                                         | t <sub>ADL</sub><br>t <sub>ADH</sub> | -                | x (3+ALE+RWS+TW)-35 | -     | 140     | -      | 94.5      |      |
| $\overline{\text{RD}}$ asserted to D[15:0] data in                                                                            | t <sub>RD</sub>                      | -                | x (1+TW)-30         | -     | 45      | -      | 25.5      |      |
| RD width low                                                                                                                  | t <sub>RR</sub>                      | x (1+TW)-12      | -                   | 63    | -       | 43.5   | -         |      |
| D[15:0] hold after RD negated                                                                                                 | t <sub>HR</sub>                      | x (1+RWH)-7      | -                   | 43    | -       | 30     | -         |      |
| RD negated to next A[23:0] output                                                                                             | t <sub>RAE</sub>                     | x (1+RWH+CSH)-15 | -                   | 60    | -       | 40.5   | -         |      |
| WR width low                                                                                                                  | t <sub>WW</sub>                      | x (1+TW)-15      | -                   | 60    | -       | 40.5   | -         |      |
| D[15:0] valid to WR negated                                                                                                   | t <sub>DW</sub>                      | x (1+TW)-15      | -                   | 60    | -       | 40.5   | -         |      |
| D[15:0] hold after WR negated                                                                                                 | t <sub>WD</sub>                      | x (1+RWH)-7      | -                   | 43    | -       | 30     | -         |      |

#### 26.7 AC Electrical Characteristics

| Demenden                                                                                                                      | Ourseland                            | Ec               | uation              | 401  | ИНz | 54N  | ИНz  | Unit |
|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------|---------------------|------|-----|------|------|------|
| Parameter                                                                                                                     | Symbol                               | Min.             | Max                 | Min. | Мах | Min. | Мах  | Unit |
| System clock period (x)                                                                                                       | t <sub>SYS</sub>                     | x                | -                   | 25   | -   | 18.5 | -    |      |
| External bus clock (EXBCLK)                                                                                                   | t <sub>CYC</sub>                     | х                | -                   | 25   | -   | 18.5 | -    |      |
| A[15:0] valid to ALE low                                                                                                      | t <sub>AL</sub>                      | x (1+ALE)-30     | -                   | 20   | -   | 7    | -    |      |
| A[15:0] hold after ALE low                                                                                                    | t <sub>LA</sub>                      | x (1+RWS)-15     | -                   | 35   | -   | 22   | -    |      |
| ALE width high                                                                                                                | t <sub>LL</sub>                      | x (1+ALE)-30     | -                   | 20   | -   | 7    | -    |      |
| ALE low to $\overline{\text{RD}}$ or $\overline{\text{WR}}$ asserted                                                          | t <sub>LC</sub>                      | x (1+RWS)-15     | -                   | 35   | -   | 22   | -    |      |
| $\overline{RD}$ or $\overline{WR}$ negated to ALE high                                                                        | t <sub>CL</sub>                      | x (1+RWH+CSH)-25 | -                   | 50   | -   | 30.5 | -    |      |
| A[15:0] valid to $\overline{RD}$ or $\overline{WR}$ asserted<br>A[23:16] valid to $\overline{RD}$ or $\overline{WR}$ asserted | t <sub>ACL</sub><br>t <sub>ACH</sub> | x (1+ALE+RWS)-15 | -                   | 45   | -   | 25.5 | -    |      |
| A[23:16] hold after RD or WR nega-<br>ted                                                                                     | t <sub>CAR</sub>                     | x (1+RWH+CSH)-25 | -                   | 50   | -   | 30.5 | -    | ns   |
| A[15:0] valid to D[15:0] data in<br>A[23:16] valid to D[15:0] data in                                                         | t <sub>ADL</sub><br>t <sub>ADH</sub> | -                | x (3+ALE+RWS+TW)-45 | -    | 130 | -    | 84.5 |      |
| RD asserted to D[15:0] data in                                                                                                | t <sub>RD</sub>                      | -                | x (1+TW)-40         | -    | 35  | -    | 15.5 |      |
| RD width low                                                                                                                  | t <sub>RR</sub>                      | x (1+TW)-20      | -                   | 55   | -   | 35.5 | -    |      |
| D[15:0] hold after RD negated                                                                                                 | t <sub>HR</sub>                      | x (1+RWH)-15     | -                   | 35   | -   | 22   | -    |      |
| RD negated to next A[23:0] output                                                                                             | t <sub>RAE</sub>                     | x (1+RWH+CSH)-25 | -                   | 50   | -   | 30.5 | -    |      |
| WR width low                                                                                                                  | t <sub>WW</sub>                      | x (1+TW)-20      | _                   | 55   | -   | 35.5 | -    |      |
| D[15:0] valid to WR negated                                                                                                   | t <sub>DW</sub>                      | x (1+TW)-20      | -                   | 55   | -   | 35.5 | -    |      |
| D[15:0] hold after WR negated                                                                                                 | t <sub>WD</sub>                      | x (1+RWH)-15     | -                   | 35   | -   | 22   | -    |      |

#### DVDD3A = 3.6V to 2.7V, DVDD3B = 3.6V to 1.65V

Read cycle timing ( minimum bus cycle )

(Neither Cycle expander, ALE wait, RD setup, Internal wait, CS recovery nor RD recovery function are used.)



Read cycle timing (1 bus cycle per 8 clock)

(ALE wait, RD setup, Internal wait, CS recovery and RD recovery function are set to 1 cycle though Cycle expander function is not used.)



Read cycle timing (1 bus cycle per 9 clock)

(ALE wait, RD setup, Internal wait, CS recovery and RD recovery function are set to 1 cycle though Cycle expander function is set double.)



Write cycle timing ( minimum bus cycle )

(Neither Cycle expander, ALE wait, WR setup, Internal wait, CS recovery nor WR recovery function are used.)



Write cycle timing (1 bus cycle per 8 clock)

(ALE wait, WR setup, Internal wait, CS recovery and WR recovery function are set to 1 cycle though Cycle expander function is not used.)



## 26.7.14 Debug Communication

#### 26.7.14.1 SWD Interface

| Parameter                                | Symbol           | Min. | Max | Unit |
|------------------------------------------|------------------|------|-----|------|
| CLK cycle                                | T <sub>dck</sub> | 100  | -   |      |
| CLK rise $\rightarrow$ Output data hold  | T <sub>d1</sub>  | 4    | -   |      |
| CLK fall $\rightarrow$ Output data valid | T <sub>d2</sub>  | -    | 30  | ns   |
| Input data valid $\rightarrow$ CLK rise  | T <sub>ds</sub>  | 20   | -   |      |
| $CLK \ rise \to Input \ data \ hold$     | T <sub>dh</sub>  | 15   | -   |      |

### 26.7.14.2 JTAG Interface

| Parameter                                        | Symbol           | Min. | Max | Unit |
|--------------------------------------------------|------------------|------|-----|------|
| CLK cycle                                        | T <sub>dck</sub> | 100  | -   |      |
| $CLK \text{ fall} \to Output \text{ data hold}$  | T <sub>d3</sub>  | 4    | -   |      |
| $CLK \text{ fall} \to Output \text{ data valid}$ | T <sub>d4</sub>  | -    | 50  | ns   |
| Input data valid $\rightarrow$ CLK rise          | T <sub>ds</sub>  | 20   | -   |      |
| $CLK \text{ rise} \to Input \text{ data hold}$   | T <sub>dh</sub>  | 15   | -   |      |



## 26.7.15 ETM Trace

| Parameter                                  | Symbol              | Min. | Max | Unit |
|--------------------------------------------|---------------------|------|-----|------|
| TRACECLK cycle                             | t <sub>tclk</sub>   | 37   | -   |      |
| TRACEDATA valid ← TRACECLK rise            | t <sub>setupr</sub> | 2    | -   |      |
| TRACECLK rise $\rightarrow$ TRACEDATA hold | t <sub>holdr</sub>  | 1    | -   | ns   |
| TRACEDATA valid ← TRACECLK fall            | t <sub>setupf</sub> | 2    | -   |      |
| TRACECLK fall $\rightarrow$ TRACEDATA hold | t <sub>holdf</sub>  | 1    | -   |      |



## 26.7.16 On chip oscillator

| Parameter             | Symbol | Condition        | Min. | Тур. | Max | Unit |
|-----------------------|--------|------------------|------|------|-----|------|
| Oscillating frequency | IHOSC  | Ta = -40 to 85°C | 9    | 10   | 11  | MHz  |

Note: The on-chip-oscillator can not be used as system clock (fsys) which is required oscillation accuracy.

## 26.7.17 External oscillation

| Parameter                  | Symbol | Condition        | Min. | Тур. | Max | Unit |
|----------------------------|--------|------------------|------|------|-----|------|
| High frequency oscillation | EHOSC  | Ta = -40 to 85°C | 8    | -    | 16  | MHz  |

## 26.7.18 External clock input

| Parameter                      | Symbol             | Min. | Тур. | Max | Unit |
|--------------------------------|--------------------|------|------|-----|------|
| External clock frequency       | t <sub>ehcin</sub> | 8    | -    | 27  | MHz  |
| External clock duty            | -                  | 45   | -    | 55  | %    |
| External clock input rise time | t <sub>rehc</sub>  | -    | -    | 10  | ns   |
| External clock input fall time | t <sub>fehc</sub>  | -    | -    | 10  | ns   |



## 26.7.19 Flash Characteristics

| Parameter                                | Condition                                                                          | Min. | Тур. | Max | Unit  |
|------------------------------------------|------------------------------------------------------------------------------------|------|------|-----|-------|
| Guarantee on Flash-memory re-<br>writing | DVDD3A = AVDD3 = RVDD3 = 2.7 V ~ 3.6 V,<br>DVDD3B = 1.65 V ~ 3.6 V, Ta = 0 to 70°C | -    | -    | 200 | Times |

#### 26.7.19.1 Noise Filter Characteristics

| Parameter                   | Symbol | Min. | Тур. | Max | Unit |
|-----------------------------|--------|------|------|-----|------|
| Analog noise canceler width | -      | 15   | 30   | 60  | ns   |

# TOSHIBA

## 26.8 Recommended Oscillation Circuit



## Figure 26-1 High-frequency oscillation connection

Note:To obtain a stable oscillation, load capacity and the position of the oscillator must be configured properly. Since these factors are strongly affected by substratepatterns, please evaluate oscillation stability using the substrate you use.

The TX03 has been evaluated by the oscillator vender below. Please refer this information when selecting external parts

## 26.8.1 Ceramic oscillator

The TX03 recommends the high-frequency oscillator by Murata Manufacturing Co., Ltd.

Please refer to the following URL for details.

http://www.murata.co.jp

## 26.9 Handling Precaution

### 26.9.1 Solderability

| Test parameter | Test condition                                                                                                                                  | Note                                   |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| Solderability  | Use of Sn-37Pb solder Bath<br>Solder bath temperature = 230°C, Dipping time = 5 seconds<br>The number of times = one, Use of R-type flux        | Pass:                                  |
| Solderability  | Use of Sn-3.0Ag-0.5Cu solder bath<br>Solder bath temperature = 245°C, Dipping time = 5 seconds<br>The number of times = one, Use of R-type flux | solderability rate until forming ≥ 95% |

### 26.9.2 Power-on sequence

The power-on sequence must include the time for the internal regulator, internal flash memory and internal oscillator to be stable and the reset. In the TX03, the internal circuit automatically insert the time for the internal regulator which requires the time at least 1 ms and after this, internal reset operation requires 4096 cycles on internal oscillation, therefore, A little bit of time differences occur until CPU start operate. And there are multiple independent Power supply, therefore you must be followed the procedure of Power-On.

If you use one of four power sources (DVDD3A, DVDD3B, RVDD3, AVDD3) with a different voltage, or you use only DVDD3B with a different voltage (1.65V), set the power supply to satisfy the following condition: DVDD3A=RVDD3=AVDD3 rising time (time to guaranteed operating voltage)  $\leq$  DVDD3B rising time (time to guaranteed operating voltage).

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.



Figure 26-2 shows the power-on sequence.



## 27. Package Dimensions

Type:P-TFBGA113-0606-0.50A4



#### **RESTRICTIONS ON PRODUCT USE**

- Toshiba Corporation, and its subsidiaries and affiliates (collectively "TOSHIBA"), reserve the right to make changes to the information in this document, and related hardware, software and systems (collectively "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 all operating parameters for such designs and applications. TOSHIBA ASSUMES NO LIABILITY FOR CUSTOMERS' PRODUCT DESIGN OR APPLICATIONS.
- Product is intended for use in general electronics applications (e.g., computers, personal equipment, office equipment, measuring equipment, industrial robots and home electronics appliances) or for specific applications as expressly stated in this document.

Product is neither intended nor warranted for use in equipment 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 or serious public impact ("Unintended Use"). Unintended Use includes, without limitation, equipment used in nuclear facilities, equipment used in the aerospace industry, 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, devices related to electric power, and equipment used in finance-related fields. Do not use Product for Unintended Use unless specifically permitted in this document.

- 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 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.