

## 8 Bit Microcontroller TLCS-870/X Series

## TMP88F846UG

**TOSHIBA CORPORATION** 



## **Revision History**

| Date     | Revision |                  |
|----------|----------|------------------|
| 2008/2/8 | 1        | First Release    |
| 2009/9/3 | 2        | Contents Revised |
|          |          |                  |

# **Table of Contents**

#### **TMP88F846UG** 1.1 1.2 1.3 Pin Names and Functions 1.4 **Functional Description** 2. 2.1 Functions of the CPU Core..... .9 2.1.1 Memory Address Map..... .....9 2.1.2 Program Memory (ROM)..... 2.1.3 Data Memory (RAM)..... ....10 ...... 2.1.4 System Clock Control Circuit..... .....11 ....., 2.1.4.1 On-Chip Oscillator 2.1.4.2 Timing Generator 2.1.4.3 Standby Control Circuit 2.1.4.4 Controlling Operation Modes 2.1.5 Reset Circuit..... 2.1.5.1 External Reset Input 2.1.5.2 Address Trap Reset 2.1.5.3 Watchdog Timer Reset 2.1.5.4 System Clock Reset 2.1.5.5 Voltage detection reset 2.1.5.6 Power-on Reset 2.1.5.7 Trimming data reset 3. Interrupt Control Circuit

| 3.1 Interrupt latches (IL39 to IL2)                           |    |
|---------------------------------------------------------------|----|
| 3.2 Interrupt enable register (EIR)                           |    |
| 3.2.1 Interrupt master enable flag (IMF)                      |    |
| 3.2.2 Individual interrupt enable flags (EF39 to EF3)         |    |
| 3.3 Interrupt Sequence                                        |    |
| 3.3.1 Interrupt acceptance processing is packaged as follows. |    |
| 3.3.2 Saving/restoring general-purpose registers              |    |
| 3.3.2.1 Using Automatic register bank switching               |    |
| 3.3.2.2 Using register bank switching                         |    |
| 3.3.2.3 Using PUSH and POP instructions                       |    |
| 3.3.2.4 Using data transfer instructions                      |    |
| 3.3.3 Interrupt return                                        | 35 |
| 3.4 Software Interrupt (INTSW)                                |    |
| 3.4.1 Address error detection                                 |    |
| 3.4.2 Debugging                                               |    |
| 3.5 External Interrupts                                       | 37 |
|                                                               |    |

#### 4. Special Function Register

| 4.1 | SFR | 39 |
|-----|-----|----|
|-----|-----|----|

| 4.2 | DBR                                                                   |          |
|-----|-----------------------------------------------------------------------|----------|
|     |                                                                       |          |
| Inp | out/Output Ports                                                      |          |
| 5.1 | Port P1 (P15 to P10)                                                  |          |
| 5.2 |                                                                       |          |
| 5.3 | Port P3 (P37 to P30)                                                  |          |
| 5.4 | Port P4 (P47 to P40)                                                  |          |
| 5.5 | Port P6 (P67 to P60)                                                  |          |
| 5.5 |                                                                       | 9        |
|     |                                                                       |          |
| Pov | wer-on reset circuit                                                  |          |
| 6.1 | Configuration                                                         | $\wedge$ |
| 6.2 |                                                                       |          |
| 0.2 |                                                                       |          |
|     |                                                                       |          |
| Vol | ltage detection circuit (VLTD)                                        |          |
|     |                                                                       | 7/5      |
| 7.1 | Configuration                                                         | ())      |
| 7.2 |                                                                       |          |
| 7.3 | Function                                                              | }        |
|     | <ul> <li>3.1 Enabling/Disabling Voltage Detection Operation</li></ul> | /        |
|     | 3.3 Detection voltage level section                                   |          |
|     | .3.4 Voltage detection flag and voltage detection status flag         |          |
| 7.4 |                                                                       |          |
|     | 4.1 Setting Procedure for Generate an interrupt                       |          |
| 7.  | 4.2 Setting procedure to generate a/reset                             |          |
|     |                                                                       |          |
| Tin | ne Base Timer (TBT) and Divider Output (DVO)                          |          |
|     |                                                                       |          |
| 8.1 | Time Base Timer                                                       |          |
| 8.2 | Divider Output (DVO)                                                  |          |
|     |                                                                       |          |
| Wa  | tchdog Timer (WDT)                                                    |          |
| 9.1 | Watchdog Timer Configuration                                          |          |
|     |                                                                       |          |
| 9.2 | 2.1 Malfunction Detection Methods Using the Watchdog Timer            |          |
|     | 2.2 Watchdog Timer Enable                                             |          |
|     | 2.3 Watchdog Timer Disable                                            |          |
|     | .2.4 Watchdog Timer Interrupt (INTWDT)                                |          |
|     | .2.5 Watchdog Timer Reset                                             | /-       |

| 10.1 | Configuration        |
|------|----------------------|
| 10.2 | TimerCounter Control |

|            | 10.3 Function                                                                                                  |                                         | 77                  |
|------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------|
|            | 10.3.1 Timer mode                                                                                              |                                         |                     |
|            | 10.3.2 External Trigger Timer Mode                                                                             |                                         |                     |
|            | 10.3.3 Event Counter Mode                                                                                      |                                         |                     |
|            | 10.3.4     Window Mode       10.3.5     Pulse Width Measurement Mode                                           |                                         |                     |
|            | 10.3.6 Programmable Pulse Generate (PPG) Output M                                                              |                                         |                     |
|            |                                                                                                                |                                         |                     |
| 11         | 1( <b>D</b> <sup>1</sup> / <sub>2</sub> <b>T</b> <sup>1</sup> / <sub>2</sub> <b>CT</b> ()                      |                                         | $\langle O \rangle$ |
| <u>11.</u> | 16-Bit Timer (CTC)                                                                                             |                                         |                     |
|            | 11.1 Configuration                                                                                             |                                         | .).)                |
|            | 11.2 Control                                                                                                   |                                         |                     |
|            | 11.3 Function                                                                                                  | <u> </u>                                |                     |
|            | 11.3.1 Timer mode with software start                                                                          |                                         |                     |
|            | 11.3.2Timer mode with external trigger start11.3.3Event counter mode                                           | ·····                                   |                     |
|            | 11.3.4 Programmable Pulse Generate (PPG) output m                                                              | node                                    | 90                  |
|            |                                                                                                                |                                         |                     |
| 12.        | 8-Bit TimerCounter 3 (TC3)                                                                                     |                                         |                     |
| 12.        | o-Bit TimerCounter 5 (TC5)                                                                                     |                                         |                     |
|            | 12.1 Configuration                                                                                             | ()                                      |                     |
|            | 12.2 TimerCounter Control                                                                                      |                                         |                     |
|            | 12.3 Function                                                                                                  |                                         |                     |
|            | 12.3.1 Timer mode                                                                                              |                                         |                     |
|            | 12.3.2 Event Counter Mode                                                                                      |                                         |                     |
|            | 12.3.3 Capture Mode                                                                                            | /                                       |                     |
|            |                                                                                                                |                                         |                     |
| 13.        | 8-Bit TimerCounter 4 (TC4)                                                                                     |                                         |                     |
|            |                                                                                                                |                                         |                     |
|            | 13.1 Configuration                                                                                             | · · · / / · / · · · · · · · · · · · · · |                     |
|            | 13.2 TimerCounter Control                                                                                      |                                         |                     |
|            | 13.3 Function                                                                                                  |                                         |                     |
|            | 13.3.1 Timer Mode<br>13.3.2 Event Counter Mode                                                                 |                                         |                     |
|            | 13.3.3 Programmable Divider Output (PDO) Mode                                                                  | //                                      |                     |
|            | 13.3.4 Pulse Width Modulation (PWM) Output Mode                                                                | 2                                       |                     |
|            |                                                                                                                | $\checkmark$                            |                     |
|            |                                                                                                                |                                         |                     |
| 14.        | Motor Control Circuit (PMD: Progr                                                                              | ammable motor driver                    | )                   |
| ~          | 14.1 Outline of Motor Control                                                                                  |                                         |                     |
|            | 14.2 Configuration of the Motor Control                                                                        | Circuit                                 |                     |
|            |                                                                                                                |                                         |                     |
|            | 14.3.1 Configuration of the position detection unit                                                            |                                         |                     |
|            | 14.3.2 Position Detection Circuit Register Functions.<br>14.3.3 Outline Processing in the Position Detection U |                                         |                     |
|            |                                                                                                                |                                         |                     |
|            | 14.4.1 Configuration of the Timer Unit                                                                         |                                         |                     |
|            | 14.4.1.1 Timer Circuit Register Functions                                                                      |                                         |                     |
|            | 14.4.1.2       Outline Processing in the Timer Unit         14.5       Three-phase PWM Output Unit             |                                         | 104                 |
|            | <b>14.5</b> Three-phase PWM Output Unit<br>14.5.1 Configuration of the three-phase PWM output                  |                                         |                     |
|            | 14511 Dia ili ili ili ili internationali                                                                       |                                         | 12т                 |

|                         | 14.5.3                 |                                                                                   | OC bits and UPWM/VPWM/WPWM                                        |            |     |
|-------------------------|------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------|------------|-----|
|                         | 14.5.4<br>14.5.5       |                                                                                   | sters                                                             |            |     |
|                         |                        | Electrical Angle Timer and W                                                      | Vaveform Arithmetic Circuit                                       | t 🔨        | 136 |
|                         | 14.6.1<br>14.6<br>14.6 | Electrical Angle Timer and Waveform<br>1.1 Functions of the Electrical Angle Time | m Arithmetic Circuit<br>er and Waveform Arithmetic Circuit Regist |            |     |
| 15.                     | Asyn                   | chronous Serial interface                                                         | (UART)                                                            |            |     |
|                         | 15.1                   | Configuration                                                                     | (                                                                 | $\bigcirc$ |     |
|                         | 15.2                   | Control                                                                           |                                                                   | $\square$  | 150 |
|                         | 15.3                   | Fransfer Data Format                                                              | 20                                                                |            |     |
|                         | 15.4                   | Fransfer Rate                                                                     |                                                                   |            |     |
|                         | 15.5                   | Data Sampling Method                                                              | (7/                                                               |            |     |
|                         | 15.6                   | Data Sampling Method<br>STOP Bit Length                                           | $\langle \vee \rangle \rangle$                                    | 0.00       |     |
|                         | 15.7                   | Parity                                                                            |                                                                   | 90/        |     |
|                         | 15.8                   | <b>Fransmit/Receive Operation</b>                                                 | 200                                                               | $\square$  | 154 |
|                         | 15.8.1                 | Data Transmit Operation                                                           |                                                                   |            | 154 |
|                         | 15.8.2                 | Data Receive Operation                                                            |                                                                   |            | 154 |
|                         | 15.9                   | Status Flag<br>Parity Error                                                       |                                                                   | .(         | 155 |
|                         | 15.9.1<br>15.9.2       | Parity Error                                                                      |                                                                   |            |     |
|                         | 15.9.2                 | Overrun Error                                                                     |                                                                   |            |     |
|                         | 15.9.4                 | Receive Data Buffer Full                                                          |                                                                   | <u> </u>   |     |
|                         | 15.9.5<br>15.9.6       | Transmit Data Buffer Empty                                                        |                                                                   | /-/        | 156 |
|                         | 15.7.0                 | Transinit End Trag.                                                               |                                                                   |            |     |
|                         |                        |                                                                                   |                                                                   |            |     |
| 16.                     | Synch                  | ronous Serial Interface (                                                         | SIO)                                                              |            |     |
|                         | 16.1                   | Configuration                                                                     |                                                                   |            | 159 |
|                         |                        | Control                                                                           | $(\Omega/ \Delta)$                                                |            |     |
|                         |                        | Serial clock                                                                      |                                                                   |            |     |
|                         | 16.3.1                 |                                                                                   |                                                                   |            |     |
|                         | 16.3<br>16.3           |                                                                                   |                                                                   |            |     |
|                         | 16.3.2                 | Shift edge                                                                        |                                                                   |            |     |
|                         | 16.3                   | 2.1 Leading edge<br>2.2 Trailing edge                                             | $\searrow$                                                        |            |     |
|                         |                        |                                                                                   |                                                                   |            |     |
|                         | /                      | Number of words to transfer.                                                      |                                                                   |            |     |
|                         | $\langle \rangle$      |                                                                                   | $\searrow$                                                        |            |     |
|                         | 16.6.1                 | 4-bit and 8-bit transfer modes                                                    |                                                                   |            |     |
| $\langle \cdot \rangle$ | 16.6.2                 | 4-bit and 8-bit receive modes                                                     |                                                                   |            |     |
|                         | 16.6.3                 | 8-bit transfer / receive mode                                                     |                                                                   |            | 167 |
|                         | $\sim$                 | $\sim$                                                                            |                                                                   |            |     |

## **17. 10-bit AD Converter (ADC)**

| 17.1   | Configuration           |  |
|--------|-------------------------|--|
|        | Register configuration  |  |
|        | Function                |  |
| 17.3.  | 1 Software Start Mode   |  |
| 17.3.2 | 2 Repeat Mode           |  |
| 17     | .3.2.1 Register Setting |  |
| 17.3.3 | 3 INTPWM Start Mode     |  |



19.12Flash Memory Status Code.21519.13Specifying the Erasure Area.21719.14Port Input Control Register.21819.15Flowchart.21919.16UART Timing.220

#### 20. Input/Output Circuitry

 20.1
 Control pins.
 221

 20.2
 Input/output ports.
 222

 20.3
 NC pins.
 222

 $\bigcirc$ 

#### 21. Electrical Characteristics

| 21.1 Absolute Maximum Datings                  |          |                            | 223 |
|------------------------------------------------|----------|----------------------------|-----|
| 21.1 Absolute Maximum Ratings                  |          |                            |     |
| 21.2 Operating Conditions                      |          |                            | 224 |
| 21.2.1 MCU mode (Flash Programming or erasing) | )        | $\sim$                     | 224 |
| 21.2.2 MCU mode (Except Flash Programming or e | erasing) |                            | 224 |
| 21.2.3 Serial PROM mode                        |          | ( ( / / 5)                 | 225 |
| 21.3 DC Characteristics                        |          | $\langle \bigcirc \rangle$ | 225 |
| 21.4 On-Chip Oscillator Characteristics        |          |                            | 226 |
| 21.5 AD Conversion Characteristics             |          | <u>}</u> ]                 | 226 |
| 21.6 Power On Reset circuit (POR)              |          |                            | 227 |
| 21.7 Voltage Detection circuit (VLTD).         | /        | /                          |     |
| 21.8 AC Characteristics                        |          |                            | 228 |
| 21.9 Flash Characteristics                     |          |                            | 228 |
| 21.10 Handling Precaution                      |          |                            |     |
|                                                | $\sim$   |                            |     |

#### 22. Package Dimensions

## CMOS 8-Bit Microcontroller

## TMP88F846UG

The TMP88F846UG is a single-chip 8-bit high-speed and high-functionality microcomputer incorporating 8192 bytes of Flash Memory. It is pin-compatible with the TMP88CH41UG (Mask ROM version). The TMP88F846UG can realize operations equivalent to those of the TMP88CH41UG by programming the on-chip Flash Memory.

|     |                    |                   |                  |                     | Y())        |
|-----|--------------------|-------------------|------------------|---------------------|-------------|
|     | Product No.        | ROM<br>(FLASH)    | RAM              | Package             | MaskROM MCU |
|     | TMP88F846UG        | 8192<br>bytes     | 512+128<br>bytes | LQFP44-P-1010-0.80B | TMP88CH41UG |
| 1.1 | Features           |                   |                  |                     |             |
|     | 1. 8-bit single cl | nip microcomputer | TLCS-870/X se    | eries VO)           | $\diamond$  |

- Instruction execution time :
  - 0.20 µs (at 20 MHz)
- 181 types & 842 basic instructions
- 2. 26 interrupt sources (External : 6 Internal : 20)
- 3. Input / Output ports (33 pins)

Large current output: 16pins (Typ. 20mA), LED direct drive

- 4. Power-on reset circuit
- 5. Voltage detection circuit(VLTD)
- 6. Prescaler
  - Time base timer
    - Divider output function (DVO)
- 7. Watchdog Timer

Select of "internal reset request" or "interrupt request".

- 8. 16-bit timer counter: 1 ch
  - Timer, External trigger, Window, Pulse width measurement,

Event counter, Programmable pulse generate (PPG) modes

- 9. 16-bit timer/eounter(CTC): 1ch
  - CTC: Timer, event counter or PPG (Programmable Pulse) output
- 10. 8-bit timer counter : 1 ch
  - Timer, Event counter, Capture modes
- 11. 8-bit timer counter : 1 ch
  - Timer, Event counter, Pulse width modulation (PWM) output,
    - Programmable divider output (PDO) modes
- 12. Programmable motor driver (PMD) : 1 ch
  - Sine wave drive circuit (built-in sine wave data-table RAM)
    - Rotor position detect function
    - Motor control timer and capture function
    - Overload protective function
    - Auto commutation and auto position detection start function

This product uses the Super Flash® technology under the licence of Silicon Storage Technology, Inc. Super Flash® is registered trademark of Silicon Storage Technology, Inc.

13. 8-bit UART/SIO : 1 ch

- 14. 10-bit successive approximation type AD converter
  - Analog input: 8 ch
- 15. Clock oscillation circuit : 1 set
- 16. Low power consumption operation (2 modes)
  - STOP mode: Oscillation stops. (Battery/Capacitor back-up.)
  - IDLE mode: CPU stops.

Only peripherals operate using high frequency clock. Release by interrupts (CPU restarts).

17. Operation voltage:

4.5 V to 5.5 V at 20MHz

## 1.2 Pin Assignment



## 1.3 Block Diagram



## 1.4 Pin Names and Functions

The TMP88F846UG has MCU mode, parallel PROM mode, and serial PROM mode. Table 1-1 shows the pin functions in MCU mode. The serial PROM mode is explained later in a separate chapter.

#### Table 1-1 Pin Names and Functions(1/3)

| Pin Name                        | Pin Number | Input/Output | Functions                                                              |
|---------------------------------|------------|--------------|------------------------------------------------------------------------|
| P15                             | 42         | IO           | PORT15                                                                 |
| P14<br>PPG1                     | 41         | 10<br>0      | PORT14<br>PPG1 output                                                  |
| P13<br>DVO                      | 40         | 10<br>0      | PORT13<br>Divider Output                                               |
| P12<br>INT2<br>TC1              | 39         | IO<br>I<br>I | PORT12<br>External interrupt 2 input<br>TC1 input                      |
| P11<br>INT1                     | 38         | O            | PORT11<br>External interrupt 1 input                                   |
| P10<br>INT0                     | 37         | 0            | PORT10<br>External interrupt 0 input                                   |
| P22<br>TC4<br>INT4<br>PWM4/PDO4 | 7          |              | PORT22<br>TC4 input<br>External interrupt 4 input<br>PWM4/PDQ4 output  |
| P21<br>TC3<br>INT3              | 6          |              | PORT21<br>TC3 pin input<br>External interrupt 3 input                  |
| P20<br>INT5<br>STOP             | 9          |              | PORT20<br>External interrupt 5 input<br>STOP mode release signal input |
| P37<br>CL1                      | 17         |              | PORT37<br>PMD over load protection input1                              |
| P36<br>EMG1                     | 16         | 10           | PORT36<br>PMD emergency stop input1                                    |
| P35<br>U1                       | 15         | 0            | PORT35<br>PMD control output U1                                        |
| P34<br>V1                       | 14         | 0 IO<br>0    | PORT34<br>PMD control output V1                                        |
| P33<br>W1                       | 13         | 0<br>0       | PORT33<br>PMD control output W1                                        |
| P32<br>X1                       | 12         | 0<br>0       | PORT32<br>PMD control output X1                                        |
| P31<br>Y1                       | 11         | 10<br>0      | PORT31<br>PMD control output Y1                                        |
| P30<br>Z1                       | 10         | 10<br>0      | PORT30<br>PMD control output Z1                                        |

#### Table 1-1 Pin Names and Functions(2/3)

| Pin Name                 | Pin Number | Input/Output     | Functions                                                                                                                                             |
|--------------------------|------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| P47<br>CTC               | 25         | IO<br>I          | PORT47<br>CTC input                                                                                                                                   |
| P46<br>PPG2              | 24         | IO<br>I          | PORT46<br>PPG2 output                                                                                                                                 |
| P45<br>SO<br>TXD         | 23         | 10<br>0<br>0     | PORT45<br>Serial Data Output<br>UART data output                                                                                                      |
| P44<br>SI<br>RXD<br>BOOT | 22         | IO<br> <br> <br> | PORT44<br>Serial Data Input<br>UART data input<br>Serial PROM mode control input                                                                      |
| P43<br>SCK               | 21         | IO<br>IO         | PORT43<br>Serial Clock I/O                                                                                                                            |
| P42<br>PDU1              | 20         | 10               | PORT42<br>PMD control input U1                                                                                                                        |
| P41<br>PDV1              | 19         |                  | PORT41<br>PMD control input V1                                                                                                                        |
| P40<br>PDW1              | 18         |                  | PORT40<br>PMD control input W1                                                                                                                        |
| P67<br>AIN7<br>DBOUT1    | 33         |                  | PORT67<br>Analog Input7<br>PMD debug output1                                                                                                          |
| P66<br>AIN6              | 32         |                  | PORT66<br>Analog Input6                                                                                                                               |
| P65<br>AIN5              | 31         | 10               | PORT65<br>Analog Input5                                                                                                                               |
| P64<br>AIN4              | 30         |                  | PORT64<br>Analog Input4                                                                                                                               |
| P63<br>AIN3              | 29         |                  | PORT63<br>Analog Input3                                                                                                                               |
| P62<br>AIN2              | 28         |                  | PORT62<br>Analog Input2                                                                                                                               |
| P61<br>AIN1              | 27         | IO<br>I          | PORT61<br>Analog Input1                                                                                                                               |
| P60<br>AINO              | 26         |                  | PORT60<br>Analog Input0                                                                                                                               |
| RESET                    | 20         | 10               | Reset signal                                                                                                                                          |
| TEST                     | 4          | 1                | Test pin for out-going test and the Serial PROM mode control<br>pin. Usually fix to low level. Fix to high level when the Serial<br>PROM mode starts. |
| VAREF                    | 34         | I                | Analog Base Voltage Input Pin for A/D Conversion                                                                                                      |
| AVDD                     | 35         | I                | Analog Power Supply                                                                                                                                   |

Table 1-1 Pin Names and Functions(3/3)

| Pin Name | Pin Number | Input/Output | Functions           |
|----------|------------|--------------|---------------------|
| AVSS     | 36         | I            | Analog Power Supply |
| VDD      | 24         | IO           | +5V                 |
| VSS      | 1          | I            | 0(GND)              |
| NC       | 43         | I            | Non Connection      |
| NC01     | 44         | I            | Non Connection      |
| NC02     | 2          | I            | Non Connection      |
| NC03     | 3          | I            | Non Connection      |

## 2. Functional Description

## 2.1 Functions of the CPU Core

The CPU core consists mainly of the CPU, system clock control circuit, and interrupt control circuit.

This chapter describes the CPU core, program memory, data memory, and reset circuit of the TMP88F846UG.

#### 2.1.1 Memory Address Map

The memory of the TMP88F846UG consists of four blocks: ROM, RAM, SFR (Special Function Registers), and DBR (Data Buffer Registers), which are mapped into one 1-Mbyte address space. The general-purpose registers consist of 16 banks, which are mapped into the RAM address space. Figure 2-1 shows a memory address map of the TMP88F846UG.



#### 2.1.2 Program Memory (ROM)

The TMP88F846UG contains 8Kbytes program memory (Flash) located at addresses 04000H to 05EFFH and addresses FFF00H to FFFFFH.

### 2.1.3 Data Memory (RAM)

The TMP88F846UG contains 512bytes +128bytes RAM. The first 128bytes location (00040H to 000BFH) of the internal RAM is shared with a general-purpose register bank.

The content of the data memory is indeterminate at power-on, so be sure to initialize it in the initialize routine.

Example :Clearing the internal RAM of the TMP88F846UG (clear all RAM addresses to 0, except bank 0)

| 00H)   |
|--------|
|        |
|        |
| (      |
| $\leq$ |
| 2      |

Note: Because general-purpose registers exist in the RAM, never clear the current bank address of RAM. In the above example, the RAM is cleared except bank 0.

#### 2.1.4 System Clock Control Circuit

The System Clock Control Circuit consists of an On-Chip Oscillator, timing generator, and standby control circuit.



### Figure 2-2 System Clock Control Circuit

#### 2.1.4.1 On-Chip Oscillator

The On-Chip Oscillator the fundamental clock which serves as the reference for the system clocks supplied to the CPU core and peripheral hardware units.

The frequency clock (frequency fc) be fixed at 20MHz, and it is changed by temperature or many years past.

Measurement of the oscillation frequency

Note: Although no hardware functions are provided that allow the fundamental clock to be monitored directly from the outside, the oscillation frequency can be measured by forwarding the pulse of a fixed frequency (e.g., clock output) to a port and monitoring it in a program while interrupts and the watchdog timer are disabled. For systems that require adjusting the oscillation frequency, an adjustment program must be created beforehand.

#### 2.1.4.2 Timing Generator

The Timing Generator generates various system clocks from the fundamental clock that are supplied to the CPU core and peripheral hardware units. The Timing Generator has the following functions:

- 1. Generate a divider output (DVO) pulse
- 2. Generate the source clock for the time base timer
- 3. Generate the source clock for the watchdog timer
- 4. Generate the internal source clock for the timer counter
- 5. Generate a warm-up clock when exiting STOP mode

#### (1) Configuration of the Timing Generator

The Timing Generator a 3-stage prescaler, 21-stage dividers, and a machine cycle counter.

When reset and when entering/exiting STOP mode, the prescaler and dividers are cleared to 0.



## TOSHIBA

**Divider Control Register** 



#### 2.1.4.3 Standby Control Circuit

The Standby Control Circuit starts/stops the high-frequency clock oscillator circuit and selects the main system clock. The System Control Registers (SYSCR1, SYSCR2) are used to control operation modes of this circuit. Figure 2-5 shows an operation mode transition diagram, followed by description of the System Control Registers.

#### (1) Single clock mode

Only the high-frequency clock oscillator circuit is used. Because the main system clock is generated from the high-frequency clock, the machine cycle time in single clock mode is 4/fc [s].

1. NORMAL mode

In this mode, the CPU core and peripheral hardware units are operated with the high-frequency clock. The TMP88F846UG enters this NORMAL mode after reset.

2. IDLE mode

In this mode, the CPU and watchdog timer are turned off while the peripheral hardware units are operated with the high-frequency clock. IDLE mode is entered into by using System Control Register 2. The device is placed out of this mode and back into NORMAL mode by an interrupt from the peripheral hardware or an external interrupt. When IMF (interrupt master enable flag) = 1 (interrupt enabled), the device returns to normal operation after the interrupt has been serviced. When IMF = 0 (interrupt disabled), the device restarts execution beginning with the instruction next to one that placed it in IDLE mode.

3. STOP mode

The entire system operation including the oscillator circuit is halted, retaining the internal state immediately before being stopped, with a minimal amount of power consumed.

STOP mode is entered into by using System Control Register 1, and is exited by  $\overline{\text{STOP}}$  pin input (level or edge selectable). After an elapse of the warm-up time, the device restarts execution beginning with the instruction next to one that placed it in STOP mode.



Table 2-1 Single Clock Mode



## TOSHIBA

R/W

R/W

R/W

#### System Control Register 1

7

STOP

6

RELM

SYSCR1 (0038H) 
 5
 4
 3
 2
 1
 0

 RETM
 OUTEN
 WUT
 (Initial value: 0000 00\*\*)

| STOP  | Place the device in STOP mode                                        |    | the CPU core and peripheral hard<br>he CPU core and peripheral hard                             |                         |   |
|-------|----------------------------------------------------------------------|----|-------------------------------------------------------------------------------------------------|-------------------------|---|
| RELM  | Select method by which the de-<br>vice is released from STOP<br>mode |    | 0: Released by a rising edge on STOP pin input<br>1: Released by a high level on STOP pin input |                         |   |
| RETM  | Select operation mode after ex-<br>iting STOP mode                   |    | D: Returns to NORMAL mode                                                                       |                         |   |
| OUTEN | Select port output state during STOP mode                            |    | 0: High-impedance state<br>1: Hold output                                                       |                         |   |
|       |                                                                      |    | When Returning                                                                                  | to NORMAL Mode          | 1 |
|       |                                                                      |    | DV1CK = 0                                                                                       | DV1CK = 1               | 1 |
| WUT   | Unit of warm-up time when ex-<br>iting STOP mode                     | 00 | 3 × 2 <sup>16</sup> /fc                                                                         | 3 × 2 <sup>17</sup> /fc | 1 |
|       |                                                                      | 01 | 216/fc                                                                                          | 2 <sup>17</sup> /fc     |   |
|       |                                                                      | 10 | 2 <sup>14</sup> /fc                                                                             | 215/fc                  |   |
|       |                                                                      | 11 | Reserved                                                                                        | Reserved                |   |

Note 1: When entering from NORMAL mode into STOP mode, always be sure to set SYSCR1<RETM> to 0.

Note 2: When the device is released from STOP mode by RESET pin input, it always returns to NORMAL mode regardless of how SYSCR1<RETM> is set.

Note 3: fc: High-frequency clock [Hz], \*: Don't care

Note 4: The values of the SYSCR1 Register bits 1 and 0 are indeterminate when read.

- Note 5: When placed the device in STOP mode, make sure to set "1" to SYSCR1<OUTEN>.
- Note 6: Releasing the device from the STOP mode causes the STOP bit to be automatically cleared to "0".
- Note 7: Select an appropriate value for the warm-up time according to the characteristic of the resonator used.

#### System Control Register 2 7 5 6 л 0 SYSCR2 (0039H) XEN 0 SYSCK IDLE (Initial value: 1000 \*\*\*\*) 0: Stop oscillation Control high-frequency oscilla-XEN tor 1: Continue or start oscillating 0: High-frequency clock (NORMAL/IDLE) Select (write)/monitor (read) SYSCK system clock 1: Reserved

| Place the de | vice in IDLE mode | 0: Keep the CPU and WDT of<br>1: Stop the CPU and WDT (I |        | itered) |  |
|--------------|-------------------|----------------------------------------------------------|--------|---------|--|
| RETM         | Operation Mode a  | after Releasing STOP Mode                                | XEN    | SYSCK   |  |
| 0            | NORMAL mode       |                                                          | 1<br>0 | 0       |  |

Note 1: When exiting STOP mode, SYSCR2<XEN and SYSCK> are automatically rewritten according to SYSCR1<RETM>.

- Note 2: When SYSCR2<XEN> is cleared to 0, the device is reset.
- Note 3: WDT: Watchdog Timer, \*: Don't care

Note 4: Be sure to write "0" to SYSCR2 Register bit6.

- Note 5: The values of the SYSCR2 Register bits 3 to 0 are indeterminate when read.
- Note 6: Change the operation mode after disabling external interrupts. If interrupts are enabled after changing operation mode, clear interrupt latches as appropriate in advance.

#### 2.1.4.4 Controlling Operation Modes

#### (1) STOP mode

STOP mode is controlled by System Control Register 1 (SYSCR1) and the  $\overline{\text{STOP}}$  pin input. The  $\overline{\text{STOP}}$  pin is shared with P20 port and  $\overline{\text{INT5}}$  (external interrupt input 5). STOP mode is entered into by setting STOP (SYSCR1 Register bit 7) to 1. During STOP mode, the device retains the following state.

- 1. Stop oscillation, thereby stopping operation of all internal circuits.
- 2. The data memory, register, program status word, and port output latch hold the state in which they were immediately before entering STOP mode.
- 3. Clear the prescaler and divider for the timing generator to 0.
- 4. The program counter holds the instruction address two instructions ahead the one that placed the device in STOP mode (e.g., "SET (SYSCR1).7").

The device is released from STOP mode by the active level or edge on STOP pin input as selected by SYSCR1<RELM>.

Note: Before entering STOP mode, be sure to disable interrupts. This is because if the signal on an external interrupt pin changes state during STOP (from entering STOP mode till completion of warm-up) the interrupt latch is set to 1, so that the device may accept the interrupt immediately after exiting STOP mode. Also, when enabling interrupts after exiting STOP mode, be sure to clear the unnecessary interrupt latches beforehand.

a. <u>Released by level</u> (when RELM = 1)

The device is released from STOP mode by a high level on STOP pin input.

Any instruction to place the device in STOP mode is ignored when executed while  $\overline{\text{STOP}}$  pin input level is high, and the device immediately goes to a release sequence (warm-up) without entering STOP mode. Therefore, before STOP mode can be entered while RELM = 1, the  $\overline{\text{STOP}}$  pin input must be verified to be low in a program. There are following methods to do this verification.

- 1. Testing the port status
- 2. INT5 interrupt (interrupt generated at a falling edge on INT5 pin input)

Example 1 :Entering STOP mode from NORMAL mode by testing P20 port

|                        | ~           |                     |                                                          |
|------------------------|-------------|---------------------|----------------------------------------------------------|
| $\langle \rangle$      | LD          | (SYSCR1), 01010000B | ; Select to be released from STOP mode by level          |
| SSTOPH :               | TEST        | (P2DR) 0            | ; Wait until $\overline{\text{STOP}}$ pin input goes low |
|                        | JRS         | F, SSTOPH           |                                                          |
| $\langle (()) \rangle$ | DI          |                     | ; IMF ← 0                                                |
|                        | SET         | (SYSCR1).7          | ; Place the device in STOP mode                          |
| $\langle \rangle$      | $(\bigcirc$ |                     |                                                          |

Example 2 Entering STOP mode from NORMAL mode by INT5 interrupt

| PINT5   | TEST | (P2DR) . 0          | ; Do not enter STOP mode if P20 port input level is |
|---------|------|---------------------|-----------------------------------------------------|
|         |      |                     | ; high, to eliminate noise                          |
|         | JRS  | F, SINT5            | ; Do not enter STOP mode if P20 port input level is |
|         |      |                     | ; high, to eliminate noise                          |
|         | LD   | (SYSCR1), 01010000B | ; Select to be released from STOP mode by level     |
|         | DI   |                     | ; IMF ← 0                                           |
|         | SET  | (SYSCR1).7          | ; Place the device in STOP mode                     |
| SINT5 : | RETI |                     |                                                     |
|         |      |                     |                                                     |



### Figure 2-6 Released from STOP Mode by Level

- Note 1: Once warm-up starts, the device does not return to STOP mode even when the STOP pin input is pulled low again.
- Note 2: If RELM is changed to 1 (level mode) after being set to 0 (edge mode), STOP mode remains unchanged unless a rising edge on STOP pin input is detected.
  - a. <u>Released by edge</u> (when RELM = 0)

The device is released from STOP mode by a rising edge on  $\overline{\text{STOP}}$  pin input. This method is used in applications where a relatively short time of program processing is repeated at certain fixed intervals. Apply a fixed-period signal (e.g., clock from the low-power oscillating source) to the  $\overline{\text{STOP}}$  pin. When RELM = 0 (edge mode), the device is placed in STOP mode even when the  $\overline{\text{STOP}}$  pin input level is high.

Example : Entering STOP mode from NORMAL mode



The device is released from STOP mode following the sequence described below.

- 1. Only the high-frequency oscillator is oscillating.
- 2. A warm-up time is inserted in order to allow for the clock oscillation to stabilize. During warmup, the internal circuits remain idle. The warm-up time can be selected from three choices according to the oscillator characteristics by using SYSCR1<WUT>.
- 3. After an elapse of the warm-up time, the device restarts normal operation beginning with the instruction next to one that placed it in STOP mode. At this time, the prescaler and divider for the timing generator start from the zero-cleared state.

|   |     | Warm-up           | )         |                                   |
|---|-----|-------------------|-----------|-----------------------------------|
|   | WUT | When Returning to |           |                                   |
|   |     | DV1CK = 0         | DV1CK = 1 |                                   |
|   | 00  | 9.831             | 19.662    |                                   |
|   | 01  | 3.277             | 6.554     | $\Diamond (0) \widehat{\diamond}$ |
|   | 10  | 0.819             | 1.638     |                                   |
|   | 11  | Reserved          | Reserved  |                                   |
| 1 |     |                   |           |                                   |

Table 2-2 Warm-up Time (Example: fc = 20 MHz)

Note: Because the warm-up time is obtained from the fundamental clock by dividing it, if the oscillation frequency fluctuates while exiting STOP mode, the warm-up time becomes to have some error. Therefore, the warm-up time must be handled as an approximate value.

The device can also be released from STOP mode by <u>pulling</u> the <u>RESET</u> pin input low, in which case the device is immediately reset as is normally reset by <u>RESET</u>. After reset, the device starts operating from NORMAL mode.

Note: When exiting STOP mode while the device is retained at low voltage, the following caution is required.

Before exiting STOP mode, the power supply voltage must be raised to the operating voltage. At this time, the RESET pin level also is high and rises along with the power supply voltage. If the device has a time-constant circuit added external to the chip, the voltage on RESET pin input does not rise as fast as the power supply voltage. Therefore, if the voltage level on RESET pin input is below the RESET pin's noninverted, high-level input voltage (hysteresis input), the device may be reset.



Figure 2-8 Entering and Exiting STOP Mode (when DV1CK = 0)

#### (2) IDLE mode

IDLE mode is controlled by System Control Register 2 (SYSCR2) and a maskable interrupt. During IDLE mode, the device retains the following state.

1. The CPU and watchdog timer stop operating.

The peripheral hardware continues operating.

- 2. The data memory, register, program status word, and port output latch hold the state in which they were immediately before entering IDLE mode.
- 3. The program counter holds the instruction address two instructions ahead the one that placed the device in IDLE mode.

#### Example :Placing the device in IDLE mode



The device can be released from IDLE mode normally or by an interrupt as selected with the interrupt master enable flag (IMF).

a. <u>Released normally</u> (when IMF = 0)

The device can be released from IDLE mode by the interrupt source enabled by the interrupt individual enable flag (EF), and restarts execution beginning with the instruction next to one that placed it in IDLE mode. The interrupt latch (IL) for the interrupt source used to exit IDLE mode normally needs to be cleared to 0 using a load instruction.

b. <u>Released by interrupt</u> (when IMF = 1)

The device can be released from IDLE mode by the interrupt source enabled by the interrupt individual enable flag (EF), and enters interrupt handling. After interrupt handling, the device returns to the instruction next to one that placed it in IDLE mode.

The device can also be released from IDLE mode by pulling the RESET pin input low, in which case the device is immediately reset as is normally reset by RESET. After reset, the device starts operating from NORMAL mode.

Note: If a watchdog timer interrupt occurs immediately before entering IDLE mode, the device processes the watchdog timer interrupt without entering IDLE mode. 2.1



Figure 2-10 Entering and Exiting IDLE Mode

#### 2.1.5 Reset Circuit

The TMP88F846UG has seven ways to generate a reset: external reset input, address trap reset, watchdog timer reset, system clock reset, voltage detect reset, power on reset and trimming data reset.

Table 2-3 shows how the internal hardware is initialized by reset operation.

At power-on time, the internal cause reset circuits (watchdog timer reset, address trap reset, and system clock reset) are not initialized.

The power-on reset signal and trimming data reset signal are input to the power-on warming-up reset circuit, which causes the device to enter a reset state. After the power-on warming-up time (tPOWUP) has elapsed, the reset is released. For details, refer to the section on the power-on reset circuit.

|  | Table 2-3 Internal Hardware Initialization by | Reset Operation |
|--|-----------------------------------------------|-----------------|
|--|-----------------------------------------------|-----------------|

| Internal Hardware                                     | Initial Value      | Internal Hardware                     | Initial Value                                    |  |
|-------------------------------------------------------|--------------------|---------------------------------------|--------------------------------------------------|--|
| Program Counter (PC)                                  | (FFFFEH to FFFFCH) | , , , , , , , , , , , , , , , , , , , |                                                  |  |
| Stack Pointer (SP)                                    | Not initialized    | Prescaler and divider for the         | <b>0</b>                                         |  |
| General-purpose Registers<br>(W, A, B, C, D, E, H, L) | Not initialized    | timing generator                      |                                                  |  |
|                                                       |                    |                                       |                                                  |  |
| Register Bank Selector (RBS)                          | 0                  | Watchdog timer                        | Enable                                           |  |
| Jump Status Flag (JF)                                 | 1 20               |                                       |                                                  |  |
| Zero Flag (ZF)                                        | Not initialized    |                                       |                                                  |  |
| Carry Flag (CF)                                       | Not initialized    | Output latch of input/output port     | See description of<br>each input/output<br>port. |  |
| Half Carry Flag (HF)                                  | Not initialized    |                                       |                                                  |  |
| Sign Flag (SF)                                        | Not initialized    |                                       |                                                  |  |
| Overflow Flag (VF)                                    | Not initialized    |                                       |                                                  |  |
| Interrupt Master Enable Flag (IMF)                    | 0                  |                                       |                                                  |  |
| Interrupt Individual Enable Flag (EF)                 | ~ <u> </u>         |                                       | See description of                               |  |
| Interrupt Latch (IL)                                  | 0                  | Control register                      | each control<br>register.                        |  |
| Interrupt Nesting Flag (INF)                          | 0                  | RAM                                   | Not initialized                                  |  |
|                                                       |                    | 7.                                    |                                                  |  |

#### 2.1.5.1 External Reset Input

The  $\overline{\text{RESET}}$  pin is a hysteresis input with a pull-up resistor included. By holding the  $\overline{\text{RESET}}$  pin low for at least three machine cycles (12/fc [s]) or more while the power supply voltage is within the rated operating voltage range and the oscillator is oscillating stably, the device is reset and its internal state is initialized.

When the  $\overline{\text{RESET}}$  pin input is released back high, the device is freed from reset and starts executing the program beginning with the vector address stored at addresses FFFFCH to FFFFEH.



## 2.1.5.2

If the CPU should start looping for reasons of noise, etc. and attempts to fetch instructions from the internal RAM,SFR or DBR area, the device generates an internal reset.

The address trap permission/prohibition is set by the address trap reset control register (ATAS,ATKEY). The address trap is permitted initially and the internal reset is generated by fetching from internal RAM,SFR or DBR area. If the address trap is prohibited, instructions in the internal RAM area can be executed.



Note:Read-modify-write instructions, such as a bit manipulation, cannot access ATAS or ATKEY register because these register are write only.

- Note 1: In development tools, address trap cannot be prohibited in the internal RAM,SFR or DBR area with the address trap control registers. When using development tools, even if the address trap permission/prohibition setting is changed in the user's program, this change is ineffective. To execute instructions from the RAM area, development tools must be set accordingly.
- Note 2: While the SWI instruction at an address immediately before the address trap area is executing, the program counter is incremented to point to the next address in the address trap area; an address trap is therefore taken immediately.

Development tool setting

- To prohibit the address trap:
  - 1. Modify the iram (mapping attribute) area to (00040H to 000BFH) in the memory map window.
  - 2. Set 000C0H to "address trap prohibition area" as a new eram (mapping attribute) area.
  - 3. Load the user program
  - 4. Execute the address trap prohibition code in the user's program

#### 2.1.5.3 Watchdog Timer Reset

Refer to the Section "Watchdog Timer."

#### 2.1.5.4 System Clock Reset

When SYSCR2<XEN> is cleared to 0 or when SYSCR2<XEN> is cleared to 0 while SYSCR2<SYSCK> = 0, the system clock is turned off, causing the CPU to become locked up. To prevent this problem, upon detecting SYSCR2<XEN> = 0, SYSCR2<XEN> = SYSCR2<SYSCK> = 0 or SYSCR2<SYSCK> = 1, the device automatically generates an internal reset signal to let the system clock continue oscillating.

#### 2.1.5.5 Voltage detection reset

A voltage detection reset is generated internally when the supply voltage (VDD) falls below the predefined detection voltage.

Refer to Section "Voltage detection circuit".

#### 2.1.5.6 Power-on Reset

A power-on reset is generated internally when the supply voltage (VDD) is turned on.

Refer to Section "Power on reset".

#### 2.1.5.7 Trimming data reset

Trimming data bits are provided for adjusting the ladder resistor used to generate the reference voltages for the power-on reset signal and voltage detecting signal. These bits are read from the flash memory and latched internally during the power-on warming up period (tPOWUP). The trimming data reset is generated if the trimming data is corrupted due to noise or other causes.
# 3. Interrupt Control Circuit

The TMP88F846UG has a total of 26 interrupt sources excluding reset. Interrupts can be nested with priorities. Two of the internal interrupt sources are pseudo non-maskable while the rest are maskable.

Interrupt sources are provided with interrupt latches (IL), which hold interrupt requests, and independent vectors. The interrupt latch is set to "1" by the generation of its interrupt request which requests the CPU to accept its interrupts. Interrupts are enabled or disabled by software using the interrupt master enable flag (IMF) and interrupt enable flag (EF). If more than one interrupts are generated simultaneously, interrupts are accepted in order which is dominated by hardware. However, there are no prioritized interrupt factors among non-maskable interrupts.

|                     | Interrupt Factors                            | Enable Condition                 | Interrupt<br>Latch | Vector Ad-<br>dress | Priority     |
|---------------------|----------------------------------------------|----------------------------------|--------------------|---------------------|--------------|
| Internal/External   | (Reset)                                      | Non-maskable                     | - /                | FFFFC               | High 0       |
| Internal            | INTSWI (Software interrupt)                  | Pseudo non-maskable              | - 🗸 (              | FEFE8               | 1            |
| Internal            | INTWDT (Watchdog timer interrupt)            | Pseudo non-maskable              | IL2                | FFFF4               | 2            |
| External            | INT0 (External interrupt 0)                  | IMF • EF3 = 1, INT0EN = 1        | IL3                | FFFF0               | 3            |
| -                   | Reserved                                     | IMF · EF4=1                      | NL4_               | FFFEC               | 4            |
| External            | INT1 (External interrupt 1)                  | IMF • EF5 = 1                    | 115                | FFFE8               | 5            |
| Internal            | INTTBT (TBT interrupt)                       | IMF · EF6 = 1                    | IL6                | FFFE4               | 6            |
| -                   | Reserved                                     | IMF EF7 = 1                      | <u> </u>           | FFFE0               | 7            |
| Internal            | INTEMG1 (ch1 Error detect interrupt)         | IMF · EF8 = 1                    | IL8                | FFFDC               | 8            |
| -                   | Reserved                                     | IMF · EF9 = 1                    | IL9                | FFFD8               | 9            |
| Internal            | INTCLM1 (ch1 Overload protection interrupt)  | IMF · EF10=1                     | IL10               | FFFD4               | 10           |
| -                   | Reserved                                     | IMF • EF11 = 1                   | IL11               | FFFD0               | 11           |
| Internal            | INTTMR31 (ch1 Timer 3 interrupt)             | IMF · EF12 = 1                   | IL12               | FFFCC               | 12           |
| -                   | Reserved                                     | IMF • EF13 = 1                   | IL13               | FFFC8               | 13           |
| -                   | Reserved                                     | IMF • EF14 = 1                   | IL14               | FFFC4               | 14           |
| External            | INT5 (External interrupt 5)                  | JMF · EF15 = 1                   | IL15               | FFFC0               | 15           |
| Internal            | INTPDC1 (ch1 Position detect interrupt)      | IMF • EF16 = 1                   | IL16               | FFFBC               | 16           |
| _                   | Reserved                                     | IME • EF17 = 1                   | IL17               | FFFB8               | 17           |
| Internal            | INTPWM1 (ch1 Waveform generator interrupt)   | IMF • EF18 = 1                   | IL18               | FFFB4               | 18           |
| -                   | Reserved                                     | IMF • EF19 = 1                   | IL19               | FFFB0               | 19           |
| Internal            | INTEDT1 (ch1 Electric angle Timer interrupt) | IMF • EF20 = 1                   | IL20               | FFFAC               | 20           |
| -                   | Reserved                                     | IMF • EF21 = 1                   | IL21               | FFFA8               | 21           |
| Internal            | INTTMR11 (ch1 Timer1 interrupt)              | IMF • EF22 = 1                   | IL22               | FFFA4               | 22           |
|                     | Reserved                                     | IMF • EF23 = 1                   | IL23               | FFFA0               | 23           |
| Internal            | INTTMR21 (ch1 Timer2 interrupt)              | IMF • EF24 = 1                   | IL24               | FFF9C               | 24           |
| - (                 | Reserved                                     | IMF • EF25 = 1                   | IL25               | FFF98               | 25           |
| Internal            | INTTC1 (TC1 interrupt)                       | IMF • EF26 = 1                   | IL26               | FFF94               | 26           |
| Internal            | INTCTC1 (CTC interrupt)                      | IMF • EF27 = 1                   | IL27               | FFF90               | 27           |
| $\langle - \rangle$ | Reserved                                     | IMF • EF28 = 1                   | IL28               | FFF8C               | 28           |
| External            | INT2 (External interrupt 2)                  | IMF • EF29 = 1                   | IL29               | FFF88               | 29           |
| External            | INT3 (External interrupt 3)                  | IMF • EF30 = 1                   | IL30               | FFF84               | 30           |
| External            | INT4 (External interrupt 4)                  | IMF • EF31 = 1                   | IL31               | FFF80               | 31           |
| Internal            | INTRX (UART receive interrupt)               | IMF • EF32 = 1                   | IL32               | FFF3C               | 32           |
| Internal            | INTTX (UART transmit interrupt)              | IMF • EF33 = 1                   | IL33               | FFF38               | 33           |
| Internal            | INTSIO (SIO interrupt)                       | IMF • EF34 = 1                   | IL33               | FFF34               | 34           |
| Internal            | INTTC3 (TC3 interrupt)                       | IMF • EF35= 1                    | IL34               | FFF34<br>FFF30      | 35           |
| Internal            | INTTC4 (TC4 interrupt)                       | IMF • EF36 = 1                   | IL35               | FFF30<br>FFF2C      | 36           |
| -                   | Reserved                                     | IMF • EF37 = 1                   | IL30               | FFF20<br>FFF28      | 30           |
| -                   | INTADC (A/D converter interrupt)             | IMF • EF37 = 1<br>IMF • EF38 = 1 |                    |                     |              |
| Internal            | INTADC (A/D converter interrupt)             | IMF • EF38 = 1<br>IMF • EF39 = 1 | IL38<br>IL39       | FFF24<br>FFF20      | 38<br>Low 39 |

Note 1: To use the watchdog timer interrupt (INTWDT), clear WDTCR1<WDTOUT> to "0" (It is set for the "Reset request" after reset is released). It is described in the section "Watchdog Timer" for details.

### 3.1 Interrupt latches (IL39 to IL2)

An interrupt latch is provided for each interrupt source, except for a software interrupt and an executed the undefined instruction interrupt. When interrupt request is generated, the latch is set to "1", and the CPU is requested to accept the interrupt if its interrupt is enabled. The interrupt latch is cleared to "0" immediately after accepting interrupt. All interrupt latches are initialized to "0" during reset.

The interrupt latches are located on address 003CH, 003DH, 002EH, 002FH and 002BH in SFR area. Each latch can be cleared to "0" individually by instruction. However, IL2 and IL3 should not be cleared to "0" by software. For clearing the interrupt latch, load instruction should be used and then IL2 should be set to "1". If the read-modify-write instructions such as bit manipulation or operation instructions are used, interrupt request would be cleared inadequately if interrupt is requested while such instructions are executed.

Since interrupt latches can be read, the status for interrupt requests can be monitored by software. But interrupt latches are not set to "1" by an instruction.

Note: In main program, before manipulating the interrupt enable flag (EF) or the interrupt latch (IL), be sure to clear IMF to "0" (Disable interrupt by DI instruction). Then set IMF newly again as required after operating on the EF or IL (Enable interrupt by EI instruction)

In interrupt service routine, because the IMF becomes "0" automatically, clearing IMF need not execute normally on interrupt service routine. However, if using multiple interrupt on interrupt service routine, manipulating EF or IL should be executed before setting IMF="1".

Example 1 :Clears interrupt latches DI ; IMF ← 0 (ILL), 0000000B LD ; IL2 to IL7  $\leftarrow$  0 (ILH), 0000000B ; IL8 to IL15 ← 0 LD (ILE), 00000000B ; IL16 to IL23 ← 0 LD LØ (ILD), 00000000B IL24 to IL31 ← 0 ĿÓ (ILC), 00000000B ; IL32 to IL39 ← 0 ; IMF ← 1 EÌ Example 2 :Reads interrupt latches WA, (ILL) ; W  $\leftarrow$  (ILH), A  $\leftarrow$  (ILL) ĹD BC, (ILE) LD ;  $B \leftarrow (ILD), C \leftarrow (ILE)$ D, (ILC) D ; D  $\leftarrow$  (ILC) Example 3 : Tests interrupt latches TEST (ILL). 7 ; if IL7 = 1 then jump F, SSET JR

### 3.2 Interrupt enable register (EIR)

The interrupt enable register (EIR) enables and disables the acceptance of interrupts, except for the pseudo nonmaskable interrupts (Software interrupt, undefined instruction interrupt, address trap interrupt and watchdog interrupt). Pseudo non-maskable interrupt is accepted regardless of the contents of the EIR.

The EIR consists of an interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). These registers are located on address 003AH, 003BH, 002CH, 002DH and 002AH in SFR area, and they can be read and written by an instructions (Including read-modify-write instructions such as bit manipulation or operation instructions).

#### 3.2.1 Interrupt master enable flag (IMF)

The interrupt enable register (IMF) enables and disables the acceptance of the whole maskable interrupt. While IMF = "0", all maskable interrupts are not accepted regardless of the status on each individual interrupt enable flag (EF). By setting IMF to "1", the interrupt becomes acceptable if the individuals are enabled.

When an interrupt is accepted, IMF is cleared to "0" after the latest status on IMF is stacked. Thus the maskable interrupts which follow are disabled temporarily. IMF flag is set to "1" by the maskable interrupt return instruction [RETI] after executing the interrupt service program routine, and MCU can accept the interrupt again. The latest interrupt request is generated already, it is available immediately after the [RETI] instruction is executed.

On the pseudo non-maskable interrupt, the non-maskable return instruction [RETN] is adopted. In this case, IMF flag is set to "1" only when it performs the pseudo non-maskable interrupt service routine on the interrupt acceptable status (IMF=1). However, IMF is set to "0" in the pseudo non-maskable interrupt service routine, it maintains its status (IMF="0").

The IMF is located on bit0 in EIRL (Address: 003AH in SFR), and can be read and written by an instruction. The IMF is normally set and cleared by [EI] and [DI] instruction respectively. During reset, the IMF is initialized to "0".

#### 3.2.2 Individual interrupt enable flags (EF39 to EF3)

Each of these flags enables and disables the acceptance of its maskable interrupt. Setting the corresponding bit of an individual interrupt enable flag to "1" enables acceptance of its interrupt, and setting the bit to "0" disables acceptance. During reset, all the individual interrupt enable flags (EF39 to EF3) are initialized to "0" and all maskable interrupts are not accepted until they are set to "1".

Note: In main program, before manipulating the interrupt enable flag (EF) or the interrupt latch (IL), be sure to clear IMF to "0" (Disable interrupt by DI instruction). Then set IMF newly again as required after operating on the EF or IL (Enable interrupt by El instruction)

In interrupt service routine, because the IMF becomes "0" automatically, clearing IMF need not execute normally on interrupt service routine. However, if using multiple interrupt on interrupt service routine, manipulating EF or IL should be executed before setting IMF="1".

Example : Enables interrupts individually and sets IMF

| / ~ |            |                      |
|-----|------------|----------------------|
| DI  |            | ; IMF $\leftarrow$ 0 |
| SET | (EIRL), .5 | ; EF5 ← 1            |
| CLR | (EIRL), .6 | ; EF6 ← 0            |
| CLR | (EIRH), .4 | ; EF12 ← 0           |
| CLR | (EIRD), .0 | ; EF24 ← 0           |
| :   |            |                      |
| El  |            | ; IMF $\leftarrow$ 1 |
|     |            |                      |



#### Interrupt Latches

Note 1: IL2 cannot alone be cleared.

- Note 2: Unable to detect the under-flow of counter.
- Note 3: The nesting counter is set "0" initially, it performs count-up by the interrupt acceptance and count-down by executing the interrupt return instruction.
- Note 4: In main program, before manipulating the interrupt enable flag (EF) or the interrupt latch (IL), be sure to clear IMF to "0" (Disable interrupt by DI instruction). Then set IMF newly again as required after operating on the EF or IL (Enable interrupt by EI instruction)

In interrupt service routine, because the IMF becomes "0" automatically, clearing IMF need not execute normally on interrupt service routine. However, if using multiple interrupt on interrupt service routine, manipulating EF or IL should be executed before setting IMF="1".

Note 5: Do not clear IL with read-modify-write instructions such as bit operations.

#### Interrupt Enable Registers



Note 1: Do not set IMF and the interrupt enable flag (EF39 to EF3) to "1" at the same time.

Note 2: In main program, before manipulating the interrupt enable flag (EF) or the interrupt latch (IL), be sure to clear IMF to "0" (Disable interrupt by DI instruction). Then set IMF newly again as required after operating on the EF or IL (Enable interrupt by EI instruction)

In interrupt service routine, because the IMF becomes "0" automatically, clearing IMF need not execute normally on interrupt service routine. However, if using multiple interrupt on interrupt service routine, manipulating EF or IL should be executed before setting IMF="1".

Page 31

### 3.3 Interrupt Sequence

An interrupt request, which raised interrupt latch, is held, until interrupt is accepted or interrupt latch is cleared to "0" by resetting or an instruction. Interrupt acceptance sequence requires 12 machine cycles ( $2.4 \ \mu s \ @20 \ MHz$ ) after the completion of the current instruction. The interrupt service task terminates upon execution of an interrupt return instruction [RETI] (for maskable interrupts) or [RETN] (for non-maskable interrupts). Figure 3-1 shows the timing chart of interrupt acceptance processing.

#### 3.3.1 Interrupt acceptance processing is packaged as follows;

- a. The interrupt master enable flag (IMF) is cleared to "0" in order to disable the acceptance of any following interrupt.
- b. The interrupt latch (IL) for the interrupt source accepted is cleared to "0".
- c. The contents of the program counter (PC) and the program status word, including the interrupt master enable flag (IMF), are saved (Pushed) on the stack in sequence of PSWH, PSWL, PCE, PCH, PCL. Meanwhile, the stack pointer (SP) is decremented by 5.
- d. The entry address (Interrupt vector) of the corresponding interrupt service program, loaded on the vector table, is transferred to the program counter.
- e. Read the RBS control code from the vector table, add its MSB(4bit) to the register bank selector (RBS).
- f. Count up the interrupt nesting counter.
- g. The instruction stored at the entry address of the interrupt service program is executed.

Note: When the contents of PSW are saved on the stack, the contents of IMF are also saved.



Note 1: a: Return address, b: Entry address, c: Address which RETI instruction is stored

Note 2: On condition that interrupt is enabled, it takes 62/fc [s] at maximum (If the interrupt latch is set at the first machine cycle on 15 cycle instruction) to start interrupt acceptance processing since its interrupt latch is set.

## Figure 3-1 Timing Chart of Interrupt Acceptance/Return Interrupt Instruction

Example: Correspondence between vector table address for INTTBT and the entry address of the interrupt service program



Figure 3-2 Vector table address, Entry address

A maskable interrupt is not accepted until the IMF is set to "1" even if the maskable interrupt higher than the level of current servicing interrupt is requested.

In order to utilize nested interrupt service, the IMF is set to "1" in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags. But don't use the read-modify-write instruction for EIRL(0003AH) on the pseudo non-maskable interrupt service task.

To avoid overloaded nesting, clear the individual interrupt enable flag whose interrupt is currently serviced, before setting IMF to "1". As for non-maskable interrupt, keep interrupt service shorten compared with length between interrupt requests; otherwise the status cannot be recovered as non-maskable interrupt would simply nested.

#### 3.3.2 Saving/restoring general-purpose registers

During interrupt acceptance processing, the program counter (PC) and the program status word (PSW, includes IMF) are automatically saved on the stack, but the accumulator and others are not. These registers are saved by software if necessary. When multiple interrupt services are nested, it is also necessary to avoid using the same data memory area for saving registers. The following four methods are used to save/restore the general-purpose registers.

#### 3.3.2.1 Using Automatic register bank switching

By switching to non-use register bank, it can restore the general-purpose register at high speed.

Usually the bank register "0" is assigned for main task and the bank register "1 to 15" are for the each interrupt service task. To make up its data memory efficiency, the common bank is assigned for non-multiple interrupt factor.

It can return back to main-flow by executing the interrupt return instructions ([RETI]/[RETN]) from the current interrupt register bank automatically. Thus, no need to restore the RBS by a program.

Example : Register bank switching

| PINT | ox: | (interrupt proces | ssing) | ; Begin of interrupt routine           |
|------|-----|-------------------|--------|----------------------------------------|
|      |     | RETI              |        | ; End of interrupt                     |
|      |     | :                 |        |                                        |
| VINT | x:  | DP                | PINTxx | ; PINTxx vector address setting        |
|      |     | DB                | 1      | ; RBS <- RBS + 1 RBS setting on PINTxx |

#### 3.3.2.2 Using register bank switching

By switching to non-use register bank, it can restore the general-purpose register at high speed. Usually the bank register "0" is assigned for main task and the bank register "1 to 15" are for the each interrupt service task.

3.3 Interrupt Sequence

| PINTxx: | LD           | RBS, n      | ; RBS <- n Begin of interrupt routine                |
|---------|--------------|-------------|------------------------------------------------------|
|         | (interrupt p | processing) |                                                      |
|         | RETI         |             | ; End of interrupt, restore RBS and interrupt return |
|         | :            |             |                                                      |
| VINTxx: | DP           | PINTxx      | ; PINTxx vector address setting                      |
|         | DB           | 0           | ; RBS <- RBS + 0 RBS setting on PINTxx               |

#### Example :Register bank switching

#### 3.3.2.3 Using PUSH and POP instructions

If only a specific register is saved or interrupts of the same source are nested, general-purpose registers can be saved/restored using the PUSH/POP instructions.

Example :Save/store register using PUSH and POP instructions



Figure 3-3 Save/store register using PUSH and POP instructions

3.3.2.4 Using data transfer instructions

To save only a specific register without nested interrupts, data transfer instructions are available.

Example :Save/store register using data transfer instructions



# TOSHIBA



### Figure 3-4 Saving/Restoring General-purpose Registers under Interrupt Processing

### 3.3.3 Interrupt return

Interrupt return instructions [RETI]/[RETN] perform as follows.

|    | [RETI] Maskable Interrupt Return                                                             |    | [RETN] Non-maskable Interrupt Return                                                                                                                                                                                                              |
|----|----------------------------------------------------------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1. | The contents of the program counter and the program status word are restored from the stack. | 1. | The contents of the program counter and the program status word are restored from the stack.                                                                                                                                                      |
| 2. | The stack pointer is incremented 5 times.                                                    | 2. | The stack pointer is incremented 5 times.                                                                                                                                                                                                         |
| 3. | The interrupt master enable flag is set to "1".                                              | 3. | The interrupt master enable flag is set to "1" only when<br>a non-maskable interrupt is accepted in interrupt enable<br>status. However, the interrupt master enable flag re-<br>mains at "0" when so clear by an interrupt service pro-<br>gram. |
| 4. | The interrupt nesting counter is decremented, and the interrupt nesting flag is changed.     | 4. | The interrupt nesting counter is decremented, and the interrupt nesting flag is changed.                                                                                                                                                          |

Interrupt requests are sampled during the final cycle of the instruction being executed. Thus, the next interrupt can be accepted immediately after the interrupt return instruction is executed.

Note: When the interrupt processing time is longer than the interrupt request generation time, the interrupt service task is performed but not the main task.

### 3.4 Software Interrupt (INTSW)

Executing the SWI instruction generates a software interrupt and immediately starts interrupt processing (INTSW is highest prioritized interrupt). However, if processing of a non-maskable interrupt is already underway, executing the SWI instruction will not generate a software interrupt but will result in the same operation as the NOP instruction.

Use the SWI instruction only for detection of the address error or for debugging.

#### 3.4.1 Address error detection

FFH is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address during single chip mode. Code FFH is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing FFH to unused areas of the program memory. Address trap reset is generated in ease that an instruction is fetched from RAM, DBR or SFR areas.

#### 3.4.2 Debugging

Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address.

### 3.5 External Interrupts

The TMP88F846UG has 6 external interrupt inputs. These inputs are equipped with digital noise reject circuits (Pulse inputs of less than a certain time are eliminated as noise).

Edge selection is also possible with INT1 to INT4. The INT0/P10 pin can be configured as either an external interrupt input pin or an input/output port, and is configured as an input port during reset.

Edge selection, and noise reject control and INT0/P10 pin function selection are performed by the external interrupt control register (EINTCR).

|        |             |          |                      | $\sim$               |                                                                                                                                                                             |
|--------|-------------|----------|----------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source | Pin         | Sub-Pin  | Enable Conditions    | Release Edge (level) | Digital Noise Reject                                                                                                                                                        |
| INTO   | <b>INTO</b> | P10      | IMF + EF3 + INT0EN=1 | Falling edge         | Pulses of less than 2/fc [s] are eliminated as<br>noise. Pulses of 6/fc [s] or more are considered<br>to be signals. (at CGCR <dv1ck>=0).</dv1ck>                           |
| INT1   | INT1        | P11      | IMF + EF5 = 1        | Falling edge         | Pulses of less than 15/fc or 63/fc [s] are elimina-<br>ted as noise. Pulses of 48/fc or 192/fc [s] or more<br>are considered to be signals.<br>(at CGCR <dv1ck>=0).</dv1ck> |
| INT2   | INT2        | P12/TC1  | IMF + EF29 = 1       | Rising edge          | Pulses of less than 7/fc [s] are eliminated as                                                                                                                              |
| INT3   | INT3        | P21/TC3  | IMF + EF30 = 1       |                      | noise. Pulses of 24/fc [s] or more are considered                                                                                                                           |
| INT4   | INT4        | P22/TC4  | IMF + EF31 = 1       | $\square(\bigcirc)$  | to be signals.(at CGCR <dv1ck>=0).</dv1ck>                                                                                                                                  |
| INT5   | INT5        | P20/STOP | IMF + EF15 = 1       | Falling edge         | Pulses of less than 2/fc [s] are eliminated as noise. Pulses of 6/fc [s] or more are considered to be signals.                                                              |

Note 1: In NORMAL or IDLE mode, if a signal with no noise is input on an external interrupt pin, it takes a maximum of "signal establishment time" from the input signal's edge to set the interrupt latch.

(1) INT1 pin 49/fc [s] ( at EINTCR<INT1NC> = "1"), 193/fc [s] ( at EINTCR<INT1NC> = "0")

(2) INT2 to INT4 pins 25/fc [s]

Note 2: When EINTCR<INT0EN> = "0", IL3 is not set even if a falling edge is detected on the INT0 pin input.

Note 3: When a pin with more than one function is used as an output and a change occurs in data or input/output status, an interrupt request signal is generated in a pseudo manner. In this case, it is necessary to perform appropriate processing such as disabling the interrupt enable flag.

#### External Interrupt Control Register

| EINTCR  | 7      | 6      | 5      | 4 | 3      | 2      | 1      | 0 |                            |
|---------|--------|--------|--------|---|--------|--------|--------|---|----------------------------|
| (0037H) | INT1NC | INTOEN | INT4ES |   | INT3ES | INT2ES | INT1ES |   | (Initial value: 0000 000*) |

|  | $\sim$  |                            |                                                                                                                      |     |
|--|---------|----------------------------|----------------------------------------------------------------------------------------------------------------------|-----|
|  | INTINC  | Noise reject time select   | 0: Pulses of less than 63/fc [s] are eliminated as noise<br>1: Pulses of less than 15/fc [s] are eliminated as noise | R/W |
|  | INTOEN  | P10/INTO pin configuration | 0: P10 input/output port<br>1: INT0 pin (Port P10 should be set to an input mode)                                    | R/W |
|  | INT4 ES | INT4 edge select           | 00: Rising edge<br>01: Falling edge<br>10: Rising edge and Falling edge<br>11: H level                               | R/W |
|  | INT3 ES | INT3 edge select           |                                                                                                                      |     |
|  | INT2 ES | INT2 edge select           | 0: Rising edge<br>1: Falling edge                                                                                    | R/W |
|  | INT1 ES | INT1 edge select           |                                                                                                                      |     |

Note 1: fc: High-frequency clock [Hz], \*: Don't care

Note 2: When the external interrupt control register (EINTCR) is overwritten, the noise canceller may not operate normally. It is recommended that external interrupts are disabled using the interrupt enable register (EIR).

Note 3: The maximum time from modifying EINTCR<INT1NC> until a noise reject time is changed is 26/fc.

Note 4: In case RESET pin is released while the state of INT4 pin keeps "H" level, the external interrupt 4 request is not generated even if the INT4 edge select(EINTCR<INT4ES>) is specified as "H" level. The rising edge is needed after RESET pin is released.

- 3. Interrupt Control Circuit
- 3.5 External Interrupts

## 4. Special Function Register

The TMP88F846UG adopts the memory mapped I/O system, and all peripheral control and transfers are performed through the special function register (SFR) or the data buffer register (DBR). The SFR is mapped on address 0000H to 003FH, DBR is mapped on address 1F80H to 1FFFH.

This chapter shows the arrangement of the special function register (SFR) and data buffer register (DBR) for TMP88F846UG.

### 4.1 SFR

| <b></b> |          |                  |  |
|---------|----------|------------------|--|
| Address | Read     | Write            |  |
| 0000Н   | Reserved |                  |  |
| 0001H   | P1DR     |                  |  |
| 0002H   | P2DR     |                  |  |
| 0003H   | P3DR     |                  |  |
| 0004H   | P4DR     |                  |  |
| 0005H   | Reserved |                  |  |
| 0006H   | P6DR     | ( )              |  |
| 0007H   | Reserved | $(\overline{O})$ |  |
| 0008H   | Reserved |                  |  |
| 0009H   | Reserved |                  |  |
| 000AH   | Reserved |                  |  |
| 000BH   | PICR     | //               |  |
| 000CH   | Reserved |                  |  |
| 000DH   | Reserved |                  |  |
| 000EH   | Reserved |                  |  |
| 000FH   | TC1CR    |                  |  |
| 0010H   | TC1DRAL  |                  |  |
| 0011H   | TC1DRAH  |                  |  |
| 0012H   | TC1DRBL  |                  |  |
| 0013H   | TC1DRBH  |                  |  |
| 0014H   | CTC1CR1  |                  |  |
| 0015H   | CTC1CR2  |                  |  |
| 0016H   |          | CTC1DRL          |  |
| 0017H   |          | CTC1DRH          |  |
| 0018H   | Reserved |                  |  |
| 0019Н ( | Reserved |                  |  |
| 001AH   | TC4CR    |                  |  |
| 001BH   | TC4DR    |                  |  |
| 001CH   | TC3DRA   |                  |  |
| 001DH   | TC3DRB   | -                |  |
| 001EH   | TC3CR    |                  |  |
| 001FH   | Reserved |                  |  |
| 0020H   | Reserved |                  |  |
| 0021H   | Reserved |                  |  |
| 0022H   | Reserved |                  |  |
| 0023H   | Reserved |                  |  |
| 0024H   | Reserved |                  |  |
| 0025H   | Reserved |                  |  |

| Address                  | Read   | Write   |
|--------------------------|--------|---------|
| 0026H                    | A      | DCCRA   |
| 0027H                    | A      | DCCRB   |
| 0028H                    | ADCDRL | <hr/>   |
| 0029H                    | ADCDRH |         |
| 002AH                    |        | EIRC    |
| 002BH                    |        | ILC     |
| 002CH                    |        | EIRE    |
| 002DH                    |        | EIRD    |
| 002EH                    |        | ILE     |
| 002FH                    |        | ILD     |
| 0030H                    |        | CGCR    |
| 0031H                    | R      | eserved |
| 0032H                    | R      | eserved |
| 0033H                    | ( R    | eserved |
| 0034H                    | -      | WDTCR1  |
| 0035H                    | 1(     | WDTCR2  |
| 0036H                    |        | TBTCR   |
| 0037H                    | E      |         |
| 0038H                    | s      | SYSCR1  |
| 0039H                    | ş      | YSCR2   |
| 003AH                    |        | EIRL    |
| 003BH                    |        | EIRH    |
| 003CH                    |        | ILL     |
| 003DH                    |        | ILH     |
| 003EH                    |        | PSWL    |
| 003FH                    |        | PSWH    |
| 1: Do not access reserve |        |         |

Note 1: Do not access reserved areas by the program.

Note 2: -; Cannot be accessed.

Note 3: Write-only registers and interrupt latches cannot use the read-modify-write instructions (Bit manipulation instructions such as SET, CLR, etc. and logical operation instructions such as AND, OR, etc.).

## 4.2 DBR

|                      | Address | PMD ch        | Read                              | Write           |
|----------------------|---------|---------------|-----------------------------------|-----------------|
|                      | 1F80H   |               | -                                 | -               |
|                      | 1F81H   |               | -                                 |                 |
|                      | 1F82H   |               | -                                 |                 |
|                      | 1F83H   |               | P3C                               | DE (            |
|                      | 1F84H   |               | P4C                               | DE              |
|                      | 1F85H   |               | 7                                 | $\langle (7/5)$ |
|                      | 1F86H   |               | -                                 |                 |
|                      | 1F87H   |               | -                                 |                 |
|                      | 1F88H   |               |                                   |                 |
|                      | 1F89H   |               | P3                                | 3R              |
|                      | 1F8AH   |               | P4                                |                 |
|                      | 1F8BH   |               |                                   | N <u>5</u>      |
|                      | 1F8CH   |               | P60                               |                 |
|                      | 1F8DH   |               |                                   |                 |
|                      | 1F8EH   |               | $\langle \langle \rangle \rangle$ |                 |
|                      | 1F8FH   |               | ~~~~-                             |                 |
|                      | 1F90H   |               |                                   |                 |
|                      | 1F91H   |               | UARTSR                            | UARTCRA         |
|                      | 1F92H   |               |                                   | UARTCRB         |
|                      | 1F93H   |               | RDBUF                             | TDBUF           |
|                      | 1F94H   |               | $\bigcirc$ - $\bigcirc$           | ATAS            |
|                      | 1F95H   |               | $\bigcirc$ -                      | ATKEY           |
|                      | 1F96H   | (C            | - \                               | SIOCR1          |
|                      | 1F97H   |               | SIOSR                             | SIOCR2          |
|                      | 1F98H   |               | SIO                               | 3R0             |
|                      | 1F99H   | $(\forall ))$ | SIO                               | 3R1             |
|                      | 1F9AH   | $\sum$        | sion                              | BR2             |
|                      | 1F9BH   |               | SIO                               | BR3             |
|                      | 1F9CH   |               | SIO                               | 3R4             |
|                      | 1F9DH   | $\searrow$    | SIO                               | BR5             |
|                      | 1F9EH   |               | SIOI                              | 3R6             |
|                      | 1F9FH   | $\mathcal{D}$ | SIO                               | 3R7             |
|                      | 1FA0H   | for PMD ch.1  | PDC                               | CRA             |
| <                    | 1FA1H   | for PMD ch.1  | PDC                               | RB              |
|                      | 1FA2H   | for PMD ch.1  | PDCRC                             | -               |
| $\overline{\langle}$ | 1FA3H   | for PMD ch.1  | SDF                               | REG             |
|                      | 1FA4H   | for PMD ch.1  | MTC                               | CRA             |
|                      | 1FA5H   | for PMD ch.1  | МТС                               | CRB             |
|                      | 1FA6H   | for PMD ch.1  | MCAPL                             | -               |
|                      | 1FA7H   | for PMD ch.1  | MCAPH                             | -               |
|                      | 1FA8H   | for PMD ch.1  | CMI                               | P1L             |
|                      | 1FA9H   | for PMD ch.1  | CMF                               | Р1Н             |
|                      | 1FAAH   | for PMD ch.1  | CMI                               | P2L             |
|                      | 1FABH   | for PMD ch.1  | CMF                               | P2H             |
|                      | 1FACH   | for PMD ch.1  | CMI                               | P3L             |
|                      | 1FADH   | for PMD ch.1  | CMF                               | P3H             |
|                      | 1FAEH   | for PMD ch.1  | MDC                               |                 |
|                      | 1FAFH   | for PMD ch.1  | MDC                               | CRB             |

| Address | PMD ch                       | Read                    | Write       |  |
|---------|------------------------------|-------------------------|-------------|--|
| 1FB0H   | for PMD ch.1                 | EMG                     | GCRA        |  |
| 1FB1H   | for PMD ch.1                 | EMGCRB                  |             |  |
| 1FB2H   | for PMD ch.1                 | MDC                     | DUTL        |  |
| 1FB3H   | for PMD ch.1                 | MDC                     | ОЛТН        |  |
| 1FB4H   | for PMD ch.1                 | MDCNTL                  |             |  |
| 1FB5H   | for PMD ch.1                 | MDCNTH                  | -           |  |
| 1FB6H   | for PMD ch.1                 | MDF                     | RDL (7/     |  |
| 1FB7H   | for PMD ch.1                 | MDP                     | RDH         |  |
| 1FB8H   | for PMD ch.1                 | CM                      | PUL         |  |
| 1FB9H   | for PMD ch.1                 | CMI                     | PUH         |  |
| 1FBAH   | for PMD ch.1                 | CM                      | RVL         |  |
| 1FBBH   | for PMD ch.1                 | СМІ                     | PVH A       |  |
| 1FBCH   | for PMD ch.1                 | CMI                     |             |  |
| 1FBDH   | for PMD ch.1                 | CMF                     | WH A (O)    |  |
| 1FBEH   | for PMD ch.1                 | DTR                     |             |  |
| 1FBFH   | for PMD ch.1                 |                         | EMGREL      |  |
| 1FC0H   | for PMD ch.1                 | EDO                     |             |  |
| 1FC1H   | for PMD ch.1                 | EDC                     | CRB         |  |
| 1FC2H   | for PMD ch.1                 | EDS                     | SETL (// S) |  |
| 1FC3H   | for PMD ch.1                 | EDS                     | ЕТН         |  |
| 1FC4H   | for PMD ch.1                 | ELD                     | EGL         |  |
| 1FC5H   | for PMD ch.1                 | ELD                     | EGH         |  |
| 1FC6H   | for PMD ch.1                 |                         | IPL         |  |
| 1FC7H   | for PMD ch.1                 | AM                      | IPH         |  |
| 1FC8H   | for PMD ch.1                 | EDCAPL                  | -           |  |
| 1FC9H   | for PMD ch.1                 | EDCAPH                  | -           |  |
| 1FCAH   | for PMD ch.1                 | -                       | WFMDR       |  |
| 1FCBH   | $\bigcirc \bigcirc \bigcirc$ | $\sim$ (7/ $\diamond$ ) | -           |  |
| 1FCCH   |                              | VDCR1                   |             |  |
| 1FCDH   |                              | VDCR2                   |             |  |
| 1FCEH   | $\searrow$                   | Reserved                |             |  |
| to      |                              |                         |             |  |
| 1FFDH   |                              | Reserved                |             |  |
| 1FFEH   | 4                            | SP                      | CR          |  |
| (IRFFH) |                              | FLS                     | SCR         |  |

Note 1: Do not access reserved areas by the program.

Note 2: -; Cannot be accessed.

Note 3: Write-only registers and interrupt latches cannot use the read-modify-write instructions (Bit manipulation instructions such as SET, CLR, etc. and logical operation instructions such as AND, OR, etc.).

# 5. Input/Output Ports

The TMP88F846UG contains 5 input/output ports comprised of 33 pins.

|         | Primary Function | Secondary Functions                                                                                                   |
|---------|------------------|-----------------------------------------------------------------------------------------------------------------------|
| Port P1 | 6-bit I/O port   | External interrupt input, Timer/counter input/output, divider output                                                  |
| Port P2 | 3-bit I/O port   | External interrupt input, Timer/counter input/output, STOP mode release signal input                                  |
| Port P3 | 8-bit I/O port   | Motor control input/output                                                                                            |
| Port P4 | 8-bit I/O port   | Timer/counter output, Serial interface input/output, motor control circuit in-<br>put, Serial PROM mode control input |
| Port P6 | 8-bit I/O port   | Analog input and motor control circuit output                                                                         |

All output ports contain a latch, and the output data therefore are retained by the latch. But none of the input ports have a latch, so it is desirable that the input data be retained externally until it is read out, or read several times before being processed. Figure 5-1 shows input/output timing.

The timing at which external data is read in from input/output ports is S1 state in the read cycle of instruction execution. Because this timing cannot be recognized from the outside, transient input data such as chattering needs to be dealt with in a program. The timing at which data is forwarded to input/output ports is S2 state in the write cycle of instruction execution.



Figure 5-1 Example of Input/Output Timing

When an operation is performed for read from any input/output port except programmable input/output ports, whether the input value of the pin or the content of the output latch is read depends on the instruction executed, as shown below.

- 1. Instructions which read the content of the output latch
  - XCH r, (src)
  - SET/CLR/CPL (src).b
  - SET/CLR/CPL (pp).g
  - LD (src).b, CF
  - LD (pp).b, CF
  - XCH CF, (src). b
  - ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), n
  - ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) instructions, the (src) side thereof
  - MXOR (src), m
- 2. Instructions which read the input value of the pin

Any instructions other than those listed above and ADD/ADDC/SUB/SUBB/AND/OR/XOR (src),(HL) instructions, the (HL) side thereof

### 5.1 Port P1 (P15 to P10)

Port P1 is an 6-bit input/output port shared with external interrupt input, timer/counter input/output, and divider output. This port is switched between input and output modes using the P1 port input/output control register (P1CR). When reset, the P1CR register is initialized to 0, with the P1 port set for input mode. Also, the output latch (P1DR) is initialized to 0 when reset.



## 5.2 Port P2 (P22 to P20)

Port P2 is a 3-bit input/output port shared with external interrupt input and STOP mode release signal. When using this port as these functional pins or an input port, set the output latch to 1. When reset, the output latch is initialized to 1.

We recommend using the P20 pin as external interrupt input, STOP mode release signal input, or input port. When using this port as an output port, note that the interrupt latch is set by a falling edge of output pulse. And note that outputs on this port during STOP mode go to a high-impedance state even if SYSCR1<OUTEN> is set "1", because P20 port is also used as STOP pin.

When a read instruction is executed on P2 port, indeterminate values are read in from bits 7 to 3.

When any read-modify-write instruction is executed on P2 port, the content of the output latch is read out. When any other instruction is executed, the external pin state is read out.



- Note 1: When a read instruction is executed on P2 port, indeterminate values are read in from bits 7 to 3.
- Note 2: Port P20 is used as STOP pin. Therefore, when stop mode is started, SYCR1<OUTEN> does not affect to P20, and P20 becomes High-Z mode.
- Note 3: \*: Don't care

## 5.3 Port P3 (P37 to P30)

Port P3 is an 8-bit input/output port. This port is switched between input and output modes using the P3 port Input/ output Control Register (P3CR). When reset, the P3CR Register is initialized to 0, with the P3 port set for input mode. Also, the Output Latch (P3DR) is initialized to 0 when reset.

The P3 port contains bitwise programmable open-drain control. The P3 Port Open-drain Control Register (P3ODE) is used to select open-drain or tri-state mode for the port. When reset, the P3ODE Register is initialized to 0, with tri-state mode selected for the port.



Note 2: Read-modify-write (RMW) operation executes at open-drain mode is selected, read out the output latch states.

When any other instruction is executed, external pin states is read out.

Note 3: For PMD circuit output, set the P3DR output latch to 1.

Note 4: When using P3 port as an input/output port, disable the EMG1 circuit.

### 5.4 Port P4 (P47 to P40)

Port P4 is an 8-bit input/output port shared with serial interface input/output and serial PROM mode control input. This port is switched between input and output modes using the P4 port input/output control register (P4CR). When reset, the P4CR register is initialized to 0, with the P4 port set for input mode. Also, the output latch (P4DR) is initialized to 0 when reset.

The P4 port contains bitwise programmable open-drain control. The P4 port open-drain control register (P4ODE) is used to select open-drain or tri-state mode for the port. When reset, the P4ODE register is initialized to 0, with tri-state mode selected for the port.



Note 2: Read-modify-write (RMW) operation executes at open-drain mode is selected, read out the output latch states.

When any other instruction is executed, external pin states is read out.

Note 3: When using the CTC 16-bit timer (CTC) as an ordinary timer, set P47 (CTC) for output mode.

## 5.5 Port P6 (P67 to P60)

Port P6 is an 8-bit input/output port shared with AD converter analog input. This port is switched between input and output modes using the P6 port input/output control register (P6CR), P6 port output latch (P6DR), and ADC-CRA<AINDS>. When reset, the P6CR Register and the P6DR output latch are initialized to 0 while ADC-CRA<AINDS> is set to 1, so that P67 to P60 have their inputs fixed low (= 0). When using the P6 port as an input port, set the corresponding bits for input mode (P6CR = 0, P6DR = 1). The reason why the output latch = 1 is because it is necessary to prevent current from flowing into the shared data input circuit. When using the port as an output port, set the P6CR Register's corresponding bits to 1. When using the port for analog input, set the corresponding bits for analog input (P6CR = 0, P6DR = 0). Then set ADCCRA<AINDS> = 0, and AD conversion will start.

The ports used for analog input must have their output latches set to 0 beforehand. The actual input channels for AD conversion are selected using ADCCRA<SAIN>.

Although the bits of P6 port not used for analog input can be used as input/output ports, do not execute output instructions on these ports during AD conversion. This is necessary to maintain the accuracy of AD conversion. Also, do not apply rapidly changing signals to ports adjacent to analog input during AD conversion.



If an input instruction is executed while the P6DR output latch is cleared to 0, data "0" is read in from said bits.

Note 1: The pins used for analog input cannot be set for output mode (P6CR = 1) because they become shorted with external signals.

Note 2: When a read instruction is executed on bits of this port which are set for analog input mode, data "0" is read in.

Note 3: For DBOUT1 output, set the P6DR (P67) output latch to 1.

Note 4: When using this port in input mode (including analog input), do not use bit manipulating or other read-modify-write instructions. When a read instruction is executed on the bits of this port that are set for input, the contents of the pins are read in, so that if a read-modify-write instruction is executed, their output latches may be rewritten, making the pins unable to accept input. (A read-modify-write instruction first reads data from all of the eight bits and after modifying them (bit manipulation), writes data for all of the eight bits to the output latches.)

## 6. Power-on reset circuit

The power-on reset circuit generates a reset when the TMP88F846UG is powered on. It also generates a power-on reset signal if the supply voltage drops below the detection voltage of the power-on reset circuit.

### 6.1 Configuration

The power-on reset circuit is comprised of a reference voltage generator and a comparator.

The comparator compares the supply voltage divided by a resistor ladder with the reference voltage generated by the reference voltage generator.



### 6.2 function

When the TMP88F846UG is powered on, the power-on reset circuit generates a power-on reset signal while the supply voltage is below the power-on reset release voltage. The power-on reset signal is released when the supply voltage rises above the power-on reset release voltage.

When the TMP88F846UG is shut off, the power-on reset circuit generates a power-on reset signal when the supply voltage drops below the power-on reset detection voltage.

While the power-on reset signal is generated, the warm-up counter circuit, CPU and peripheral circuits are reset.

Upon release of the power-on reset signal, the warm-up counter circuit starts operating. After the warm-up time has elapsed, the CPU and peripheral circuits are released from the reset state.

After the supply voltage reaches the power-on reset release voltage level, it must be raised to the operating range before the power-on warm-up time expires. If the supply voltage is not in the operating range at the completion of the power-on warm-up time, the TMP88F846UG cannot operate properly.



- Note 1: The power-on reset circuit may not operate properly depending on transitions in supply voltage (V<sub>DD</sub>). When designing your application system, careful consideration must be given to ensure proper operation of the power-on reset circuit by referring to the device's electrical characteristics.
- Note 2: The input clock to the warm-up counter is derived from the oscillation circuit. Because the oscillation frequency is unstable until the oscillation circuit stabilizes, the warm-up time includes error.
- Note 3: The supply voltage must be raised to satisfy the condition  $t_{VDD} < t_{PWUP}$ .

### Figure 6-2 Operation timing of the power-on reset circuit

# TOSHIBA

# 7. Voltage detection circuit (VLTD)

The voltage detecting circuit monitors the supply voltage level and generates an interrupt or reset upon detection of a low-voltage condition.

Note: The voltage detection circuit may not operate properly depending on transitions in supply voltage (VDD). When designing your application system, careful consideration must be given to ensure proper operation of the voltage detection circuit by referring to the device's electrical characteristics.

## 7.1 Configuration

The voltage detection circuit is comprised of a reference voltage generator, a detection voltage select circuit, a comparator and two control registers.

The supply voltage (VDD) is divided by the ladder resistor and input to the detection voltage select circuit. The detection voltage select circuit selects a voltage according to the specified detection voltage (VD1LVL), and the comparator compares it with the reference voltage. When the comparator detects the selected voltage, a voltage detection reset signal or an INTVLTD interrupt request signal can be generated.

Whether to generate a voltage detection reset signal or an INTVLTD interrupt request signal can be programmed by software. In the former case, a voltage detection reset signal is generated when the supply voltage (VDD) becomes lower than the detection voltage (VD1LVL). In the latter case, an INTVLTD interrupt request signal is generated when the supply voltage (VDD) falls to the detection voltage level.

Note: Since the comparators used for voltage detection do not have a hysteresis structure, INTVLTD interrupt request signals may be generated frequently if the supply voltage (VDD) is close to the detection voltage (VDxLVL). INTVLTD interrupt request signals may be generated not only when the supply voltage falls to the detection voltage but also when it rises to the detection voltage.



Figure 7-1 Voltage detection circuit diagram

Note: In the "development tool" of this device, since operation of the voltage detection circuit is not supported, even if it detects the set-up voltage, interrupt is not generated. Please check using a real device about actual operation.

## 7.2 Control

The voltage detection circuit is controlled by the Voltage Detect Control Register 1 and Voltage Detect Control Register 2.

| voltage d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | etection c                                      | ontrol re                                                                                                         | gister1                                                                             |                 |                |                                                |                                                                      |             | $\langle \rangle$ |                      |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------|----------------|------------------------------------------------|----------------------------------------------------------------------|-------------|-------------------|----------------------|-----|
| VDCR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7                                               | 6                                                                                                                 | 5                                                                                   | 4               | 3              | 2                                              | 1                                                                    | 0           |                   |                      |     |
| (1FCCH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0                                               | 0                                                                                                                 | 0                                                                                   | 1               | VD1F           | VD1SF                                          | · VD                                                                 | 1LVL        | (Initial: 0*10    | 0000)                |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |                                                                                                                   |                                                                                     |                 |                |                                                |                                                                      | /           |                   |                      |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VD1F                                            | Voltage detection 1 flag<br>VD1F (VDD <vd1lvl becoming,="" keeping<br="" when="" with="">state) (Note 2)</vd1lvl> |                                                                                     |                 |                |                                                | Read         0: VDD ≥ VD1LVL         1: VDD < VD1LVL                 |             |                   |                      | R/W |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VD1SE / (Large and competing related to VDD and |                                                                                                                   |                                                                                     |                 |                | 0 : VDD 2 VD1LVL Read<br>1 : VDD < VD1LVL only |                                                                      |             |                   |                      |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VD1LV                                           | L Voltag                                                                                                          | ge detectior                                                                        | n 1 level se    | lect           |                                                | 00 : 4.3 to 4.7<br>01 : 4.0 to 4.4<br>10 : Reserved<br>11 : Reserved |             |                   | $\leq 0$             | R/W |
| <ul> <li>Note 1: The VDCR1 is initialized by a power-on reset or an external reset input.</li> <li>Note 2: If the VD1F bit is cleared by software at the same time as it is set by detection of a low-voltage condition, the setting operation overrides the clearing operation so that the bit is set to 1.</li> <li>Note 3: Be sure to write "0" to VDCR1 Register bits 7 and 5, and write "1" to VDCR1 Register bit 4.</li> <li>Note 4: The values of the VDCR1 Register bit 6 is indeterminate when read.</li> </ul> |                                                 |                                                                                                                   |                                                                                     |                 |                |                                                | etting                                                               |             |                   |                      |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |                                                                                                                   | rol regist                                                                          | ter 2           |                | 3_                                             |                                                                      | 1           | 0                 |                      |     |
| (1F0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CDH)                                            |                                                                                                                   | $\langle ( \langle \langle \langle \rangle \rangle \rangle \rangle \rangle \rangle$ | $(\mathcal{S})$ |                | 0                                              | <b>V</b> o                                                           | VD1MOD      | VD1EN             | (Initial: **** 0000) |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VD1MO                                           | D Voltaç                                                                                                          | ge detection                                                                        | 1 operatio      | on mode sele   | ct 🔨 🗸                                         | ): INTVLTD ii<br>I : Voltage de                                      |             | et signal occu    | Irrence              | R/W |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VD1EN                                           | I Voltag                                                                                                          | ge detection                                                                        | 1 operatio      | on enable/disa | able I                                         | ) :Voltage det<br>I : Voltage de                                     |             |                   |                      | R/W |
| Not                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | e 1. Note                                       |                                                                                                                   | 2 is only i                                                                         | nitialized      | hy a nower-    | -on reset                                      | or an extern                                                         | al reset in | nut               |                      |     |

Note 2: Be sure to write "0" to VDCR2 Register bits 3 and 2.

### 7.3 Function

The voltage detection circuit allows detection voltage level to be specified. The detection voltage, whether to enable or disable voltage detect operation and the action to be taken when the supply voltage (VDD) falls to or below the detection voltage (VD1LVL) can be programmed by software.

### 7.3.1 Enabling/Disabling Voltage Detection Operation

Setting the VDCR2<VD1EN> bit to 1 enables voltage detect operation and clearing this bit to 0 disables it. Immediately after release of a power-on reset, VDCR2<VD1EN>, is cleared to 0.

Note: Setting VDCR2<VD1EN> to 1 while the supply voltage is below the detection voltage (VDD < VD1LVL) immediately causes an INTVLTD interrupt or a voltage detect x reset signal to be generated.

#### 7.3.2 Selecting the Voltage Detect Operating Mode

When VDCR2<VD1MOD> is set to "0", the voltage detection operation mode is set to generate INTVLTD interrupt request signals. When VDCR2<VD1MOD> is set to "1", the operation mode is set to generate voltage detection reset signals.

• When the operation mode is set to generate INTVLTD interrupt signals (VDCR2<VD1MOD>="0")

When VDCR2<VD1EN>="1", an INTVLTD interrupt request signal is generated when the supply voltage (VDD) falls to the detection voltage (VD1LVL).



#### Figure 7-2 Voltage Detection Internal Request

Note: Since the comparators used for voltage detection do not have a hysteresis structure, INTVLTD interrupt request signals may be generated frequently when the supply voltage (VDD) is close to the detection voltage (VD1LVL). INTVLTD interrupt request signals may be generated not only when the supply voltage falls to the detection voltage but also when it rises to the detection voltage.

When the operation mode is set to generate voltage detection reset signals (VDCR2<VD1MOD>="1")

When VDCR2<VD1EN>="1", a voltage detection reset signal is generated when the supply voltage (VDD) becomes lower than the detection voltage (VD1LVL).

VDCR1 and VDCR2 are initialized by a power-on reset or an external reset input only. A voltage detection reset signal is generated continuously as long as the supply voltage (VDD) is lower than the detection voltage (VDxLVL).





### 7.3.3 Detection voltage level section

The detection voltage level is selected by programming the VDCR1<VD1LVL> bits.

#### 7.3.4 Voltage detection flag and voltage detection status flag

The voltage detect flag (VDCR1<VD1F>) and voltage detect status flag (VDCR1<VD1SF>) indicate the relation between the supply voltage (VDD) and the detection voltage (VD1LVL), i.e., whether VDD is above or equal to VD1LVL or VDD is below VD1LVL.

When VDCR2<VD1EN>=1, a drop of the supply voltage (VDD) below the detection voltage (VD1LVL) causes the VDCR1<VD1F> flag to be set. This flag remains set until it is cleared by software. VDCR1<VD1F> is not cleared to 0 when the supply voltage (VDD) becomes equal to or higher than the detection voltage (VD1LVL).

Once VDCR1<VD1F> has been set to 1, this state is retained even if VDCR2<VD1EN> is cleared to 0. VDCR1<VD1F> can only be cleared by writing a 0.

When VDCR2<VD1EN>=1, a drop of the supply voltage (VDD) below the detection voltage (VD1LVL) also causes the VDCR1<VD1SF> flag to be set to 1. When VDD rises above VD1LVL, the VDCR1<VD1SF> flag is cleared to 0.

Unlike the VDCR1<VD1F> flag, the VDCR1<VD1SF> flag does not remain set and changes its state according to the relation between VDD and VD1LVL,

Note:Depending on the voltage detect timing, the voltage detect status flag (VDCR1<VD1SF>) may be set one machine cycle before the voltage detect flag (VDCR1<VD1F>) is set.



Figure 7-4 Change of voltage detection flag and voltage detection status flag

### 7.4 Setting of register

#### 7.4.1 Setting Procedure for Generate an interrupt

The following shows the setting procedure for generating an INTVLTD interrupt upon detection of a low-voltage condition.

- 1. Clear the INTVLTD interrupt enable flag <EF4> to 0.
- 2. Select the detection voltage by programming the VDCR1<VD1LVL>bits.
- 3. Clear the VDCR2<VD1MOD> bit to 0 to generate an INTVLTD interrupt upon detection of a low-voltage condition.
- 4. Set the VDCR2<VD1EN> bit to 1 to enable voltage detect operation.
- 5. Wait for 5  $\mu$ s until the voltage detection circuit stabilizes.
- 6. Ensure that the VDCR1<VD1SF> is 0.
- 7. Clear the INTVLTD interrupt latch <IL4> to 0 and set the interrupt enable flag <EF4> to 1 to enable interrupts.

To disable the voltage detection circuit while it is enabled with the INTVLTD interrupt request, make the following setting:

- 1. Clear the INTVLTD interrupt enable flag <EF4> to 0.
- 2. Clear the VDCR2<VD1EN> bit to 0 to disable voltage detect operation.

Note: If the voltage detection circuit is disabled without clearing INTVLTD interrupt enable flag <EF4>, unexpected interrupt request may occur.

Note: When the supply voltage (VDD) is close to the detection voltage (VD1LVL), voltage detection request signals may be generated frequently. If this may pose any problem, execute appropriate wait processing depending on fluctuations in the system power supply and clear the interrupt latch before returning from the INTVLTD interrupt service routine.

#### 7.4.2 Setting procedure to generate a reset

The following shows the setting procedure for generating a voltage detect 1 reset signal upon detection of a low-voltage condition.

- 1. Clear the INTVLTD interrupt enable flag <EF4> to 0.
- 2. Select the detection voltage by programming the VDCR1<VD1LVL>bits.
- 3. Clear the VDCR2<VD1MOD> bit to 0 to generate an INTVLTD interrupt upon detection of a low-voltage condition.
- 4. Set the VDCR2<VD1EN> bit to 1 to enable voltage detect operation.
- 5. Wait for 5  $\mu$ s until the voltage detection circuit stabilizes.
- 6. Ensure that the VDCR1 $\leq$ VD1SF $\geq$  bit is 0.
- 7. Clear the VDCR1<VD1F> bit to 0.
- 8. Set the VDCR2<VD1MOD> bit to 1 to generate a voltage detect x reset signal upon detection of a low-voltage condition.
- Note 1: The VDCR1 and VDCR2 are only initialized by a power-on reset or an external reset input. Therefore, at the time when a low-voltage detect reset is released, if the supply voltage (VDD) is found to be below the detection voltage (VD1LVL) before VDCR2<VD1EN> is cleared to 0, a voltage detect reset will immediately be generated.
- Note 2: The voltage detect reset signal remains asserted while the supply voltage (VDD) is below the detection voltage (LD1LVL).

To disable the voltage detection circuit while it is enabled with the voltage detection reset, make the following setting:

- 1. Clear the INTVLTD interrupt enable flag <EF4> to 0.
- 2. Clear the VDCR2<VD1MOD> bit to 0 to generate an INTVLTD interrupt upon detection of a low-voltage condition.
- 3. Clear the VDCR2<VD1EN> bit to 0 to disable the voltage detect operation.

Note: If the voltage detection circuit is disabled without clearing INTVLTD interrupt enable flag <EF4>, unexpected interrupt request may occur.

# 8. Time Base Timer (TBT) and Divider Output ( $\overline{DVO}$ )

### 8.1 Time Base Timer

The time base timer generates time base for key scanning, dynamic displaying, etc. It also provides a time base timer interrupt (INTTBT).

An INTTBT (Time Base Timer Interrupt) is generated on the first falling edge of source clock (The divider output of the timing generator which is selected by TBTCK.) after time base timer has been enabled.

The divider is not cleared by the program; therefore, only the first interrupt may be generated ahead of the set interrupt period (Figure 8-2).

The interrupt frequency (TBTCK) must be selected with the time base timer disabled (TBTEN="0"). (The interrupt frequency must not be changed with the disable from the enable state.) Both frequency selection and enabling can be performed simultaneously.



Example :Set the time base timer frequency to fc/2<sup>16</sup> [Hz] and enable an INTTBT interrupt.

| LD  | (TBTCR), 00000010B  | ; TBTCK $\leftarrow$ 010 (Freq. set) |
|-----|---------------------|--------------------------------------|
| LD  | (TBTCR) , 00001010B | ; TBTEN $\leftarrow$ 1 (TBT enable)  |
| DI  |                     |                                      |
| SET | (EIRL) . 6          |                                      |
| EI  |                     |                                      |

Time Base Timer is controled by Time Base Timer control register (TBTCR).

#### Time Base Timer Control Register



Note 1: fc; High-frequency clock [Hz], \*; Don't care Note 2: Always set "0" in bit4 on TBTCR register.

#### Table 8-1 Time Base Timer Interrupt Frequency (Example : fc = 20.0 MHz)



### 8.2 Divider Output (DVO)

Approximately 50% duty pulse can be output using the divider output circuit, which is useful for piezoelectric buzzer drive. Divider output is from  $\overline{\text{DVO}}$  pin.



Note 4: Be sure to write "0" to TBTCR Register bit 4.

Example : 2.44 kHz pulse output (fc = 20.0 MHz)

Port setting

| LD | (TBTCR), 0000000B   | ; DVOCK ← "00"           |
|----|---------------------|--------------------------|
| LD | (TBTCR) , 10000000B | ; DVOEN $\leftarrow$ "1" |

8.2 Divider Output (DVO)

|       | ·                             |           | -         |  |  |  |
|-------|-------------------------------|-----------|-----------|--|--|--|
| DVOCK | Divider Output Frequency [Hz] |           |           |  |  |  |
| DVOCK | NORMAL, IDLE Mode             |           |           |  |  |  |
|       | DV1CK=0                       | DV1CK=1   |           |  |  |  |
| 00    | 2.4415 k                      | 1.22075 k |           |  |  |  |
| 01    | 4.8825 k                      | 2.4415 k  |           |  |  |  |
| 10    | 9.765 k                       | 4.8825 k  |           |  |  |  |
| 11    | 19.5325 k                     | 9.765 k   | $V \land$ |  |  |  |
|       |                               |           | Z ] ]     |  |  |  |

### Table 8-2 Divider Output Frequency ( Example : fc = 20.0 MHz )
# 9. Watchdog Timer (WDT)

The watchdog timer is a fail-safe system to detect rapidly the CPU malfunctions such as endless loops due to spurious noises or the deadlock conditions, and return the CPU to a system recovery routine.

The watchdog timer signal for detecting malfunctions can be programmed only once as "reset request" or "pseudo non-maskable interrupt request". Upon the reset release, this signal is initialized to "reset request".

When the watchdog timer is not used to detect malfunctions, it can be used as the timer to provide a periodic interrupt.

Note: Care must be taken in system design since the watchdog timer functions are not be operated completely due to effect of disturbing noise.

### 9.1 Watchdog Timer Configuration



### 9.2 Watchdog Timer Control

The watchdog timer is controlled by the watchdog timer control registers (WDTCR1 and WDTCR2). The watchdog timer is automatically enabled after the reset release.

### 9.2.1 Malfunction Detection Methods Using the Watchdog Timer

The CPU malfunction is detected, as shown below.

- 1. Set the detection time, select the output, and clear the binary counter.
- 2. Clear the binary counter repeatedly within the specified detection time.

If the CPU malfunctions such as endless loops or the deadlock conditions occur for some reason, the watchdog timer output is activated by the binary-counter overflow unless the binary counters are cleared. When WDTCR1<WDTOUT> is set to "1" at this time, the reset request is generated and then internal hardware is initialized. When WDTCR1<WDTOUT> is set to "0", a watchdog timer interrupt (INTWDT) is generated.

The watchdog timer temporarily stops counting in the STOP mode including the warm-up or IDLE mode, and automatically restarts (continues counting) when the STOP/IDLE mode is inactivated.

Note: The watchdog timer consists of an internal divider and a two-stage binary counter. When the clear code 4EH is written, only the binary counter is cleared, but not the internal divider. The minimum binary-counter overflow time, that depends on the timing at which the clear code (4EH) is written to the WDTCR2 register, may be 3/4 of the time set in WDTCR1<WDTT>. Therefore, write the clear code using a cycle shorter than 3/4 of the time set to WDTCR1<WDTT>.

Example :Setting the watchdog timer detection time to  $2^{21}/\text{fc}$  [s], and resetting the CPU malfunction detection



#### Watchdog Timer Control Register 1



Note 5: WDTCR2 is a write-only register and must not be used with any of read-modify-write instructions. If WDTCR2 is read, a unknown data is read.

#### 9.2.2 Watchdog Timer Enable

Setting WDTCR1<WDTEN> to "1" enables the watchdog timer. Since WDTCR1<WDTEN> is initialized to "1" during reset, the watchdog timer is enabled automatically after the reset release.

#### 9.2.3 Watchdog Timer Disable

To disable the watchdog timer, set the register in accordance with the following procedures. Setting the register in other procedures causes a malfunction of the microcontroller.

- 1. Set the interrupt master flag (IMF) to "0".
- 2. Set WDTCR2 to the clear code (4EH).
- 3. Set WDTCR1<WDTEN> to "0".
- 4. Set WDTCR2 to the disable code (B1H).

Note: While the watchdog timer is disabled, the binary counters of the watchdog timer are cleared.

Example :Disabling the watchdog timer

| DI  |                  | : IMF ← 0                                                |
|-----|------------------|----------------------------------------------------------|
| LD  | (WDTCR2), 04EH   | : Clears the binary counter                              |
| LDW | (WDTCR1), 0B101H | : WDTEN $\leftarrow$ 0, WDTCR2 $\leftarrow$ Disable code |
| EI  |                  | : IMF = 1                                                |

Table 9-1 Watchdog Timer Detection Time (Example: fc = 20 MHz

|      | Watchdog Timer | Detection Time[s] |
|------|----------------|-------------------|
| WDTT | NORMA          | AL Mode           |
|      | DV1CK = 0      | DV1CK = 1         |
| 00   | 1.678          | 3.355             |
| 01   | 419.430 m      | 838,861 m         |
| 10   | 104.858 m      | 209.715 m         |
| 11   | 26.214 m       | 52.429 m          |
|      |                |                   |

Note: If the watchdog timer is disabled during watchdog timer interrupt processing, the watchdog timer interrupt will never be cleared. Therefore, clear the watchdog timer (set the clear code (4EH) to WDTCR2) before disabling it, or disable the watchdog timer a sufficient time before it overflows.

### 9.2.4 Watchdog Timer Interrupt (INTWDT)

When WDTCR1<WDTOUT> is cleared to "0", a watchdog timer interrupt request (INTWDT) is generated by the binary-counter overflow.

A watchdog timer interrupt is the non-maskable interrupt which can be accepted regardless of the interrupt master flag (IMF).

When a watchdog timer interrupt is generated while the other interrupt including a watchdog timer interrupt is already accepted, the new watchdog timer interrupt is processed immediately and the previous interrupt is held pending. Therefore, if watchdog timer interrupts are generated continuously without execution of the RETN instruction, too many levels of nesting may cause a malfunction of the microcontroller.

To generate a watchdog timer interrupt, set the stack pointer before setting WDTCR1<WDTOUT>.

Example :Setting watchdog timer interrupt

| LD | SP, 02BFH           | : Sets the stack pointer |
|----|---------------------|--------------------------|
| LD | (WDTCR1), 00001000B | : WDTOUT $\leftarrow$ 0  |

### 9.2.5 Watchdog Timer Reset

When a binary-counter overflow occurs while WDTCR1<WDTOUT> is set to "1", a watchdog timer reset request is generated. When a watchdog timer reset request is generated, the internal hardware is reset. The reset time is maximum 24/fc [s] (max. 1.2 µs @ fc = 20 MHz).



- 10. 16-Bit TimerCounter 1 (TC1)
- 10.1 Configuration



Figure 10-1 TimerCounter 1 (TC1)

10.2 TimerCounter Control

10.2 TimerCounter Control

The TimerCounter 1 is controlled by the TimerCounter 1 control register (TC1CR) and two 16-bit timer registers (TC1DRA and TC1DRB).

#### Timer Register

|                                                   | 15                        | 14 1                                    |                      |                                                                   | 10                    | 98                                    | 3                                                             | 7                         | 6         | 5 4                     | 3                 | 2          | 1         | 0   |   |   |     |
|---------------------------------------------------|---------------------------|-----------------------------------------|----------------------|-------------------------------------------------------------------|-----------------------|---------------------------------------|---------------------------------------------------------------|---------------------------|-----------|-------------------------|-------------------|------------|-----------|-----|---|---|-----|
| C1DRA                                             |                           |                                         | TC1D                 | RAH (0011H                                                        | l)                    |                                       |                                                               | TC1DRAL (0010H)           |           |                         |                   |            |           |     |   |   |     |
| 011H, 0010H)                                      |                           | (Initia                                 | <u> </u>             | Read/Write                                                        |                       |                                       |                                                               |                           |           |                         |                   |            |           |     |   |   |     |
| C1DRB                                             |                           |                                         | TC1D                 | RBH (0013H                                                        | l)                    |                                       |                                                               |                           |           | TC1D                    | RBL (001          | 2H)        |           |     |   |   |     |
| 013H, 0012H)                                      |                           | (Initia                                 | I value: '           | 1111 1111 11                                                      | 11 1111)              |                                       |                                                               | Read                      | /Write (W | rite enable             | d only in         | the PPG o  | output mo | de) |   |   |     |
| TimerCou                                          | unter 1 C                 | Control R                               | egiste               | r                                                                 |                       |                                       |                                                               |                           | Ć         |                         |                   |            |           |     |   |   |     |
|                                                   | 7                         | 6                                       | 5                    | 4                                                                 | 3                     | 2                                     |                                                               | 1                         | 0         |                         |                   | $\bigcirc$ |           |     |   |   |     |
| TC1CR<br>(000FH)                                  | TFF1                      | ACAP1<br>MCAP1<br>METT1<br>MPPG1        | -                    | TC1S                                                              | тс                    | сіск                                  |                                                               |                           |           | Read/Wri<br>(Initial va | $\left( \right)$  | 0000)      | 7         |     |   |   |     |
| TFF1                                              | Timer F/F1                | control                                 | 0: 0                 | lear                                                              |                       |                                       |                                                               | $\searrow$                | 1: Set    | - (7)                   | $\rightarrow$     | $\bigcirc$ |           | R/W |   |   |     |
| ACAP1                                             | Auto captu                |                                         |                      | Auto-capture                                                      | disable               | $\sim$                                |                                                               | >                         |           | -capture e              | nable             |            |           | R/W |   |   |     |
| MCAP1                                             | ·····                     | n measureme                             | ant                  | ouble edge o                                                      | (                     | $\bigcirc$                            | $\rightarrow$                                                 | _                         | (7)       | le edge ca              |                   |            |           |     |   |   |     |
| METT1                                             | External tri<br>mode cont |                                         | er 0 : Trigger start |                                                                   |                       |                                       | 2                                                             | 1: Trigger start and stop |           |                         |                   |            | R/W       |     |   |   |     |
| MPPG1                                             | PPG outpu                 | it control                              | 0:0                  | Continuous p                                                      | ulse genera           | ation                                 |                                                               | 1 : One-shot              |           |                         |                   |            |           | 1   |   |   |     |
|                                                   |                           |                                         |                      |                                                                   |                       |                                       | Timer                                                         | Extrig-<br>ger            | Event     | Win-<br>dow             | Pulse             | PPG        |           |     |   |   |     |
|                                                   |                           |                                         |                      | Stop and cou                                                      | unter clear           |                                       |                                                               | 0                         | 0         | 0                       | 0                 | 0          | 0         |     |   |   |     |
|                                                   |                           |                                         |                      | Command st                                                        | tart                  | · · · · · · · · · · · · · · · · · · · | 15                                                            | 20                        | -         | -                       | -                 | -          | 0         |     |   |   |     |
| TC1S                                              | TC1 start co              | TC1 start                               | TC1 start control    |                                                                   | TC1 start control     |                                       | Rising edge<br>trigger/Pulse<br>ng edge cou<br>itive logic co | e/PPG)<br>nt (Event)      | w)        | $\geq$                  | <u>}</u>          | 0          | o         | 0   | 0 | 0 | R/W |
|                                                   | $\langle$                 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | (Ex<br>Fall          | Falling edge<br>-trigger/Pulse<br>ing edge cou<br>gative logic co | e/PPG)<br>int (Event) | òw)                                   |                                                               | -                         | 0         | 0                       | 0                 | 0          | 0         |     |   |   |     |
|                                                   | 4                         | $\sim$                                  |                      | $\wedge$                                                          |                       | ~                                     | 1                                                             | NORMAL,                   | IDLE mo   | de                      |                   |            |           |     |   |   |     |
|                                                   | C                         | $\mathcal{A}$                           |                      | 41                                                                | DV                    | /1CK = 0                              |                                                               |                           |           | [                       | OV1CK =           | 1          |           | 1   |   |   |     |
| телек                                             | TC1 source                | e clock selec                           | t 00                 |                                                                   | $\geq$                | fc/211                                |                                                               |                           |           |                         | fc/212            |            |           |     |   |   |     |
| TC1CK                                             | [Hz]                      |                                         | $\sim$               | 01 fc/2 <sup>7</sup>                                              |                       |                                       |                                                               |                           |           |                         | fc/2 <sup>8</sup> |            |           | R/W |   |   |     |
| $\langle \langle \langle \langle \rangle \rangle$ |                           |                                         |                      | 10 fc/2 <sup>3</sup>                                              |                       |                                       |                                                               |                           |           |                         | fc/2 <sup>4</sup> |            |           |     |   |   |     |
|                                                   |                           |                                         | 4/14                 |                                                                   |                       |                                       | Exte                                                          | rnal clock                | (TC1 pin  | input)                  |                   |            |           |     |   |   |     |
|                                                   | $\bigtriangledown$        |                                         | 00:                  | Timer/extern                                                      | al trigger tir        | mer/event c                           | counte                                                        | er mode                   |           |                         |                   |            |           |     |   |   |     |
| TC1M                                              | TC1 opera<br>lect         | ting mode se                            | -                    | Window moo<br>Pulse width r                                       |                       | ent mode                              |                                                               |                           |           |                         |                   |            |           | R/W |   |   |     |
|                                                   |                           |                                         | 11:                  | PPG (Progra                                                       | immable pu            | ilse genera                           | ite) ou                                                       | tput mode                 | •         |                         |                   |            |           |     |   |   |     |

Note 1: fc: High-frequency clock [Hz]

Note 2: The timer register consists of two shift registers. A value set in the timer register becomes valid at the rising edge of the first source clock pulse that occurs after the upper byte (TC1DRAH and TC1DRBH) is written. Therefore, write the lower byte and the upper byte in this order (it is recommended to write the register with a 16-bit access instruction). Writing only the lower byte (TC1DRAL and TC1DRBL) does not enable the setting of the timer register.

Note 3: To set the mode, source clock, PPG output control and timer F/F control, write to TC1CR during TC1CR<TC1S>=00. Set the timer F/F1 control until the first timer start after setting the PPG mode.

Note 4: Auto-capture can be used only in the timer, event counter, and window modes.

- Note 5: To set the timer registers, the following relationship must be satisfied.
  - TC1DRA > TC1DRB > 1 (PPG output mode), TC1DRA > 1 (other modes)
- Note 6: Set TC1CR<TFF1> to "0" in the mode except PPG output mode.
- Note 7: Set TC1DRB after setting TC1CR<TC1M> to the PPG output mode.
- Note 8: When the STOP mode is entered, the start control (TC1CR<TC1S>) is cleared to "00" automatically, and the timer stops. After the STOP mode is exited, set the TC1CR<TC1S> to use the timer counter again.
- Note 9: Use the auto-capture function in the operative condition of TC1. A captured value may not be fixed if it's read after the execution of the timer stop or auto-capture disable. Read the capture value in a capture enabled condition.
- Note 10: Since the up-counter value is captured into TC1DRB by the source clock of up-counter after setting TC1CR<ACAP1> to "1". Therefore, to read the captured value, wait at least one cycle of the internal source clock before reading TC1DRB for the first time.

### 10.3 Function

TimerCounter 1 has six types of operating modes: timer, external trigger timer, event counter, window, pulse width measurement, programmable pulse generator output modes.

#### 10.3.1 Timer mode

In the timer mode, the up-counter counts up using the internal clock. When a match between the up-counter and the timer register 1A (TC1DRA) value is detected, an INTTC1 interrupt is generated and the up-counter is cleared. After being cleared, the up-counter restarts counting. Setting TC1CR<ACAP1> to "1" captures the up-counter value into the timer register 1B (TC1DRB) with the auto-capture function. Use the auto-capture function in the operative condition of TC1. A captured value may not be fixed if it's read after the execution of the timer stop or auto-capture disable. Read the capture value in a capture enabled condition. Since the up-counter value is captured into TC1DRB by the source clock of up-counter after setting TC1CR<ACAP1> to "1". Therefore, to read the captured value, wait at least one cycle of the internal source clock before reading TC1DRB for the first time.

| TC1CK |                    | NORMAL,                     | IDLE Mode          | ode                         |  |  |  |  |  |  |
|-------|--------------------|-----------------------------|--------------------|-----------------------------|--|--|--|--|--|--|
|       | DV10               | DV1CK = 0 DV1CK = 1         |                    |                             |  |  |  |  |  |  |
|       | Resolution<br>[µs] | Maximum Time<br>Setting [s] | Resolution<br>[µs] | Maximum Time<br>Setting [s] |  |  |  |  |  |  |
| 00    | 102.4              | 6.7108                      | 204.8              | 13.4216                     |  |  |  |  |  |  |
| 01    | 6.4                | 0.4194                      | 12.8               | 0.8388                      |  |  |  |  |  |  |
| 10    | 0.5                | 26.214 m                    | 0.8                | 52.428 m                    |  |  |  |  |  |  |
|       |                    |                             |                    | ]]                          |  |  |  |  |  |  |

Table 10-1 Source Clock for TimerCounter 1 (Example; fc = 20 MHz)

Example 1 :Setting the timer mode with source clock  $fc/2^{11}$  [Hz] and generating an interrupt 1 second later (fc = 20 MHz, CGCR<DV1CK> = "0")



|                   | Timer start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source clock      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Counter           | $ \underbrace{\begin{array}{c} 0 \\ 0 \end{array}}_{n} 1 \\ 2 \\ 3 \\ 4 \\ 3 \\ 4 \\ 3 \\ 4 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 1 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 2 \\ 1 \\ 1$ |
| TC1DRA            | ? X n o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| INTTC1 interruput | request Match detect Counter clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                   | (a) Timer mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Source clock      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Counter           | <u>m-2</u> <u>m-1</u> <u>m</u> <u>m+1</u> <u>m+2</u> <u>m-1</u> <u>n</u> <u>n+1</u> <u>Capture</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| TC1DRB            | $\begin{array}{c} \hline \hline$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ACAP1             | (b) Auto-capture                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                   | Figure 10-2 Timer Mode Timing Chart                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | $\sum_{i} \langle a_{i} \rangle \langle a_{i} \rangle$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 10.3.2 External Trigger Timer Mode

In the external trigger timer mode, the up-counter starts counting by the input pulse triggering of the TC1 pin, and counts up at the edge of the internal clock. For the trigger edge used to start counting, either the rising or falling edge is defined in TC1CR<TC1S>.

• When TC1CR<METT1> is set to "1" (trigger start and stop)

When a match between the up-counter and the TC1DRA value is detected after the timer starts, the up-counter is cleared and halted and an INTTC1 interrupt request is generated.

If the edge opposite to trigger edge is detected before detecting a match between the up-counter and the TC1DRA, the up-counter is cleared and halted without generating an interrupt request. Therefore, this mode can be used to detect exceeding the specified pulse by interrupt.

After being halted, the up-counter restarts counting when the trigger edge is detected.

• When TC1CR<METT1> is set to "0" (trigger start)

When a match between the up-counter and the TC1DRA value is detected after the timer starts, the up-counter is cleared and halted and an INTTC1 interrupt request is generated.

The edge opposite to the trigger edge has no effect in count up. The trigger edge for the next counting is ignored if detecting it before detecting a match between the up-counter and the TC1DRA.

Since the TC1 pin input has the noise rejection, pulses of 4/fc [s] or less are rejected as noise. A pulse width of 12/fc [s] or more is required to ensure edge detection.

# Example 1 :Generating an interrupt 1 ms after the rising edge of the input pulse to the TC1 pin (fc = 20 MHz, CGCR<DV1CK > = "1").









### 10.3.3 Event Counter Mode

In the event counter mode, the up-counter counts up at the edge of the input pulse to the TC1 pin. Either the rising or falling edge of the input pulse is selected as the count up edge in TC1CR<TC1S>.

When a match between the up-counter and the TC1DRA value is detected, an INTTC1 interrupt is generated and the up-counter is cleared. After being cleared, the up-counter restarts counting at each edge of the input pulse to the TC1 pin. Since a match between the up-counter and the value set to TC1DRA is detected at the edge opposite to the selected edge, an INTTC1 interrupt request is generated after a match of the value at the edge opposite to the selected edge.

Two or more machine cycles are required for the low-or high-level pulse input to the TC1 pin.

Setting TC1CR<ACAP1> to "1" captures the up-counter value into TC1DRB with the auto capture function. Use the auto-capture function in the operative condition of TC1. A captured value may not be fixed if it's read after the execution of the timer stop or auto-capture disable. Read the capture value in a capture enabled condition. Since the up-counter value is captured into TC1DRB by the source clock of up-counter after setting TC1CR<ACAP1> to "1". Therefore, to read the captured value, wait at least one cycle of the internal source clock before reading TC1DRB for the first time.



#### 10.3.4 Window Mode

In the window mode, the up-counter counts up at the rising edge of the pulse that is logical ANDed product of the input pulse to the TC1 pin (window pulse) and the internal source clock. Either the positive logic (count up during high-going pulse) or negative logic (count up during low-going pulse) can be selected.

When a match between the up-counter and the TC1DRA value is detected, an INTTCP interrupt is generated and the up-counter is cleared.

Define the window pulse to the frequency which is sufficiently lower than the internal source clock programmed with TC1CR<TC1CK>.



#### 10.3.5 Pulse Width Measurement Mode

In the pulse width measurement mode, the up-counter starts counting by the input pulse triggering of the TC1 pin, and counts up at the edge of the internal clock. Either the rising or falling edge of the internal clock is selected as the trigger edge in TC1CR<TC1S>. Either the single- or double-edge capture is selected as the trigger edge in TC1CR<MCAP1>.

• When TC1CR<MCAP1> is set to "1" (single-edge capture)

Either high- or low-level input pulse width can be measured. To measure the high-level input pulse width, set the rising edge to TC1CR<TC1S>. To measure the low-level input pulse width, set the falling edge to TC1CR<TC1S>.

When detecting the edge opposite to the trigger edge used to start counting after the timer starts, the up-counter captures the up-counter value into TC1DRB and generates an INTTC1 interrupt request. The up-counter is cleared at this time, and then restarts counting when detecting the trigger edge used to start counting.

• When TC1CR<MCAP1> is set to "0" (double-edge capture)

The cycle starting with either the high- or low-going input pulse can be measured. To measure the cycle starting with the high-going pulse, set the rising edge to TC1CR<TC1S>. To measure the cycle starting with the low-going pulse, set the falling edge to TC1CR<TC1S>.

When detecting the edge opposite to the trigger edge used to start counting after the timer starts, the up-counter captures the up-counter value into TC1DRB and generates an INTTC1 interrupt request. The up-counter continues counting up, and captures the up-counter value into TC1DRB and generates an INTTC1 interrupt request when detecting the trigger edge used to start counting. The up-counter is cleared at this time, and then continues counting.

- Note 1: The captured value must be read from TC1DRB until the next trigger edge is detected. If not read, the captured value becomes a don't care. It is recommended to use a 16-bit access instruction to read the captured value from TC1DRB.
- Note 2: For the single-edge capture, the counter after capturing the value stops at "1" until detecting the next edge. Therefore, the second captured value is "1" larger than the captured value immediately after counting starts.
- Note 3: The first captured value after the timer starts may be read incorrectively, therefore, ignore the first captured value.

Example :Duty measurement (resolution fc/2<sup>7</sup> [Hz], CGCR<DV1CK> = "0")

| imple .Duty measure | ment (resolut  |                                 |                                                             |
|---------------------|----------------|---------------------------------|-------------------------------------------------------------|
|                     | CLR            | (INTTC1SW). 0                   | ; INTTC1 service switch initial setting                     |
|                     |                |                                 | ; Address set to convert INTTC1SW at each INTTC1            |
|                     | LD             | (TC1CR), 00000110B              | ; Sets the TC1 mode and source clock                        |
|                     | DI             |                                 | ; IMF= "0"                                                  |
|                     | SET            | (EIRD). 2                       | ; Enables INTTC1                                            |
|                     | EI             |                                 | ; IMF= "1"                                                  |
|                     | LD             | (TC1CR), 00100110B              | ; Starts TC1 with an external trigger at MCAP1 = 0          |
|                     | :              |                                 | $\langle (// ) \rangle$                                     |
| PINTTC1:            | CPL            | (INTTC1SW). 0                   | ; INTTC1 interrupt, inverts and tests INTTC1 service switch |
|                     | JRS            | F, SINTTC1                      |                                                             |
|                     | LD             | A, (TC1DRBL)                    | ; Reads TC1DRB (High-level pulse width)                     |
|                     | LD             | W,(TC1DRBH)                     |                                                             |
|                     | LD             | (HPULSE), WA                    | ; Stores high-level pulse width in RAM                      |
|                     | RETI           |                                 | (7)                                                         |
| SINTTC1:            | LD             | A, (TC1DRBL)                    | ; Reads TC1DRB (Cycle)                                      |
|                     | LD             | W,(TC1DRBH)                     |                                                             |
|                     | LD             | (WIDTH), WA                     | ; Stores cycle in RAM                                       |
|                     | :              |                                 |                                                             |
|                     | RETI           | ((                              | ; Duty calculation                                          |
|                     | :              |                                 |                                                             |
| VINTTC1:            | DW             | PINTTC1                         | /INTTC1 Interrupt vector                                    |
|                     |                |                                 |                                                             |
|                     |                |                                 | WIDTH                                                       |
|                     |                | HPULSE                          |                                                             |
| TC1                 | nin            |                                 |                                                             |
|                     |                |                                 |                                                             |
| INTT                | C1 interrupt r | equest                          |                                                             |
| INTT                | C1SW           |                                 |                                                             |
|                     |                | $\geq -\langle \langle \rangle$ |                                                             |
|                     |                |                                 |                                                             |
|                     | ~              |                                 |                                                             |
|                     | ζ.,            |                                 |                                                             |
|                     | $\searrow$     |                                 |                                                             |
|                     | $\mathcal{D}$  |                                 |                                                             |
|                     | リー             |                                 |                                                             |
|                     |                | $\sim (\bigcirc)$               |                                                             |
|                     |                |                                 |                                                             |
|                     | $\checkmark$   | $\searrow$                      |                                                             |
| ~                   |                |                                 |                                                             |



#### 10.3.6 Programmable Pulse Generate (PPG) Output Mode

In the programmable pulse generation (PPG) mode, an arbitrary duty pulse is generated by counting performed in the internal clock. To start the timer, TC1CR<TC1S> specifies either the edge of the input pulse to the TC1 pin or the command start. TC1CR<MPPG1> specifies whether a duty pulse is produced continuously or not (one-shot pulse).

• When TC1CR<MPPG1> is set to "0" (Continuous pulse generation)

When a match between the up-counter and the TC1DRB value is detected after the timer starts, the level of the PPG pin is inverted and an INTTC1 interrupt request is generated. The up-counter continues counting. When a match between the up-counter and the TC1DRA value is detected, the level of the PPG pin is inverted and an INTTC1 interrupt request is generated. The up-counter is cleared at this time, and then continues counting and pulse generation.

When TC1CR<TC1S> is cleared to "00" during PPG output, the PPG pin retains the level immediately before the counter stops.

• When TC1CR<MPPG1> is set to "1" (One-shot pulse generation)

When a match between the up-counter and the TC1DRB value is detected after the timer starts, the level of the  $\overline{PPG}$  pin is inverted and an INTTC1 interrupt request is generated. The up-counter continues counting. When a match between the up-counter and the TC1DRA value is detected, the level of the  $\overline{PPG}$  pin is inverted and an INTTC1 interrupt request is generated. TC1CR<TC1S> is cleared to "00" automatically at this time, and the timer stops. The pulse generated by PPG retains the same level as that when the timer stops.

Since the output level of the  $\overline{PPG}$  pin can be set with TC1CR<TFF1> when the timer starts, a positive or negative pulse can be generated. Since the inverted level of the timer F/F1 output level is output to the  $\overline{PPG}$  pin, specify TC1CR<TFF1> to "0" to set the high level to the  $\overline{PPG}$  pin, and "1" to set the low level to the  $\overline{PPG}$  pin. Upon reset, the timer F/F1 is initialized to "0".

- Note 1: To change TC1DRA or TC1DRB during a run of the timer, set a value sufficiently larger than the count value of the counter. Setting a value smaller than the count value of the counter during a run of the timer may generate a pulse different from that specified.
- Note 2: Do not change TC1CR<TFF1> during a run of the timer. TC1CR<TFF1> can be set correctly only at initialization (after reset). When the timer stops during PPG, TC1CR<TFF1> can not be set correctly from this point onward if the PPG output has the level which is inverted of the level when the timer starts. (Setting TC1CR<TFF1> specifies the timer F/F1 to the level inverted of the programmed value.) Therefore, the timer F/F1 needs to be initialized to ensure an arbitrary level of the PPG output. To initialize the timer F/F1, change TC1CR<TC1M> to the timer mode (it is not required to start the timer mode), and then set the PPG mode. Set TC1CR<TFF1> at this time.
- Note 3: In the PPG mode, the following relationship must be satisfied.
  - TC1DRA > TC1DRB

```
Note 4: Set TC1DRB after changing the mode of TC1M to the PPG mode.
```

Example :Generating a pulse which is high-going for 800  $\mu$ s and low-going for 200  $\mu$ s (fc = 20 MHz, CGCR<DV1CK> = "0")

|     | Setting port       |                                                                    |
|-----|--------------------|--------------------------------------------------------------------|
| LD  | (TC1CR), 10001011B | ; Sets the PPG mode, selects the source clock                      |
| LDW | (TC1DRA), 04E2H    | ; Sets the cycle (1 ms $\div$ 24/fc $\mu s$ = 04E2H)               |
| LDW | (TC1DRB), 00FAH    | ; Sets the low-level pulse width (200 $\mu s \div 2^4/fc$ = 00FAH) |
| LD  | (TC1CR), 10010111B | ; Starts the timer                                                 |
|     |                    |                                                                    |





# 11. 16-Bit Timer (CTC)

### 11.1 Configuration





### 11.2 Control

Compare timer/counter 1 is controlled using Compare timer/counter 1 Control Registers (CTC1CR1 and CTC1CR2), as well as three 16-bit Timer Registers (CTC1DRA, CTC1DRB, and CTC1DRC).

| Compare                 | Time                       | er Regi    | iste                 | rs (CT                             | C1D             | RH: 0                | 001             | 7h, C  | TC1               | ORL:   | 000                     | 16h)                     |       |           | $\langle \rangle$         |                                   |
|-------------------------|----------------------------|------------|----------------------|------------------------------------|-----------------|----------------------|-----------------|--------|-------------------|--------|-------------------------|--------------------------|-------|-----------|---------------------------|-----------------------------------|
|                         | 15                         | 14         | 13                   | 12                                 | 11              | 10                   | 9               | 8      | 7                 | 6      | 5                       | 4                        | 3     | 2         | 1 0                       | Write only                        |
| CTC1DRA                 |                            |            |                      | CTC1D                              | RAH             |                      |                 |        |                   |        |                         | CTC1                     | DRAL  |           | $(\bigcirc$               | (Initial value: ******** *******) |
| r                       | 15                         | 14         | 13                   | 12                                 | 11              | 10                   | 9               | 8      | 7                 | 6      | 5                       | 4                        | 3     | 2         | 1 0                       | Write only                        |
| CTC1DRB                 |                            |            |                      | CTC1D                              | RBH             |                      |                 |        |                   |        |                         | CTC1                     | DRBL  | $-\ell$   | $\langle \rangle \rangle$ | (Initial value: ******** *******) |
| 070/000                 | 15                         | 14         | 13                   | 12                                 | 11              | 10                   | 9               | 8      | 7                 | 6      | 5                       | 4                        | 3     | 2         | 1 0                       | Write only                        |
| CTC1DRC                 |                            |            |                      | CTC1D                              | RCH             |                      |                 |        |                   |        |                         | CTC1                     | DRCL  | $\supset$ | <u>}</u>                  | (Initial value: ******** *******) |
| N<br>Compare            | v                          | vrite inst | ructi                | ons suc                            | h as \$         | SET, CI              | _R, e           | tc.    |                   |        | (                       | $\overline{\mathcal{O}}$ |       | ~         |                           | he read-modify-                   |
| CTC1CR1                 |                            | 7          |                      | 6                                  |                 | 5                    |                 | 4      |                   | 3      | ( )                     | $\rightarrow$            |       | 1 /       | $ \mathbf{P} \mathbf{Q} $ | R/W                               |
| lower addres            | s C                        | TC1RES     |                      | PGFF0                              |                 | CTC1M                | С               | TC1CY  | C                 | rC1SE  | $\overline{\mathbf{A}}$ | TC1E                     | СТО   | C1SM      | CTC15                     | (Initial value: 00000000)         |
| CTC1CR2<br>upper addres |                            | 7          |                      | 6<br>EX-<br>TRGDIS                 |                 | 5<br>CTC             | C1RE            | 4<br>G | <u> </u>          | 3      | c                       | 2<br>TC1CK               |       |           | 0<br>CTC1FF0              | R/W<br>(Initial value: *0000000)  |
| N<br>N<br>N             | lote 2<br>lote 3<br>lote 4 | : Write    | TC1<br>ne Ll<br>to C | CR1 <c<br>DW inst<br/>TC1DR</c<br> | ructio<br>H/L A | n for wi<br>A, B, an | ite to<br>d C F | the C  | TC1DF<br>ers as r | many a | is set                  | with th                  | e CTC | 1CR2      | ual to or grea            | C1REG bit.                        |

#### Setting-up the CTC1CR1 Register

|         |                               |                                               | Timer    | Event      | PPG             |              |  |
|---------|-------------------------------|-----------------------------------------------|----------|------------|-----------------|--------------|--|
| CTC1S   | Control start                 | 0: Stop and clear counter<br>1: Command start | о        | о          | о               |              |  |
|         |                               |                                               | 0        | 0          | o               |              |  |
| CTC1SM  | Select start                  | 0: Software start                             | o        | 0          | 0               |              |  |
| 01010   |                               | 1: External trigger start                     | 0        | $(\times)$ | ) Po            |              |  |
| CTC1E   | Select external trigger edge  | 0: Enable one edge                            | 0        | 0          | o               |              |  |
| OTOTE   | Gelect external trigger edge  | 1: Enable both edges                          | o ( /    | ×          | о               |              |  |
| CTC1SE  | Select external trigger start | 0: Rising edge                                | 0        | o          | o               | <b>D</b> 444 |  |
|         | edge                          | 0                                             | •        | o          | R/W             |              |  |
| CTC1CY  | Select cycle                  | 0: Successive                                 | o        | 0          | o               |              |  |
| CICICI  |                               | 1: One shot                                   | 0        | ×          | 0               |              |  |
| CTC1M   | Set operation mode            | 0: Timer/Event counter modes                  | $\sim$   | /          | $\mathcal{A}$   | $\searrow$   |  |
|         |                               | 1: PPG (programmable pulse generator) out     | put mode |            | 5               | >            |  |
| PPGFF0  | Select PPG output             | 0: Forward output immediately after start     |          |            |                 |              |  |
|         |                               | 1: Reverse output immediately after start     |          | $\sim$     | $(\mathcal{U})$ |              |  |
| CTC1RES | Reset all                     | 0: Normal operation                           |          | $\sim$     |                 |              |  |
|         |                               | 1: CTC1 reset                                 | (        |            | $\checkmark$    |              |  |

#### Setting-up the CTC1CR2 Register

| CTC1FF0  | Control timer output F/F0    | 0: Clear<br>1: Set  |                                                |                           |       | )                 |         |     |   |     |
|----------|------------------------------|---------------------|------------------------------------------------|---------------------------|-------|-------------------|---------|-----|---|-----|
|          |                              |                     | NORMAL and IDLE Modes                          |                           |       |                   |         |     |   |     |
|          |                              |                     | DV1CK = 0                                      | DV1CK = 1                 | Timer | Event             | PPG     |     |   |     |
|          | (                            | 000                 | fc/211                                         | fc/212                    | 0     | -                 | ×       |     |   |     |
|          |                              | 001                 | fc/27                                          | fc/2 <sup>8</sup>         | o     | -                 | ×       |     |   |     |
|          | Select timer/counter clock   | 010                 | fc/2⁵                                          | fc/2 <sup>6</sup>         | o     | -                 | ×       |     |   |     |
| CTC1CK   | source                       | 011                 | fc/23                                          | fc/2⁴                     | о     | -                 | ×       |     |   |     |
|          | Unit: Hz                     | 100                 | fc/2 <sup>2</sup>                              | fc/2 <sup>3</sup>         | о     | -                 | O Note3 | R/W |   |     |
|          |                              |                     |                                                | 101 🗸                     | fc/2  | fc/2 <sup>2</sup> | o       | -   | o | R/W |
|          |                              | 110                 |                                                | _                         | ×     | ×                 | ×       |     |   |     |
|          | $\sim$                       | 111                 |                                                | clock input<br>bin input) | -     | 0                 | ×       |     |   |     |
|          |                              | 00: CTC             | 1DRA                                           |                           | 1REG  |                   |         |     |   |     |
| CTC1REG  | Set registers used by timer/ |                     | 1DRA + CTC1DRE                                 |                           | 2REG  |                   |         |     |   |     |
| $\sim$   | counter                      | 10: CTC<br>11: Rese | 1DRA + CTC1DRE<br>erved                        | 3 + CIC1DRC               | 3REG  |                   |         |     |   |     |
| EXTRGDIS | External trigger input Note4 |                     | e external trigger ir<br>le external trigger i | -                         |       |                   |         |     |   |     |

Note 1: fc: Clock [Hz]

Note 2: Make sure the timer/counter is idle (CTC1CR1<CTC1SM, CTC1S> = 00) before setting operation mode, edge, start, source clock, external trigger timer mode control, and PPG output control.

Note 3: When DV1CK=1, CTC1CR2<CTC1CK>=100 cannot be used.

Note 4: When CTC1 input is not used in the CTC1 timer, external trigger input must be disabled (CTC1CR2<EXTRGDIS> = 1) regardless of the selected mode.

Note 5: The CTC1DRB and CTC1DRC Registers cannot be accessed for write unless they are set for PPG output mode and specified with CTC1CR2<CTC1REG>.

Note 6: CTC1CR1<CTC1E> is effective only when using an external clock as trigger (CTC1CR1<CTC1SM>).

Note 7: Data must be written to as many data registers as set with CTC1CR2<CTC1REG>.

Note 8: To write data to CTC1DRA/B/C, use the LDW instruction, or use the LD instruction writing in order of L, H.

Note 9: Data register values must be written to the respective registers before starting. To modify the values after starting, write the new data within an interval from an INTCTC1 interrupt to the next INTCTC1.

- Note 10: Specifying CTC1CR1<CTC1RES> = 1 causes all conditions to be reset. Even when the CTC circuit is operating, they are reset, and the PPG output becomes "0". However, only the INTCTC1 signal is not reset if the signal is being generated.
- Note 11: For event counter mode (when CTC pin input is selected in timer mode), the active edge of the external trigger to count can be selected with CTC1CR1<CTC1SE>.

Note 12: Disabling external trigger input with CTC1CR2<EXTRGDIS> creates the 0 input state.

Note 13: To stop the counter by software at trigger start, set CTC1CR2<CTC1SM, CTC1S> = 00.

Note 14: The number of registers set and the values set in the timer registers must meet the conditions shown below.

| Number of Registers |            | Timer Register Value Conditions                                   |
|---------------------|------------|-------------------------------------------------------------------|
|                     | 1 Register | CTC1DRA≥2                                                         |
| CTC1REG             | 2 Register | CTC1DRB > CTC1DRA + 1, and CTC1DRA ≥ 2                            |
|                     | 3 Register | CTC1DRC > CTC1DRB + 1, CTC1DRB > CTC1DRA + 1, and CTC1DRA $\ge 2$ |
| 6                   |            |                                                                   |

|                | $\overline{0}$ |                        |
|----------------|----------------|------------------------|
|                |                |                        |
|                | $\bigcirc$     | $(\mathcal{C})^{\vee}$ |
|                |                | 25                     |
|                |                |                        |
|                |                |                        |
| $(\bigcirc 5)$ |                |                        |
|                |                |                        |
|                | 25)            |                        |
|                | >              |                        |
|                |                |                        |
|                |                |                        |
|                |                |                        |
|                |                |                        |
|                |                |                        |

### 11.3 Function

Compare timer/counter 1 has three modes: timer, event counter, and programmable pulse generator output modes.

#### 11.3.1 Timer mode with software start

In this mode, the timer/counter (16-bit counter) counts up synchronously with the internal clock. When the counter value and the set value of Compare Timer Register 1A (CTC1DRA) match, an INTCTC1 interrupt is generated and the counter is cleared. After the counter is cleared, it restarts and continues counting up.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | NORMAL and IDLE Modes |                          |                 |                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------|-----------------|--------------------------|
| CTC1CK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | DV1C                  | CK = 0                   | DV1CK = 1       |                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Resolution [µs]       | Maximum Setting Time [s] | Resolution [µs] | Maximum Setting Time [s] |
| 000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 102.4                 | 6.71                     | 204,8           | 13.42                    |
| 001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 6.4                   | 0.419                    | 12.8            | 0.839                    |
| 010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1.6                   | 0.105                    | 3.2             | 0.210                    |
| 011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0.4                   | 26.21 m                  | 0.8             | 52.43 m                  |
| 100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0.2                   | 13.11 m                  | 0.4             | 26.21 m                  |
| 101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0.1                   | 6.55 m                   | 0.2             | 13.11 m                  |
| 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -                     |                          | -(7/\$          | -                        |
| Internal clock       Image: Counter       Image: O       Image: Counter       Image: Cou |                       |                          |                 |                          |
| Figure 11-2 Timer Mode Timing Chart                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       |                          |                 |                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       |                          |                 |                          |
| Note: If the CTC input port (P47) is set for input mode, the timer/counter is reset by an input edge on port.<br>When using the timer/counter as an ordinary timer, set CTC1CR2 <extrgdis> to 1 or set P47 for output mode.</extrgdis>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                          |                 |                          |

Table 11-1 Internal Clock Source for Compare Timer/Counter 1 (Example: fc = 20 MHz)

#### 11.3.2 Timer mode with external trigger start

In this timer mode, the timer/counter starts counting as triggered by input on CTC pin (rising or falling edge selected with CTC1CR1<CTC1SE>). The source clock is an internal clock. For successive cycles, when the counter value and the set value of the CTC1DRA Register match, an INTCTC1 interrupt is generated and the counter is cleared and then restarted. The counter is stopped by a trigger input on CTC pin and restarted by the next trigger input. For a one-shot cycle, when the counter value and the set value of the CTC1DRA Register match, an INTCTC1 interrupt is generated and the counter is cleared and stopped. The counter restarts counting up by input on CTC pin. When CTC1CR1<CTC1E> = 1, the counter is cleared and stops counting at an edge on CTC pin input opposite the active edge that triggers the counter to start counting. In this mode, an interrupt can be generated by entering a pulse which has a certain width. When CTC1CR1<CTC1E> = 0, opposite edges on CTC input are ignored.





(II) When rising start edge is selected, with counting enabled on both edges ( CTC1SE = 0, CTC1E = 1 )

### Figure 11-4 External Trigger Mode Timing Chart

### 11.3.3 Event counter mode

In this mode, the timer/counter counts up at the active edge on CTC pin input (rising or falling edge selected with the CTC1CR1<CTC1SE> which is provided for selecting external trigger edge). When the counter value and the set value of the CTC1DRA Register match, an INTCTC1 interrupt is generated and the counter is cleared. After the counter is cleared, it restarts and continues counting up at each edge on CTC pin input. The maximum applied frequency is shown in the table below. Because coincidence detection is made at an edge opposite the selected edge, the external clock signal on CTC pin must always be entered.



Figure 11-5 Event Counter Mode Timing Chart

| Table 11-2 External | Clock Source for | Compare T | imer/Counter 1 |
|---------------------|------------------|-----------|----------------|
|                     |                  |           |                |

|                                | NORMAL and IDLE Modes   |
|--------------------------------|-------------------------|
| Maximum applied frequency [Hz] | Up to fc/2 <sup>2</sup> |
| Minimum pulse width            | 2²/fc and over          |

### 11.3.4 Programmable Pulse Generate (PPG) output mode

The timer/counter starts counting as a command or edge on CTC pin input (rising/falling edge and one/both edges respectively selected with the CTC1CR1<CTC1SE> and CTC1CR1<CTC1E>). The source clock is an internal clock. When matched with the CTC1DR A/B/C Registers, the timer output F/F corresponding to each mode is inverted. When matched with the CTC1DR A/B/C Registers next time, the timer output F/F is inverted again. An INTCTC1 interrupt request is generated when the counter value matches the maximum register value set by CTC1CR2<CTCREG>. The timer output F/F is cleared to 0 when reset. Because CTC1CR2<CTC1FF0> can be used to set the initial value for the timer output F/F, an active-high or active-low pulse whichever is desired can be output. The CTC1DRB and CTC1DRC Registers cannot be accessed for write unless they are set for PPG output mode and the registers used are selected with CTC1CR2<CTC1REG>. The number of registers set can be altered during operation. In this case, however, be sure to set the number of registers used and write values to the data register before the next CTC1INIT1 is output after the first CTC1INIT1 output. Even when only altering the data register values while leaving the number of registers unchanged, be sure to do this within the same period of time.

|        | NORMAL and IDLE Modes                    |                 |                          |  |
|--------|------------------------------------------|-----------------|--------------------------|--|
| CTC1CK | DV1CK = 0                                | DV10            | CK = 1                   |  |
|        | Resolution [µs] Maximum Setting Time [s] | Resolution [µs] | Maximum Setting Time [s] |  |
| 000    | - (0) - (5)                              | -               | -                        |  |
| 001    |                                          | -               | -                        |  |
| 010    |                                          | - \             | -                        |  |
| 011    |                                          | -               | -                        |  |
| 100    | 0.2 13.11 m                              | -               | -                        |  |
| 101    | 0.1 6.55 m                               | 0.2             | 13.11m                   |  |
| 110    |                                          | -               | -                        |  |

Table 11-3 Internal Clock Source for Compare Timer/Counter 1 (Example: fc = 20 MHz)

Note: When Port P47 is set as a CTC input port, an edge input resets the timer/counter. when PPG output mode is selected and external trigger start is not used, set CTC1CR2<EXTRGDIS> to "1" or set P47 as an output port.

(I) One register used (CTC1REG = 00) When set to command start. Command start CTC pin input Counter 0 3 Timer Register A n PPG2 pin output INTCTC1 interrupt Successive Figure 11-6 One Register Command Start Mode Timing Chart.  $\bigcirc$ (II) Two registers used (CTC1REG = 01) When set to the external trigger rising edge start and the one edge enable. a) Successive Start Stop CTC pin input Internal clock Counter 0 m 0 Timer Register A m Timer Register B n PPG2 pin output Initial value INTCTC1 interrupt Successive b) One shot Start Start CTC pin input Internal clock Counter 0 m 0 Timer Register A m Timer Register B n PPG2 pin output INTCTC1 interrupt



One shot



When set to the external trigger rising edge start and the both edges enable.

Figure 11-8 Two Register Both edges Trigger Start Mode Timing Chart

| (III) Three registers<br>When set to co | s used (CTC1REG = 10)<br>ommand start.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| a) Successive                           | ommand start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CTC pin input                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Counter                                 | $\frac{1}{2} \times \frac{1}{2} \times \frac{1}$ |
| Timer Register A                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Timer Register B                        | X n h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Timer Register C                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PPG2 pin output                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| INTCTC1<br>interrupt                    | Successive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| b) One shot                             | ommand start Command restart                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CTC pin input                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Counter                                 | $ \underbrace{-0 \stackrel{!}{\underset{i}{}} \chi 1 \chi_{ij}^{ij} \chi m \chi m + 1 \chi_{ij}^{ij} \chi n \chi_{0} + 1 \chi_{ij}^{ij} \chi s \chi = 0 \qquad \chi 1 \chi_{ij}^{ij} \chi m \chi m + 1 $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Timer Register A                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Timer Register B                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Timer Register C                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PPG2 pin output                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| INTCTC1<br>interrupt                    | One shot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Note: In the single-shot mode, the PPG pin output is not toggled at the last register match; it stays at the value specified with CTC1CR2<CTC1FF0>.

Figure 11-9 Three Register Command Start Mode Timing Chart

Detail operation at start that varies depending on how CTC1CR2<CTC1FF0> and CTC1CR1<PPGFF0> are set during PPG output.



| CTC1FF0 = 0<br>PPGFF0 = 0 | CTC1FF0 setting<br>(write to CTC1CR1 Register) Or trigger start<br>Internal clock<br>Counter 0 1 2 3 0 n n+1 n+2 n+3<br>PPG output                   |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTC1FF0 = 1<br>PPGFF0 = 0 | CTC1FF0 setting<br>(write to CTC1CR1 Register) Command start<br>or trigger start<br>Internal clock<br>Counter 0 1 2 3 () n n+1 n+2 n+3<br>PPG output |
| CTC1FF0 = 0<br>PPGFF0 = 1 | CTC1FF0 setting<br>(write to CTC1CR1 Register) or trigger start<br>Internal clock<br>Counter<br>PPG output                                           |
| CTC1FF0 = 1<br>PPGFF0 = 1 | CTC1FF0.setting<br>(write to CTC1CR1 Register)<br>Internal clock<br>Counter<br>PPG output                                                            |

By changing the port-shared output for PPG output before the counter starts counting after setting CTC1CR2<CTC1FF0>, it is possible to determine the initial value of PPG output.

# 12. 8-Bit TimerCounter 3 (TC3)

# 12.1 Configuration



Note: Function input may not operate depending on I/O port setting. For more details, see the chapter "I/O Port".



12.2 TimerCounter Control

# 12.2 TimerCounter Control

The TimerCounter 3 is controlled by the TimerCounter 3 control register (TC3CR) and two 8-bit timer registers (TC3DRA and TC3DRB).



- Note 1: fc: High-frequency clock [Hz], \*: Don't care
- Note 2: Set the operating mode and source clock when TimerCounter stops (TC3CR<TC3S> = 0).
- Note 3: To set the timer registers, the following relationship must be satisfied.
  - TC3DRA > 1 (Timer/event counter mode)
- Note 4: Auto-capture (TC3CR<ACAP>) can be used only in the timer and event counter modes.
- Note 5: When the read instruction is executed to TC3CR, the bit 5 and 7 are read as a don't care.
- Note 6: Do not program TC3DRA when the timer is running (TC3CR<TC3S> = 1).
- Note 7: When the STOP mode is entered, the start control (TC3CR<TC3S>) is cleared to 0 automatically, and the timer stops. After the STOP mode is exited, TC3CR<TC3S> must be set again to use the timer counter.

### 12.3 Function

TimerCounter 3 has three types of operating modes: timer, event counter and capture modes.

#### 12.3.1 Timer mode

In the timer mode, the up-counter counts up using the internal clock. When a match between the up-counter and the timer register 3A (TC3DRA) value is detected, an INTTC3 interrupt is generated and the up-counter is cleared. After being cleared, the up-counter restarts counting. Setting TC3CR<ACAP> to 1 captures the up-counter value into the timer register 3B (TC3DRB) with the auto-capture function. The count value during timer operation can be checked by executing the read instruction to TC3DRB.

Note: 00H which is stored in the up-counter immediately after detection of a match is not captured into TC3DRB. (Figure 12-2)



Table 12-1 Source Clock for TimerCounter 3 (Example: fc = 20 MHz)

|        |                           |                   |                           | $\sim$             |                              |
|--------|---------------------------|-------------------|---------------------------|--------------------|------------------------------|
| ٦      | тсзск                     | NORMAL, IDLE mode |                           |                    |                              |
| <      | $\langle \langle \rangle$ |                   | DV1CK = 0                 | <i>J</i>           | DV1CK = 1                    |
|        |                           | Resolution        | Maximum Time Setting [ms] | Resolution<br>[µs] | Maximum Time Setting<br>[ms] |
| $\sim$ | 000                       | 409.6             | 104.45                    | 819.2              | 208.90                       |
| Z/L    | 001                       | 204.8             | 52.22                     | 409.6              | 104.45                       |
|        | 010                       | 102.4             | 26.11                     | 204.8              | 52.22                        |
|        | 011                       | 51.2              | 13.06                     | 102.4              | 26.11                        |
|        | 100                       | 25.6              | 6.53                      | 51.2               | 13.06                        |
|        | 101                       | 12.8              | 3.06                      | 25.6               | 6.53                         |
|        | 110                       | 6.4               | 1.63                      | 12.8               | 3.06                         |
| $\sim$ |                           | $\sim$            |                           |                    |                              |


#### 12.3.2 **Event Counter Mode**

In the event counter mode, the up-counter counts up at the rising edge of the input pulse to the TC3 pin.

When a match between the up-counter and TC3DRA value is detected, an INTTC3 interrupt is generated and up-counter is cleared. After being cleared, the up-counter restarts counting at each rising edge of the input pulse to the TC3 pin. Since a match is detected at the falling edge of the input pulse to TC3 pin, an INTTC3 interrupt request is generated at the falling edge immediately after the up-counter reaches the value set in TC3DRA.

The maximum applied frequencies are shown in Table 12-2. The pulse width larger than one machine cycle is required for high-going and low-going pulses.

Setting TC3CR<ACAP> to 1 captures the up-counter value into TC3DRB with the auto-capture function. The count value during a timer operation can be checked by the read instruction to TC3DRB.

Note:00H which is stored in the up-counter immediately after detection of a match is not captured into TC3DRB. (Figure 12-2)

Example : Inputting 50 Hz pulse to TC3, and generating interrupts every 0.5 s

| LD | (TC3CR), 00001110B | : Sets the clock mode     |
|----|--------------------|---------------------------|
| LD | (TC3DRA), 19H      | : 0.5 s ÷ 1/50 = 25 = 19H |
| LD | (TC3CR), 00011110B | : Starts TC3.             |

Table 12-2 Maximum Frequencies Applied to TC3



#### 12.3.3 Capture Mode

In the capture mode, the pulse width, frequency and duty cycle of the pulse input to the TC3 pin are measured with the internal clock. The capture mode is used to decode remote control signals, and identify AC50/60 Hz.

When the falling edge of the TC3 input is detected after the timer starts, the up-counter value is captured into TC3DRB. Hereafter, whenever the rising edge is detected, the up-counter value is captured into TC3DRA and the INTTC3 interrupt request is generated. The up-counter is cleared at this time. Generally, read TC3DRB and TC3DRA during INTTC3 interrupt processing. After the up-counter is cleared, counting is continued and the next up-counter value is captured into TC3DRB.

When the rising edge is detected immediately after the timer starts, the up-counter value is captured into TC3DRA only, but not into TC3DRB. The INTTC3 interrupt request is generated. When the read instruction is executed to TC3DRB at this time, the value at the completion of the last capture (FF immediately after a reset) is read.

The minimum input pulse width must be larger than one cycle width of the source clock programmed in TC3CR<TC3CK>.

The INTTC3 interrupt request is generated if the up-counter overflow (FFH) occurs during capture operation before the edge is detected. TC3DRA is set to FFH and the up-counter is cleared. Counting is continued by the up-counter, but capture operation and overflow detection are stopped until TC3DRA is read. Generally, read TC3DRB first because capture operation and overflow detection resume by reading TC3DRA.

>

|                                                                                             | Timer start |               |                     |                   |                                      |         |                        |
|---------------------------------------------------------------------------------------------|-------------|---------------|---------------------|-------------------|--------------------------------------|---------|------------------------|
| TC3CR <tc3s< td=""><td>·</td><td></td><td></td><td></td><td></td><td></td><td></td></tc3s<> | ·           |               |                     |                   |                                      |         |                        |
| Source<br>clock                                                                             |             |               |                     |                   | μ'nπ                                 |         |                        |
| Counter                                                                                     |             |               | 0X1X <b>,</b> ,Xm1X |                   | $\sqrt{0}$ $1$ $\sqrt{2}$ $\sqrt{3}$ | X,XER   | ) <b>X</b> 1 X 2 X 3 X |
| TC3 pin input                                                                               |             |               | )<br>د              |                   |                                      |         |                        |
| Internal wavefo                                                                             | rm          |               | Capture             | $\langle \rangle$ | Capture                              |         | ţ                      |
| TC3DRA                                                                                      |             | Capture       | k                   | Capture           | X n                                  | Capture | FF (Overflow)          |
| TC3DRB                                                                                      |             |               |                     | m                 |                                      | FE      |                        |
| INTTC3<br>interrupt reques                                                                  | st          | [             |                     |                   | Л                                    |         |                        |
| Read of TC3DF                                                                               | RA          | $\sum \alpha$ |                     |                   |                                      |         |                        |
|                                                                                             |             | ला            |                     |                   |                                      |         |                        |
|                                                                                             |             | Figure 12-    | -5 Capture N        | lode Timing (     | Chart                                |         |                        |
| $\leq$                                                                                      |             | $\mathcal{Q}$ | )                   |                   |                                      |         |                        |
|                                                                                             |             | $\sim$        |                     |                   |                                      |         |                        |

## TOSHIBA

# 13. 8-Bit TimerCounter 4 (TC4)

## 13.1 Configuration



### 13.2 TimerCounter Control

The TimerCounter 4 is controlled by the TimerCounter 4 control register (TC4CR) and timer registers 4 (TC4DR).



- Note 1: fc: High-frequency clock [Hz], \*: Don't care
- Note 2: To set the timer registers, the following relationship must be satisfied.  $1 \le TC4DR \le 255$
- Note 3: To start timer operation (TC4CR<TC4S> =  $0 \rightarrow 1$ ) or disable timer operation (TC4CR<TC4S> =  $1 \rightarrow 0$ ), do not change the TC4CR<TC4M, TC4CK> setting. During timer operation (TC4CR<TC4S> =  $1 \rightarrow 1$ ), do not change it, either. If the setting is programmed during timer operation, counting is not performed correctly.
- Note 4: The event counter and PWM output modes are used only in the NOMAL and IDLE modes.
- Note 5: When the STOP mode is entered, the start control (TC4S) is cleared to "0" automatically.
- Note 6: The bit 6 and 7 of TC4CR are read as a don't care when these bits are read.
- Note 7: In the timer, event counter and PDO modes, do not change the TC4DR setting when the timer is running.
- Note 8: When the high-frequency clock fc exceeds 10 MHz, do not select the source clock of TC4CR< TC4CK> = 110.
- Note 9: For available source clocks depending on the operation mode, refer to the following table.

|        |       | $A \rightarrow ($ | ( ) )      |                    |          |          |
|--------|-------|-------------------|------------|--------------------|----------|----------|
|        |       | $\langle \rangle$ | Timer Mode | Event Counter Mode | PDO Mode | PWM Mode |
|        |       | 000               | 0          | -                  | 0        | -        |
| $\sim$ |       | 001               | > o        | -                  | 0        | -        |
|        |       | 010               | 0          | -                  | 0        | -        |
|        | TC4CK | 011               | 0          | -                  | -        | 0        |
|        |       | 100               | -          | -                  | -        | 0        |
|        |       | 101               | -          | -                  | -        | 0        |
|        |       | 110               | -          | -                  | -        | 0        |
|        |       | 111               | -          | 0                  | -        | ×        |

Note: O : Available source clock

### 13.3 Function

TimerCounter 4 has four types of operating modes: timer, event counter, programmable divider output (PDO), and pulse width modulation (PWM) output modes.

#### 13.3.1 Timer Mode

In the timer mode, the up-counter counts up using the internal clock. When a match between the up-counter and the TC4DR value is detected, an INTTC4 interrupt is generated and the up-counter is cleared. After being cleared, the up-counter restarts counting.

|       | _          |                      |            |                      |                          |  |  |
|-------|------------|----------------------|------------|----------------------|--------------------------|--|--|
| TC4CK |            | NORMAL, IDLE Mode    |            |                      |                          |  |  |
|       |            | DV1CK = 0            | 2          | DV1CK = 1            | $\langle \frown \rangle$ |  |  |
|       | Resolution | Maximum Time Setting | Resolution | Maximum Time Setting |                          |  |  |
|       | [µs]       | [ms]                 |            | [ms]                 | $\sim$                   |  |  |
| 000   | 102.4      | 26.11                | 204.8      | 52.22                | $\sim$                   |  |  |
| 001   | 6.4        | 1.63                 | 12.8       | 3.28                 |                          |  |  |
| 010   | 1.6        | 0.41                 | 3.2        | 0.82                 |                          |  |  |
| 011   | 0.4        | 0.10                 | 0.8        | 0.20                 |                          |  |  |
|       |            |                      |            | $\sim$               | -                        |  |  |

Table 13-1 Internal Source Clock for TimerCounter 4 (Example: fc = 20 MHz)

#### 13.3.2 Event Counter Mode

In the event counter mode, the up-counter counts up at the rising edge of the input pulse to the TC4 pin.

When a match between the up-counter and the TC4DR value is detected, an INTTC4 interrupt is generated and the up-counter is cleared. After being cleared, the up-counter restarts counting at rising edge of the TC4 pin. Since a match is detected at the falling edge of the input pulse to the TC4 pin, the INTTC4 interrupt request is generated at the falling edge immediately after the up-counter reaches the value set in TC4DR.

The minimum pulse width applied to the TC4 pin are shown in Table 13-2. The pulse width larger than two machine cycles is required for high- and low-going pulses.

Note: The event counter mode can used in the NORMAL and IDLE modes only.



Table 13-2 External Source Clock for TimerCounter 4

| $\mathcal{A}($ | Minimum Pulse Width |
|----------------|---------------------|
|                | NORMAL, IDLE mode   |
| High-going     | 2 <sup>3</sup> /fc  |
| Low-going      | 2³/fc               |
| 2              |                     |

#### 13.3.3 Programmable Divider Output (PDO) Mode

The programmable divider output (PDO) mode is used to generated a pulse with a 50% duty cycle by counting with the internal clock.

When a match between the up-counter and the TC4DR value is detected, the logic level output from the  $\overline{PDO4}$  pin is switched to the opposite state and INTTC4 interrupt request is generated. The up-counter is cleared at this time and then counting is continued. When a match between the up-counter and the TC4DR value is detected, the logic level output from the  $\overline{PDO4}$  pin is switched to the opposite state again and INTTC4 interrupt request is generated. The up-counter is cleared at this time, and then counting and PDO are continued.

When the timer is stopped, the  $\overline{PDO4}$  pin is high. Therefore, if the timer is stopped when the  $\overline{PDO4}$  pin is low, the duty pulse may be shorter than the programmed value.



#### 13.3.4 Pulse Width Modulation (PWM) Output Mode

The pulse width modulation (PWM) output mode is used to generate the PWM pulse with up to 8 bits of resolution by an internal clock.

When a match between the up-counter and the TC4DR value is detected, the logic level output from the  $\overline{PWM4}$  pin becomes low. The up-counter continues counting. When the up-counter overflow occurs, the  $\overline{PWM4}$  pin becomes high. The INTTC4 interrupt request is generated at this time.

When the timer is stopped, the  $\overline{PWM4}$  pin is high. Therefore, if the timer is stopped when the  $\overline{PWM4}$  pin is low, one PMW cycle may be shorter than the programmed value.

TC4DR is serially connected to the shift register. If TC4DR is programmed during PWM output, the data set to TC4DR is not shifted until one PWM cycle is completed. Therefore, a pulse can be modulated periodically. For the first time, the data written to TC4DR is shifted when the timer is started by setting TC4CR<TC4S> to 1.

Note 1: The PWM output mode can be used only in the NORMAL and IDEL modes.

Note 2: In the PWM output mode, program TC4DR immediately after the INTTC4 interrupt request is generated (typically in the INTTC4 interrupt service routine.) When the programming of TC4DR and the INTTC4 interrupt occur at the same time, an unstable value is shifted, that may result in generation of pulse different from the programmed value until the next INTTC4 interrupt request is issued.

TOSHIBA



## 14. Motor Control Circuit (PMD: Programmable motor driver)

The TMP88F846UG contains one channel of motor control circuits used for sinusoidal waveform output. This motor control circuit can control brushless DC motors or AC motors with or without sensors. With its primary functions like those listed below incorporated in hardware, it helps to accomplish sine wave motor control easily, with the software load significantly reduced.

- 1. Rotor position detect function
  - Can detect the rotor position, with or without sensors
  - Can be set to determine the rotor position when detection matched a number of times, to prevent erroneous detection
  - · Can set a position detection inhibit period immediately after PWM-on
- 2. Independent timer and timer capture functions for motor control
  - Contains one-channel magnitude comparison timer and two-channel coincidence comparison timers that operate synchronously for position detection
- 3. PWM waveform generating function
  - Generates 12-bit PWM with 100 ns resolution
  - · Can set a frequency of PWM interrupt occurrence
  - Can set the dead time at PWM-on
- 4. Protective function
  - · Provides overload protective function based on protection signal input
- 5. Emergency stop function in case of failure
  - Can be made to stop in an emergency by EMG input or timer overflow interrupt
  - · Not easily cleared by software runaway
- 6. Auto commutation/Auto position detection start function
  - Comprised of dual-buffers, can activate auto commutation synchronously with position detection or timer
  - Can set a position detection period using the timer function and start auto position detection at the set time
- 7. Electrical angle timer function
  - Can count 360 degrees of electrical angle with a set period in the range of 0 to 383
  - Can output the counted electrical angle to the waveform arithmetic circuit
- 8. Waveform arithmetic circuit
  - Calculate the output duty cycle from the sine wave data and voltage data which are read from the RAM based on the electrical angle timer
  - · Output the calculation result to the waveform synthesis circuit

### 14.1 Outline of Motor Control

The following explains the method for controlling a brushless DC motor with sine wave drive. In a brushless DC motor, the rotor windings to which to apply electric current are determined from the rotor's magnetic pole position, and the current-applied windings are changed as the rotor turns. The rotor's magnetic pole position is determined using a sensor such as a hall IC or by detecting polarity change (zero-cross) points of the induced voltage that develops in the motor windings (sensorless control). For the sensorless case, the induced voltage is detected by applying electric current to two phases and not applying electric current to the remaining other phase. In this two-phase current on case, there are six current application patterns as shown in Table 14-1, which are changed synchronously with the phases of the rotor. In this two-phase current on case, the current on time in each phase is 120 degrees relative to 180 degrees of the induced voltage.

| Current        |        | Up  | per Transis | stor | Lo    | wer Transis | stor |                    |
|----------------|--------|-----|-------------|------|-------|-------------|------|--------------------|
| Application Pa | attern | u   | v           | w    | x     | ) [x        | z    | Current on Winding |
| Mode 0         |        | ON  | OFF         | OFF  | OFF   | ON          | OFF  | U→V>               |
| Mode 1         |        | ON  | OFF         | OFF  | OFF ( | ØFF         | ON   | U→W                |
| Mode 2         |        | OFF | ON          | OFF  | OFF   | OFF         | ON   | V→W                |
| Mode 3         |        | OFF | ON          | OFF  | ON    | QFF         | OFF  | VəU                |
| Mode 4         |        | OFF | OFF         | ON   | ON    | OFF         | OFF  | W→U                |
| Mode 5         |        | OFF | OFF         | ON   | OFF   | ON          | OFF  | W→V                |

| Table 14-1 | <b>Current Application Patterns</b> |
|------------|-------------------------------------|
|------------|-------------------------------------|

Note: One of the upper or lower transistors is PWM controlled.

For brushless DC motors, the number of revolutions is controlled by an applied voltage, and the voltage application is controlled by PWM. At this time, the current on windings need to be changed in synchronism with the phases of the voltage induced by revolutions. Control timing in cases where the current on windings are changed by means of sensorless control is illustrated in Figure 14-4. For three-phase motors, zero-crossing occurs six times during one cycle of the induced voltage (electrical angle 360 degrees), so that the electrical angle from one zero-cross point to the next is 60 degrees. Assuming that this period comprises one mode, the rotor position can be divided into six modes by zero-cross points. The six current application patterns shown above correspond one for one to these six modes. The timing at which the current application patterns are changed (commutation) is out of phase by 30 degrees of electrical angle, with respect to the position detection by an induced voltage.

Mode time is obtained by detecting a zero-cross point at some timing and finding an elapsed time from the preceding zero-cross point. Because mode time corresponds to 60 degrees of electrical angle, the following applies for the case illustrated in Figure 14-4.

1. Current on windings changeover (commutation) timing

30 degrees of electrical angle = mode time/2

2. Position detection start timing 45 degrees of electrical angle = mode time  $\times 3/4$ 

3. Failure determination timing 120 degrees of electrical angle = mode time  $\times 2$ 

Timings are calculated in this way. The position detection start timing in 2 is needed to prevent erroneous detection of the induced voltage for reasons that even after current application is turned off, the current continues flowing due to the motor reactance.

Control is exercised by calculating the above timings successively for each of the zero-cross points detected six times during 360 degrees of electrical angle and activating commutation, position detection start, and other operations according to that timing.

In this way, operations can be synchronized to the phases of the induced voltage of the motor.

The timing needed for motor control as in this example can be set freely as desired by using the internal timers of the microcontroller's PMD unit.

Also, sine wave control requires controlling the PWM duty cycle for each pulse. Control of PWM duty cycles is accomplished by counting degrees of electrical angle and calculating the sine wave data and voltage data at the counted degree of electrical angle.



Figure 14-2 Example of Sensorless DC Motor Control Timing Chart

## 14.2 Configuration of the Motor Control Circuit

The motor control circuit consists of various units. These include a position detection unit to detect the zero-cross points of the induced voltage or position sensor signal, a timer unit to generate events at three instances of electrical angle timing, and a three-phase PWM output unit to produce three-phase output PWM waveforms. Also included are an electrical angle timer unit to count degrees of electrical angle and a waveform arithmetic unit to calculate sinusoidal waveform output duty cycles. The input/output units are configured as shown in the diagram below. When using ports for the PMD function, set the Port input/output control register (P3CRi) to 0 for the input ports, and for the output ports, set the data output latch (P3i) to 1 and then the port input/output control register to 1. Other input/output ports can be set in the same way for use of the PMD function.



#### Figure 14-3 Block Diagram of the Motor Control Circuit

- Note 1: Always use the LDW instruction to set data in the 9, 12 and 16-bit data registers.
- Note 2: The EMG circuit initially is enabled. For PMD output, fix the EMG input port (P36) "H" high level or disable the EMG circuit before using for PMD output.
- Note 3: The EMG circuit initially is enabled. When using Port P3 as input/output IO ports, disable EMG.
- Note 4: When going to STOP mode, be sure to turn all of the PMD functions off before entering STOP mode.



## 14.3 Position Detection Unit

The Position Detection Unit identifies the motor's rotor position from input patterns on the position signal input port. Applied to this position signal input port is the voltage status of the motor windings for the case of sensorless DC motors or a Hall element signal for the case of DC motors with sensors included. The expected patterns corresponding to specific rotor positions are set in the PMD Output Register (MDOUT) beforehand, and when the input position signal and the expected value match as the rotation, a position detection interrupt (INTPDC) is generated. Also, unmatch detection mode is used to detect the direction of motor rotation, where when the status of the position detection interrupt is generated.

For three-phase brushless DC motors, there are six patterns of position signals, one for each mode, as summarized in Table 14-2 from the timing chart in Figure 14-2. Once a predicted position signal pattern is set in the MDOUT register, a position detection interrupt is generated the moment the position signal input port goes to mode indicated by this expected value. The position signals at each phase in the diagram are internal signals which cannot be observed from the outside.

|                            |                   | $\langle \langle \rangle$ | $\sim$        | $\langle \rangle$ $ h\rangle$ |
|----------------------------|-------------------|---------------------------|---------------|-------------------------------|
| Table 14-2 Posi            | tion Signal Input | Patterns                  | $\rightarrow$ | $\leq$                        |
| Position<br>Detection Mode | U Phase (PDU)     | V Phase (PDV)             | W Phase (PDW) | 20                            |
| Mode 0                     | Н                 |                           | H C           | $\geq$                        |
| Mode 1                     | н <               |                           |               |                               |
| Mode 2                     | н                 | Н                         |               |                               |
| Mode 3                     | L                 | 💛 н                       | (V(L))        |                               |
| Mode 4                     | $\mathcal{L}$     | > н/                      | Н             |                               |
| Mode 5                     |                   | L                         | н             |                               |
|                            |                   |                           |               |                               |





#### Figure 14-4 Configuration of the Position Detection Circuit

• The position detection unit is controlled by the Position Detection Control Register (PDCRA, PDCRB). After the position detection function is enabled, the unit starts sampling the position detection port with Timer 2 or in software. For the case of ordinary mode, when the status of the position detection input port matches the expected value of the PMD Output Register, the unit generates a position detection interrupt/and finishes sampling, waiting for start of the next sampling.

When unmatch detection mode is selected for position detection, the unit stores the sampled status of the position detection port in memory at the time it started sampling. When the port input status changes from the status in which it was at start of sampling, an interrupt is generated.

- In unmatch detection mode, the port status at start of sampling can be read (PDCRC<PDTCT>).
- When starting and stopping position detection synchronously with the timer, position detection is started by Timer 2 and position detection is stopped by Timer 3.
- Sampling mode can be selected from three modes available: mode where sampling is performed only while PWM is on, mode where sensors such as Hall elements are sampled regularly, and mode where sampling is performed while the lower side is conducting current (when performing sampling only while PWM is on, DUTY must be set for all three phases in common).
- When sampling mode is selected for detecting position while the lower phases are conducting current, sampling is performed for a period from when the set sampling delay time has elapsed after the lower side started conducting current till when the current application is turned off. Sampling is performed independently at each phase, and the sampling result is retained while sampling is idle. If while sampling at some phase is idle, the input and the expected value at other phase being sampled match, position is detected and an interrupt is generated.

- A sampling delay is provided for use in modes where sampling is made while PWM is on or the lower phases are conducting current. It helps to prevent erroneous detection due to noise that occurs immediately after the transistor turns on, by starting sampling a set time after the PWM signal turned on.
- When detecting position while PWM is on or the lower phases are conducting current, a method can be selected whether to recount occurrences of matched position detection after being compared for each PWM signal on (logical sum of three-phase PWM signals) (e.g., starting from 0 in each PWM cycle) or counting occurrences of matching continuously (PDCRB<SPLMD> is used to enable/disable recounting occurrences of matching while PWM is on).

 $( \langle \frown \rangle$ 

#### 14.3.2 Position Detection Circuit Register Functions

| PDCRC  |       |                                                                                                |                                                                                                                                                                                                                                                                                                                                      |
|--------|-------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5, 4   | EMEM  | Hold result of position detec-<br>tion at PWM edge<br>(Detect position detected po-<br>sition) | These bits hold the comparison result of position detection at falling or rising edge of PWM pulse. Bits 5 and 4 are set to 1 when position is detected at the falling or the rising edge, respectively. They show whether position is detected in the current PWM pulse, during PWM off, or in the immediately preceding PWM pulse. |
| 3      | SMON  | Monitor sampling status                                                                        | When read, this bit shows the sampling status.                                                                                                                                                                                                                                                                                       |
| 2 to 0 | PDTCT | Hold position signal input sta-<br>tus                                                         | This bit holds the status of the position signal input at the time position detection started in unmatch mode.                                                                                                                                                                                                                       |

| PDCRB  |       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7, 6   | SPLCK | Sampling period | Select fc/2 <sup>2</sup> , fc/2 <sup>3</sup> , fc/2 <sup>4</sup> , or fc/2 <sup>5</sup> for the position detection sampling period.                                                                                                                                                                                                                                                                                          |
| 5, 4   | SPLMD | Sampling mode   | Select one of three modes: sampling only when PWM signal is active (when PWM is on), sampling regularly, or sampling when the lower side (X, Y, Z) phases are conducting current.                                                                                                                                                                                                                                            |
| 3 to 0 | PDCMP | Sampling count  | In ordinary mode, when the port status and the set expected value match and continuously match as many times as the sampling counts set, a position detection signal is output and an interrupt is generated. In unmatch detection mode, when the said status and value do not match and continuously unmatch as many times as the sampling counts set, a position detection signal is output and an interrupt is generated. |
|        |       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                              |

| PDCRA |         |                                                |                                                                                                                                                                                                                                                                                                                                                         |
|-------|---------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | SWSTP   | Stop sampling in software                      | Sampling can be stopped in software by setting this bit to 1 (e.g., by writing to this register). Sampling is performed before stopping and when position detection results match, a position detection interrupt is generated, with sampling thereby stopped.                                                                                          |
| 6     | swstt < | Start sampling in software                     | Sampling can be started by setting this bit to 1 (e.g., by writing to this register).                                                                                                                                                                                                                                                                   |
| 5     | SPTM3   | Stop sampling using Timer 3                    | Sampling can be stopped by a trigger from Timer 3 by setting this bit to 1.<br>Sampling is performed before stopping and when position detection results match, a po-<br>sition detection interrupt is generated, with sampling thereby stopped.                                                                                                        |
| 4     | STTM2   | Start sampling using Timer 2                   | Sampling can be started by a trigger from Timer 3 by setting this bit to 1.                                                                                                                                                                                                                                                                             |
| 3     | PDNUM   | Number of position signal in-<br>put pins      | Select whether to use three pins (PDU/PDV/PDW) or one pin (PDU only) for position signal input. When one pin is selected, the expected values of PDV and PDW are ignored. When performing position detection with two pins or a pin other than PDU, position signal input can be masked as 0 by setting unused pin(s) for output.                       |
| 2     | RCEN    | Recount occurrences of matching when PWM is on | When performing sampling while PWM is on, occurrences of matching are recounted each time PWM signal turns on by setting this bit to 1 (when recounting occurrences of matching, the count is reset each time PWM turns off). When this bit is set to 0, occurrences of matching are counted continuously regardless PWM interval.                      |
| 1     | DTMD    | Position detection mode                        | Setting this bit to 0 selects ordinary mode where position is detected when the expected value set in the register and the port input unmatch and then match. Setting this bit to 1 selects unmatch detection mode where position is detected at the time the port status changes to another one from the status in which it was when sampling started. |
| 0     | PDCEN   | Position detection function                    | The position detection function is activated by setting this bit to 1.                                                                                                                                                                                                                                                                                  |

SDREG

| 6 to 0 | SDREG | Sampling delay | Set a time for which to stop sampling in order to prevent erroneous detection due to noise that occurs immediately after PWM output turns on (immediately after the transistor turns on). (Figure 14-5) |
|--------|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|--------|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

14.3 Position Detection Unit



## Figure 14-5 Position Detection Sampling Timing with the PWMON Period Selected



## TOSHIBA

| PDCRC                    | 7                                                         | 6                                                                                  | 5 4                                                                                                                                                                                                                                                      | 3                 | 2                                                                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                   |                                                              |       |
|--------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------------|-------|
| 01FA2H)                  | -                                                         | - [                                                                                | EMEM                                                                                                                                                                                                                                                     | SMON              |                                                                                                                                                                                                                                                                                                                 | PDTCT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                     | (Initial value: **00 0000)                                   |       |
|                          |                                                           |                                                                                    |                                                                                                                                                                                                                                                          |                   |                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     |                                                              |       |
| Г                        |                                                           |                                                                                    | 1                                                                                                                                                                                                                                                        |                   | 00: Detecto                                                                                                                                                                                                                                                                                                     | d in the e                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | urrent nulo                                         |                                                              | 1     |
|                          |                                                           |                                                                                    | Hold result of positi                                                                                                                                                                                                                                    | on detection      | 00: Detecte<br>01: Detecte                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -                                                   |                                                              |       |
|                          | 5, 4                                                      | EMEM                                                                               | at PWM edge (Dete<br>detected position)                                                                                                                                                                                                                  | ect position      | 10: Detecte                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     |                                                              |       |
|                          |                                                           |                                                                                    |                                                                                                                                                                                                                                                          |                   | 11: Detecte                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     |                                                              |       |
| _                        |                                                           |                                                                                    |                                                                                                                                                                                                                                                          |                   | 0: Sampling                                                                                                                                                                                                                                                                                                     | g idle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | $\sum$                                              |                                                              | - R   |
|                          | 3                                                         | SMON                                                                               | Monitor sampling st                                                                                                                                                                                                                                      | tatus             | 1: Sampling                                                                                                                                                                                                                                                                                                     | g in progre                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ess (                                               |                                                              |       |
|                          | 2 to 0                                                    | PDTCT                                                                              | Hold position signal                                                                                                                                                                                                                                     | l input status    |                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     | signal input during unmatch detection<br>W, V, and U phases. |       |
| _                        |                                                           |                                                                                    |                                                                                                                                                                                                                                                          |                   |                                                                                                                                                                                                                                                                                                                 | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | $\square$                                           |                                                              | -     |
|                          | 7                                                         | 6                                                                                  | 5 4                                                                                                                                                                                                                                                      | 3                 | 2                                                                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                   |                                                              |       |
| PDCRB                    |                                                           | SPLCK                                                                              | SPLMD                                                                                                                                                                                                                                                    |                   | PDCM                                                                                                                                                                                                                                                                                                            | /P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                     | (Initial value: 0000 0000)                                   |       |
| D1FA1H)                  |                                                           |                                                                                    | -                                                                                                                                                                                                                                                        |                   |                                                                                                                                                                                                                                                                                                                 | WC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ))                                                  |                                                              |       |
| _                        |                                                           |                                                                                    | 4                                                                                                                                                                                                                                                        |                   | C                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     |                                                              |       |
|                          |                                                           |                                                                                    |                                                                                                                                                                                                                                                          |                   | 00: fc/2 <sup>2</sup> [H                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     |                                                              |       |
|                          | 7,6                                                       | SPLCK                                                                              | Select sampling inp                                                                                                                                                                                                                                      | out clock         | 01: fc/23 (4)                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     |                                                              |       |
|                          | , -                                                       |                                                                                    |                                                                                                                                                                                                                                                          | 6                 | 10: fc/24 (80                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     | 77^                                                          |       |
| -                        |                                                           |                                                                                    |                                                                                                                                                                                                                                                          | (                 | 11: fc/2⁵ (1.                                                                                                                                                                                                                                                                                                   | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ( V                                                 | <u>/_))</u>                                                  | -     |
|                          |                                                           |                                                                                    |                                                                                                                                                                                                                                                          | 00: Sample        |                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                     | R/                                                           |       |
|                          | 5.4                                                       | SPLMD                                                                              | Sampling mode                                                                                                                                                                                                                                            |                   | 01: Sample                                                                                                                                                                                                                                                                                                      | / -/ -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                     | and all a second                                             |       |
|                          | σ, .                                                      |                                                                                    |                                                                                                                                                                                                                                                          |                   | N10: Sample                                                                                                                                                                                                                                                                                                     | e when low                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | er phases                                           | conducting current                                           |       |
|                          | 0, 1                                                      |                                                                                    | (                                                                                                                                                                                                                                                        | $\langle \rangle$ | Y                                                                                                                                                                                                                                                                                                               | od ho                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                     |                                                              |       |
| -                        | 0, 1                                                      |                                                                                    | Desition detection                                                                                                                                                                                                                                       |                   | 11: Reserve                                                                                                                                                                                                                                                                                                     | ed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | $\searrow//$                                        |                                                              | -     |
| -                        | 3 to 0                                                    | PDCMP                                                                              | Position detection r<br>counts                                                                                                                                                                                                                           | matched           | 11: Reserve                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | s 0 and 1 ar                                        | e assumed to be one time.)                                   | -     |
| -                        | - ,                                                       | PDCMP                                                                              |                                                                                                                                                                                                                                                          | matched           | 11: Reserve                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | s 0 and 1 ar                                        | e assumed to be one time.)                                   |       |
| Note                     | 3 to 0                                                    |                                                                                    | counts                                                                                                                                                                                                                                                   | $\hat{)}$         | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                     |                                                              |       |
| Note                     | 3 to 0                                                    |                                                                                    |                                                                                                                                                                                                                                                          | $\hat{)}$         | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                     |                                                              |       |
| Note                     | 3 to 0                                                    |                                                                                    | counts                                                                                                                                                                                                                                                   | $\hat{)}$         | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                     |                                                              |       |
| Note                     | 3 to 0                                                    |                                                                                    | counts                                                                                                                                                                                                                                                   | $\hat{)}$         | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ion detect                                          |                                                              |       |
|                          | 3 to 0                                                    |                                                                                    | counts                                                                                                                                                                                                                                                   | $\hat{)}$         | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                     |                                                              |       |
| PDCRA                    | 3 to 0                                                    | changing sett                                                                      | ing, keep the PDCI                                                                                                                                                                                                                                       | $\hat{)}$         | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ion detect                                          |                                                              |       |
| PDCRA                    | 3 to 0                                                    | changing sett                                                                      | counts                                                                                                                                                                                                                                                   | EN bit reset      | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts<br>ble posit                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ion detect                                          | ion function).                                               | -     |
| Note<br>PDCRA<br>01FA0H) | 3 to 0                                                    | changing sett                                                                      | counts                                                                                                                                                                                                                                                   | EN bit reset      | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts<br>ble posit                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ion detect                                          | ion function).                                               |       |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SWST                          | changing sett                                                                      | counts<br>ing, keep the PDCI<br>5 4<br>SPTM3 STTM2                                                                                                                                                                                                       | EN bit reset      | 11: Reserve                                                                                                                                                                                                                                                                                                     | es (Counts<br>ble posit<br>1<br>DTMD                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ion detect                                          | ion function).                                               |       |
| PDCRA                    | 3 to 0                                                    | changing sett                                                                      | counts                                                                                                                                                                                                                                                   | EN bit reset      | 11: Reservent<br>1 to 15 time<br>to "0" (disa                                                                                                                                                                                                                                                                   | es (Counts<br>ble posit<br>1<br>DTMD                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ion detect                                          | ion function).                                               |       |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SwsT<br>7                     | changing sett                                                                      | counts   ing, keep the PDCI   5 4   SPTM3 STTM2   Stop sampling in so                                                                                                                                                                                    | EN bit reset      | 11: Reservent<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No operation                                                                                                                                                                                                                                   | ble posit                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ion detect                                          | ion function).                                               | -<br> |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SWST                          | changing sett                                                                      | counts<br>ing, keep the PDCI<br>5 4<br>SPTM3 STTM2                                                                                                                                                                                                       | EN bit reset      | 11: Reservent<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san                                                                                                                                                                                                                        | tion<br>npling<br>ation                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ion detect                                          | ion function).                                               |       |
| PDCRA                    | 3 to 0<br>2: When 0<br>7<br>5WST<br>7<br>6                | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT                                    | counts   ing, keep the PDCI   5 4   5 4   SPTM3 STTM2   Stop sampling in so   Start sampling in so                                                                                                                                                       | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop sam<br>0: No opera                                                                                                                                                                                                           | tion<br>npling<br>ation                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ion detect                                          | ion function).                                               |       |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SwsT<br>7                     | changing sett                                                                      | counts   ing, keep the PDCI   5 4   SPTM3 STTM2   Stop sampling in so                                                                                                                                                                                    | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start san                                                                                                                                                                                           | tion<br>npling<br>ation                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ion detect                                          | ion function).                                               |       |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SWST<br>7<br>6<br>5           | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3                           | counts   ing, keep the PDCI   5 4   5 4   SPTM3 STTM2   Stop sampling in so   Start sampling in so   Stop sampling usin                                                                                                                                  | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start san<br>0: Disable                                                                                                                                                                             | tion<br>npling<br>ation                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ion detect                                          | ion function).                                               |       |
| PDCRA                    | 3 to 0<br>2: When 0<br>7<br>5WST<br>7<br>6                | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT                                    | counts   ing, keep the PDCI   5 4   5 4   SPTM3 STTM2   Stop sampling in so   Start sampling in so                                                                                                                                                       | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start sar<br>0: Disable<br>1: Enable                                                                                                                                                                | tion<br>npling<br>ation                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ion detect                                          | ion function).                                               | - v   |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SWST<br>7<br>6<br>5           | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3<br>STTM2                  | counts     ing, keep the PDCI     5   4     5   4     SPTM3   STTM2     Stop sampling in so     Start sampling usin     Start sampling usin                                                                                                              | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start sar<br>0: Disable<br>1: Enable<br>0: Disable                                                                                                                                                  | ation<br>npling                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0<br>PDCEN                                          | ion function).<br>(Initial value: 0000 0000)                 |       |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SWST<br>7<br>6<br>5           | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3                           | counts   ing, keep the PDCI   5 4   5 4   SPTM3 STTM2   Stop sampling in so   Start sampling in so   Stop sampling usin                                                                                                                                  | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start san<br>0: Disable<br>1: Enable<br>0: Disable                                                                                                                                                  | ation<br>mpling<br>e three pir                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0<br>PDCEN                                          | ion function).<br>(Initial value: 0000 0000)                 |       |
| PDCRA                    | 3 to 0<br>2: When 0<br>7<br>5<br>7<br>6<br>4<br>3         | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3<br>STTM2<br>PDNUM         | counts     ing, keep the PDCI     5   4     SPTM3   STTM2     Stop sampling in so     Start sampling usin     Start sampling usin     Start sampling usin     Number of position pins                                                                    | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start sar<br>0: Disable<br>1: Enable<br>0: Disable<br>1: Enable<br>0: Compare<br>1: Compare                                                                                                         | ation<br>mpling<br>e three pin<br>e one pin                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0<br>PDCEN                                          | ion function).<br>(Initial value: 0000 0000)                 | -     |
| PDCRA                    | 3 to 0<br>e: When o<br>7<br>SWST<br>7<br>6<br>5           | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3<br>STTM2                  | counts     ing, keep the PDCI     5   4     5   4     SPTM3   STTM2     Stop sampling in so     Start sampling in so     Stop sampling usin     Start sampling usin     Start sampling usin     Number of position                                       | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start sar<br>0: Disable<br>1: Enable<br>0: Disable<br>1: Enable<br>0: Compare<br>1: Compare                                                                                                         | ation<br>npling<br>e three pin<br>e counting                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0<br>PDCEN<br>s (PDU/PE<br>PDU) only<br>from previo | ion function).<br>(Initial value: 0000 0000)<br>V/PDW)       | -     |
| PDCRA                    | 3 to 0<br>2: When a<br>7<br>SWST<br>7<br>6<br>4<br>3<br>2 | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3<br>STTM2<br>PDNUM<br>RCEN | counts     ing, keep the PDCI     5   4     SPTM3   STTM2     Stop sampling in sc     Start sampling in sc     Start sampling usin     Start sampling usin     Start sampling usin     Number of position pins     Recount occurrence ing when PWM is of | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start sar<br>0: Disable<br>1: Enable<br>0: Disable<br>1: Enable<br>0: Compare<br>1: Compare<br>0: Continue<br>1: Recount                | ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling<br>ation<br>mpling | 0<br>PDCEN<br>s (PDU/PE<br>PDU) only<br>from previo | ion function).<br>(Initial value: 0000 0000)<br>V/PDW)       | -     |
| PDCRA                    | 3 to 0<br>2: When 0<br>7<br>5<br>7<br>6<br>4<br>3         | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3<br>STTM2<br>PDNUM         | counts     ing, keep the PDCI     5   4     SPTM3   STTM2     Stop sampling in so     Start sampling in so     Start sampling usin     Start sampling usin     Start sampling usin     Number of position pins     Recount occurrence                    | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start sar<br>0: Disable<br>1: Enable<br>0: Disable<br>1: Enable<br>0: Compare<br>1: Compare<br>0: Continue                                                            | as (Counts<br>ble posit<br>1<br>DTMD<br>ation<br>mpling<br>ation<br>mpling<br>e three pin<br>e one pin<br>e counting<br>e each time<br>r mode                                                                                                                                                                                                                                                                                                                                           | 0<br>PDCEN                                          | ion function).<br>(Initial value: 0000 0000)<br>V/PDW)       | - w   |
| PDCRA                    | 3 to 0<br>2: When a<br>7<br>SWST<br>7<br>6<br>4<br>3<br>2 | changing sett<br>6<br>P SWSTT<br>SWSTP<br>SWSTT<br>SPTM3<br>STTM2<br>PDNUM<br>RCEN | counts     ing, keep the PDCI     5   4     SPTM3   STTM2     Stop sampling in sc     Start sampling in sc     Start sampling usin     Start sampling usin     Start sampling usin     Number of position pins     Recount occurrence ing when PWM is of | EN bit reset      | 11: Reserve<br>1 to 15 time<br>to "0" (disa<br>2<br>RCEN<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Stop san<br>0: No opera<br>1: Start sar<br>0: Disable<br>1: Enable<br>0: Disable<br>1: Enable<br>0: Compare<br>1: Compare<br>0: Continue<br>1: Recount<br>0: Ordinary | as (Counts<br>ble posit<br>1<br>DTMD<br>ation<br>mpling<br>ation<br>mpling<br>e three pin<br>e one pin<br>e counting<br>e each time<br>r mode                                                                                                                                                                                                                                                                                                                                           | 0<br>PDCEN                                          | ion function).<br>(Initial value: 0000 0000)<br>V/PDW)       |       |

#### Position Detection Circuit Registers [Addresses (PMD1)]

Note:Read-modify-write instructions, such as a bit manipulation instruction, cannot access the PDCRA because it contains a write only bit.





## 14.4 Timer Unit



The timer unit has an up counter (mode timer) which is cleared by a position detection interrupt (INTPDC). Using this counter, it can generate three types of timer interrupts (INTTMR1 to 3). These timer interrupts may be used to produce a commutation trigger, position detection start trigger, etc. Also, the mode timer has a capture function which automatically captures register data in synchronism with position detection or overload protection. This capture function allows motor revolutions to be calculated by measuring position detection intervals.

#### 14.4.1 Configuration of the Timer Unit

The timer unit consists mainly of a mode timer, three timer comparator, and mode capture register, and is controlled by timer control registers and timer compare registers.

- The mode timer can be reset by a signal from the position detection circuit, Timer 3, or overload protective circuit. If the mode timer overflows without being reset, it stops at FFFFH and sets an overflow flag in the control register.
- The value of the mode timer during counting can be read by capturing the count in software and reading the capture register.
- Timer 1 and Timers 2 and 3 generate an interrupt signal by magnitude comparison and matching comparison, respectively. Therefore, Timer 1 can generate an interrupt signal even when it could not write to the compare register in time and the counter value at the time of writing happens to exceed the register's set value.
- When any one of Timers 1 to 3 interrupts occurs, the next interrupts can be enabled by writing a new value to the respective compare registers (CMP1, CMP2, CMP3).
- When capturing by position detection is enabled, the capture register has the timer value captured in it each time position is detected. In this way, the capture register always holds the latest value.

Page 119

#### 14.4.1.1 Timer Circuit Register Functions

MTCRB

| 7 | DBOUT | Debug output                                   | Debug output can be produced by setting this bit to 1. Because interrupt signals to the interrupt control circuit are used for each interrupt, hardware debugging without software delays are possible. See the debug output diagram (Figure 14-8). Output ports: P67 for PMD1. |
|---|-------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | TMOF  | Mode timer overflow                            | This bit shows that the timer has overflowed.                                                                                                                                                                                                                                   |
| 3 | CLCP  | Capture mode timer by over-<br>load protection | When this bit is set to 1, the timer value can be captured using the overload protection signal (CL) as a trigger.                                                                                                                                                              |
| 2 | SWCP  | Capture mode timer in soft-<br>ware            | When this bit is set to 1, the timer value can be captured in software (e.g., by writing to this register).                                                                                                                                                                     |
| 1 | PDCCP | Capture mode timer by posi-<br>tion detection  | When this bit is set to 1, the timer value can be captured using the position detection signal as a trigger.                                                                                                                                                                    |

| MTCRA   |       |                                         |                                                                                                                                                                                                        |
|---------|-------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7, 6, 5 | TMCK  | Select clock                            | Select the timer clock.                                                                                                                                                                                |
| 4       | RBTM3 | Reset mode timer from Timer 3           | When this bit is set to 1, the mode timer is reset by a trigger from Timer 3.                                                                                                                          |
| 3       | RBCL  | Reset mode timer by overload protection | When this bit is set to 1, the mode timer is reset by the overload protection signal (CL) as a trigger.                                                                                                |
| 2       | SWRES | Reset mode timer in software            | When this bit is set to 1, the mode timer is reset in software (e.g., by writing to this register)                                                                                                     |
| 1       | RBPDC | Reset mode timer by position detection  | When this bit is set to 1, the mode timer is reset by the position detection signal as a trigger.                                                                                                      |
| 0       | TMEN  | Enable/disable mode timer               | The mode timer is started by setting this bit to 1. Therefore, Timers 1 to 3 must be set with CMP before setting this bit. If this bit is set to 0 after setting CMP, CMP settings become ineffective. |

| MCAP | Mode capture                       | Position detection interval can be read out.                                                                                                                                                    |
|------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                                    |                                                                                                                                                                                                 |
| CMP1 | Timer 1 (commutation)              | Timers 1 to 3 are enabled while the mode timer is operating. An interrupt can be generated                                                                                                      |
| CMP2 | Timer 2 (position detection start) | once by setting the corresponding bit in this register. The interrupt is disable when an in-<br>terrupt is generated or the timer is reset. To use the timer again, set the register back again |
| CMP3 | Timer 3 (overflow)                 | even if data is same.                                                                                                                                                                           |



Figure 14-8 DBOUT Debug Output Diagram

#### Timer Circuit Registers [Addresses (PMD1)]



Note 1: When changing MTCRA<TMCK> setting, keep the MTCRA<TMEN> bit reset to "0" (disable mode timer).

Note 2: Read-modify-write instructions, such as a bit manipulation instruction, cannot access the MTCRA because it contains a write-only bit.

| MCAP                                                                                                                                                                     | F   | E  | D        | С              | В  | А  | 9  | 8  | 7      | 6                                    | 5       | 4       | 3          | 2       | 1          | 0                    |                                    |      |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|----------|----------------|----|----|----|----|--------|--------------------------------------|---------|---------|------------|---------|------------|----------------------|------------------------------------|------|--|
| (01FA7H, 01FA6H)                                                                                                                                                         | DF  | DE | DD       | DC             | DB | DA | D9 | D8 | D7     | D6                                   | D5      | D4      | D3         | D2      | D1         | D0                   | (Initial value: 0000 0000<br>0000) | 0000 |  |
|                                                                                                                                                                          |     |    |          |                |    |    |    |    |        |                                      |         |         |            |         |            |                      |                                    |      |  |
| МС                                                                                                                                                                       | CAP |    | Mode     | captu          | re |    |    |    | Po     | osition                              | detect  | ion int | erval      |         | <          | $\bigcirc$           |                                    | R    |  |
|                                                                                                                                                                          |     |    |          |                |    |    |    |    |        |                                      |         |         |            |         |            | Ć                    |                                    |      |  |
| CMP1<br>(01FA9H, 01FA8H)                                                                                                                                                 | F   | E  | D        | С              | В  | A  | 9  | 8  | 7      | 6                                    | 5       | 4       | 3          | 2       | 1          | 0                    | (Initial value: 0000 0000 0000     |      |  |
|                                                                                                                                                                          | DF  | DE | DD       | DC             | DB | DA | D9 | D8 | D7     | D6                                   | D5      | D4      | D3         | D2      | Dt         | D0                   | (initial value: 0000 0000<br>0000) | 0000 |  |
|                                                                                                                                                                          |     | -  |          |                |    |    |    |    |        |                                      |         |         | $\langle$  | $\sum$  | V          | IJ                   |                                    |      |  |
| CMP2                                                                                                                                                                     | F   | E  | D        | С              | В  | A  | 9  | 8  | 7      | 6                                    | 5       | 4       | 3          | 2       | L          | 0                    |                                    |      |  |
| (01FABH, 01FAAH)                                                                                                                                                         | DF  | DE | DD       | DC             | DB | DA | D9 | D8 | D7     | D6                                   | D5      | D4      | D3         | D2      | DI         | D0                   | (Initial value: 0000 0000<br>0000) | 0000 |  |
|                                                                                                                                                                          |     |    |          |                |    |    |    |    |        |                                      |         | ~       | $\bigcirc$ | $\sum$  |            |                      |                                    |      |  |
| CMP3                                                                                                                                                                     | F   | E  | D        | С              | В  | А  | 9  | 8  | 7      | 6                                    | 5       | 4       | 3          | 2       | 1          | 0                    |                                    |      |  |
| (01FADH, 01FACH)                                                                                                                                                         | DF  | DE | DD       | DC             | DB | DA | D9 | D8 | D7     | D6                                   | D5      | 704     | D3         | D2      | D1         | D0                   | (Initial value: 0000 0000<br>0000) | 0000 |  |
|                                                                                                                                                                          |     | 1  |          | 1              |    |    |    |    |        |                                      | ~       | $\leq$  | )          |         | $\diamond$ | $\overline{\langle}$ | (1)                                |      |  |
| CMP1                                                                                                                                                                     |     |    | Timer    | <sup>.</sup> 1 |    |    |    |    | М      | agnitu                               | de con  | pariso  | on con     | npare   | registe    | 95                   |                                    |      |  |
| CMP2                                                                                                                                                                     |     |    | Timer 2  |                |    |    |    | м  | atchin | g com                                | parisor | n comp  | oare re    | egister | $\Delta$   |                      | R/W                                |      |  |
| CMP3                                                                                                                                                                     |     |    | Timer    | 3              |    |    |    |    | M      | Matching comparison compare register |         |         |            |         |            |                      |                                    |      |  |
| Note: Read-modify-write instructions, such as a bit manipulation instruction, cannot access the MTCRB or MTCRA register because these registers contain write-only bits. |     |    |          |                |    |    |    |    |        |                                      |         |         |            |         |            |                      |                                    |      |  |
|                                                                                                                                                                          |     |    |          | (              | (  |    | 5) |    |        |                                      |         |         |            | /       |            |                      |                                    |      |  |
|                                                                                                                                                                          |     | 4  |          |                |    | J  |    |    |        | 72                                   |         | ~       |            |         |            |                      |                                    |      |  |
|                                                                                                                                                                          |     |    | <u>)</u> |                |    | 0  |    |    | $\geq$ |                                      |         |         |            |         |            |                      |                                    |      |  |



#### 14.4.1.2 Outline Processing in the Timer Unit

## 14.5 Three-phase PWM Output Unit

The Three-phase PWM Output Unit has the function to generate three-phase PWM waves with any desired pulse width and the commutation function capable of brushless DC motor control. In addition, it has the protective functions such as overload protection and emergency stop functions necessary to protect the power drive unit, and the dead time adding function which helps to prevent the in-phase upper/lower transistors from getting shorted by simultaneous turn-on when switched over.

For the PWM output pin (U,V,W,X,Y,Z), set the port register PxDR and PxCR (x = 3) to 1. The PWM output initially is set to be active low, so that if the output needs to be used active high, set up the MDCRA Register accordingly.

#### 14.5.1 Configuration of the three-phase PWM output unit

The three-phase PWM output unit consists of a pulse width modulation circuit, commutation control circuit, protective circuit (emergency stop and overload), and a dead time control circuit.

#### 14.5.1.1 Pulse width modulation circuit (PWM waveform generating unit)

This circuit produces three-phase independent PWM waveforms with an equal PWM frequency. For PWM waveform mode, triangular wave modulation or sawtooth wave modulation can be selected by using the PMD Control Register (MDCRA) bit 1. The PWM frequency is set by using the PMD Period Register (MDPRD). The following shows the relationship between the value of this register and the PWM counter clock set by the MDCRB Register, PWMCK.

| Sawtooth wave PWM: M    | DPRD R | Register set value = |              | 1                   |
|-------------------------|--------|----------------------|--------------|---------------------|
| Sawtoour wave I wivi. W |        | P                    | WM frequency | $[Hz] \times PWMCK$ |
|                         |        |                      |              |                     |

Triangular wave PWM: MDPRD Register set value =  $\frac{1}{PWM \text{ frequency } [H_Z] \times 2 \times PWMCK}$ 

The PMD Period Register (MDPRD) is comprised of dual-buffers, so that CMPU, V, W Register is updated with PWM period.

When the waveform arithmetic circuit is operating, the PWM waveform output unit receives calculation results from the waveform arithmetic circuit and by using the results as CMPU, V, W Register set value, it outputs independent three-phase PWM waveforms. When the waveform calculation function is enabled by the waveform arithmetic circuit and transfer of calculation results into the CMPU to W Registers is enabled (with EDCRA Register bit 2), the CMPU to W Registers are disabled against writing.

When the waveform calculation function is enabled (with EDCRA Register bit 1) and transfer of calculation results into the CMPU, V, W Registers is disabled (with EDCRA Register bit 2), the calculation results are transferred to the buffers of CMPU, V, W Registers, but not output to the port.

Read-accessing the CMPU, V, and W registers can read the calculation results of the waveform arithmetic circuit that have been input to a buffer. After changing the read calculation result data by software, writing the changed data to the CMPU, V, and W registers enables an arbitrary waveform other than a sinusoidal wave to be output. When the registers are read after writing, the values written to the registers are read out if accessed before the calculation results are transferred after calculation is finished.



The values of the PWM Compare Registers (CMPU/V/W) and the carrier wave generated by the PWM Counter (MDCNT) are compared for the relative magnitude by the comparator to produce PWM waveforms.

The PWM Counter is a 12-bit up/down counter with a 100 ns (at fc = 20 MHz) resolution.

For three-phase output control, two methods of generating three-phase PWM waveforms can be set.

- 1. Three-phase independent mode: Values are set independently in the three-phase PMD Compare Registers to produce three-phase independent PWM waveforms. This method may be used to produce sinusoidal or any other desired drive waveforms.
- 2. Three-phase common mode: A value is set in only the U-phase PMD Compare Register to produce three in-phase PWM waveforms using the U phase set value. This method may be used for DC motor square wave drive.

The three-phase PMD Compare Registers each have a comparison register to comprise a dual-buffer structure. The values of the PMD Compare Registers are loaded into their respective comparison registers synchronously with PWM period.



#### 14.5.1.2 Commutation control circuit

Output ports are controlled depending on the contents set in the PMD Output Register (MDOUT). The contents set in this register are divided into two, one for selecting the synchronizing signal for port output, and one for setting up port output. The synchronizing signal can be selected from Timers 1 or 2, position detection signal, or without sync. Port output can be synchronized to this synchronizing signal before being further synchronized to the PWM signal sync. The MDOUT Register's synchronizing signal select bit becomes effective immediately after writing. Other bits are dual-buffered, and are updated by the selected synchronizing signal.

Example: Commutation timing for one timer period with PWM synchronization specified



Output on six ports can be set to be active high or active low independently of each other by using the MDCRA Register bits 5 and 4. Furthermore, the U, V, and W phases can individually be selected between PWM output and H/L output by using the MDOUT Register bits A to 8 and 5 to 0. When PWM output is selected, PWM waveforms are output; when H/L output is selected, a waveform which is fixed high or low is output. The MDOUT Register bits E to C set the expected position signal value for the position detection circuit.



Figure 14-10 Pulse Width Modulation Circuit





## 14.5.2 Register Functions of the Waveform Synthesis Circuit

/

| PWM   | CK    | Soloot | PWM counter clock                          | Select PWM counter clock.                                                                                                                                                                                                                                             |                           |                                                                                                                                                                        |  |  |  |
|-------|-------|--------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MDCRA |       |        |                                            |                                                                                                                                                                                                                                                                       |                           |                                                                                                                                                                        |  |  |  |
| 7     | HL    | FINT   | Select half-period interrupt               | When this bit is set to 1, INTPWM is generated every half period (at triangular wave peal and valley) in the case of center PWM output and PINT = 00. In other cases, this setting has no meaning.                                                                    |                           |                                                                                                                                                                        |  |  |  |
| 6     | DTYMD |        | DTYMD DUTY mode                            |                                                                                                                                                                                                                                                                       | DUTY mode                 | Select whether to set the duty cycle independently for three phases using the CMPU to V Registers or in common for all three phases by setting the CMPU Register only. |  |  |  |
| 5     | POLH  |        | POLH Upper-phase port polarity             |                                                                                                                                                                                                                                                                       | Upper-phase port polarity | Select the upper-phase output port polarity. Make sure the waveform synthesis function (MDCRA Register bit 0) is idle before selecting this port polarity.             |  |  |  |
| 4     | P     | OLL    | Lower-phase port polarity                  | Select the lower-phase output port polarity. Make sure the waveform synthesis function (MDCRA Register bit 0) is idle before selecting this port polarity.                                                                                                            |                           |                                                                                                                                                                        |  |  |  |
| 3, 2  | Р     | INT    | PWM interrupt frequency                    | Select the frequency at which to generate a PWM interrupt from four choices available:<br>every PWM period or once every 2, 4, or 8 PWM periods. When setting of this bit is altere<br>while operating, an interrupt may be generated at the time the bit is altered. |                           |                                                                                                                                                                        |  |  |  |
| 1     | PW    | MMD    | PWM mode                                   | Select PWM mode. PWM mode 0 is an edge PWM (sawtooth wave), and PWM mode a center PWM (triangular wave).                                                                                                                                                              |                           |                                                                                                                                                                        |  |  |  |
| 0     | PW    | /MEN   | Enable/Disable waveform generation circuit | When enabling this circuit (for waveform output), be sure to set the output port polarity other bits of this register (other than MDCRA bit 0) beforehand.                                                                                                            |                           |                                                                                                                                                                        |  |  |  |
| DTR   |       |        |                                            |                                                                                                                                                                                                                                                                       |                           |                                                                                                                                                                        |  |  |  |
| DTF   | ٦     | Dead   | time                                       | Set the dead time between the upper-phase and lower-phase outputs.                                                                                                                                                                                                    |                           |                                                                                                                                                                        |  |  |  |

| UPDWN                | PWM counter flag                                              | This bit indicates whether the PWM counter is counting up or down. When edge PWM (sawtooth wave) is selected, it is always set to 0.                                                                                                                                                                                                                                                                      |
|----------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PDEXP                | Mode compare register                                         | Set the data to be compared with the position detection input port. The comparison data is<br>adopted as the expected value simultaneously when port output sync settings made with<br>MDOUT are reflected in the ports.<br>(This is the expected position detection input value for the output set with MDOUT next<br>time.)                                                                             |
| PSYNC                | Select PWM synchronization                                    | Select whether or not to synchronize port output to PWM period after being synchronized to the synchronizing signal selected with SYNCS. If selected to be synchronized to PWM, output is kept waiting for the next PWM after being synchronized with SYNCS. Waveform settings are overwritten if new settings are written to the register during this time, and output is generated with those settings. |
| WPWM<br>VPWM<br>UPWM | Control UVW-phase PWM<br>outputs                              | Set U, V, and W-phase port outputs. (See the Table 14-3)                                                                                                                                                                                                                                                                                                                                                  |
| SYNCS                | Select port output sync signal                                | Select the synchronizing signal with which to output UVW-phase settings to ports. The synchronizing signal can be selected from Timers 1 or 2, position detection, or asynchronous. Select asynchronous when the initial setting, otherwise the above setting isn't reflected immediately.                                                                                                                |
| woc<br>voc<br>uoc    | Control UVW-phase outputs                                     | Set U, V, and W-phase port outputs. (See the Table 14-3)                                                                                                                                                                                                                                                                                                                                                  |
|                      | PDEXP<br>PSYNC<br>WPWM<br>UPWM<br>UPWM<br>SYNCS<br>WOC<br>YOC | PDEXP Mode compare register   PSYNC Select PWM synchronization   WPWM Control UVW-phase PWM   VPWM Control UVW-phase PWM   UPWM Select port output sync signal   WOC Control UVW-phase outputs                                                                                                                                                                                                            |

| MDCNT | PWM counter    | This is a 12-bit read-only register used to count PWM periods.                                                                                                                                                                                                                     |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                |                                                                                                                                                                                                                                                                                    |
| MDPRD | Set PWM period | This register determines PWM period, and is dual-buffered, allowing PWM period to be altered even while the PWM counter is operating. The buffers are loaded every PWM period. When 100 ns is selected for the PWM counter clock, make sure the least significant bit is set to 0. |

# TOSHIBA

| CMPV<br>CMPW    | S                                     | Set PWM pulse width |                                  |              |                                                                    | dual-buffer                                                  |                    | ulse widths output in the respective l<br>pulse widths are determined by com |     |  |
|-----------------|---------------------------------------|---------------------|----------------------------------|--------------|--------------------------------------------------------------------|--------------------------------------------------------------|--------------------|------------------------------------------------------------------------------|-----|--|
| Wavefor         | m Synt                                | hesis Circı         | uit Registers [/                 | Addresses    | s (PMD1                                                            | )]                                                           |                    |                                                                              |     |  |
|                 | 7                                     | 6                   | 5 4                              | 3            | 2                                                                  | 1                                                            | 0                  |                                                                              |     |  |
| MDCRB           | -                                     | -                   |                                  | -            | -                                                                  | PW                                                           | мск                | (Initial value: **** **00)                                                   |     |  |
| (0117411)       |                                       |                     |                                  |              | -                                                                  |                                                              |                    |                                                                              |     |  |
|                 | 1, 0                                  | PWMCK               | PWM counter Se                   | lect clock   | 01: fc/2 <sup>2</sup><br>10: fc/2 <sup>3</sup>                     | [Hz] (100 ns<br>(200 ns at 2<br>(400 ns at 2<br>(800 ns at 2 | 20 MHz)<br>20 MHz) |                                                                              | R/W |  |
| Note            |                                       |                     | ting, keep the PW                |              | et to "0" (c                                                       |                                                              |                    | nthesis function).                                                           |     |  |
| MDCRA           | 7<br>HLFIN                            | 6<br>T DTYMD        | 5 4<br>POLH POLL                 | 3            | 2<br>NT                                                            | PWMMD                                                        | 0                  | (Initial value: 0000 0000)                                                   |     |  |
| (01FAEH)        |                                       |                     |                                  |              |                                                                    |                                                              |                    |                                                                              |     |  |
|                 | 7                                     | HLFINT              | Select half-period               | l interrupt  | < 7                                                                | upt as specif<br>upt every ha                                | 1                  | en PINT = 00                                                                 |     |  |
|                 | 6                                     | DTYMD               | DUTY mode                        |              | 0: U phase in common<br>1: Three phases independent                |                                                              |                    |                                                                              |     |  |
|                 | 5                                     | POLH                | Upper-phase por                  | t polarity   | 0: Active low<br>1: Active high<br>0: Active low<br>1: Active high |                                                              |                    |                                                                              |     |  |
|                 | 4                                     | POLL                | Lower-phase por                  | t polarity   |                                                                    |                                                              |                    |                                                                              |     |  |
|                 | 3, 2 PINT Select PWM interrupt (trigg |                     |                                  |              | 00: Interrupt every period                                         |                                                              |                    |                                                                              |     |  |
|                 | 1 <                                   | RWMMD               | PWM mode                         |              |                                                                    | mode0 (Edg<br>mode1 (Cer                                     | •                  | ,                                                                            |     |  |
|                 | 0                                     | PWMEN               | Enable/disable w thesis function | aveform syn- | 0: Disab<br>1: Enabl                                               | le<br>e (Waveforn                                            | n output)          |                                                                              |     |  |
|                 | Z                                     |                     | 5 4                              | 3            | 2                                                                  | 1                                                            | 0                  |                                                                              | ·   |  |
| DTR<br>(01FBEH) |                                       | > -                 | D5 D4                            | D3           | D2                                                                 | D1                                                           | D0                 | (Initial value: **00 0000)                                                   |     |  |
| г               | 5 to 0                                | DTR                 | Dead time                        |              | 03/50                                                              | hit (i                                                       | 05 0               | at 20 MHz)                                                                   | R/W |  |

Note: When changing setting, keep the MDCRA<PWMEN> bit reset to "0" (disable wave form synthesis function).

14.5 Three-phase PWM Output Unit

|                     | F                        | E     | D                        | С           | В            | А                                                                                                                        | 9                                        | 8         |                                    |  |  |  |
|---------------------|--------------------------|-------|--------------------------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----------|------------------------------------|--|--|--|
| MDOUT               | UPDWI                    | И     | PDEXP                    |             | PSYNC        | WPWM                                                                                                                     | VPWM                                     | UPWM      |                                    |  |  |  |
| (01FB3H,<br>01FB2H) | 7                        | 6     | 5                        | 4           | 3            | 2                                                                                                                        | 1                                        | 0         |                                    |  |  |  |
|                     | S                        | YNCS  | WO                       | WOC         |              | OC UOC                                                                                                                   |                                          | C         | (Initial value: 00000000 00000000) |  |  |  |
| _                   |                          |       |                          |             |              |                                                                                                                          |                                          |           |                                    |  |  |  |
|                     | F                        | UPDWN | PWM cour                 | nter flag   |              | 0: Counting up<br>1: Counting down                                                                                       |                                          |           |                                    |  |  |  |
|                     | E, D, C                  | PDEXP | Compariso<br>detection   | on register | for position | bit D: V-p                                                                                                               | ohase expe<br>hase expect<br>hase expect | ted value |                                    |  |  |  |
|                     | B PSYNC Select PWM synch |       |                          |             | onization    | 0: Asyncl<br>1: Synch                                                                                                    |                                          |           |                                    |  |  |  |
|                     | A                        | WPWM  | W-phase I                | PWM outp    | out          | 0: H/L level output<br>1: PWM waveform output                                                                            |                                          |           |                                    |  |  |  |
|                     | 9                        | VPWM  | V-phase P                | WM outp     | ut           | 0: H/L level output<br>1: PWM waveform output                                                                            |                                          |           |                                    |  |  |  |
|                     | 8                        | UPWM  | U-phase F                | WM outp     | ut           | 0: H/L level output<br>1: PWM waveform output                                                                            |                                          |           |                                    |  |  |  |
|                     | 7, 6                     | SYNCS | Select por<br>synchroniz |             | 1            | 00: Asynchronous<br>01: Synchronized to position detection<br>10: Synchronized to Timer 1<br>11: Synchronized to Timer 2 |                                          |           |                                    |  |  |  |
|                     | 5, 4                     | WOC   | Control W                | -phase ou   | Itput        |                                                                                                                          |                                          |           |                                    |  |  |  |
|                     | 3, 2                     | VOC   | Control V-               | phase out   | tput         | See the table 1-3                                                                                                        |                                          |           |                                    |  |  |  |

## 14.5.3 Port output as set with UOC/VOC/WOC bits and UPWM/VPWM/WPWM bits

### Table 14-3 Example of Pin Output Settings

Control U-phase output

|             | ι      | J-phase out<br>(PC | put polarity<br>)LH,POLL : |                     | ,<br>h  | (      |  |  |  |  |
|-------------|--------|--------------------|----------------------------|---------------------|---------|--------|--|--|--|--|
|             | UPWM   |                    |                            |                     |         |        |  |  |  |  |
|             | UOC    | 1: PWN             | 1 output                   | 0: H/L level output |         |        |  |  |  |  |
|             | $\geq$ | U phase            | X phase                    | U phase             | X phase | $\geq$ |  |  |  |  |
|             | 0.0    | PWM                | PWM                        | <u>ц(</u>           | L       |        |  |  |  |  |
| $\sim$      | 0 1    | L                  | PWM                        | L                   | н       |        |  |  |  |  |
|             | 10     | PWM                | ∧L (                       | H                   | ∕_L     |        |  |  |  |  |
| $\langle -$ | -11    | PWM                | RWM                        | H                   | ) н     |        |  |  |  |  |
|             |        |                    | $\sim$                     |                     |         | •      |  |  |  |  |

UOC

1, 0

#### U-phase output polarity: Active low (POLH,POLL = 0)

|     |         |          | -                   |         |  |  |
|-----|---------|----------|---------------------|---------|--|--|
| UOC | UPWM    |          |                     |         |  |  |
|     | 1: PWM  | 1 output | 0: H/L level output |         |  |  |
|     | U phase | X phase  | U phase             | X phase |  |  |
| 0 0 | PWM     | PWM      | н                   | н       |  |  |
| 0 1 | н       | PWM      | н                   | L       |  |  |
| 1 0 | PWM     | н        | L                   | н       |  |  |
| 11  | PWM     | PWM      | L                   | L       |  |  |

# TOSHIBA



#### 14.5.4 Protective Circuit

This circuit consists of an EMG protective circuit and overload protective circuit. These circuits are activated by driving their respective port inputs active.



a. EMG protective circuit

This protective circuit is used for emergency stop, when the EMG protective circuit is enabled. When the signal on EMG input port goes active (negative edge triggered), the six ports are immediately disabled high-impedance against output and an EMG interrupt (INTEMG) is generated. The EMG Control Register (EMGCRA) is used to set EMG protection. If the EMGCRA<EMGST> shows the value "4" when read, it means that the EMG protective circuit is operating. To return from the EMG protective state, reset the MDOUT Register bits A to 0 and set the EMGCRA<RTE> to 1. Returning from the EMG protective state is effective when the EMG protective input has been released back high. To disable the EMG function, set data "5AH" and "A5H"sequentially in the EMG disable Register (EMGREL) and reset the EMGCRA<EMGEN> to 0. When the EMG function is disabled, EMG interrupts (INTEMG) are not generated.

The EMG protective circuit is initially enabled. Before disabling it, fully study on adequacy.

b. Overload protective circuit

The overload protective circuit is set by using the EMG Control Registers (EMGCRA/B). To activate overload protection, set the EMGCRB<CLEN> to 1 to enable the overload protective circuit. The circuit starts operating when the overload protective input is pulled low.

To return from overload state, there are three methods to use: return by a timer (EMGCRB<RTTM1>), return by PWM sync (EMGCRB<RTPWM>), or return manually (EMGCRB<RTCL>). These methods are usable when the overload protective input has been released back high.

The number of times the overload protective input is sampled can be set by using the EMG-CRA<CLCNT>. The sampling times can be set in the range of 1 to 15 times at 200 ns period (when fc = 20 MHz). If a low level is detected as many times as the specified number, overload protection is assumed.

The output disabled phases during overload protection are set by using the EMGCRB<CLMD>. This facility allows selecting to disable no phases, all phases, PWM phases, or all upper phases/all lower phases. When selected to disable all upper phases/all lower phases, port output is determined by their turn-on status immediately before being disabled. When two or more upper phases are active, all upper phases are turned on and all lower phases are turned off; when two or more lower phases are active, all upper phases are turned off and all lower phases are turned on.

When output phase are cut off, output is inactive (low in the case of high active). When the overload protective circuit is disabled, overload protective interrupts (INTCLM) are not generated.



### 14.5.5 Functions of Protective Circuit Registers

| EMGREL | EMG disable | The EMG protective circuit is disable from the disabled state by writing "5AH" and "A5H" to this register in that order. After that, the EMGCRA Register needs to be set. |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             |                                                                                                                                                                           |

| EMGCRB |       |                                                          |                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | RTCL  | Return from overload protec-<br>tive state               | When this bit is set to 1, the motor control circuit is returned from overload protective state<br>in software (e.g., by writing to this register). Also, the current state can be known by reading<br>this bit. MDOUT outputs at return from the overload protective state remain as set before<br>the overload protective input was driven active. |
| 6      | RTPWM | Return by PWM sync                                       | When this bit is set to 1, the motor control circuit is returned from overload protective state<br>by PWM sync. If RTCL is set to 1, RTCL has priority.                                                                                                                                                                                              |
| 5      | RTTM1 | Return by timer sync                                     | When this bit is set to 1, the motor control circuit is returned from overload protective state by Timer 1 sync. If RTCL is set to 1, RTCL has priority.                                                                                                                                                                                             |
| 4      | CLST  | Overload protective state                                | The status of overload protection can be known by reading this bit.                                                                                                                                                                                                                                                                                  |
| 3, 2   | CLMD  | Select output disabled phases during overload protection | Select the phases to be disabled against output during overload protection. This facility allows selecting to disable no phases, all phases, PWM phases, or all upper phases/all lower phases.                                                                                                                                                       |
| 1      | CNTST | Stop counter during overload protection                  | Can stop the PWM counter during overload protection.                                                                                                                                                                                                                                                                                                 |
| 0      | CLEN  | Enable/Disable overload pro-<br>tection                  | Enable or disable the overload protective function.                                                                                                                                                                                                                                                                                                  |
| FNOODA |       | *                                                        |                                                                                                                                                                                                                                                                                                                                                      |

EMGCRA

| EMGCRA |       |                                            |                                                                                                                                                                                                                                                                       |
|--------|-------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 4 | CLCNT | Overload protection sampling time          | Set the length of time the overload protective input port is sampled.                                                                                                                                                                                                 |
| 2      | EMGST | EMG protective state                       | The status of EMG protection can be known by reading this bit.                                                                                                                                                                                                        |
| 1      | RTE   | Return from EMG protective state           | The motor control circuit is returned from EMG protective state by setting this bit to "1".<br>When returning, set the MDOUT Register A to 0 bits to "0". Then set the EMGCRA Register<br>bit 1 to "1" and set MDOUT waveform output. Then set up the MDCRA Register. |
| 0      | EMGEN | Enable/Disable EMG protec-<br>tive circuit | The EMG protective circuit is activated by setting this bit to 1. This circuit initially is enabled.<br>(To disable this circuit, make sure key code 5AH and A5H are written to the EMGREL1<br>Register beforehand.)                                                  |
|        |       |                                            |                                                                                                                                                                                                                                                                       |

| Protective Circuit Registers [Addresses (PMD1)]                    |    |      |                                                                |            |           |    |    |    |                            |  |
|--------------------------------------------------------------------|----|------|----------------------------------------------------------------|------------|-----------|----|----|----|----------------------------|--|
|                                                                    | 7  | 6    | 5                                                              | 4          | 3         | 2  | 1  | 0  | _                          |  |
| EMGREL<br>(01FBFH)                                                 | D7 | 2 D6 | D5                                                             | D4         | D3        | D2 | D1 | D0 | (Initial value: 0000 0000) |  |
|                                                                    |    |      |                                                                |            |           |    |    |    |                            |  |
| 7 to 0 EMGREL EMG disable Can disable by writing 5AH and then A5H. |    |      |                                                                |            | then A5H. | W  |    |    |                            |  |
|                                                                    |    |      | $\left( \begin{array}{c} \\ \\ \\ \end{array} \right) \right)$ | $\bigcirc$ | ~         |    |    |    |                            |  |

Note:Read-modify-write instructions, such as a bit manipulation instruction, cannot access the EMGREL register because this register is write only.
# TOSHIBA



| 7    | RTCL  | Return from overload protective state                                   | 0: No operation<br>1: Return from protective state                                                                                                                                         | w   |
|------|-------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|      |       |                                                                         |                                                                                                                                                                                            |     |
| 6    | RTPWM | Enable/Disable return from<br>overload protective state by<br>PWM sync  | 0: Disable<br>1: Enable                                                                                                                                                                    |     |
| 5    | RTTM1 | Enable/Disable return from<br>overload protective state by tim-<br>er 1 | 0: Disable<br>1: Enable                                                                                                                                                                    | R/W |
| 4    | CLST  | Overload protective state                                               | 0: No operation<br>1: Under protection                                                                                                                                                     | R   |
| 3, 2 | CLMD  | Select output disabled phases during overload protection                | 00: No phases disabled against output<br>01: All phases disabled against output<br>10: PWM phases disabled against output<br>11: All upper/All lower phases disabled against output (Note) |     |
| 1    | CNTST | Stop PWM counter during over-<br>load protection                        | 0: Do not stop<br>1: Stop the counter                                                                                                                                                      | R/W |
| 0    | CLEN  | Enable/Disable overload pro-<br>tective circuit                         | 0: Disable<br>1: Enable                                                                                                                                                                    |     |

Note: If during overload protection the port output state in two or more upper phases is on, all lower phases are disabled and all upper phases are enabled for output; when two or more lower phases are on, all upper phases are disabled and all lower phases are enabled for output.

2 6 5 0 4 1 EMGCRA CLCNT EMGST RTE EMGEN (Initial value: 0000 \*001) (01FB0H)

| _ |        |       |                                               | $\sim$                                                      |     |
|---|--------|-------|-----------------------------------------------|-------------------------------------------------------------|-----|
|   | 7 to 4 | CLCNT | Overload protection sampling number of times. | 2²/fc × n ( n = 1 to 15, 0 and 1 are set as 1 at 20 MHz )   | R/W |
|   | 2      | EMGST | EMG protective state                          | 0: No operation<br>1: Under protection                      | R   |
|   | 1 <    | RTE   | Return from EMG state                         | 0: No operation<br>1: Return from protective state (Note 1) | w   |
|   | 0      | EMGEN | Enable/Disable EMG protective circuit         | 0: Disable<br>1: Enable                                     | R/W |

Note 1: An instruction specifying a return from the EMG state is invalid if the EMG input is "L".

Note 2: Read-modify-write instructions, such as a bit manipulation instruction, cannot access the EMGCRB or EMGCRA register because these registers contain write-only bits.

## 14.6 Electrical Angle Timer and Waveform Arithmetic Circuit

Electrical Angle Timer



### 14.6.1 Electrical Angle Timer and Waveform Arithmetic Circuit

The Electrical Angle Timer finishes counting upon reaching the value set by the Period Set Register (EDSET). The Electrical Angle Timer counts 360 degrees of electrical angle in the range of 0 to 383 (17FH) and is cleared to 0 upon reaching 383. In this way, it is possible to obtain the electrical angle of the frequency proportional to the value set by the Period Set Register. The period with which to count up can be corrected by using the Period Correction Register, allowing for fine adjustment of the frequency. The electrical angles counted by the Electrical Angle Timer are presented to the Waveform Arithmetic Circuit. An electrical angle timer interrupt signal is generated each time the Electrical Angle Timer finishes counting.

The Waveform Arithmetic Circuit has a sine wave data table, which is used to extract sine wave data based on the electrical angle data received from the Electrical Angle Timer. This sine wave data is multiplied by the value of the Voltage Amplitude Register. For 2-phase modulation, the product obtained by this multiplication is presented to the waveform synthesis circuit. For 3-phase modulation, waveform data is further calculated based on the product of multiplication and the electrical angle data and the value of the PWM Period Register. The calculation is performed each time the Electrical Angle Timer finishes counting or when a value is set in the Electrical Angle Register, and the calculation results consisting of the U phase, the V phase (+120 degrees), and the W phase (+240 degrees) are sequentially presented to the PWM waveform output circuit. The sine wave data table is stored in the RAM and requires initialization.

- To correct the period, set the number of times 'n' to be corrected in the Period Correction Register (EDSET Register F to C bits). The period is corrected by adding 1 to electrical angle counts 16 for 'n' times. For example, when a value 3 is set in the Period Correction Register, the period for 13 times out of electrical angle counts 16 is the value "mH" set in the Period Set Register, and that for 3 times is "m + 1H". (Correction is made almost at equal intervals.)
- Because the electrical angle counter (ELDEG) can be accessed even while the Electrical Angle Timer is operating, the electrical angles can be corrected during operation.
- The Electrical Angle Capture EDCAP captures the electrical angle value from the Electrical Angle Counter at the time the position is detected.
- When the waveform calculation function is enabled, waveform calculation is performed each time the electrical angle counter (ELDEG) are accessed for write or the Electrical Angle Timer finishes counting.
- The calculation is performed in 35 machine cycle of execution time, or 7 μs (at 20 MHz).
- When transfer of calculation result to the CMP Registers is enabled (EDCRA<RWREN>), the calculation results are transferred to the CMPU to W Registers. (This applies only when the waveform calculation function is enabled with the EDCRA<CALCEN>.) The CMPU to W Registers are disabled against write while the transfer remains enabled. The calculation results can be read from the CMPU to W Registers while the waveform calculation function func
- The calculated results can be modified and the modified data can be set in the CMPU to W Registers in software. This makes it possible to output any desired waveform other than sine waves.

If a transfer (EDCRA register bit 2) of the calculated results to the CMP register is disabled, readaccessing the CMPU to W registers can read the calculated results. (Before read-accessing these registers, make sure that the calculation is completed.)

To initialize the entire RAM data of the sine wave data table, set the addresses at which to set, sequentially from 000H to 17FH, in the ELDEG Register, and write waveform data to the WFMDR Register each time. Make sure the Waveform Arithmetic Circuit is disabled when writing this data.

- Note 1: The value set in the Period Set Register (EDSET Register EDT bits) must be equal to or greater than 010H. Any value smaller than this is assumed to be 010H.
- Note 2: The sine wave data that is read consists of the U phase, the V phase whose electrical angle is +120 (-120) degrees relative to the U phase, and the W phase whose electrical angle is +240 (-240) degrees relative to the U phase.
- Note 3: If a period corresponding to an electrical angle of one degree is shorter than the required calculation time, the previously calculated results are used.

### 14.6.1.1 Functions of the Electrical Angle Timer and Waveform Arithmetic Circuit Registers

| EDCRB | -       |                                                                             |                                                                                                                                                                                                                    |
|-------|---------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | CALCST  | Start calculation by software                                               | Forcefully start calculation. When this bit is written while the waveform arithmetic circuit is calculating, the calculation is terminated and then newly started.                                                 |
| 2     | CALCBSY | Calculation flag                                                            | By reading this bit, the operation status of the waveform arithmetic circuit can be obtained.                                                                                                                      |
| 1     | EDCALEN | Enable/disable calculation<br>start synchronized with elec-<br>trical angle | Select whether to start calculation when the electrical angle timer finishes counting or when a value is set in the electrical angle register. When disabled, calculation is only started when CALCST is set to 1. |
| 0     | EDISEL  | Electrical angle interrupt                                                  | Set the electrical angle interrupt signal request timing to either when the electrical angle timer finishes counting or upon end of calculation.                                                                   |

| EDCRA |        |                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | EDCNT  | Electrical angle count up/<br>down                      | Set whether the electrical angle timer counts up or down.                                                                                                                                                                                                                                                                                                                                                                      |
| 6     | EDRV   | Select V-, W-phase                                      | Select phase direction of V-phase and W-phase in relation to U-phase.                                                                                                                                                                                                                                                                                                                                                          |
| 5, 4  | EDCK   | Select clock                                            | Select the clock for the electrical angle timer. This setting can be altered even while the electrical angle timer is operating.                                                                                                                                                                                                                                                                                               |
| 3     | C2PEN  | Switch between 2-phase and 3-phase modulations          | Select the modulation method with which to perform waveform calculation.<br>Two-phase modulation DATA = ramdata (ELDEG) × AMP<br>Three-phase modulation: DATA = $\frac{MOPRD}{2} \pm \frac{ramdata(ELDEG) \times AMP}{2}$<br>Note: The ± sign during 3-phase modulation changes depending on the electrical angle.<br>+ for electrical angles 0 to 179 degrees (191)<br>- for electrical angles 180 (192) to 360 (383) degrees |
| 2     | RWREN  | Auto transfer calculation re-<br>sults to CPM registers | Enable/disable transfer of calculation results by the waveform arithmetic circuit. When the waveform calculation function is enabled while at the same time transfer is enabled, calculation results are set as U, V, and W-phase duty cycles of the PWM generation circuit and are reflected in the ports.                                                                                                                    |
| 1     | CALCEN | Enable/disable waveform cal-<br>culation function       | Enable/disable the waveform calculation function. Calculations are performed by the wave-<br>form arithmetic circuit by enabling the waveform calculation function. When the waveform<br>calculation function is enabled, the calculated results can be read from the U, V, and W-<br>phase compare registers (CMPU, V, W) of the PWM generation circuit.                                                                      |
| 0     | EDTEN  | Electrical angle timer                                  | Enable/disable the electrical angle timer. When enabled, the electrical angle timer starts counting; when disabled, the electrical angle timer stops counting and is cleared to 0.                                                                                                                                                                                                                                             |
|       |        |                                                         | ~ (7)\$                                                                                                                                                                                                                                                                                                                                                                                                                        |

| EDSET  |       |                                 | $\langle \langle \rangle \rangle$                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|--------|-------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| F to C | EDTH  | Correct electrical angle period | Correct the period by adding 1 to electrical angle counts 16 for "n" times. The timer cour the electrical angle period set value "m" for $(16 - n)$ times and counts $(m + 1)$ for "n" time                                                                                         |  |  |  |  |  |  |  |
| B to 0 | EDT   | Electrical angle period         | Set the electrical angle period.                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|        |       | 17                              |                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| ELDE   | G Ele | ectrical angle                  | Read the electrical angle. This register can also be set to initialize or correct the angle while counting. Any value greater than 17FH cannot be set.                                                                                                                              |  |  |  |  |  |  |  |
|        |       |                                 |                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|        | Se    | t voltage amplitude             | Set the voltage amplitude. The waveform arithmetic circuit multiplies the data set here by the sine wave data read out from the sine wave RAM. The amplitude has its upper limit determined by the set value of the MDPRD register when performing this multiplication.             |  |  |  |  |  |  |  |
|        |       |                                 |                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| EDCA   | AP Ca | pture electrical angle          | Capture the value from the electrical angle timer when the position is detected.                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|        |       |                                 |                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| WFME   | DR Se | t sine wave data                | To initialize the entire RAM data of the sine wave table, set the addresses at which to sequentially from 000H to 17FH, in the ELDEG register, and write waveform data to th WFMDR register each time. Make sure the waveform arithmetic circuit is disabled who writing this data. |  |  |  |  |  |  |  |

# TOSHIBA

Typical Settings of Sine Wave Data



Note: During 3-phase modulation, the sign changes at 180 degrees of electrical angle.

Figure 14-17 Typical Settings of Sine Wave Data

List of the Electrical Angle Timer and Waveform Arithmetic Circuit Registers [Addresses (PMD1)]

|          | 7  | 6 | 5 | 4 | 3      | 2       | _1      | <b>0</b> |                                        |
|----------|----|---|---|---|--------|---------|---------|----------|----------------------------------------|
| EDCRB    | -  | - | - | - | CALCST | CALCBSY | EDCALEN | EDISEL   | (Initial value: **** 0000)             |
| (01FC1H) | i. |   |   |   |        |         |         |          | [ (········ · ······ · ······ · ·····) |

| 3 |          | CALCST  | Start calculation by software                                            | 0: No operation<br>1: Start calculation                                                                                        | w   |
|---|----------|---------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----|
| 2 |          | CALCBSY | Calculation flag                                                         | 0: Waveform Arithmetic Circuit stopped<br>1: Waveform Arithmetic Circuit calculating                                           | R   |
| 1 | $\wedge$ | EDCALEN | Enable/disable calculation start synchronized with electrical an-<br>gle | <ul><li>0: Start calculation insync with electrical angle</li><li>1: Do not calculation insync with electrical angle</li></ul> | R/W |
| 0 | Â        | EDISEL  | Electrical angle interrupt                                               | <ul><li>0: Interrupt when the Electrical Angle Timer finishes counting</li><li>1: Interrupt upon end of calculation</li></ul>  |     |

Note:Read-modify-write instructions, such as a bit manipulation instruction, cannot access the EDCRB register because this register is write only.



| _ |      |       |                                                   |                                                                                                                                                                              |     |
|---|------|-------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|   | 7    | EDCNT | Electrical angle count up/down                    | 0: Count up<br>1: Count down                                                                                                                                                 |     |
| - | 6    | EDRV  | Select V-, W-phase                                | 0: V = U + 120°, W = U + 240°<br>1: V = U - 120°, W = U - 240°                                                                                                               |     |
|   | 5, 4 | EDCK  | Select clock                                      | 00: fc/2 <sup>3</sup> (400 ns at 20 MHz)<br>01: fc/2 <sup>4</sup> (800 ns at 20 MHz)<br>10: fc/2 <sup>5</sup> (1.6 μs at 20 MHz)<br>11: fc/2 <sup>6</sup> (3.2 μs at 20 MHz) |     |
|   | 3    | C2PEN | Switch between 2-/3-phase modulations             | 0: 2-phase modulation<br>1: 3-phase modulation                                                                                                                               | R/W |
|   | 2    | RWREN | Transfer calculation result to<br>CMP registers   | 0: Disable<br>1: Enable                                                                                                                                                      |     |
| Ī | 1    | CALC  | Enable/disable waveform cal-<br>culation function | 0: Disable<br>1: Enable                                                                                                                                                      |     |
|   | 0    | EDTEN | Electrical angle Enable/disable mode timer        | 0: Disable<br>1: Enable                                                                                                                                                      |     |

Note: When changing the EDCRA<EDCK> setting, keep the EDCRA<EDTEN> bit reset "0" (Disable electrical angle timer).

| EDSET            | F | Е  | D  | С | В | A         | 9                 | 8             | 7 | 6 | 5  | 4 3 2 | 1 | 0 |                                       |
|------------------|---|----|----|---|---|-----------|-------------------|---------------|---|---|----|-------|---|---|---------------------------------------|
| (01FC3H, 01FC2H) |   | ED | тн |   |   | $\square$ | ,                 | $\mathcal{D}$ | / | E | σт |       |   |   | (Initial value: 00000000<br>00010000) |
|                  |   |    |    |   |   | (         | $\langle \rangle$ | /             |   |   |    |       |   |   | -                                     |

| F to C | EDTH | Correct period (n) | 0 to 15 times | DAA |
|--------|------|--------------------|---------------|-----|
| B to 0 | EDT  | Set period (m)     | ≥ 010H        | R/W |
|        |      |                    | $(\vee / ))$  |     |

One period of the Electrical Angle Timer, T, is expressed by the equation below.

=  $\left(m + \frac{n}{16}\right) \times 384 \times \text{set clock[s]}$  where m = set period, n = period correction

# TOSHIBA

| ELDEG                | 3                    | F            | Е             | D            | С           | В                       | А                | 9                | 8                 | 7         | 6          | 5               | 4       | 3         | 2       | 1       | 0       |                                       |        |
|----------------------|----------------------|--------------|---------------|--------------|-------------|-------------------------|------------------|------------------|-------------------|-----------|------------|-----------------|---------|-----------|---------|---------|---------|---------------------------------------|--------|
| (01FC5H, 01          | FC4H)                | -            | -             | -            | -           | -                       | -                | -                | D8                | D7        | D6         | D5              | D4      | D3        | D2      | D1      | D0      | (Initial value: ******0 0000          | 00000) |
|                      |                      |              |               |              |             |                         |                  |                  |                   |           |            |                 |         |           |         |         |         | J                                     |        |
|                      | 8 to 0               | El           | DEG           |              | Elect       | rical a                 | ngle             |                  |                   | S         | et the I   | nitially        | and t   | he cou    | int val | ues of  | electri | cal angle.                            | R/W    |
|                      |                      |              |               |              |             |                         |                  |                  |                   | ·         |            |                 |         |           |         |         | Ĉ       |                                       |        |
| AMP                  | FOOLN <sup>!"</sup>  | F            | E             | D            | С           | В                       | A                | 9                | 8                 | 7         | 6          | 5               | 4       | 3         | 2       | 1       | 6       | $\mathcal{Y}$                         |        |
| (01FC7H, 01          | FC0H)                | -            | -             | -            | -           | DB                      | DA               | D9               | D8                | D7        | D6         | D5              | D4      | D3        | D2      | D1      | Do      | (Initial value: ****0000<br>00000000) |        |
|                      |                      |              |               |              |             |                         |                  | !                | <b>!</b>          |           |            |                 |         | $\langle$ | $\sum$  | V       | フナ      | <u>.</u>                              |        |
|                      | B to 0               | A            | MP            |              | Set v       | oltage                  | 9                |                  |                   | S         | et the v   | /oltage         | e to be | used      | during  | wave    | form c  | alculation.                           | R/W    |
|                      |                      |              |               |              |             |                         |                  |                  |                   |           |            |                 |         |           |         | リン      |         |                                       |        |
| EDCAF<br>(01FC9H, 01 |                      | F            | E             | D            | С           | В                       | A                | 9                | 8                 | 7         | 6          | 5               | 4       | 3         | 2       | 1       | 0       |                                       |        |
|                      |                      | -            | -             | -            | -           | -                       | -                | -                | D8                | D7        | D6         | D5              | D4      | D3        | D2      | D1      | D0      | (Initial value: *****0 0000           | 0000)  |
|                      |                      |              |               |              |             |                         |                  |                  |                   |           |            |                 | 77.     | $\wedge$  | 7       |         | (       |                                       |        |
|                      | 8 to 0               | E            | DCAP          |              | Capt<br>gle | ured v                  | alue o           | f elect          | rical a           | n- EI     | lectrica   | l angle         | e timei | r value   | when    | positi  | on is d | letected.                             | R      |
|                      |                      |              |               |              | 3.4         |                         |                  |                  |                   |           | 1          | Ì               | 5       |           |         | 6       |         |                                       |        |
|                      | 7                    |              | 6             |              | 5           |                         | 4                |                  | 3                 | ~         | 2          | $\geq$          | 1       | C         | )       | (C      | 6       |                                       |        |
| WFMDR<br>(01FCAH     | 1 D                  | 7            | D6            | ;            | D5          |                         | D4               |                  | D3                |           | D2         |                 | 01      | D         | 0       | (Initia | l value | · ********)                           |        |
| (011 07 11           | ,                    |              |               |              |             |                         |                  |                  |                   |           | $\searrow$ | ~               |         |           |         | /       | )       |                                       |        |
|                      |                      | T            |               |              |             |                         |                  |                  | 40                |           | >          |                 | 4       |           | $\sim$  | $\sum$  | /       |                                       |        |
|                      | 7 to 0               | W            | FMDR          |              | Sine        | wave                    | data             | 6                | $\overline{}$     | $\exists$ | rite sir   | ne wav          | e data  | a to RA   | M of s  | sine wa | ave     |                                       | W      |
| No                   | te <sup>.</sup> Read | -mod         | lifv_wr       | ite in       | struct      | ions                    | such             |                  | hit ma            | ninul     | ation      | instru          | ction   | cann      | ot ac   |         | the W   | /FMDR register be-                    |        |
| NO                   | cause                | e this       | regis         | ter is       | write       | only.                   |                  | asa              |                   | anipui    | allon      |                 | cuon,   | Cari      |         | 0033    |         | TIMDIT TEgister De-                   |        |
|                      |                      |              |               |              |             |                         |                  | $\left( \right)$ |                   |           |            | $\square$       |         |           |         |         |         |                                       |        |
|                      |                      |              |               |              |             |                         | $\sum_{i=1}^{n}$ | ٧                |                   |           | ~          | R               | $\geq$  |           |         |         |         |                                       |        |
|                      |                      |              |               | $\frown$     | (           | $\langle / /$           |                  |                  |                   |           | $\sim$     | $\overline{-1}$ | >       |           |         |         |         |                                       |        |
|                      |                      |              |               | $\square$    | )           |                         | )                |                  | ~                 |           | 7/<        | 2               |         |           |         |         |         |                                       |        |
|                      |                      |              | $\leq$        | $\checkmark$ | $\sim$      |                         |                  | <                | $\langle \rangle$ |           | S          | )               |         |           |         |         |         |                                       |        |
|                      |                      |              |               |              |             |                         | 4                |                  |                   | $\geq$    |            |                 |         |           |         |         |         |                                       |        |
|                      |                      | ~            | ~             |              | $\searrow$  |                         |                  |                  | $\overline{)}$    |           |            |                 |         |           |         |         |         |                                       |        |
|                      |                      | $\leq$       | 2             |              |             |                         |                  |                  |                   | $\geq$    |            |                 |         |           |         |         |         |                                       |        |
|                      |                      | $\sim$       |               | Ŋ            |             |                         |                  | 7                |                   |           |            |                 |         |           |         |         |         |                                       |        |
| $\sim$               |                      | $\square$    | $\mathcal{D}$ |              |             |                         | 2                |                  |                   |           |            |                 |         |           |         |         |         |                                       |        |
|                      | > /                  | $\leq$       | Ŋ             |              | $\land$     | 6                       |                  | $\sim$           |                   |           |            |                 |         |           |         |         |         |                                       |        |
| $\langle -$          |                      | $\mathbf{i}$ |               | (            | $\square$   | $\mathcal{I}_{\langle}$ | $\bigcirc$       | )                |                   |           |            |                 |         |           |         |         |         |                                       |        |
|                      |                      |              |               |              | 2           | $\overline{)}$          | $\smile$         | ~                |                   |           |            |                 |         |           |         |         |         |                                       |        |
|                      | $\searrow$           |              |               |              |             |                         | >                |                  |                   |           |            |                 |         |           |         |         |         |                                       |        |

### 14.6.1.2 List of PMD Related Control Registers

### (1) Input/output Pins and Input/output Control Registers

PMD1 Input/Output Pins (P3, P4) and Port Input/Output Control Registers (P3CR, P4CR)

| Name | Address | Bit     | R or W | Description                                                                           |
|------|---------|---------|--------|---------------------------------------------------------------------------------------|
|      |         | 7       | R/W    | Overload protection (CL1)                                                             |
| P3DR | 00003H  | 6       | R/W    | EMG input (EMG1)                                                                      |
|      |         | 5 to 0  | R/W    | U1/V1/W1/X1/Y1/Z1 outputs.                                                            |
| P4DR | 00004H  | 2 to 0  | R/W    | Position signal inputs (PDU1, PDV1, PDW1).                                            |
| P3CR | 01F89H  | 7 to 0  | R/W    | P3 port input/output control (can be set bitwise).<br>0: Input mode<br>1: Output mode |
| P4CR | 01F8AH  | 2, 1, 0 | R/W    | P0 port input/output control (can be set bitwise).<br>0: Input mode<br>1: Output mode |

Note: When using these pins as PMD function or input port, set the Output Latch (P\*DR) to 1.

Example of the PMD Pin Port Setting

|      |              |          | $\sim$ | $\sim$     |      |
|------|--------------|----------|--------|------------|------|
|      | Input/Output | P3DR     | P3CR   | P4DR       | P4CR |
| CL1  | Input        | *        | 0      | )          | -    |
| EMG1 | Input        |          | 0      | <u> </u>   | -    |
| U1   | Output       |          | 1      | <u>``-</u> | -    |
| PDU1 | Input        | <u> </u> |        | *          | 0    |

 $\overline{}$ 

### (2) Motor Control Circuit Control Registers [Address : PMD1]

Position Detection Control Register (PDCR) and Sampling Delay Register (SDREG)

| Name  | Address | Bit    | R or W | Description                                                                                                                                                                               |
|-------|---------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         | 5, 4   | R      | Detect the position-detected position.<br>00: Within the current pulse 01: When PWM is off<br>10: Within the current pulse 11: Within the preceding pulse<br>Monitor the sampling status. |
| PDCRC | 01FA2H  | 3      | R      | 0: Sampling idle<br>1: Sampling in progress                                                                                                                                               |
|       |         | 2 to 0 | R      | Holds the status of the position signal input during unmatch detection<br>mode.<br>Bits 2, 1, and 0: W, V, and U phases                                                                   |
|       |         | 7, 6   | R/W    | Select the sampling input clock [Hz].<br>00: fc/2 <sup>2</sup> 01: fc/2 <sup>3</sup><br>10: fc/2 <sup>4</sup> 11: fc/2 <sup>5</sup>                                                       |
| PDCRB | 01FA1H  | 5, 4   | R/W    | Sampling mode.<br>00: When PWM is on<br>01: Regularly<br>10: When lower phases are turned on                                                                                              |
|       |         | 3 to 0 | R/W    | Detection position match counts 1 to 15.                                                                                                                                                  |
|       |         | 7      | ×      | 0: No operation<br>1: Stop sampling in software                                                                                                                                           |
|       |         | 6      | W      | 0: No operation<br>1: Start sampling in software                                                                                                                                          |
|       |         | 5      | R/W    | Stop sampling using Timer 3.<br>0: Disable<br>1: Enable                                                                                                                                   |
|       |         | 4      | R/W    | Start sampling using Timer 2.<br>0: Disable<br>1: Enable                                                                                                                                  |
| PDCRA | 01FA0H  | 3      | RW     | Number of position signal input pins.<br>0: Compare three pins (PDU/PDV/PDW)<br>1: Compare one pin (PDU) only                                                                             |
| <     |         | 2      | R/W    | Count occurrences of matching when PWM is on.<br>0: Subsequent to matching counts when PWM previously was on<br>1: Recount occurrences of matching each time PWM is on                    |
|       |         | 1      | R/W    | Position detection mode.<br>0: Ordinary mode<br>1: Unmatch detection mode                                                                                                                 |
|       |         | 0      | R/W    | Enable/Disable position detection function.<br>0: Disable<br>1: Enable (Sampling starts)                                                                                                  |
| SDREG | 01FA3H  | 6 to 0 | R/W    | Sampling delay.<br>2³/fc × n bits (n = 0 to 6, maximum 50.8 μs at 20 MHz).                                                                                                                |

| Name  | Address        | Bit     | R or W | Description                                                                                                                                                                                                                                                                                                                                      |
|-------|----------------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                | 7       | R/W    | Debug output.<br>0: Disable<br>1: Enable (P67 for PMD1)                                                                                                                                                                                                                                                                                          |
|       |                | 5       | R      | Mode timer overflow.<br>0: No overflow<br>1: Overflowed occurred                                                                                                                                                                                                                                                                                 |
| MTCRB | 01FA5H         | 3       | R/W    | Capture mode timer by overload protection.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                            |
|       |                | 2       | w      | Capture mode timer by software.<br>0: No operation<br>1: Capture                                                                                                                                                                                                                                                                                 |
|       |                | 1       | R/W    | Capture mode timer by position detection.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                             |
|       |                | 7, 6, 5 | R/W    | Select clock for mode timer [Hz].<br>000: fc/2 <sup>3</sup> (400 ns at 20 MHz)<br>010: fc/2 <sup>4</sup> (800 ns at 20 MHz)<br>100: fc/2 <sup>5</sup> (1.6 µs at 20 MHz)<br>110: fc/2 <sup>6</sup> (3.2 µs at 20 MHz)<br>001: fc/2 <sup>7</sup> (6.4 µs at 20 MHz)<br>011: Reserved<br>101: Reserved<br>111: Reserved<br>Reset timer by Timer 3. |
| MTCRA | 01FA4H         |         | R/W    | 0: Disable<br>1: Enable<br>Reset timer by overload protection.                                                                                                                                                                                                                                                                                   |
|       |                |         | R/W    | 0: Disable<br>1: Enable<br>Reset timer by software.                                                                                                                                                                                                                                                                                              |
|       |                | 2       | W      | 0: No operation<br>1: Reset                                                                                                                                                                                                                                                                                                                      |
| <     |                | 1       | R/W    | Reset timer by position detection.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                    |
|       |                | O       | R/W    | Enable/Disable mode timer.<br>0: Disable<br>1: Enable (timer starts)                                                                                                                                                                                                                                                                             |
| MCAP  | 01FA7H, 01FA6H | F to 0  | R      | Mode capture register.                                                                                                                                                                                                                                                                                                                           |
| CMP1  | 01FA9H, 01FA8H | F to 0  | R/W    | Compare Register 1.                                                                                                                                                                                                                                                                                                                              |
| CMP2  | 01FABH, 01FAAH | F to 0  | R/W    | Compare Register 2.                                                                                                                                                                                                                                                                                                                              |
| CMP3  | 01FADH, 01FACH | F to 0  | R/W    | Compare Register 3.                                                                                                                                                                                                                                                                                                                              |

Mode Timer Control Register (MTCR), Mode Capture Register (MCAP), and Compare Registers (CMP1, CMP2, CMP3)

| Name  | Address              | Bit     | R or W                                                                                                                                                               | Description                                                                                                                                                        |
|-------|----------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MDCRB | 01FAFH               | 1, 0    | R/W                                                                                                                                                                  | Select clock for PWM counter.<br>00: fc/2 (100 ns at 20 MHz) 01: fc/2² (200 ns at 20 MHz)<br>10: fc/2³ (400 ns at 20 MHz) 11: fc/2⁴ (800 ns at 20 MHz)             |
|       |                      | 7       | R/W                                                                                                                                                                  | Select half-period interrupt<br>0: Interrupt every period as specified in PINT.<br>1: Interrupt every half-period only PINT=00.                                    |
|       |                      | 6       | R/W                                                                                                                                                                  | DUTY mode.<br>0: U phase in common<br>1: Three phases independent                                                                                                  |
|       |                      | 5       | R/W                                                                                                                                                                  | Upper-phase port polarity.<br>0: Active low<br>1: Active high                                                                                                      |
| MDCRA | 01FAEH               | 4       | R/W                                                                                                                                                                  | Lower-phase port polarity.<br>0: Active low<br>1: Active high                                                                                                      |
|       |                      | 3, 2    | R/W                                                                                                                                                                  | Select PWM interrupt (trigger).<br>00: Interrupt once every period<br>01: Interrupt once 2 periods<br>10: Interrupt once 4 periods<br>11: Interrupt once 8 periods |
|       |                      | 1       | R/W                                                                                                                                                                  | PWM.mode.<br>0: PWM mode0 (edge: sawtooth wave)<br>1: PWM mode1 (center: triangular wave)                                                                          |
|       |                      | 0       | R/W                                                                                                                                                                  | Enable/disable waveform synthesis function.<br>0: Disable<br>1: Enable (waveform output)                                                                           |
| DTR   | 01FBEH               | 5 to 0  | R/W                                                                                                                                                                  | Set dead time.<br>2³/fc × 6bit (maximum 25.2 μs at 20 MHz).                                                                                                        |
|       |                      | F       | R                                                                                                                                                                    | 0: Count up<br>1: Count down                                                                                                                                       |
|       |                      | E, D, C | R/W                                                                                                                                                                  | Comparison register for position detection.<br>6: W<br>5: V<br>4: U                                                                                                |
| <     |                      | в       | R/W                                                                                                                                                                  | Select PWM synchronization.<br>0: Asynchronous with PWM period<br>1: Synchronized                                                                                  |
|       |                      |         | R/W                                                                                                                                                                  | W-phase PWM output.<br>0: H/L level output<br>1: PWM waveform output                                                                                               |
| MDOUT | MDOUT 01FB3H, 01FB2H | 9       | R/W                                                                                                                                                                  | V-phase PWM output.<br>0: H/L level output<br>1: PWM waveform output                                                                                               |
|       | 8                    | R/W     | U-phase PWM output.<br>0: H/L level output<br>1: PWM waveform output                                                                                                 |                                                                                                                                                                    |
|       | 7, 6                 | R/W     | Select port output synchronizing signal.<br>00: Asynchronous<br>01: Synchronized to position detection<br>10: Synchronized to Timer 1<br>11: Synchronized to Timer 2 |                                                                                                                                                                    |
|       |                      | 5, 4    | R/W                                                                                                                                                                  | Control W-phase output                                                                                                                                             |
| 1     |                      | 3, 2    | R/W                                                                                                                                                                  | Control V-phase output                                                                                                                                             |
|       |                      | 1, 0    | R/W                                                                                                                                                                  | Control U-phase output                                                                                                                                             |

PMD Control Register (MDCR), Dead Time Register (DTR), and PMD Output Register (MDOUT)

14.6 Electrical Angle Timer and Waveform Arithmetic Circuit

PWM Counter (MDCNT), PMD Period Register (MDPRD), and PMD Compare Registers (CMPU, CMPV, CMPW)

| Name  | Address        | Bit    | R or W | Description                        |
|-------|----------------|--------|--------|------------------------------------|
| MDCNT | 01FB5H, 01FB4H | B to 0 | R      | Read the PWM period counter value. |
| MDPRD | 01FB7H, 01FB6H | B to 0 | R/W    | PWM period MDPRD ≥ 010H.           |
| CMPU  | 01FB9H, 01FB8H | B to 0 | R/W    | Set U-phase PWM duty cycle.        |
| CMPV  | 01FBBH, 01FBAH | B to 0 | R/W    | Set V-phase PWM duty cycle.        |
| CMPW  | 01FBDH, 01FBCH | B to 0 | R/W    | Set W-phase PWM duty cycle.        |

### EMG Disable Code Register (EMGREL) and EMG Control Register (EMGCR)

| EMGREL | 01FBFH | 7 to 0 |     |                                                                                                                                                                                                                                                  |
|--------|--------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |        | 7 to 0 | W   | Code input for disable EMG protection circuit.<br>Can be disable by writing 5AH and then A5H.                                                                                                                                                    |
|        |        | 7      | w   | Return from overload protective state.<br>0: No operation<br>1: Return from protective state                                                                                                                                                     |
|        |        | 6      | R/W | Condition for returning from overload protective state:<br>Synchronized to PWM.<br>0: Disable<br>1: Enable                                                                                                                                       |
|        |        | 5      | R/W | Enable/Disable return from overload protective state by timer 1.<br>0: Disable<br>1: Enable                                                                                                                                                      |
| EMGCRB | 01FB1H | 4      | R   | Overload protective state.<br>0: No operation<br>1: Under protection                                                                                                                                                                             |
|        |        | 3,2    | R/W | Select output disabled phases during overload protection.<br>00: No phases disabled against output<br>01: All phases disabled against output<br>10: PWM phases disabled against output<br>11: All upper/All lower phases disabled against output |
|        |        | 1 <    | R/W | Stop PWM counter (MDCNT) during overload protection.<br>0: Do not stop<br>1: Stop                                                                                                                                                                |
|        |        | 0      | R/W | Enable/Disable overload protective circuit.<br>0: Disable<br>1: Enable                                                                                                                                                                           |
|        |        | 7 to 4 | R/W | Overload protection sampling time.<br>$2^2/fc \times n (n = 1 to 15, at 20 MHz)$                                                                                                                                                                 |
|        |        | 2      | R   | EMG protective state.<br>0: No operation<br>1: Under protection                                                                                                                                                                                  |
| EMGCRA | 01FB0H | 1      | w   | Return from EMG protective state.<br>0: No operation<br>1: Return from protective state                                                                                                                                                          |
|        |        | 0      | R/W | Enable/Disable function of the EMG protective circuit.<br>0: Disable<br>1: Enable<br>(This circuit initially is enabled (= 1). To disable this circuit, make sure<br>key code 5AH and A5H are written to the EMGREL1 Register before-            |

Electrical Angle Control Register (EDCR), Electrical Angle Period Register (EDSET), Electrical Angle Set Register (ELDEG), Voltage Set Register (AMP), and Electrical Angle Capture Register (EDCAP).

| Name         | Address        | Bit    | R or W                                                                                                                        | Description                                                                                                                    |
|--------------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
|              |                | 3      | W                                                                                                                             | 0: No operation<br>1: Start calculation                                                                                        |
|              | 0450411        | 2      | R                                                                                                                             | 0: Waveform Arithmetic Circuit stopped<br>1: Waveform Arithmetic Circuit calculation                                           |
| EDCRB        | 01FC1H         | 1      | R/W                                                                                                                           | <ul><li>0: Start calculation insync with electrical angle</li><li>1: Do not calculation insync with electrical angle</li></ul> |
|              | 0              | R/W    | <ul><li>0: Interrupt when the Electrical Angle Timer finishes counting</li><li>1: Interrupt upon end of calculation</li></ul> |                                                                                                                                |
|              |                | 7      | R/W                                                                                                                           | 0: Count up<br>1: Count down                                                                                                   |
|              |                | 6      | R/W                                                                                                                           | 0: V = U + 120°, W = U + 240°<br>1: V = U - 120°, W = U - 240°                                                                 |
| EDCRA 01FC0H | 5, 4           | R/W    | Select clock.<br>00: fc/2 <sup>3</sup> 01: fc/2 <sup>4</sup><br>10: fc/2 <sup>5</sup> 11: fc/2 <sup>6</sup>                   |                                                                                                                                |
|              | 01FC0H         | 3      | R/W                                                                                                                           | Switch between 2/3-phase modulations.<br>0: Two-phase modulation<br>1: Three-phase modulation                                  |
|              |                | 2      | R/W                                                                                                                           | Transfer calculation result to CMP registers.<br>0: Disable<br>1: Enable                                                       |
|              |                | 1      | R/W                                                                                                                           | Enable/disable waveform calculation function.<br>0: Disable<br>1: Enable                                                       |
|              |                | 0      | R/W                                                                                                                           | Electrical angle timer.<br>0: Disable<br>1: Enable                                                                             |
| EDSET        | 01FC3H, 01FC2H | F to C | R/W                                                                                                                           | Correct period (n) 0 to 15 times.                                                                                              |
| LDOLI        |                | B to 0 | R/W                                                                                                                           | Set period (1/m counter) ≥ 010H                                                                                                |
| ELDEG        | 01FC5H, 01FC4H | 8 to 0 | R/W                                                                                                                           | Initially set and count values of electrical angle.                                                                            |
| AMP          | 01FC7H, 01FC6H | B to 0 | R/W                                                                                                                           | Set voltage used during waveform calculation.                                                                                  |
| EDCAP        | 01FC9H, 01FC8H | 8 to 0 | R                                                                                                                             | Electrical angle timer value when position is detected.                                                                        |
| WFMDR        | 01FCAH         | 7 to 0 | W                                                                                                                             | Set sine wave data.                                                                                                            |

# 15. Asynchronous Serial interface (UART)

The TMP88F846UG has a asynchronous serial interface (UART). It can connect the peripheral circuits through TXD and RXD pin. TXD and RXD pin are also used as the general port. For TXD pin, the corresponding general port should be set output mode (Set its output control register to "1" after its output port latch to "1"). For RXD pin, should be set input mode.

This UART and SIO can not use simultaneously because their input/output ports are common.

When using UART of TMP88F846UG, it might be impossible to communicate because of the error of the oscillation frequency. Moreover, the oscillation frequency changes and it is impossible to communicate by the temperature change etc. Therefore, we recommend you to adjust the transmission rate by the communication protocol as follows.

[For Example]

- 1. Fixed data (ex: 05AH) is transmitted at head byte of transmission data or constant intervals from the host side whose oscillation is stable.
- 2. The host side keeps transmitting fixed data until receiving the ACK from remote side. The usual communication is restarted after ACK reception.
- 3. Remote side adjusts a transfer rate finely until receiving fixed data. When receiving fixed data, an ACK is transmitted to host and communication is usually restarted.

## 15.1 Configuration



Figure 15-1 UART (Asynchronous Serial Interface)

## 15.2 Control

UART is controlled by the UART Control Registers (UARTCRA, UARTCRB). The operating status can be monitored using the UART status register (UARTSR).



- Note 1: When operations are disabled by setting UARTCRA<TXE and RXE> bits to "0", the setting becomes valid when data transmit or receive complete. When the transmit data is stored in the transmit data buffer, the data are not transmitted. Even if data transmit is enabled, until new data are written to the transmit data buffer, the current data are not transmitted.
- Note 2: The transmit clock and the parity are common to transmit and receive.
- Note 3: UARTCRA<RXE> and UARTCRA<TXE> should be set to \*0\* before UARTCRA<BRG> is changed.
- Note 4: In case fc = 20MHz, the timer counter 4 (TC4) is available as a baud rate generator.

#### **UART Control Register2** UARTCRB 5 4 3 0 (01F92H) RXDNC STOPBR (Initial value: \*\*\*\* \*000) 00: No noise rejection (Hysteresis input) Selection of RXD input noise 01: Rejects pulses shorter than 31/fc [s] as noise RXDNC rejectio time 10: Rejects pulses shorter than 63/fc [s] as noise Write 11: Rejects pulses shorter than 127/fc [s] as noise only 1 bit 0: STOPBR Receive stop bit length 1: 2 bits

Note 1: Settings of RXDNC are limited depending on the transfer clock specified by BRG. The combination "O" is available but please do not select the combination "-". The transfer clock is calculated by the following equation : Transfer clock [Hz] =INTTC4 sourcec clock [Hz] ÷ TC4DR set value

|                                                                 |                        | RXDNC setting              |                                                         |                                                         |                                                          |  |  |  |
|-----------------------------------------------------------------|------------------------|----------------------------|---------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------|--|--|--|
| BRG setting                                                     | Transfer clock<br>[Hz] | 00<br>(No noise rejection) | 01<br>(Reject pulses shorter<br>than 31/fc[s] as noise) | 10<br>(Reject pulses shorter<br>than 63/fc[s] as noise) | 11<br>(Reject pulses shorter<br>than 127/fc[s] as noise) |  |  |  |
| 000                                                             | fc/13                  | 0                          | 0                                                       | 0                                                       | -                                                        |  |  |  |
| 110                                                             | fc/8                   | 0                          | -                                                       | -                                                       | -                                                        |  |  |  |
| (When the transfer clock gen-<br>erated by timer/counter inter- | fc/16                  | 0                          | 0                                                       |                                                         | > -                                                      |  |  |  |
| rupt is the same as the right<br>side column)                   | fc/32                  | 0                          | 0                                                       |                                                         | -                                                        |  |  |  |
| The setting except the                                          | above                  | 0                          | 0                                                       |                                                         | 0                                                        |  |  |  |

### **UART Status Register**

| (01F91H) PERR FERR OERR RBFL TEND TBEP (Initial value: 0000 11**) | UARTSR   | 7 | 6 | 5 | 4    | 3    | 2    | 1 | 0 |                        | 12   |
|-------------------------------------------------------------------|----------|---|---|---|------|------|------|---|---|------------------------|------|
|                                                                   | (01F91H) |   |   |   | RBFL | TEND | TBEP |   | 6 | (Initial value: 0000 1 | 1**) |

| PERR | Parity error flag               | 0: No parity error<br>1: Parity error                                                                                       |      |
|------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------|------|
| FERR | Framing error flag              | 0: No framing error<br>1: Framing error                                                                                     |      |
| OERR | Overrun error flag              | 0: No overrun error<br>1: Overrun error                                                                                     | Read |
| RBFL | Receive data buffer full flag   | 0: Receive data buffer empty<br>1: Receive data buffer full                                                                 | only |
| TEND | Transmit end flag               | 0: On transmitting<br>1: Transmit end                                                                                       |      |
| TBEP | Transmit data buffer empty flag | <ol> <li>0: Transmit data buffer full (Transmit data writing is finished)</li> <li>1: Transmit data buffer empty</li> </ol> |      |
| TBEP | Transmit data buffer empty flag |                                                                                                                             |      |

Note: When an INTTXD is generated, TBEP flag is set to "1" automatically.



Transfer Data Format

15.3

# 15.3 Transfer Data Format

In UART, an one-bit start bit (Low level), stop bit (Bit length selectable at high level, by UARTCRA<STBT>), and parity (Select parity in UARTCRA<PE>; even- or odd-numbered parity by UARTCRA<EVEN>) are added to the transfer data. The transfer data formats are shown as follows.



# TOSHIBA

## 15.4 Transfer Rate

The baud rate of UART is set of UARTCRA<BRG>. The example of the baud rate are shown as follows.

| BRG | Sourc        | ce Clock     |
|-----|--------------|--------------|
| BRG | 16 MHz       | 8 MHz        |
| 000 | 76800 [baud] | 38400 [baud] |
| 001 | 38400        | 19200        |
| 010 | 19200        | 9600         |
| 011 | 9600         | 4800         |
| 100 | 4800         | 2400         |
| 101 | 2400         | 1200         |

### Table 15-1 Transfer Rate (Example)

When INTTC4 is used as the UART transfer rate (when UARTCRA<BRG>= "110"), the transfer clock and transfer rate are determined as follows:

### Transfer clock [Hz] = TC4 source clock [Hz] / TC4DR setting value

Transfer Rate [baud] = Transfer clock [Hz] / 16

## 15.5 Data Sampling Method

The UART receiver keeps sampling input using the clock selected by UARTCRA<BRG> until a start bit is detected in RXD pin input. RT clock starts detecting "L" level of the RXD pin. Once a start bit is detected, the start bit, data bits, stop bit(s), and parity bit are sampled at three times of RT7, RT8, and RT9 during one receiver clock interval (RT clock). (RT0 is the position where the bit supposedly starts.) Bit is determined according to majority rule (The data are the same twice or more out of three samplings).



Figure 15-4 Data Sampling Method

## 15.6 STOP Bit Length

Select a transmit stop bit length (1 bit or 2 bits) by UARTCRA<STBT>.

## 15.7 Parity

Set parity / no parity by UARTCRA<PE> and set parity type (Odd- or Even-numbered) by UARTCRA<EVEN>.

## 15.8 Transmit/Receive Operation

### 15.8.1 Data Transmit Operation

Set UARTCRA<TXE> to "1". Read UARTSR to check UARTSR<TBEP> = "1", then write data in TDBUF (Transmit data buffer). Writing data in TDBUF zero-clears UARTSR<TBEP>, transfers the data to the transmit shift register and the data are sequentially output from the TXD pin. The data output include a one-bit start bit, stop bits whose number is specified in UARTCRA<STBT> and a parity bit if parity addition is specified. Select the data transfer baud rate using UARTCRA<BRG>. When data transmit starts, transmit buffer empty flag UARTSR<TBEP> is set to "1" and an INTTXD interrupt is generated.

While UARTCRA<TXE> = "0" and from when "1" is written to UARTCRA<TXE> to when send data are written to TDBUF, the TXD pin is fixed at high level. When transmitting data, first read UARTSR, then write data in TDBUF. Otherwise, UARTSR<TBEP> is not zero-cleared and transmit does not start.

### 15.8.2 Data Receive Operation

Set UARTCRA<RXE> to "1". When data are received via the RXD pin, the receive data are transferred to RDBUF (Receive data buffer). At this time, the data transmitted includes a start bit and stop bit(s) and a parity bit if parity addition is specified. When stop bit(s) are received, data only are extracted and transferred to RDBUF (Receive data buffer). Then the receive buffer full flag UARTSR<RBFL> is set and an INTRXD interrupt is generated. Select the data transfer baud rate using UARTCRA<BRG>.

If an overrun error (OERR) occurs when data are received, the data are not transferred to RDBUF (Receive data buffer) but discarded; data in the RDBUF are not affected.

Note: When a receive operation is disabled by setting UARTCRA<RXE> bit to "0", the setting becomes valid when data receive is completed. However, if a framing error occurs in data receive, the receive-disabling setting may not become valid. If a framing error occurs, be sure to perform a re-receive operation.

15.9.2

#### Status Flag 15.9

#### 15.9.1 Parity Error

When parity determined using the receive data bits differs from the received parity bit, the parity error flag UARTSR<PERR> is set to "1". The UARTSR<PERR> is cleared to "0" when the RDBUF is read after reading the UARTSR.



When all bits in the next data are received while unread data are still in RDBUF, overrun error flag UARTSR<OERR> is set to "1". In this case, the receive data is discarded; data in RDBUF are not affected. The UARTSR<OERR> is cleared to "0" when the RDBUF is read after reading the UARTSR.

| UARTSR <rbfl></rbfl> |                                                 |
|----------------------|-------------------------------------------------|
| RXD pin              | Final bit Stop                                  |
| Shift register       | xxx0** xxxx0* 1xxxx0                            |
| RDBUF                | УУУУУ                                           |
| UARTSR <oerr></oerr> | After reading UARTSR then<br>RDBUF clears OERR. |
| INTRXD interrupt     |                                                 |
|                      | Figure 15-7 Generation of Overrun Error         |

Note: Receive operations are disabled until the overrun error flag UARTSR<OERR> is cleared.

### 15.9.4 Receive Data Buffer Full

Loading the received data in RDBUF sets receive data buffer full flag UARTSR<RBFL> to "1". The UARTSR<RBFL> is cleared to "0" when the RDBUF is read after reading the UARTSR.

| RXD pin              | Final bit          | Stop            | $\overline{\mathcal{N}}$                        |
|----------------------|--------------------|-----------------|-------------------------------------------------|
|                      |                    |                 |                                                 |
| Shift register       | xxx0**             | xxxx0*          | <u>1xxxx0</u>                                   |
|                      | $\overline{C}$     | $\land$         | ¥                                               |
| RDBUF                | хуху               |                 | (                                               |
|                      |                    |                 |                                                 |
| UARTSR <rbfl></rbfl> |                    |                 | After reading UARTSR then<br>RDBUF clears RBFL. |
| INTRXD interrupt     |                    | (75)            | ]                                               |
|                      |                    |                 |                                                 |
| Figu                 | re 15-8 Generation | of Receive Data | a Buffer Full                                   |

Note: If the overrun error flag UARTSR<OERR> is set during the period between reading the UARTSR and reading the RDBUF, it cannot be cleared by only reading the RDBUF. Therefore, after reading the RDBUF, read the UARTSR again to check whether or not the overrun error flag which should have been cleared still remains set.

## 15.9.5 Transmit Data Buffer Empty

When no data is in the transmit buffer TDBUF, that is, when data in TDBUF are transferred to the transmit shift register and data transmit starts, transmit data buffer empty flag UARTSR<TBEP> is set to "1". The UARTSR<TBEP> is cleared to "0" when the TDBUF is written after reading the UARTSR.

# TOSHIBA





## 15.9.6 Transmit End Flag

When data are transmitted and no data is in TDBUF (UARTSR<TBEP> = "1"), transmit end flag UARTSR<TEND> is set to "1". The UARTSR<TEND> is cleared to "0" when the data transmit is stated after writing the TDBUF.

| Shift register       | ***1xx X ****1x X ****1   | Х 1уууу0 Х*1уууу |
|----------------------|---------------------------|------------------|
| TXD pin              | Stop Data write for TDBUF | Start Bit 0      |
| UARTSR <tbep></tbep> |                           |                  |
| UARTSR <tend></tend> |                           |                  |
| INTTXD interrupt     |                           | 'n               |
|                      |                           |                  |

Figure 15-10 Generation of Transmit End Flag and Transmit Data Buffer Empty



# 16. Synchronous Serial Interface (SIO)

The TMP88F846UG has a clocked-synchronous 8-bit serial interface. Serial interface has an 8-byte transmit and receive data buffer that can automatically and continuously transfer up to 64 bits of data.

Serial interface is connected to outside peripheral devices via SO, SI, SCK port.

This SIO and UART can not use simultaneously because their input/output ports are common.

## 16.1 Configuration



## 16.2 Control

The serial interface is controlled by SIO control registers (SIOCR1/SIOCR2). The serial interface status can be determined by reading SIO status register (SIOSR).

The transmit and receive data buffer is controlled by the SIOCR2<BUF>. The data buffer is assigned to address 01F98H to 01F9FH for SIO in the DBR area, and can continuously transfer up to 8 words (bytes or nibbles) at one time. When the specified number of words has been transferred, a buffer empty (in the transmit mode) or a buffer full (in the receive mode or transmit/receive mode) interrupt (INTSIO) is generated.

When the internal clock is used as the serial clock in the 8-bit receive mode and the 8-bit transmit/receive mode, a fixed interval wait can be applied to the serial clock for each word transferred. Four different wait times can be selected with SIOCR2<WAIT>.



Note 1: fc; High-frequency clock [Hz]

Note 2: Set SIOCR1<SIOS> to "0" and SIOCR1<SIOINH> to "1" when setting the transfer mode or serial clock.

Note 3: SIOCR1 is write-only register, which cannot access any of in read-modify-write instruction such as bit operate, etc.

# TOSHIBA

#### SIOCR2 3 2 0 6 4 1 5 (Initial value: \*\*\*0 0000) WAIT BUF (1F97H) Always sets "00" except 8-bit transmit / receive mode. 00: $T_f = T_D$ (Non wait) 01: T<sub>f</sub> = 2T<sub>D</sub> ( Wait) WAIT Wait control 10: T<sub>f</sub> = 4T<sub>D</sub> (Wait) 11: T<sub>f</sub> = 8T<sub>D</sub> (Wait) 000: 1 word transfer 01F98H Write 001: 2 words transfer 01F98H ~ 01F99H only 010: 3 words transfer 01F98H ~ 01F9AH 011: 4 words transfer 01F98H ~ 01F9BH Number of transfer words BUF (Buffer address in use) 100: 5 words transfer 01F98H ~ 01F9CH 101: 6 words transfer 01F98H ~ 01F9DH 110: 7 words transfer 01F98H ~ 01F9EH 111: 8 words transfer 01F98H ~ 01F9FH

SIO Control Register 2

Note 1: The lower 4 bits of each buffer are used during 4-bit transfers. Zeros (0) are stored to the upper 4bits when receiving.

- Note 2: Transmitting starts at the lowest address. Received data are also stored starting from the lowest address to the highest address. (The first buffer address transmitted is 01F98H).
- Note 3: The value to be loaded to BUF is held after transfer is completed.
- Note 4: SIOCR2 must be set when the serial interface is stopped (SIOF = 0).
- Note 5: \*: Don't care
- Note 6: SIOCR2 is write-only register, which cannot access any of in read-modify-write instruction such as bit operate, etc.
- Note 7: T<sub>f</sub>; Frame time, T<sub>D</sub>; Data transfer time



Figure 16-2 Frame time  $(T_f)$  and Data transfer time  $(T_D)$ 

SIO Status Register

| SIOSR   | 7    | 6   | 5 | 4 | 3 | 2 | 1 | 0 |                            |
|---------|------|-----|---|---|---|---|---|---|----------------------------|
| (1F97H) | SIOF | SEF |   |   |   |   |   |   | (Initial value: 00** ****) |

| SIOF | Serial transfer operating status monitor |          | Transfer terminated<br>Transfer in process               | Read |
|------|------------------------------------------|----------|----------------------------------------------------------|------|
| SEF  | Shift operating status monitor           | 0:<br>1: | Shift operation terminated<br>Shift operation in process | only |

Note 1: After SIOCR1<SIOS> is cleared to "0", SIOSR<SIOF> is cleared to "0" at the termination of transfer or the setting of SIOCR1<SIOINH> to "1".

## 16.3 Serial clock

### 16.3.1 Clock source

Internal clock or external clock for the source clock is selected by SIOCR1 <SCK>.

### 16.3.1.1 Internal clock

Any of six frequencies can be selected. The serial clock is output to the outside on the  $\overline{\text{SCK}}$  pin. The  $\overline{\text{SCK}}$  pin goes high when transfer starts.

When data writing (in the transmit mode) or reading (in the receive mode or the transmit/receive mode) cannot keep up with the serial clock rate, there is a wait function that automatically stops the serial clock and holds the next shift operation until the read/write processing is completed.



### 16.3.1.2 External clock

An external clock connected to the  $\overline{SCK}$  pin is used as the serial clock. In this case, the  $\overline{SCK}$  (P43) port should be set to input mode. To ensure shifting, a pulse width of more than 2<sup>4</sup>/fc is required. This pulse is needed for the shift operation to execute certainly. Actually, there is necessary processing time for interrupting, writing, and reading. The minimum pulse is determined by setting the mode and the program.

SCK pin (Input)



 $t_{SCKL}, t_{SCKH} > 2^4/fc$ 

## Figure 16-4 External clock pulse width

### 16.3.2 Shift edge

The leading edge is used to transmit, and the trailing edge is used to receive

### 16.3.2.1 Leading edge

Transmitted data are shifted on the leading edge of the serial clock (falling edge of the SCK pin input/ output).

### 16.3.2.2 Trailing edge

Received data are shifted on the trailing edge of the serial clock (rising edge of the SCK pin input/output).



## 16.4 Number of bits to transfer

Either 4-bit or 8-bit serial transfer can be selected. When 4-bit serial transfer is selected, only the lower 4 bits of the transmit/receive data buffer register are used. The upper 4 bits are cleared to "0" when receiving.

The data is transferred in sequence starting at the least significant bit (LSB).

## 16.5 Number of words to transfer

Up to 8 words consisting of 4 bits of data (4-bit serial transfer) or 8 bits (8-bit serial transfer) of data can be transferred continuously. The number of words to be transferred can be selected by SIOCR2<BUF>.

An INTSIO interrupt is generated when the specified number of words has been transferred. If the number of words is to be changed during transfer, the serial interface must be stopped before making the change. The number of words can be changed during automatic-wait operation of an internal clock. In this case, the serial interface is not required to be stopped.



Figure 16-6 Number of words to transfer (Example: 1word = 4bit)

## 16.6 Transfer Møde

SIOCR1<SIOM> is used to select the transmit, receive, or transmit/receive mode.

## 16.6.1 4-bit and 8-bit transfer modes

In these modes, firstly set the SIO control register to the transmit mode, and then write first transmit data (number of transfer words to be transferred) to the data buffer registers (DBR).

After the data are written, the transmission is started by setting SIOCR1<SIOS> to "1". The data are then output sequentially to the SO pin in synchronous with the serial clock, starting with the least significant bit (LSB). As soon as the LSB has been output, the data are transferred from the data buffer register to the shift register. When the final data bit has been transferred and the data buffer register is empty, an INTSIO (Buffer empty) interrupt is generated to request the next transmitted data.

When the internal clock is used, the serial clock will stop and an automatic-wait will be initiated if the next transmitted data are not loaded to the data buffer register by the time the number of data words specified with the SIOCR2<BUF> has been transmitted. Writing even one word of data cancels the automatic-wait; therefore, when transmitting two or more words, always write the next word before transmission of the previous word is completed.

Note: Automatic waits are also canceled by writing to a DBR not being used as a transmit data buffer register; therefore, during SIO do not use such DBR for other applications. For example, when 3 words are transmitted, do not use the DBR of the remained 5 words. When an external clock is used, the data must be written to the data buffer register before shifting next data. Thus, the transfer speed is determined by the maximum delay time from the generation of the interrupt request to writing of the data to the data buffer register by the interrupt service program.

The transmission is ended by clearing SIOCR1<SIOS> to "0" or setting SIOCR1<SIOINH> to "1" in buffer empty interrupt service program.

SIOCR1<SIOS> is cleared, the operation will end after all bits of words are transmitted.

That the transmission has ended can be determined from the status of SIOSR<SIOF> because SIOSR<SIOF> is cleared to "0" when a transfer is completed.

When SIOCR1<SIOINH> is set, the transmission is immediately ended and SIOSR<SIOF> is cleared to "0".

When an external clock is used, it is also necessary to clear SIOCR1<SIOS> to "0" before shifting the next data; If SIOCR1<SIOS> is not cleared before shift out, dummy data will be transmitted and the operation will end.

If it is necessary to change the number of words, SIOCR1<SIOS> should be cleared to "0", then SIOCR2<BUF> must be rewritten after confirming that SIOSR<SIOF> has been cleared to "0".

|                      | Clear SIOS                                                                  |
|----------------------|-----------------------------------------------------------------------------|
| SIOCR1 <sios></sios> |                                                                             |
| SIOSR <siof></siof>  |                                                                             |
| SIOSR <sef></sef>    |                                                                             |
| SCK pin<br>(Output)  |                                                                             |
| SO pin               | $\frac{1}{a_0 a_1 a_2 a_3 a_4 a_5 a_6 a_7 b_0 b_1 b_2 b_3 b_4 b_5 b_6 b_7}$ |
| INTSIO interrupt     |                                                                             |
| DBR                  |                                                                             |
| V                    | Arite Write<br>(a) (b)                                                      |
| $\sim$               | 7                                                                           |
| Figure 1             | 6-7 Transfer Mode (Example: 8bit, 1word transfer, Internal clock)           |
|                      |                                                                             |
|                      |                                                                             |



### 16.6.2 4-bit and 8-bit receive modes

After setting the control registers to the receive mode, set SIOCR1<SIOS> to "1" to enable receiving. The data are then transferred to the shift register via the SI pin in synchronous with the serial clock. When one word of data has been received, it is transferred from the shift register to the data buffer register (DBR). When the number of words specified with the SIOCR2<BUF> has been received, an INTSIO (Buffer full) interrupt is generated to request that these data be read out. The data are then read from the data buffer registers by the interrupt service program.

When the internal clock is used, and the previous data are not read from the data buffer register before the next data are received, the serial clock will stop and an automatic-wait will be initiated until the data are read. A wait will not be initiated if even one data word has been read.

Note:Waits are also canceled by reading a DBR not being used as a received data buffer register is read; therefore, during SIO do not use such DBR for other applications.

When an external clock is used, the shift operation is synchronized with the external clock; therefore, the previous data are read before the next data are transferred to the data buffer register. If the previous data have not been read, the next data will not be transferred to the data buffer register and the receiving of any more data will be canceled. When an external clock is used, the maximum transfer speed is determined by the delay between the time when the interrupt request is generated and when the data received have been read.

The receiving is ended by clearing SIOCR1<SIOS> to "0" or setting SIOCR1<SIOINH> to "1" in buffer full interrupt service program.

When SIOCR1<SIOS> is cleared, the current data are transferred to the buffer. After SIOCR1<SIOS> cleared, the receiving is ended at the time that the final bit of the data has been received. That the receiving has ended can be determined from the status of SIOSR<SIOF>. SIOSR<SIOF> is cleared to "0" when the receiving is ended. After confirmed the receiving termination, the final receiving data is read. When SIOCR1<SIOINH> is set, the receiving is immediately ended and SIOSR<SIOF> is cleared to "0". (The received data is ignored, and it is not required to be read out.)

If it is necessary to change the number of words in external clock operation, SIOCR1<SIOS> should be cleared to "0" then SIOCR2<BUF> must be rewritten after confirming that SIOSR<SIOF> has been cleared to "0". If it is necessary to change the number of words in internal clock, during automatic-wait operation which occurs after completion of data receiving, SIOCR2<BUF> must be rewritten before the received data is read out.



Figure 16-10 Receive Mode (Example: 8bit, 1word transfer, Internal clock)

## 16.6.3 8-bit transfer / receive mode

After setting the SIO control register to the 8-bit transmit/receive mode, write the data to be transmitted first to the data buffer registers (DBR). After that, enable the transmit/receive by setting SIOCR1<SIOS> to "1". When transmitting, the data are output from the SO pin at leading edges of the serial clock. When receiving, the data are input to the SI pin at the trailing edges of the serial clock. When the all receive is enabled, 8-bit data are transferred from the shift register to the data buffer register. An INTSIO interrupt is generated when the number of data words specified with the SIOCR2<BUF> has been transferred. Usually, read the receive data from the buffer register in the interrupt service. The data buffer register is used for both transmitting and receiving; therefore, always write the data to be transmitted after reading the all received data.

When the internal clock is used, a wait is initiated until the received data are read and the next transfer data are written. A wait will not be initiated if even one transfer data word has been written.

When an external clock is used, the shift operation is synchronized with the external clock; therefore, it is necessary to read the received data and write the data to be transmitted next before starting the next shift operation. When an external clock is used, the transfer speed is determined by the maximum delay between generation of an interrupt request and the received data are read and the data to be transmitted next are written.

The transmit/receive operation is ended by clearing SIOCR1<SIOS> to "0" or setting SIOCR1<SIOINH> to "1" in INTSIO interrupt service program.

When SIOCR1<SIOS> is cleared, the current data are transferred to the buffer. After SIOCR1<SIOS> cleared, the transmitting/receiving is ended at the time that the final bit of the data has been transmitted.

That the transmitting/receiving has ended can be determined from the status of SIOSR<SIOF>. SIOSR<SIOF> is cleared to "0" when the transmitting/receiving is ended.

When SIOCR1<SIOINH> is set, the transmit/receive operation is immediately ended and SIOSR<SIOF> is cleared to "0".

If it is necessary to change the number of words in external clock operation, SIOCR1<SIOS> should be cleared to "0", then SIOCR2<BUF> must be rewritten after confirming that SIOSR<SIOF> has been cleared to "0".

If it is necessary to change the number of words in internal clock, during automatic-wait operation which occurs after completion of transmit/receive operation, SIOCR2<BUF> must be rewritten before reading and writing of the receive/transmit data.

Note: The buffer contents are lost when the transfer mode is switched. If it should become necessary to switch

|                      | the transfer mode, and receiving by cleaning SIOCR (SIOS> to 0, read the last data and then switch the transfer mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Clear SIOS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| SIOCR1 <sios></sios> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SIOSR <siof></siof>  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SIOSR <sef></sef>    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SCK pin<br>(output)  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SO pin               | $\begin{array}{c} \begin{array}{c} \begin{array}{c} \begin{array}{c} \begin{array}{c} \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \end{array} \\ \end{array} $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| SI pin               | $\underbrace{\begin{array}{c} \begin{array}{c} \\ \\ \end{array}} \\ \begin{array}{c} \\ \\ \end{array} \\ \begin{array}{c} \\ \end{array} \\ \begin{array}{c} \\ \\ \end{array} \\ \begin{array}{c} \\ \end{array} \\ \begin{array}{c} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \end{array} \\ \begin{array}{c} \\ \end{array} \\ \begin{array}{c} \\ \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \\ \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \\ \end{array} \\ $ |
| INTSIO interrupt     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| DBR                  | A A A A A A A A A A A A A A A A A A A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| $\sim$ (             | Write (a) Read out (c) Write (b) Read out (d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Figure 16-11 Transfer / Receive Mode (Example: 8bit, 1word transfer, Internal clock)



Figure 16-12 Transmitted Data Hold Time at End of Transfer / Receive



16.6 Transfer Mode
# 17. 10-bit AD Converter (ADC)

The TMP88F846UG have a 10-bit successive approximation type AD converter.

### 17.1 Configuration

The circuit configuration of the 10-bit AD converter is shown in Figure 17-1.

It consists of control register ADCCRA and ADCCRB, converted value register ADCDRH and ADCDRL, a DA converter, a sample-hold circuit, a comparator, and a successive comparison circuit.



## 17.2 Register configuration

The AD converter consists of the following four registers:

1. AD converter control register 1 (ADCCRA)

This register selects the analog channels and operation mode (Software start or repeat) in which to perform AD conversion and controls the AD converter as it starts operating.

2. AD converter control register 2 (ADCCRB)

This register selects the AD conversion time and controls the connection of the DA converter (Ladder resistor network).

3. AD converted value register 1 (ADCDRH)

This register used to store the digital value after being converted by the AD converter.

4. AD converted value register 2 (ADCDRL)

This register monitors the operating status of the AD converter.

#### AD Converter Control Register 1



| A  | DRS | AD conversion start         | 0:                                                                                                                                           | -<br>AD conversion start                                                                                                                                                                                     |     |
|----|-----|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| A  | MD  | AD operating mode           | 00:<br>01:<br>10:<br>11:                                                                                                                     | AD operation disable<br>Software start mode<br>INTPWM start mode<br>Repeat mode                                                                                                                              |     |
| AI | NDS | Analog input control        | 0:<br>1:                                                                                                                                     | Analog input enable<br>Analog input disable                                                                                                                                                                  |     |
| S  |     | Analog input channel select | 0000:<br>0001:<br>0010:<br>0010:<br>0100:<br>0101:<br>0110:<br>0111:<br>1000:<br>1001:<br>1100:<br>1100:<br>1100:<br>1110:<br>1110:<br>1111: | AIN0<br>AIN1<br>AIN2<br>AIN3<br>AIN4<br>AIN5<br>AIN6<br>AIN7<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved | R/W |

- Note 1: Select analog input channel during AD converter stops (ADCDRL<ADBF> = "0").
- Note 2: When the analog input channel is all use disabling, the ADCCRA<AINDS> should be set to "1".
- Note 3: During conversion, Do not perform port output instruction to maintain a precision for all of the pins because analog input port use as general input port. And for port near to analog input, Do not input intense signaling of change.
- Note 4: The ADCCRA<ADRS> is automatically cleared to "0" after starting conversion.
- Note 5: Do not set ADCCRA<ADRS> newly again during AD conversion. Before setting ADCCRA<ADRS> newly again, check ADCDRL<EOCF> to see that the conversion is completed or wait until the interrupt signal (INTADC) is generated (e.g., interrupt handling routine).
- Note 6: After STOP mode is started, AD converter control register1 (ADCCRA) is all initialized and no data can be written in this register. Therefore, to use AD converter again, set the ADCCRA newly after returning to NORMAL mode.
- Note 7: After RESET, ADCCRA<SAIN> is initialized Reserved setting. Therefore, set the appropriate analog input channel to ADCCRA<SAIN> when use AD converter.

# TOSHIBA

Note 8: After ADCCRA is set to 00H, AD conversion can not be started for four cycles. Thus, four NOPs must be inserted before setting the ADCCRA<ADRS>.



#### AD Converter Control Register 2

- Note 1: Always set bit0 in ADCCRB to "0" and set bit4 in ADCCRB to "1".
- Note 2: When a read instruction for ADCCRB, bit6 to 7 in ADCCRB read in as undefined data.
- Note 3: After STOP mode is started, AD converter control register2 (ADCCRB) is all initialized and no data can be written in this register. Therefore, to use AD converter again, set the ADCCRB newly after returning to NORMAL mode.

|   | Condition<br>ACK | Conversion<br>time | 20 MHz  | 16 MHz  | 8 MHz    |
|---|------------------|--------------------|---------|---------|----------|
|   | 000              | 39/fc              | -       |         | -        |
|   | 001              | $\bigcirc$         | Rese    | ved     |          |
|   | 010              | 78/fc              | 4       | -       | -        |
| 2 | 011              | 156/fc             |         | $\sim$  | 19.5 µs  |
| r | 100              | 312/fc             | 15.6 µs | 19.5 µs | 39.0 µs  |
|   | 101              | 624/fc             | 31.2 µs | 39.0 µs | 78.0 µs  |
|   | 110              | 1248/fc            | 62.4 µs | 78.0 µs | 156.0 µs |
|   | 111              |                    | Rese    | rved    |          |
|   |                  |                    |         |         |          |

Table 17-1 ACK setting and Conversion time (at CGCR<DV1CK>="0")



| Condition<br>ACK | Conversion<br>time | 20 MHz  | 16 MHz  | 8 MHz    |
|------------------|--------------------|---------|---------|----------|
| 000              | 39/fc              | -       | -       | -        |
| /001             |                    | Reser   | ved     |          |
| 010              | 78/fc              | -       | -       | -        |
| 011              | 156/fc             | -       | -       | 19.5 µs  |
| 100              | 312/fc             | 15.6 µs | 19.5 µs | 39.0 µs  |
| 101              | 624/fc             | 31.2 µs | 39.0 µs | 78.0 µs  |
| 110              | 1248/fc            | 62.4 µs | 78.0 µs | 156.0 µs |
| 111              |                    | Reser   | ved     |          |

Note 1: Setting for "-" in the above table are inhibited. fc: High Frequency oscillation clock [Hz]

Note 2: Set conversion time setting should be kept more than the following time by Analog reference voltage (VAREF).

| VAREF =                      | 4.5 to 5.5 \                                   | / 15.6                                                                                                                                 | δ µs and mo                                                                                                                                                                                        | re                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |                                                |                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ted value                    | e Regist                                       | er 1                                                                                                                                   |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | $\sim$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7                            | 6                                              | 5                                                                                                                                      | 4                                                                                                                                                                                                  | 3                                                                                                                                                                                                                                                          | 2                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| AD09                         | AD08                                           | AD07                                                                                                                                   | AD06                                                                                                                                                                                               | AD05                                                                                                                                                                                                                                                       | AD04                                                                                                                                                                                                                                                    | AD03                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | AD02                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | (Initial value: 0000 0000)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ted value                    | e Regist<br><sub>6</sub>                       | er 2<br>5                                                                                                                              | 4                                                                                                                                                                                                  | 3                                                                                                                                                                                                                                                          | 2                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| AD01                         | AD00                                           | EOCF                                                                                                                                   | ADBF                                                                                                                                                                                               |                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                         | $\bigcirc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | $\square$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | (Initial value: 0000 ****)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ,                            |                                                |                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                         | 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | $\rightarrow$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| EOCF                         | AD con                                         | AD conversion end flag                                                                                                                 |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                         | // < \                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ADBF AD conversion BUSY flag |                                                |                                                                                                                                        |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                         | rsion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                              | ted valu<br>7<br>AD09<br>ted valu<br>7<br>AD01 | ted value Regist          7       6         AD09       AD08         ted value Regist       7         7       6         AD01       AD00 | ted value Register 1          7       6       5         AD09       AD08       AD07         ted value Register 2       7       6       5         AD01       AD00       EOCF       AD conversion end | ted value Register 1          7       6       5       4         AD09       AD08       AD07       AD06         ted value Register 2       7       6       5       4         7       6       5       4       4         AD01       AD00       EOCF       ADBF | ted value Register 1         7       6       5       4       3         AD09       AD08       AD07       AD06       AD05         ted value Register 2         7       6       5       4       3         AD01       AD00       EOCF       ADBF       ADBF | r       6       5       4       3       2         AD09       AD08       AD07       AD06       AD05       AD04         ted value Register 2       7       6       5       4       3       2         7       6       5       4       3       2         AD01       AD00       EOCF       ADBF       0:       B4         EOCF       AD conversion end flag       0:       B4       1:       C4         ADBE       AD conversion BUSY flag       0:       D1:       D1:       D1:       D1: | ted value Register 1         7       6       5       4       3       2       1         AD09       AD08       AD07       AD06       AD05       AD04       AD03         ted value Register 2       7       6       5       4       3       2       1         AD01       AD00       EOCF       ADBF       0:       Before or duri 1:       Conversion conve | r       6       5       4       3       2       1       0         AD09       AD08       AD07       AD06       AD05       AD04       AD03       AD02         ted value Register 2       7       6       5       4       3       2       1       0         7       6       5       4       3       2       1       0         AD01       AD00       EOCF       ADBF       0       Effore or during convers         EOCF       AD conversion end flag       0:       Before or during convers       1:       Conversion completed         ADBE       AD conversion BUSY flag       0:       During stop of AD conversion       0:       During stop of AD conversion | ted value Register 1          7       6       5       4       3       2       1       0         AD09       AD08       AD07       AD06       AD05       AD04       AD03       AD02       (Initial value: 0000 0000)         ted value Register 2       7       6       5       4       3       2       1       0         7       6       5       4       3       2       1       0         AD01       AD00       EOCF       ADBF       (Initial value: 0000 ****)         EOCF       AD conversion end flag       0:       Before or during conversion         1:       Conversion completed       0:       During stop of AD conversion         ADBE       AD conversion BUSY flag       0:       During stop of AD conversion |

- Note 1: The ADCDRL<EOCF> is cleared to "0" when reading the ADCDRH. Therefore, the AD conversion result should be read to ADCDRL more first than ADCDRH.
- Note 2: The ADCDRL<ADBF> is set to "1" when AD conversion starts, and cleared to "0" when AD conversion finished. It also is cleared upon entering STOP mode.
- Note 3: If a read instruction is executed for ADCDRL, read data of bit3 to bit0 are unstable.

### 17.3 Function

#### 17.3.1 Software Start Mode

After setting ADCCRA<AMD> to "01" (software start mode), set ADCCRA<ADRS> to "1". AD conversion of the voltage at the analog input pin specified by ADCCRA<SAIN> is thereby started.

After completion of the AD conversion, the conversion result is stored in AD converted value registers (ADCDRH, ADCDRL) and at the same time ADCDRL<EOCF> is set to 1, the AD conversion finished interrupt (INTADC) is generated.

ADRS is automatically cleared after AD conversion has started. Do not set ADCCRA<ADRS> newly again (Restart) during AD conversion. Before setting ADCCRA<ADRS> newly again, check ADCDRL<EOCF> to see that the conversion is completed or wait until the interrupt signal (INTADC) is generated (e.g., interrupt handling routine).



#### 17.3.2 Repeat Mode

AD conversion of the voltage at the analog input pin specified by ADCCRA<SAIN> is performed repeatedly. In this mode, AD conversion is started by setting ADCCRA<ADRS> to "1" after setting ADCCRA<AMD> to "11" (Repeat mode).

After completion of the AD conversion, the conversion result is stored in AD converted value registers (ADCDRH, ADCDRL) and at the same time ADCDRL<EOCF> is set to 1, the AD conversion finished interrupt (INTADC) is generated.

In repeat mode, each time one AD conversion is completed, the next AD conversion is started. To stop AD conversion, set ADCCRA<AMD> to "00" (Disable mode) by writing 0s. The AD convert operation is stopped immediately. The converted value at this time is not stored in the AD converted value register.



- 1. Set up the AD converter control register 1 (ADCCRA) as follows:
  - Choose the channel to AD convert using AD input channel select (SAIN).
  - Specify analog input enable for analog input control (AINDS).
  - Specify AMD for the AD converter control operation mode (software or repeat mode).
- 2. Set up the AD converter control register 2 (ADCCRB) as follows:
  - Set the AD conversion time using AD conversion time (ACK). For details on how to set the conversion time, refer to Table 17-1, Table 17-2 and AD converter control register 2.
    Choose IREFON for DA converter control.
- 3. After setting up (1) and (2) above, set AD conversion start (ADRS) of AD converter control register 1 (ADCCRA) to "1". If software start mode has been selected, AD conversion starts immediately.
- 4. After an elapse of the specified AD conversion time, the AD converted value is stored in AD converted value register 1 (ADCDRH) and the AD conversion finished flag (EOCF) of AD converted value register 2 (ADCDRL) is set to "1", upon which time AD conversion interrupt INTADC is generated.

EOCF is cleared to "0" by a read of the conversion result. However, if reconverted before a register read, although EOCF is cleared the previous conversion result is retained until the next conversion is completed.

Example :After selecting the conversion time 15.6 µs at 20 MHz and the analog input channel AIN4 pin, perform AD conversion once. After checking EOCF, read the converted value, store the lower 2 bits in address 0009EH and store the upper 8 bits in address 0009FH in RAM. The operation mode is software start mode.

|         | : (port setting) | :                    | ;Set port register appropriately before setting AD converter registers. |
|---------|------------------|----------------------|-------------------------------------------------------------------------|
|         | :                | :                    | ; (Refer to section I/O port in details)                                |
|         | LD               | (ADCCRA) , 00100100B | ; Select Software start mode, Analog input enable, and AIN4             |
|         | LD               | (ADCCRB) , 00011000B | ;Select conversion time(312/fc) and operation mode                      |
|         |                  |                      | $\sim$ (7/5)                                                            |
|         | SET              | (ADCCRA) . 7         | ; ADRS = 1(AD conversion start)                                         |
| SLOOP : | TEST             | (ADCDRB) . 5         | ; EOCF= 1 ?                                                             |
|         | JRS              | T, SLOOP             |                                                                         |
|         |                  |                      |                                                                         |
|         | LD               | A , (ADCDRL)         | ; Read result data                                                      |
|         | LD               | (9EH) , A            |                                                                         |
|         | LD               | A , (ADCDRH)         | ;Read result data                                                       |
|         | LD               | (9FH), A             |                                                                         |
|         |                  |                      |                                                                         |

#### 17.3.3 INTPWM Start Mode

AD conversion can be started by the PWM interrupt (INTPWM) provided as part of the PMD function.

To use INTPWM start mode, set ADCCRA<AMD> to "10" to put the AD converter in a standby state. While the AD converter is in this state, generation of an INTPWM interrupt set ADCCRA<ADRS> to "1" and starts AD conversion.

After the AD conversion operation is completed, the conversion result is stored in the AD conversion value registers (ADCDRH, ADCDRL). At the same time, ADCDRL<EOCF> is set to "1" and an end-of-conversion interrupt (INTADC) is generated.

To perform the next AD conversion in INTPWM start mode, set ADCCRA<AINDS> to "1" (to analog input disable) and then set ADCCRA<AINDS> to "0" (to analog input enable) to put the AD converter in a standby state.

To stop AD conversion, write "0" to ADCCRA<AMD>. This will immediately stop the AD conversion operation in progress. At this time, the conversion value is not stored in the AD conversion value registers, and the AD converter immediately exits a standby state.



To change the AD conversion operation, first clear ADCCRA<AMD> to "00" to disable AD operation, and then set ADCCRA again.

### 17.4 STOP mode during AD Conversion

When standby mode (STOP mode) is entered forcibly during AD conversion, the AD convert operation is suspended and the AD converter is initialized (ADCCRA and ADCCRB are initialized to initial value). Also, the conversion result is indeterminate. (Conversion results up to the previous operation are cleared, so be sure to read the conversion results before entering standby mode (STOP mode).) When restored from standby mode (STOP mode), AD conversion is not automatically restarted, so it is necessary to restart AD conversion. Note that since the analog reference voltage is automatically disconnected, there is no possibility of current flowing into the analog reference voltage.

# 17.5 Analog Input Voltage and AD Conversion Result

The analog input voltage is corresponded to the 10-bit digital value converted by the AD as shown in Figure 17-5.



# TOSHIBA

## 17.6 Precautions about AD Converter

#### 17.6.1 Analog input pin voltage range

Make sure the analog input pins (AIN0 to AIN7) are used at voltages within VAREF to AVSS. If any voltage outside this range is applied to one of the analog input pins, the converted value on that pin becomes uncertain. The other analog input pins also are affected by that.

#### 17.6.2 Analog input shared pins

The analog input pins (AIN0 to AIN7) are shared with input/output ports. When using any of the analog inputs to execute AD conversion, do not execute input/output instructions for all other ports. This is necessary to prevent the accuracy of AD conversion from degrading. Not only these analog input shared pins, some other pins may also be affected by noise arising from input/output to and from adjacent pins.

#### 17.6.3 Noise Countermeasure

The internal equivalent circuit of the analog input pins is shown in Figure 17-6. The higher the output impedance of the analog input source, more easily they are susceptible to noise. Therefore, make sure the output impedance of the signal source in your design is 5 k $\Omega$  or less. Toshiba also recommends attaching a capacitor external to the chip.



# 18. Flash Memory

TMP88F846UG has 8192 bytes flash memory (address: 04000H to 05EFFH and FFF00H to FFFFH). The write and erase operations to the flash memory are controlled in the following three types of mode.

- MCU mode

The flash memory is accessed by the CPU control in the MCU mode. This mode is used for software bug correction and firmware change after shipment of the device since the write operation to the flash memory is available by retaining the application behavior.

- Serial PROM mode

The flash memory is accessed by the CPU control in the serial PROM mode. Use of the serial interface (UART) enables the flash memory to be controlled by the small number of pins. TMP88F846UG in the serial PROM mode supports on-board programming which enables users to program flash memory after the microcontroller is mounted on a user board.

- Parallel PROM mode

The parallel PROM mode allows the flash memory to be accessed as a stand-alone flash memory by the program writer provided by the third party. High-speed access to the flash memory is available by controlling address and data signals directly. For the support of the program writer, please ask Toshiba sales representative.

In the MCU and serial PROM modes, the flash memory control register (FLSCR) is used for flash memory control. This chapter describes how to access the flash memory using the flash memory control register (FLSCR) in the MCU and serial PROM modes.

## 18.1 Flash Memory Control

The flash memory is controlled via the flash memory control register (FLSCR) and flash memory stanby control resister (FLSSTB).



Note 1: The command sequence of the flash memory can be executed only when FLSCR<FLSMD>="0011B". In other cases, any attempts to execute the command sequence are ineffective.

Note 2: FLSCR<FLSMD> must be set to either "1100B" or "0011B".

Note 3: Bits 3 to 0 in FLSCR register are always read as don't care.

### 18.1.1 Flash Memory Command Sequence Execution Control (FLSCR<FLSMD>)

The flash memory can be protected from inadvertent write due to program error or microcontroller misoperation. This write protection feature is realized by disabling flash memory command sequence execution via the flash memory control register (write protect). To enable command sequence execution, set FLSCR<FLSMD> to "0011B". To disable command sequence execution, set FLSCR<FLSMD> to "1100B". After reset, FLSCR<FLSMD> is initialized to "1100B" to disable command sequence execution. Normally, FLSCR<FLSMD> should be set to "1100B" except when the flash memory needs to be written or erased.

### 18.2 Command Sequence

The command sequence in the MCU and the serial PROM modes consists of six commands (JEDEC compatible), as shown in Table 18-1.

#### Table 18-1 Command Sequence

|   | Command Sequence                | 1st Bus Write Cy-<br>cle |      | 2nd Bus Write Cy-<br>cle |      | 3rd Bus Write Cy-<br>cle |      | 4th Bus Write Cy-<br>cle |                  | 5th Bus Write Cy-<br>cle |      | 6th Bus Write Cy-<br>cle |      |
|---|---------------------------------|--------------------------|------|--------------------------|------|--------------------------|------|--------------------------|------------------|--------------------------|------|--------------------------|------|
|   |                                 | Address                  | Data | Address                  | Data | Address                  | Data | Address                  | Data             | Address                  | Data | Address                  | Data |
| 1 | 1 Byte program                  | 04555H                   | AAH  | 04AAA<br>H               | 55H  | 04555H                   | A0H  | BA<br>(Note 1)           | Data<br>(Note 1) | $\bigcirc$               | -    | -                        | -    |
| 2 | Sector Erase<br>(4-kbyte Erase) | 04555H                   | AAH  | 04AAA<br>H               | 55H  | 04555H                   | 80H  | 04555H                   | AAH              | 04AAA<br>H               | 55H  | SA<br>(Note 2)           | 30H  |
| 3 | Chip Erase<br>(All Erase)       | 04555H                   | AAH  | 04AAA<br>H               | 55H  | 04555H                   | 80H  | 04555H                   | ААН              | 04AAA<br>H               | 55H  | 04555H                   | 10H  |
| 4 | Product ID Entry                | 04555H                   | AAH  | 04AAA<br>H               | 55H  | 04555H                   | 90H  | 77                       | > -              | -                        | 2    | > -                      | -    |
|   | Product ID Exit                 | ХХН                      | F0H  | -                        | -    | -                        | - (  | $\bigcirc$               | - <              | $\sum_{i=1}^{n}$         | 2/6  | ) -                      | -    |
| 5 | Product ID Exit                 | 04555H                   | AAH  | 04AAA<br>H               | 55H  | 04555H                   | FOH  |                          | -                |                          | S    | -                        | -    |
| 6 | Security Program                | 04555H                   | AAH  | 04AAA<br>H               | 55H  | 04555H                   | A5H  | 04F7FH                   | 00H              | $\mathcal{D}$            | -    | -                        | -    |

Note 1: Set the address and data to be written.

Note 2: Set the address which is the specified sector. (The area to be erased is specified with the upper 8 bits of the address.) (Example) In case " Sector 1 ", SA is " 0x05yyy ".

#### 18.2.1 Byte Program

This command writes the flash memory for each byte unit. The addresses and data to be written are specified in the 4th bus write cycle. Each byte can be programmed in a maximum of 40  $\mu$ s. The next command sequence cannot be executed until the write operation is completed. To check the completion of the write operation, perform read operations repeatedly until the same data is read twice from the same address in the flash memory. During the write operation, any consecutive attempts to read from the same address is reversed bit 6 of the data (toggling between 0 and 1).

Note: To rewrite data to Flash memory addresses at which data (including FFH) is already written, make sure to erase the existing data by "sector erase" or "chip erase" before rewriting data.

# 18.2.2 Sector Erase (4-kbyte Erase)

This command erases the flash memory in units of 4 kbytes. The flash memory area to be erased is specified by the upper 4 bits of the 6th bus write cycle address. For example, to erase 4 kbytes from F000H to FFFFH, specify one of the addresses in F000H-FFFFH as the 6th bus write cycle. The sector erase command is effective only in the MCU and serial PROM modes, and it cannot be used in the parallel PROM mode.

A maximum of 30 ms is required to erase 4 kbytes. The next command sequence cannot be executed until the erase operation is completed. To check the completion of the erase operation, perform read operations repeatedly for data polling until the same data is read twice from the same address in the flash memory. During the erase operation, any consecutive attempts to read from the same address is reversed bit 6 of the data (toggling between 0 and 1).

#### 18.2.3 Chip Erase (All Erase)

This command erases the entire flash memory in approximately 30 ms. The next command sequence cannot be executed until the erase operation is completed. To check the completion of the erase operation, perform read

operations repeatedly for data polling until the same data is read twice from the same address in the flash memory. During the erase operation, any consecutive attempts to read from the same address is reversed bit 6 of the data (toggling between 0 and 1). After the chip is erased, all bytes contain FFH.

#### 18.2.4 Product ID Entry

This command activates the Product ID mode. In the Product ID mode, the vendor ID, the flash ID, and the security program status can be read from the flash memory.

| Cell | Address | Meaning                 | Read Value                               |
|------|---------|-------------------------|------------------------------------------|
|      | 04000H  | Vendor ID               | 98H                                      |
|      | 04001H  | Flash macro ID          | 41H                                      |
|      |         |                         | 1DH: 120 kbytes                          |
|      |         |                         | 0EH: 60 kbytes                           |
|      | 04002H  | Flash size              | 0BH: 48 kbytes                           |
| 1    |         |                         | 07H: 32 kbytes                           |
| 1    |         |                         | 05H: 24 kbytes                           |
|      |         |                         | 03H: 16 kbytes                           |
|      |         |                         | 01H: 8 kbytes                            |
|      |         |                         | 00H: 4 kbytes                            |
|      | 0457511 |                         | FFH: Security program disabled           |
|      | 04F7FH  | Security program status | Other than FFH: Security program enabled |

Table 18-2 Values To Be Read in the Product ID Mode

Note: The value at address 04002H (flash size) depends on the size of flash memory incorporated in each product. For example, if the product has 16-kbyte flash memory, "03H" is read from address 04002H.

#### 18.2.5 Product ID Exit

This command is used to exit the Product ID mode.

#### 18.2.6 Security Program

This command enables the read/write protection setting in the flash memory. When the security program is enabled, the flash memory cannot be read and cannot be written in the parallel PROM mode. In the serial PROM mode, the flash write and RAM loader commands cannot be executed.

To disable the security program setting, it is necessary to execute the chip erase command sequence. Whether or not the security program is enabled can be checked by reading 04F7FH in the Product ID mode. For details, see Table 18-2.

It takes a maximum of 40  $\mu$ s to set security program in the flash memory. The next command sequence cannot be executed until this operation is completed. To check the completion of the sequrity program operation, perform read operations repeatedly for data polling until the same data is read twice from the same address in the flash memory. During the security program operation, any attempts to read from the same address is reversed bit 6 of the data (toggling between 0 and 1).

### 18.3 Toggle Bit (D6)

After the byte program, chip erase, and security program command sequence is executed, any consecutive attempts to read from the same address is reversed bit 6 (D6) of the data (toggling between 0 and 1) until the operation is completed. Therefore, this toggle bit provides a software mechanism to check the completion of each operation.

Usually perform read operations repeatedly for data polling until the same data is read twice from the same address in the flash memory. After the byte program, chip erase, or security program command sequence is executed, the initial read of the toggle bit always produces a "1".

### 18.4 Access to the Flash Memory Area

When the write, erase and security program are set in the flash memory, read and fetch operations cannot be performed in the entire flash memory area. Therefore, to perform these operations in the entire flash memory area, access to the flash memory area by the control program in the BOOTROM or RAM area. (The flash memory program cannot write to the flash memory.) The serial PROM or MCU mode is used to run the control program in the BOOT-ROM or RAM area.

- Note 1: The flash memory can be written or read for each byte unit. Erase operations can be performed either in the entire area or in units of 4 kbytes, whereas read operations can be performed by an one transfer instruction. However, the command sequence method is adopted for write and erase operations, requiring several-byte transfer instructions for each operation.
- Note 2: To rewrite data to Flash memory addresses at which data (including FFH) is already written, make sure to erase the existing data by "sector erase" or "chip erase" before rewriting data.

### 18.4.1 Flash Memory Control in the Serial PROM Mode

The serial PROM mode is used to access to the flash memory by the control program provided in the BOOT-ROM area. Since almost of all operations relating to access to the flash memory can be controlled simply by the communication data of the serial interface (UART), these functions are transparent to the user. For the details of the serial PROM mode, see "Serial PROM Mode."

To access to the flash memory by using peripheral functions in the serial PROM mode, run the RAM loader command to execute the control program in the RAM area. The procedures to execute the control program in the RAM area is shown in "18.4.1.1 How to write to the flash memory by executing the control program in the RAM area (in the RAM loader mode within the serial PROM mode)".

18.4.1.1 How to write to the flash memory by executing the control program in the RAM area (in the RAM loader mode within the serial PROM mode)

(Steps 1 and 2 are controlled by the BOOTROM, and steps 3 to 9 are controlled by the control program executed in the RAM area.)

- 1. Transfer the write control program to the RAM area in the RAM loader mode.
- 2. Jump to the RAM area.
- 3. Disable (DI) the interrupt master enable flag (IMF  $\leftarrow$  "0").
- 4. Set FLSCR<FLSMD> to "0011B" (to enable command sequence execution).
- 5. Execute the erase command sequence.
- 6. Read the same flash memory address twice.
  - (Repeat step 6 until the same data is read by two consecutive reads operations.)
- 7. Execute the write command sequence.
- 8. Read the same flash memory address twice.

(Repeat step 8 until the same data is read by two consecutive reads operations.)

- 9. Set FLSCR<FLSMD> to "1100B" (to disable command sequence execution).
- Note 1: Before writing to the flash memory in the RAM area, disable interrupts by setting the interrupt master enable flag (IMF) to "0". Usually disable interrupts by executing the DI instruction at the head of the write control program in the RAM area.
- Note 2: Since the watchdog timer is disabled by the BOOTROM in the RAM loader mode, it is not required to disable the watchdog timer by the RAM loader program.

| Imple .A                                          | itter chip erasu       | ire, ine prog    | ram in the KAM area w                    | rites data 3FH to address F000H.      |
|---------------------------------------------------|------------------------|------------------|------------------------------------------|---------------------------------------|
|                                                   |                        | DI               |                                          | : Disable interrupts (IMF← "0")       |
|                                                   |                        | LD               | (FLSCR),0011_1000B                       | : Enable command sequence execution.  |
|                                                   |                        | LD               | IX,04555H                                |                                       |
|                                                   |                        | LD               | IY,04AAAH                                | $\langle \rangle$                     |
|                                                   |                        | LD               | HL,0F000H                                |                                       |
| ;                                                 | #### Flash Memo        | ory Chip erase F | Process ####                             | $\langle ( ) \rangle$                 |
|                                                   |                        | LD               | (IX),0AAH                                | : 1st bus write cycle                 |
|                                                   |                        | LD               | (IY),55H                                 | : 2nd bus write cycle                 |
|                                                   |                        | LD               | (IX),80H                                 | : 3rd bus write cycle                 |
|                                                   |                        | LD               | (IX),0AAH                                | : 4th bus write cycle                 |
|                                                   |                        | LD               | (IY),55H                                 | : 5th bus write cycle                 |
|                                                   |                        | LD               | (IX),10H                                 | : 6th bus write cycle                 |
| 5                                                 | SLOOP1:                | LD               | A,(IX)                                   |                                       |
|                                                   |                        | CMP              | A,(IX)                                   | (7)                                   |
|                                                   |                        | JR               | NZ,sLOOP1                                | : Loop until the same value is read.  |
| ;                                                 | #### Flash Memo        | ory Write Proces | s ####                                   |                                       |
|                                                   |                        | LD               | (IX),0AAH                                | : 1st bus write cycle                 |
|                                                   |                        | LD               | (IY),55H                                 | : 2nd bus write cycle                 |
|                                                   |                        | LD               | (IX),0A0H                                | : 3rd bus write cycle                 |
|                                                   |                        | LD               | (HL),3FH                                 | : 4th bus write cycle, (F000H) = 3FH  |
| 5                                                 | SLOOP2:                | LD               | A,(HL)                                   |                                       |
|                                                   |                        | CMP              | A,(HL)                                   |                                       |
|                                                   |                        | JR               | NZ,sLOOP2                                | : Loop until the same value is read.  |
|                                                   |                        | LD               | (FLSCR),1100_1000B                       | : Disable command sequence execution. |
| 5                                                 | SLOOP3:                | JP               | sLOOP3                                   |                                       |
|                                                   |                        | (                | 775                                      |                                       |
|                                                   |                        |                  | $\sim$                                   | 77                                    |
|                                                   | <                      |                  |                                          | /_ ))                                 |
|                                                   |                        |                  |                                          |                                       |
|                                                   |                        |                  |                                          |                                       |
|                                                   | $\sim$                 |                  |                                          |                                       |
|                                                   |                        |                  | $\sim$                                   |                                       |
|                                                   |                        |                  | $\mathcal{A}($                           |                                       |
| <                                                 | $\langle (()) \rangle$ | )                |                                          |                                       |
|                                                   |                        |                  | ( )                                      |                                       |
| $\langle \langle \langle \langle \rangle \rangle$ | $ \rightarrow $        |                  | $\rightarrow \bigcirc \bigcirc \bigcirc$ |                                       |
|                                                   |                        | 22               |                                          |                                       |
|                                                   | $\searrow$             |                  | $\searrow$                               |                                       |

Example :After chip erasure, the program in the RAM area writes data 3FH to address F000H.

#### 18.4.2 Flash Memory Control in the MCU mode

In the MCU mode, write operations are performed by executing the control program in the RAM area. Before execution of the control program, copy the control program into the RAM area or obtain it from the external using the communication pin. The procedures to execute the control program in the RAM area in the MCU mode are described below.

# 18.4.2.1 How to write to the flash memory by executing a user write control program in the RAM area (in the MCU mode)

(Steps 1 and 2 are controlled by the program in the flash memory, and steps 3 through 11 are controlled by the control program in the RAM area.)

- 1. Transfer the write control program to the RAM area.
- 2. Jump to the RAM area.
- 3. Disable (DI) the interrupt master enable flag (IMF  $\leftarrow$  "0").
- 4. Disable the watchdog timer, if it is used.
- 5. Set FLSCR<FLSMD> to "0011B" (to enable command sequence execution),
- 6. Execute the erase command sequence.
- 7. Read the same flash memory address twice.

(Repeat step 7 until the same data is read by two consecutive read operations.)

- 8. Execute the write command sequence.
- 9. Read the same flash memory address twice.

(Repeat step 9 until the same data is read by two consecutive read operations.)

- 10. Set FLSCR<FLSMD> to "1100B" (to disable command sequence execution).
- 11. Jump to the flash memory area.
- Note 1: Before writing to the flash memory in the RAM area, disable interrupts by setting the interrupt master enable flag (IMF) to "0". Usually disable interrupts by executing the DI instruction at the head of the write control program in the RAM area.
- Note 2: When writing to the flash memory, do not intentionally use non-maskable interrupts (the watchdog timer must be disabled if it is used). If a non-maskable interrupt occurs while the flash memory is being written, unexpected data is read from the flash memory (interrupt vector), resulting in malfunction of the micro-controller.

Example : After sector erasure (E000H-EFFFH), the program in the RAM area writes data 3FH to address E000H.

|                 | DI             |                    | : Disable interrupts (IMF←"0")        |
|-----------------|----------------|--------------------|---------------------------------------|
|                 | LD             | (WDTCR2),4EH       | : Clear the WDT binary counter.       |
|                 | LDW            | (WDTCR1),0B101H    | : Disable the WDT.                    |
|                 | LD             | (FLSCR),0011_1000B | : Enable command sequence execution.  |
|                 | LD             | IX,04555H          |                                       |
|                 | LD             | IY,04AAAH          |                                       |
|                 | LD             | HL,0E000H          |                                       |
| ; #### Flash Me | mory Sector Er | ase Process ####   | $\langle (// ) \rangle$               |
|                 | LD             | (IX),0AAH          | : 1st bus write cycle                 |
|                 | LD             | (IY),55H           | : 2nd bus write cycle                 |
|                 | LD             | (IX),80H           | : 3rd bus write cycle                 |
|                 | LD             | (IX),0AAH          | : 4th bus write cycle                 |
|                 | LD             | (IY),55H           | : 5th bus write cycle                 |
|                 | LD             | (HL),30H           | : 6th bus write cycle                 |
| sLOOP1:         | LD             | A,(IX)             |                                       |
|                 | CMP            | A,(IX)             |                                       |
|                 | JR             | NZ,sLOOP1          | : Loop until the same value is read.  |
| ; #### Flash Me | mory Write Pro | cess ####          |                                       |
|                 | LD             | (IX),0AAH          | : 1st bus write cycle                 |
|                 | LD             | (IY),55H           | : 2nd bus write cycle                 |
|                 | LD             | (IX),0A0H          | 3rd bus write cycle                   |
|                 | LD             | (HL),3FH           | : 4th bus write cycle, (E000H)=3FH    |
| sLOOP2:         | LD             | A,(HL)             |                                       |
|                 | CMP            | A,(HL)             | $\sim$                                |
|                 | JR             | NZ,sLOOP2          | : Loop until the same value is read.  |
|                 | LD             | (FLSCR),1100_1000B | : Disable command sequence execution. |
|                 | JP             | XXXXH              | : Jump to the flash memory area.      |
|                 |                |                    | (7/8)                                 |
|                 |                |                    |                                       |

Example : This write control program reads data from address F000H and stores it to 98H in the RAM area.



: Read data from address F000H.

: Store data to address 98H.

# 19. Serial PROM Mode

### 19.1 Outline

The TMP88F846UG has a 4096 byte BOOTROM (Mask ROM) for programming to flash memory. The BOOT-ROM is available in the serial PROM mode, and controlled by TEST, BOOT, RESET and some pins. Communication is performed via UART. The serial PROM mode has seven types of operating mode. Flash memory writing, RAM loader, Flash memory SUM output, Product ID code output, Flash memory status output, Elash memory erasing and Flash memory security program setting. Memory address mapping in the serial PROM mode differs from that in the MCU mode. Figure 19-1 shows memory address mapping in the serial PROM mode.

Table 19-1 Operating Range in the Serial PROM Mode

|                       | -   |     |       |
|-----------------------|-----|-----|-------|
| Parameter             | Min | Max | Unit  |
| Power supply          | 4.5 | 5.5 | V) Ly |
| High frequency (Note) | 8   | 20  | MHz   |
|                       |     |     |       |

Note 1: Though included in above operating range, some of high frequencies are not supported in the serial PROM mode. For details, refer to "Table 19-5".

### 19.2 Memory Mapping

The Figure 19-1 shows memory mapping in the Serial PROM mode and MCU mode.

In the serial PROM mode, the BOOTROM (Mask ROM) is mapped in addresses from 3000H to 3FFFH.



Figure 19-1 Memory Address Maps

Note 2: As for TMP88F846UG, high frequencies becomes 20MHz fixation by a built-in oscillator. Moreover, there is a case where communication becomes impossible, since the frequency of a built-in oscillator is changed with temperature etc. Please use in normal temperature (around 25 degrees ) as much as possible.

## 19.3 Serial PROM Mode Setting

#### 19.3.1 Serial PROM Mode Control Pins

To execute on-board programming, activate the serial PROM mode. Table 19-2 shows pin setting to activate the serial PROM mode.

| Table 19-2 Serial PROM | Mode Setting |
|------------------------|--------------|
|------------------------|--------------|

| Pin          | Setting |
|--------------|---------|
| TEST pin     | High    |
| BOOT/RXD pin | High    |
| RESET pin    |         |

Note: The BOOT pin is shared with the UART communication pin (RXD pin) in the serial PROM mode. This pin is used as UART communication pin after activating serial PROM mode

#### 19.3.2 Pin Function

In the serial PROM mode, TXD (P45) and RXD (P44) are used as a serial interface pin.

| Table 19-3 Pin | Function in | the Serial | PROM | Mode |
|----------------|-------------|------------|------|------|
|                |             |            |      |      |

| Pin Name<br>(Serial PROM Mode) | Input/<br>Output | Function                                                                                                                                                                                                                                                                                                      |        | Pin Name<br>(MCU Mode) |  |
|--------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------|--|
| TXD                            | Output           | Serial data output (Note 3)                                                                                                                                                                                                                                                                                   |        | P45                    |  |
| BOOT/RXD                       | Input/Input      | Serial PROM mode control/Serial data input (Not                                                                                                                                                                                                                                                               | ote 1) | P44                    |  |
| RESET                          | -Input 🗸         | Serial PROM mode control                                                                                                                                                                                                                                                                                      |        | RESET                  |  |
| TEST                           | Input            | Fixed to high                                                                                                                                                                                                                                                                                                 |        | TEST                   |  |
| VDD, AVDD                      | Power<br>supply  | 4.5 to 5.5 V                                                                                                                                                                                                                                                                                                  |        |                        |  |
| VSS, AVSS                      | Power<br>supply  | 0 V                                                                                                                                                                                                                                                                                                           |        |                        |  |
| VAREF                          | Power<br>supply  | Leave open or apply input reference voltage.                                                                                                                                                                                                                                                                  |        |                        |  |
| I/O ports except<br>P45, P44   | I/O              | These ports are in the high-impedance state in the serial PROM mode. The input level is fixed to the port inputs with a hardware feature to prevent overlap current. (The port inputs are invalid.) To make the port inputs valid, set the pin of the SPCR register to "1" by the RAM loader control program. |        |                        |  |

Note 1: During on-board programming with other parts mounted on a user board, be careful no to affect these communication control pins.

Note 2: TXD port is set a open-drain port in seriarl PROM mode and it needs pull-up resistor.



#### Figure 19-3 Example Connection for On-Board Writing

- Note 1: When other parts on the application board effect the UART communication in the serial PROM mode, isolate these pins by a jumper or switch.
- Note 2: When the reset control circuit on the application board effects activation of the serial PROM mode, isolate the pin by a jumper or switch.
- Note 3: For connection of other pins, refer to "Table 19-3 Pin Function in the Serial PROM Mode".

#### 19.3.4 Activating the Serial PROM Mode

The following is a procedure to activate the serial PROM mode. "Figure 19-4 Serial PROM Mode Timing" shows a serial PROM mode timing.

- 1. Supply power to the VDD pin.
- 2. Set the  $\overline{\text{RESET}}$  pin to low.
- 3. Set the TEST pin and BOOT/RXD pins to high.
- 4. Wait until the power supply and clock oscillation stabilize.
- 5. Set the  $\overline{\text{RESET}}$  pin to high.
- 6. Input the matching data (5AH) to the BOOT/RXD pin after setup sequence. For details of the setup timing, refer to "19.16 UART Timing".



### 19.4 Interface Specifications for UART

The following shows the UART communication format used in the serial PROM mode.

To perform on-board programming, the communication format of the write controller must also be set in the same manner.

The default baud rate is 9600 bps regardless of operating frequency of the microcontroller. The baud rate can be modified by transmitting the baud rate modification data shown in Table 19-4 to TMP88F846UG. The Table 19-5 shows an operating frequency and baud rate. The frequencies which are not described in Table 19-5 can not be used.

- Baud rate (Default): 9600 bps
- Data length: 8 bits
- Parity addition: None
- Stop bit: 1 bit

#### Table 19-4 Baud Rate Modification Data

| Baud rate modification data | 04H   | 05H   | 06H 07H     | 0AH   | 18H 28H    |
|-----------------------------|-------|-------|-------------|-------|------------|
| Baud rate (bps)             | 76800 | 62500 | 57600 38400 | 31250 | 19200 9600 |

#### Table 19-5 Operating Frequency and Baud Rate in the Serial PROM Mode

|          | Reference                    | Baud Rate (bps)        | 768                   | 300   | 62    | 500                     | 576   | 600 | 384   | 400   | 312   | 250  | 192   | 200   | 96    | 00    |
|----------|------------------------------|------------------------|-----------------------|-------|-------|-------------------------|-------|-----|-------|-------|-------|------|-------|-------|-------|-------|
| (Note 3) | Baud Rate                    | Modification Da-<br>ta | 04                    | ŀΗ    | 05    | ы                       | Of    | бH  | 07    | 7H    | 04    | ΛH   | 18    | BH    | 28    | 3H    |
| (Note 3) | Ref. Fre-<br>quency<br>(MHz) | Rating<br>(MHz)        | Baud<br>rate<br>(bps) | (%)   | (bps) | (%)                     | (bps) | (%) | (bps) | (%)   | (bps) | (%)  | (bps) | (%)   | (bps) | (%)   |
| 7        | 20                           | 18.80 to 20.64         | 76923                 | +1.73 | ((-   | $\overline{\mathbb{N}}$ | -     | -   | 39063 | +0.16 | 31250 | 0.00 | 19531 | +1.73 | 9766  | +1.73 |

Note 1: "Ref. Frequency" and "Rating" show frequencies available in the serial PROM mode. Though the frequency is supported in the serial PROM mode, the serial PROM mode may not be activated correctly due to the frequency difference in the external controller (such as personal computer) and oscillator, and load capacitance of communication pins.

- Note 2: It is recommended that the total frequency difference is within ±3% so that auto detection is performed correctly by the reference frequency.
- Note 3: The external controller must transmit the matching data (5AH) repeatedly till the auto detection of baud rate is performed. This number indicates the number of times the matching data is transmitted for each frequency.

## 19.5 Operation Command

The eight commands shown in Table 19-6 are used in the serial PROM mode. After reset release, the TMP88F846UG waits for the matching data (5AH).

| Table 19-6 Operation | Command in the | Serial PROM Mode |
|----------------------|----------------|------------------|
|                      | Command in the |                  |

| Command Data | Operating Mode                        | Description                                                                                                                                                 |
|--------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5AH          | Setup                                 | Matching data. Execute this command after releasing the reset.                                                                                              |
| F0H          | Flash memory erasing                  | Erases the flash memory area (address 4000H to 05EFFH, and FFF00 to FFFFFH).                                                                                |
| 30H          | Flash memory writing                  | Writes to the flash memory area (address 4000H to 05EFFH, and FFF00 to FFFFFH).                                                                             |
| 60H          | RAM loader                            | Writes to the specified RAM area (address 0040H to 10BFH).                                                                                                  |
| 90H          | Flash memory SUM output               | Outputs the 2-byte checksum upper byte and lower byte in this order for the entire area of the flash memory (address 4000H to 05EFFH, and FFF00 to FFFFFH). |
| С0Н          | Product ID code output                | Outputs the product ID code (13-byte data).                                                                                                                 |
| C3H          | Flash memory status output            | Outputs the status code (7-byte data) such as the security program condition.                                                                               |
| FAH          | Flash memory security program setting | Enables the security program.                                                                                                                               |

### 19.6 Operation Mode

The serial PROM mode has seven types of modes, that are (1) Flash memory erasing, (2) Flash memory writing, (3) RAM loader, (4) Flash memory SUM output, (5) Product ID code output, (6) Flash memory status output and (7) Flash memory security program setting modes. Description of each mode is shown below.

1. Flash memory erasing mode

The flash memory is erased by the chip erase (erasing an entire flash area) or sector erase (erasing sectors in 4-kbyte units). The erased area is filled with FFH. When the security program is enabled, the sector erase in the flash erasing mode can not be performed. To disable the security program, perform the chip erase. Before erasing the flash memory, TMP88F846UG checks the passwords except a blank product. If the password is not matched, the flash memory erasing mode is not activated.

2. Flash memory writing mode

Data is written to the specified flash memory address for each byte unit. The external controller must transmit the write data in the Intel Hex format (Binary). If no error is encountered till the end record, TMP88F846UG calculates the checksum for the entire flash memory area (4000H to 05EFFH, and FFF00H to FFFFFH), and returns the obtained result to the external controller. When the security program is enabled, the flash memory writing mode is not activated. In this case, perform the chip erase command beforehand in the flash memory erasing mode. Before activating the flash memory writing mode, TMP88F846UG checks the password except a blank product. If the password is not matched, flash memory writing mode is not activated.

RAM loader mode

3.

The RAM loader transfers the data in Intel Hex format sent from the external controller to the internal RAM. When the transfer is completed normally, the RAM loader calculates the checksum. After transmitting the results, the RAM loader jumps to the RAM address specified with the first data record in order to execute the user program. When the security program is enabled, the RAM loader mode is not activated. In this case, perform the chip erase beforehand in the flash memory erasing mode. Before activating the RAM loader mode, TMP88F846UG checks the password except a blank product. If the password is not matched, flash RAM loader mode is not activated.

4. Flash memory SUM output mode

The checksum is calculated for the entire flash memory area (4000H to 05EFFH, and FFF00H to FFFFFH), and the result is returned to the external controller. Since the BOOTROM does not support the operation command to read the flash memory, use this checksum to identify programs when managing revisions of application programs.

5. Product ID code output mode

The code used to identify the product is output. The code to be output consists of 21-byte data, which includes the information indicating the area of the ROM incorporated in the product. The external controller reads this code, and recognizes the product to write.

(In the case of TMP88F846UG, the addresses from 4000H to 05EFFH, and FFF00H to FFFFFH become the ROM area.)

6. Flash memory status output mode

The status of the area from FFFE0H to FFFFFH, and the security program condition are output as 7-byte code. The external controller reads this code to recognize the flash memory status.

7. Flash memory security program setting mode

This mode disables reading and writing the flash memory data in parallel PROM mode. In the serial PROM mode, the flash memory writing and RAM loader modes are disabled. To disable the flash memory security program, perform the chip erase in the flash memory erasing mode.

### 19.6.1 Flash Memory Erasing Mode (Operating command: F0H)

Table 19-7 shows the flash memory erasing mode.

| Table 19-7 Flash Memory Erasing Me | ode |
|------------------------------------|-----|
|------------------------------------|-----|

|                         | Transfer Byte               | Transfer Data from the External<br>Controller to TMP88F846UG  | Baud Rate                                | Transfer Data from TMP88F846UG to the<br>External Controller                                 |
|-------------------------|-----------------------------|---------------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------|
|                         | 1st byte<br>2nd byte        | Matching data (5AH)<br>-                                      | 9600 bps<br>9600 bps                     | - (Automatic baud rate adjustment)<br>OK: Echo back data (5AH)<br>Error: No data transmitted |
|                         | 3rd byte<br>4th byte        | Baud rate change data (Table 19-4)<br>-                       | 9600 bps<br>9600 bps                     | -<br>OK: Echo back data<br>Error: A1H × 3, A3H × 3, 62H × 3 (Note 1)                         |
|                         | 5th byte<br>6th byte        | Operation command data (F0H)<br>-                             | Modified baud rate<br>Modified baud rate | -<br>OK: Echo back data (F0H)<br>Error: A1H × 3, A3H × 3, 63H × 3 (Note 1)                   |
|                         | 7th byte<br>8th byte        | Password count storage address bit 23 to 16 (Note 4, 5)       | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                         | 9th byte<br>10th byte       | Password count storage address bit 15<br>to 08 (Note 4, 5)    | Modified baud rate<br>Modified baud rate | -<br>ØK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                         | 11th byte<br>12th byte      | Password count storage address bit 07<br>to 00 (Note 4, 5)    | Modified baud rate<br>Modified baud rate | OK: Nothing transmitted<br>Error: Nothing transmitted                                        |
| BOOT<br>ROM             | 13th byte<br>14th byte      | Password comparison start address bit<br>23 to 16 (Note 4, 5) | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                         | 15th byte<br>16th byte      | Password comparison start address bit<br>15 to 08 (Note 4, 5) | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                         | 17th byte<br>18th byte      | Password comparison start address bit<br>07 to 00 (Note 4, 5) | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                         | 19th byte<br>:<br>m'th byte | Password string (Note 4, 5)                                   | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                         | n'th - 2 byte               | Erase area specification (Note 2)                             | Modified baud rate                       | -                                                                                            |
|                         | n'th - 1 byte               | A A                                                           | Modified baud rate                       | OK: Checksum (Upper byte) (Note 3)<br>Error: Nothing transmitted                             |
|                         | n'th byte                   | -                                                             | Modified baud rate                       | OK: Checksum (Lower byte) (Note 3)<br>Error: Nothing transmitted                             |
| $\langle \cdot \rangle$ | n'th + 1 byte               | (Wait for the next operation command data)                    | Modified baud rate                       | -                                                                                            |

Note 1: "xxH × 3" indicates that the device enters the halt condition after transmitting 3 bytes of xxh.

Note 2: Refer to "19.13 Specifying the Erasure Area".

Note 3: Refer to "19.8 Checksum (SUM)".

Note 4: Refer to "19.10 Passwords".

Note 5: Do not transmit the password string for a blank product.

Note 6: When a password error occurs, TMP88F846UG stops UART communication and enters the halt mode. Therefore, when a password error occurs, initialize TMP88F846UG by the RESET pin and reactivate the serial PROM mode.

Note 7: If an error occurs during transfer of a password address or a password string, TMP88F846UG stops UART communication and enters the halt condition. Therefore, when a password error occurs, initialize TMP88F846UG by the RESET pin and reactivate the serial PROM mode.

Description of the flash memory erasing mode

- 1. The 1st through 4th bytes of the transmitted and received data contain the same data as in the flash memory writing mode.
- 2. The 5th byte of the received data contains the command data in the flash memory erasing mode (F0H).
- 3. When the 5th byte of the received data contains the operation command data shown in Table 19-6, the device echoes back the value which is the same data in the 6th byte position of the received data (in this case, F0H). If the 5th byte of the received data does not contain the operation command data, the device enters the halt condition after sending 3 bytes of the operation command error code (63H).
- 4. The 7th thorough m'th bytes of the transmitted and received data contain the same data as in the flash memory writing mode. In the case of a blank product, do not transmit a password string. (Do not transmit a dummy password string.)
- 5. The n'th 2 byte contains the erasure area specification data. The upper 4 bits and lower 4 bits specify the start address and end address of the erasure area, respectively. For the detailed description, see "19.13 Specifying the Erasure Area".
- 6. The n'th 1 byte and n'th byte contain the upper and lower bytes of the checksum, respectively. For how to calculate the checksum, refer to "19.8 Checksum (SUM)". Checksum is calculated unless a receiving error or Intel Hex format error occurs. After sending the end record, the external controller judges whether the transmission is completed correctly by receiving the checksum sent by the device.
- 7. After sending the checksum, the device waits for the next operation command data.

Page 199

### 19.6.2 Flash Memory Writing Mode (Operation command: 30H)

Table 19-8 shows flash memory writing mode process.

Table 19-8 Flash Memory Writing Mode Process

|             | Transfer Byte                       | Transfer Data from External Controller<br>to TMP88F846UG   | Baud Rate                                | Transfer Data from TMP88F846UG to Ex-<br>ternal Controller                                                                 |
|-------------|-------------------------------------|------------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
|             | 1st byte<br>2nd byte                | Matching data (5Ah)<br>-                                   | 9600 bps<br>9600 bps                     | <ul> <li>(Automatic baud rate adjustment)</li> <li>OK: Echo back data (5AH)</li> <li>Error: Nothing transmitted</li> </ul> |
|             | 3rd byte<br>4th byte                | Baud rate modification data<br>(See Table 19-4)<br>-       | 9600 bps<br>9600 bps                     | -<br>OK: Echo back data<br>Error: A1H × 3, A3H × 3, 62H × 3 (Note 1)                                                       |
|             | 5th byte<br>6th byte                | Operation command data (30H)<br>-                          | Modified baud rate<br>Modified baud rate | -<br>OK: Echo back data (30H)<br>Error: A1H × 3, A3H × 3, 63H × 3 (Note 1)                                                 |
|             | 7th byte<br>8th byte                | Password count storage address bit 23 to 16 (Note 4)       | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                                                 |
|             | 9th byte<br>10th byte               | Password count storage address bit 15<br>to 08 (Note 4)    | Modified baud rate                       | OK: Nothing transmitted<br>Error: Nothing transmitted                                                                      |
|             | 11th byte<br>12th byte              | Password count storage address bit 07<br>to 00 (Note 4)    | Modified baud rate                       | OK: Nothing transmitted<br>Error: Nothing transmitted                                                                      |
| BOOT<br>ROM | 13th byte<br>14th byte              | Password comparison start address bit<br>23 to 16 (Note 4) | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                                                 |
|             | 15th byte<br>16th byte              | Password comparison start address bit<br>15 to 08 (Note 4) | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                                                 |
|             | 17th byte<br>18th byte              | Password comparison start address bit<br>07 to 00 (Note 4) | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                                                 |
|             | 19th byte<br>:                      | Password string (Note 5)                                   | Modified baud rate                       | -                                                                                                                          |
|             | m'th byte                           |                                                            |                                          | OK: Nothing transmitted<br>Error: Nothing transmitted                                                                      |
| 4           | m'th + 1 byte<br>:<br>n'th - 2 byte | Intel Hex format (binary)<br>(Note 2)                      | Modified baud rate                       | -                                                                                                                          |
|             | n'th - 1 byte                       | - 620                                                      | Modified baud rate                       | OK: SUM (Upper byte) (Note 3)<br>Error: Nothing transmitted                                                                |
|             | n'th byte                           | -                                                          | Modified baud rate                       | OK: SUM (Lower byte) (Note 3)<br>Error: Nothing transmitted                                                                |
|             | n'th + 1 byte                       | (Wait state for the next operation com-<br>mand data)      | Modified baud rate                       | -                                                                                                                          |

Note 1: "xxH × 3" indicates that the device enters the halt condition after sending 3 bytes of xxH. For details, refer to "19.7 Error Code".

Note 2: Refer to "19.9 Intel Hex Format (Binary)".

Note 3: Refer to "19.8 Checksum (SUM)".

Note 4: Refer to "19.10 Passwords".

Note 5: If addresses from FFFE0H to FFFFFH are filled with "FFH", the passwords are not compared because the device is considered as a blank product. Transmitting a password string is not required. Even in the case of a blank product, it is required to specify the password count storage address and the password comparison start address. Transmit these data from the external controller. If a password error occurs due to incorrect password count storage address or password

9.

comparison start address, TMP88F846UG stops UART communication and enters the halt condition. Therefore, when a password error occurs, initialize TMP88F846UG by the RESET pin and reactivate the serial ROM mode.

- Note 6: If the security program is enabled or a password error occurs, TMP88F846UG stops UART communication and enters the halt confition. In this case, initialize TMP88F846UG by the RESET pin and reactivate the serial ROM mode.
- Note 7: If an error occurs during the reception of a password address or a password string, TMP88F846UG stops UART communication and enters the halt condition. In this case, initialize TMP88F846UG by the RESET pin and reactivate the serial PROM mode.
- Note 8: Do not write only the address from FFFE0H to FFFFFH when all flash memory data is the same. If only these area are written, the subsequent operation can not be executed due to password error.
- Note 9: To rewrite data to Flash memory addresses at which data (including FFH) is already written, make sure to erase the existing data by "sector erase" or "chip erase" before rewriting data.

Description of the flash memory writing mode

- 1. The 1st byte of the received data contains the matching data. When the serial PROM mode is activated, TMP88F846UG (hereafter called device), waits to receive the matching data (5AH). Upon reception of the matching data, the device automatically adjusts the UART's initial baud rate to 9600 bps.
- 2. When receiving the matching data (5AH), the device transmits an echo back data (5AH) as the second byte data to the external controller. If the device can not recognize the matching data, it does not transmit the echo back data and waits for the matching data again with automatic baud rate adjustment. Therefore, the external controller should transmit the matching data repeatedly till the device transmits an echo back data. The transmission repetition count varies depending on the frequency of device. For details, refer to Table 19-5.
- 3. The 3rd byte of the received data contains the baud rate modification data. The five types of baud rate modification data shown in Table 19-4 are available. Even if baud rate is not modified, the external controller should transmit the initial baud rate data (28H: 9600 bps).
- 4. Only when the 3rd byte of the received data contains the baud rate modification data corresponding to the device's operating frequency, the device echoes back data the value which is the same data in the 4th byte position of the received data. After the echo back data is transmitted, baud rate modification becomes effective. If the 3rd byte of the received data does not contain the baud rate modification data, the device enters the halts condition after sending 3 bytes of baud rate modification error code (62H).
- 5. The 5th byte of the received data contains the command data (30H) to write the flash memory.
- 6. When the 5th byte of the received data contains the operation command data shown in Table 19-6, the device echoes back the value which is the same data in the 6th byte position of the received data (in this case, 30H). If the 5th byte of the received data does not contain the operation command data, the device enters the halt condition after sending 3 bytes of the operation command error code (63H).
- 7. The 7th byte contains the data for 23 to 16 bits of the password count storage address. When the data received with the 7th byte has no receiving error, the device does not send any data. If a receiving error or password error occurs, the device does not send any data and enters the halt condition.
- 8. The 9th byte contains the data for 15 to 8 bits of the password count storage address. When the data received with the 9th byte has no receiving error, the device does not send any data. If a receiving error or password error occurs, the device does not send any data and enters the halt condition.
  - The 11th byte contains the data for 7 to 0 bits of the password count storage address. When the data received with the 11th byte has no receiving error, the device does not send any data. If a receiving error or password error occurs, the device does not send any data and enters the halt condition.
- 10. The 13th byte contains the data for 23 to 16 bits of the password comparison start address. When the data received with the 13th byte has no receiving error, the device does not send any data. If a receiving error or password error occurs, the device does not send any data and enters the halt condition.
- 11. The 15th byte contains the data for 15 to 8 bits of the password comparison start address. When the data received with the 15th byte has no receiving error, the device does not send any data. If a receiving error or password error occurs, the device does not send any data and enters the halt condition.
- 12. The 17th byte contains the data for 7 to 0 bits of the password comparison start address. When the data received with the 17th byte has no receiving error, the device does not send any data. If a receiving error or password error occurs, the device does not send any data and enters the halt condition.
- 13. The 19th through m'th bytes contain the password data. The number of passwords becomes the data (N) stored in the password count storage address. The external password data is compared with N-byte data from the address specified by the password comparison start address. The external controller should

send N-byte password data to the device. If the passwords do not match, the device enters the halt condition without returning an error code to the external controller. If the addresses from FFFE0H to FFFFFH are filled with "FFH", the passwords are not conpared because the device is considered as a blank product.

- 14. The m'th + 1 through n'th 2 bytes of the received data contain the binary data in the Intel Hex format. No received data is echoed back to the external controller. After receiving the start mark (3AH for ":") in the Intel Hex format, the device starts data record reception. Therefore, the received data except 3AH is ignored until the start mark is received. After receiving the start mark, the device receives the data record, that consists of data length, address, record type, write data and checksum. Since the device starts checksum calculation after receiving an end record, the external controller should wait for the checksum after sending the end record. If a receiving error or Intel Hex format error occurs, the device enters the halts condition without returning an error code to the external controller.
- 15. The n'th 1 and n'th bytes contain the checksum upper and lower bytes. For details on how to calculate the SUM, refer to "19.8 Checksum (SUM)". The checksum is calculated only when the end record is detected and no receiving error or Intel Hex format error occurs. After sending the end record, the external controller judges whether the transmission is completed correctly by receiving the checksum sent by the device.
- 16. After transmitting the checksum, the device waits for the next operation command data.

### 19.6.3 RAM Loader Mode (Operation Command: 60H)

Table 19-9 shows RAM loader mode process.

Table 19-9 RAM Loader Mode Process

|             | Transfer Bytes         | Transfer Data from External Controller<br>to TMP88F846UG   | Baud Rate                                | Transfer Data from TMP88F846UG to External Controller                                        |
|-------------|------------------------|------------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------|
|             | 1st byte<br>2nd byte   | Matching data (5AH)<br>-                                   | 9600 bps<br>9600 bps                     | - (Automatic baud rate adjustment)<br>OK: Echo back data (5AH)<br>Error: Nothing transmitted |
|             | 3rd byte               | Baud rate modification data<br>(See Table 19-4)            | 9600 bps                                 |                                                                                              |
|             | 4th byte               | -                                                          | 9600 bps                                 | OK: Echo back data<br>Error: A1H × 3, A3H × 3, 62H × 3 (Note 1                               |
|             | 5th byte<br>6th byte   | Operation command data (60H)<br>-                          | Modified baud rate<br>Modified baud rate | -<br>OK: Echo back data (60H)<br>Error; A1H × 3, A3H × 3, 63H × 3 (Note 1                    |
|             | 7th byte<br>8th byte   | Password count storage address bit 23<br>to 16 (Note 4)    | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|             | 9th byte<br>10th byte  | Password count storage address bit 15<br>to 08 (Note 4)    | Modified baud rate                       | OK: Nothing transmitted<br>Error: Nothing transmitted                                        |
| DOOT        | 11th byte<br>12th byte | Password count storage address bit 07<br>to 00 (Note 4)    | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
| BOOT<br>ROM | 13th byte<br>14th byte | Password comparison start address bit<br>23 to 16 (Note 4) | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|             | 15th byte<br>16th byte | Password comparison start address bit<br>15 to 08 (Note 4) | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|             | 17th byte<br>18th byte | Password comparison start address bit<br>07 to 00 (Note 4) | Modified baud rate                       | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|             | 19th byte              | Password string (Note 5)                                   | Modified baud rate                       | -                                                                                            |
|             | m'th byte              | 5 5                                                        |                                          | OK: Nothing transmitted<br>Error: Nothing transmitted                                        |
| <           | m'th + 1 byte          | Intel Hex format (Binary)<br>(Note 2)                      | Modified baud rate                       | -                                                                                            |
|             | n'th - 2 byte          |                                                            | Modified baud rate                       | -                                                                                            |
|             | n'th - 1 byte          |                                                            | Modified baud rate                       | OK: SUM (Upper byte) (Note 3)<br>Error: Nothing transmitted                                  |
|             | n'th byte              | . ~                                                        | Modified baud rate                       | OK: SUM (Lower byte) (Note 3)<br>Error: Nothing transmitted                                  |
| RAM         | -                      | The program jumps to the start address                     | of RAM in which the first transfe        | erred data is written.                                                                       |

Note 1: "xxH × 3" indicates that the device enters the halt condition after sending 3 bytes of xxH. For details, refer to "19.7 Error Code".

Note 2: Refer to "19.9 Intel Hex Format (Binary)".

Note 3: Refer to "19.8 Checksum (SUM)".

Note 4: Refer to "19.10 Passwords".

Note 5: If addresses from FFFE0H to FFFFFH are filled with "FFH", the passwords are not compared because the device is considered as a blank product. Transmitting a password string is not required. Even in the case of a blank product, it is required to specify the password count storage address and the password comparison start address. Transmit these data

from the external controller. If a password error occurs due to incorrect password count storage address or password comparison start address, TMP88F846UG stops UART communication and enters the halt condition. Therefore, when a password error occurs, initialize TMP88F846UG by the RESET pin and reactivate the serial ROM mode.

- Note 6: After transmitting a password string, the external controller must not transmit only an end record. If receiving an end record after a password string, the device may not operate correctly.
- Note 7: If the security program is enabled or a password error occurs, TMP88F846UG stops UART communication and enters the halt condition. In this case, initialize TMP88F846UG by the RESET pin and reactivate the serial PROM mode.
- Note 8: If an error occurs during the reception of a password address or a password string, TMP88F846UG stops UART communication and enters the halt condition. In this case, initialize TMP88F846UG by the RESET pin and reactivate the serial PROM mode.
- Note 9: To re-write data for the address of flash memory which has already written data (include "EF"), make sure to erase the data first by the sector erase or chip erase, and then write new data to the flash memory.

Description of RAM loader mode

- 1. The 1st through 4th bytes of the transmitted and received data contains the same data as in the flash memory writing mode.
- 2. In the 5th byte of the received data contains the RAM loader command data (60H).
- 3. When th 5th byte of the received data contains the operation command data shown in Table 19-6, the device echoes back the value which is the same data in the 6th byte position (in this case, 60H). If the 5th byte does not contain the operation command data, the device enters the halt condition after sending 3 bytes of operation command error code (63H).
- 4. The 7th through m'th bytes of the transmitted and received data contain the same data as in the flash memory writing mode.
- 5. The m'th + 1 through n'th 2 bytes of the received data contain the binary data in the Intel Hex format. No received data is echoed back to the external controller. After receiving the start mark (3AH for ":") in the Intel Hex format, the device starts data record reception. Therefore, the received data except 3AH is ignored until the start mark is received. After receiving the start mark, the device receives the data record, that consists of data length, address, record type, write data and checksum. The writing data of the data record is written into RAM specified by address. Since the device starts checksum calculation after receiving an end record, the external controller should wait for the checksum after sending the end record. If a receiving error or Intel Hex format error occurs, the device enters the halts condition without returning an error code to the external controller.
- 6. The n'th 1 and n'th bytes contain the checksum upper and lower bytes. For details on how to calculate the SUM, refer to "19.8 Checksum (SUM)". The checksum is calculated only when the end record is detected and no receiving error or Intel Hex format error occurs. After sending the end record, the external controller judges whether the transmission is completed correctly by receiving the checksum sent by the device.
- 7. After transmitting the checksum to the external controller, the boot program jumps to the RAM address that is specified by the first received data record.



### 19.6.4 Flash Memory SUM Output Mode (Operation Command: 90H)

Table 19-10 shows flash memory SUM output mode process.

|             | Transfer Bytes       | Transfer Data from External Control-<br>ler to TMP88F846UG | Baud Rate                                | Transfer Data from TMP88F846UG to Ex-<br>ternal Controller                                   |
|-------------|----------------------|------------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------|
|             | 1st byte<br>2nd byte | Matching data (5AH)<br>-                                   | 9600 bps<br>9600 bps                     | - (Automatic baud rate adjustment)<br>OK: Echo back data (5AH)<br>Error: Nothing transmitted |
|             | 3rd byte             | Baud rate modification data<br>(See Table 19-4)            | 9600 bps                                 |                                                                                              |
|             | 4th byte             | -                                                          | 9600 bps                                 | OK: Echo back data<br>Error: A1H × 3, A3H × 3, 62H × 3 (Note 1)                              |
| BOOT<br>ROM | 5th byte<br>6th byte | Operation command data (90H)<br>-                          | Modified baud rate<br>Modified baud rate | -<br>OK: Echo back data (90H)<br>Error: A1H × 3, A3H × 3, 63H × 3 (Note 1)                   |
|             | 7th byte             | -                                                          | Modified baud rate                       | OK: SUM (Upper byte) (Note 2)<br>Error: Nothing transmitted                                  |
|             | 8th byte             | -                                                          | Modified baud rate                       | OK: SUM (Lower byte) (Note 2)<br>Error: Nothing transmitted                                  |
|             | 9th byte             | (Wait for the next operation command data)                 | Modified baud rate                       |                                                                                              |

Note 1: "xxH × 3" indicates that the device enters the halt condition after sending 3 bytes of xxH. For details, refer to "19.7 Error Code".

Note 2: Refer to "19.8 Checksum (SUM)".

Description of the flash memory SUM output mode

- 1. The 1st through 4th bytes of the transmitted and received data contains the same data as in the flash memory writing mode.
- 2. The 5th byte of the received data contains the command data in the flash memory SUM output mode (90H).
- 3. When the 5th byte of the received data contains the operation command data shown in Table 19-6, the device echoes back the value which is the same data in the 6th byte position of the received data (in this case, 90H). If the 5th byte of the received data does not contain the operation command data, the device enters the halt condition after transmitting 3 bytes of operation command error code (63H).
- 4. The 7th and the 8th bytes contain the upper and lower bits of the checksum, respectively. For how to calculate the checksum, refer to "19.8 Checksum (SUM)".

After sending the checksum, the device waits for the next operation command data.

### 19.6.5 Product ID Code Output Mode (Operation Command: C0H)

Table 19-11 shows product ID code output mode process.

Table 19-11 Product ID Code Output Process

|             | Transfer Bytes       | Transfer Data from External Controller to  | Baud Rate Transfer Data from TMP88F846UG to Ex- |                                                                                              |                                                         |  |
|-------------|----------------------|--------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------|--|
|             |                      | TMP88F846UG                                |                                                 |                                                                                              | ternal Controller                                       |  |
| BOOT<br>ROM | 1st byte<br>2nd byte | Matching data (5AH)<br>-                   | 9600 bps<br>9600 bps                            | - (Automatic baud rate adjustment)<br>OK: Echo back data (5AH)<br>Error: Nothing transmitted |                                                         |  |
|             | 3rd byte<br>4th byte | Baud rate modification data (Table 19-4)   | 9600 bps<br>9600 bps                            | -<br>OK: Echo back data<br>Error: A1H × 3, A3H × 3, 62H × 3 (Note 1                          |                                                         |  |
|             | 5th byte<br>6th byte | Operation command data (C0H)<br>-          | Modified baud rate<br>Modified baud rate        | -<br>OK: Echo back data (C0H)<br>Error: A1H × 3, A3H × 3, 63H × 3 (Note 1                    |                                                         |  |
|             | 7th byte             | (                                          | Modified baud rate                              | зан 🤇                                                                                        | Start mark                                              |  |
|             | 8th byte             |                                            | Modified baud rate                              | 12H                                                                                          | The number of transfer data (from 9th to 26th bytes)    |  |
|             | 9th byte             |                                            | Modified baud rate                              | 03H                                                                                          | Length of address (3 bytes)                             |  |
|             | 10th byte            |                                            | Modified baud rate                              | 3DH                                                                                          | Reserved data                                           |  |
|             | 11th byte            |                                            | Modified baud rate                              | (он))                                                                                        | Reserved data                                           |  |
|             | 12th byte            |                                            | Modified baud rate                              | 00H                                                                                          | Reserved data                                           |  |
|             | 13th byte            |                                            | Modified baud rate                              | 00H                                                                                          | Reserved data                                           |  |
|             | 14th byte            | (())                                       | Modified baud rate                              | 02H                                                                                          | ROM block count (2 block)                               |  |
|             | 15th byte            | $\mathbb{C}$                               | Modified baud rate                              | 00H                                                                                          | First address of ROM block 1<br>(Upper byte)            |  |
|             | 16th byte            |                                            | Modified baud rate                              | 40H                                                                                          | First address of ROM block 1<br>(Middle byte)           |  |
|             | 17th byte            | 50,00                                      | Modified baud rate                              | 00Н                                                                                          | First address of ROM block 1<br>(Lower byte)            |  |
|             | 18th byte            |                                            | Modified baud rate                              | 00H                                                                                          | End address of ROM block 1<br>(Upper byte)              |  |
|             | 19th byte            | $\rightarrow$ $\langle$                    | Modified baud rate                              | 5EH                                                                                          | End address of ROM block 1<br>(Middle byte)             |  |
|             | 20th byte            |                                            | Modified baud rate                              | FFH                                                                                          | End address of ROM block 1<br>(Lower byte)              |  |
|             | 21st byte            |                                            | Modified baud rate                              | 0FH                                                                                          | First address of ROM block 2<br>(Upper byte)            |  |
|             | 22nd byte            | $\langle \rangle $                         | Modified baud rate                              | FFH                                                                                          | First address of ROM block 2<br>(Middle byte)           |  |
|             | 23rd byte            |                                            | Modified baud rate                              | 00Н                                                                                          | First address of ROM block 2 (Lower byte)               |  |
|             | 24th byte            |                                            | Modified baud rate                              | 0FH                                                                                          | End address of ROM block 2<br>(Upper byte)              |  |
|             | 25th byte            |                                            | Modified baud rate                              | FFH                                                                                          | End address of ROM block 2<br>(Middle byte)             |  |
|             | 26th byte            |                                            | Modified baud rate                              | FFH                                                                                          | End address of ROM block 2<br>(Lower byte)              |  |
|             | 27th byte            |                                            | Modified baud rate                              | 06H                                                                                          | Checksum of transferred data<br>(9th through 26th byte) |  |
|             | 28th byte            | (Wait for the next operation command data) | Modified baud rate                              | -                                                                                            |                                                         |  |
Note: "xxH × 3" indicates that the device enters the halt condition after sending 3 bytes of xxH. For details, refer to "19.7 Error Code".

Description of Product ID code output mode

- 1. The 1st through 4th bytes of the transmitted and received data contain the same data as in the flash memory writing mode.
- 2. The 5th byte of the received data contains the product ID code output mode command data (C0H).
- 3. When the 5th byte contains the operation command data shown in Table 19-6, the device echoes back the value which is the same data in the 6th byte position of the received data (in this case, C0H). If the 5th byte data does not contain the operation command data, the device enters the halt condition after sending 3 bytes of operation command error code (63H).
- 4. The 9th through 26th bytes contain the product ID code. For details, refer to "19.11 Product ID Code".
- 5. After sending the checksum, the device waits for the next operation command data.

### 19.6.6 Flash Memory Status Output Mode (Operation Command: C3H)

Table 19-12 shows Flash memory status output mode process.

Table 19-12 Flash Memory Status Output Mode Process

|             | -                    |                                                            |                                          |                                                                                                                                       |
|-------------|----------------------|------------------------------------------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
|             | Transfer Bytes       | Transfer Data from External Con-<br>troller to TMP88F846UG | Baud Rate                                | Transfer Data from TMP88F846UG to External<br>Controller                                                                              |
|             | 1st byte<br>2nd byte | Matching data (5AH)<br>-                                   | 9600 bps<br>9600 bps                     | - (Automatic baud rate adjustment)<br>OK: Echo back data (5AH)<br>Error: Nothing transmitted                                          |
|             | 3rd byte             | Baud rate modification data<br>(See Table 19-4)            | 9600 bps                                 |                                                                                                                                       |
|             | 4th byte             | -                                                          | 9600 bps                                 | OK: Echo back data<br>Error: A1H × 3, A3H × 3, 62H × 3 (Note 1)                                                                       |
|             | 5th byte<br>6th byte | Operation command data (C3H)<br>-                          | Modified baud rate<br>Modified baud rate | -<br>OK: Echo back data (C3H)<br>Error: A1H × 3, A3H × 3, 63H × 3 (Note 1)                                                            |
|             | 7th byte             |                                                            | Modified baud rate                       | 3AH Start mark                                                                                                                        |
|             | 8th byte             |                                                            | Modified baud rate                       | 04H Byte count<br>(from 9th to 12th byte)                                                                                             |
| BOOT<br>ROM | 9th byte             |                                                            | Modified baud rate                       | 00H<br>to<br>03H                                                                                                                      |
|             | 10th byte            |                                                            | Modified baud rate                       | 00H Reserved data                                                                                                                     |
|             | 11th byte            |                                                            | Modified baud rate                       | 00H Reserved data                                                                                                                     |
|             | 12th byte            |                                                            | Modified baud rate                       | 00H Reserved data                                                                                                                     |
|             | 13th byte            |                                                            | Modified baud rate                       | Checksum 2's complement for the sum of 9th<br>through 12th bytes<br>9th byte Checksum<br>00H: 00H<br>01H: FFH<br>02H: FEH<br>03H: FDH |
|             | 14th byte            | (Wait for the next operation com-<br>mand data)            | Modified baud rate                       | -                                                                                                                                     |
|             |                      |                                                            |                                          |                                                                                                                                       |

Note 1: "xxH × 3" indicates that the device enters the halt condition after sending 3 bytes of xxH. For details, refer to "19.7 Error Code".

Note 2: For the details on status code 1, refer to "19.12 Flash Memory Status Code".

Description of Flash memory status output mode

- 1. The 1st through 4th bytes of the transmitted and received data contain the same data as in the Flash memory writing mode.
- 2. The 5th byte of the received data contains the flash memory status output mode command data (C3H).
- 3. When the 5th byte contains the operation command data shown in Table 19-6, the device echoes back the value which is the same data in the 6th byte position of the received data (in this case, C3H). If the 5th byte does not contain the operation command data, the device enters the halt condition after sending 3 bytes of operation command error code (63H).
- 4. The 9th through 13th bytes contain the status code. For details on the status code, refer to "19.12 Flash Memory Status Code".
- 5. After sending the status code, the device waits for the next operation command data.

### 19.6.7 Flash Memory Security Program Setting Mode (Operation Command: FAH)

Table 19-13 shows Flash memory security program setting mode process.

Table 19-13 Flash Memory Security Program Setting Mode Process

|                      | Transfer Bytes         | Transfer Data from External Control-<br>ler to TMP88F846UG | Baud Rate                                | Transfer Data from TMP88F846UG to Exter-<br>nal Controller                                   |
|----------------------|------------------------|------------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------|
|                      |                        |                                                            | 9600 bps<br>9600 bps                     | - (Automatic baud rate adjustment)<br>OK: Echo back data (5AH)<br>Error: Nothing transmitted |
|                      | 3rd byte               | Baud rate modification data<br>(See Table 19-4)            | 9600 bps                                 |                                                                                              |
|                      | 4th byte               | -                                                          | 9600 bps                                 | OK: Echo back data<br>Error: A1H × 3, A3H × 3, 62H × 3 (Note 1)                              |
|                      | 5th byte<br>6th byte   | Operation command data (FAH)<br>-                          | Modified baud rate<br>Modified baud rate | -<br>OK: Echo back data (FAH)<br>Error: A1H × 3, A3H × 3, 63H × 3 (Note 1)                   |
|                      | 7th byte<br>8th byte   | Password count storage address 23 to 16 (Note 2)           | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                      | 9th byte<br>10th byte  | Password count storage address 15<br>to 08 (Note 2)        | Modified baud rate<br>Modified baud rate | OK: Nothing transmitted<br>Error: Nothing transmitted                                        |
| BOOT<br>ROM          | 11th byte<br>12th byte | Password count storage address 07<br>to 00 (Note 2)        | Modified baud rate<br>Modified baud rate | OK: Nothing transmitted<br>Error: Nothing transmitted                                        |
|                      | 13th byte<br>14th byte | Password comparison start address<br>23 to 16 (Note 2)     | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                      | 15th byte<br>16th byte | Password comparison start address<br>15 to 08 (Note 2)     | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                      | 17th byte<br>18th byte | Password comparison start address<br>07 to 00 (Note 2)     | Modified baud rate<br>Modified baud rate | -<br>OK: Nothing transmitted<br>Error: Nothing transmitted                                   |
|                      | 19th byte              | Password string (Note 2)                                   | Modified baud rate                       | -                                                                                            |
|                      | m'th byte              |                                                            | Modified baud rate                       | OK: Nothing transmitted<br>Error: Nothing transmitted                                        |
| $\langle$            | n'th byte              |                                                            | Modified baud rate                       | OK: FBH (Note 3)<br>Error: Nothing transmitted                                               |
| $\overline{\langle}$ | n'+1th byte            | (Wait for the next operation com-<br>mand data)            | Modified baud rate                       | -                                                                                            |

Note 1: \*xxH × 3" indicates that the device enters the halt condition after sending 3 bytes of xxH. For details, refer to "19.7 Error Code".

Note 2: Refer to "19.10 Passwords".

Note 3: If the security program is enabled for a blank product or a password error occurs for a non-blank product, TMP88F846UG stops UART communication and enters the halt mode. In this case, initialize TMP88F846UG by the RESET pin and reactivate the serial PROM mode.

Note 4: If an error occurs during reception of a password address or a password string, TMP88F846UG stops UART communication and enters the halt mode. In this case, initialize TMP88F846UG by the RESET pin and reactivate the serial PROM mode. Description of the Flash memory security program setting mode

- 1. The 1st through 4th bytes of the transmitted and received data contain the same data as in the Flash memory writing mode.
- 2. The 5th byte of the received data contains the command data in the flash memory status output mode (FAH).
- 3. When the 5th byte of the received data contains the operation command data shown in Table 19-6, the device echoes back the value which is the same data in the 6th byte position of the received data (in this case, FAH). If the 5th byte does not contain the operation command data, the device enters the halt condition after transmitting 3 bytes of operation command error code (63H).
- 4. The 7th through m'th bytes of the transmitted and received data contain the same data as in the flash memory writing mode.
- 5. The n'th byte contains the status to be transmitted to the external controller in the case of the successful security program.

### 19.7 Error Code

When detecting an error, the device transmits the error code to the external controller, as shown in Table 19-14.

| Table 19-14 E | rror Code |
|---------------|-----------|
|---------------|-----------|

| Transmit Data | Meaning of Error Data               |
|---------------|-------------------------------------|
| 62H, 62H, 62H | Baud rate modification error.       |
| 63H, 63H, 63H | Operation command error.            |
| A1H, A1H, A1H | Framing error in the received data. |
| АЗН, АЗН, АЗН | Overrun error in the received data. |

Note: If a password error occurs, TMP88F846UG does not transmit an error code.

### 19.8 Checksum (SUM)

#### 19.8.1 Calculation Method

The checksum (SUM) is calculated with the sum of all bytes, and the obtained result is returned as a word.

The data is read for each byte unit and the calculated result is returned as a word.

Example:



The checksum which is transmitted by executing the flash memory write command, RAM loader command, or flash memory SUM output command is calculated in the manner, as shown above.

### 19.8.2 Calculation data

The data used to calculate the checksum is listed in Table 19-15.

#### Table 19-15 Checksum Calculation Data

| Operating Mode                  | Calculation Data                                                                              | Description                                                                                                                                                           |  |
|---------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Flash memory writing mode       |                                                                                               | Even when a part of the flash memory is written, the checksum                                                                                                         |  |
|                                 | Data in the entire area of the flash memory                                                   | of the entire flash memory area (04000H to 05EFFH, and<br>FFF00H to FFFFFH) is calculated.                                                                            |  |
| Flash memory SUM output mode    |                                                                                               | The data length, address, record type and checksum in Intel Her format are not included in the checksum.                                                              |  |
| RAM loader mode                 | RAM data written in the first received RAM ad-<br>dress through the last received RAM address | The length of data, address, record type and checksum in Intel Hex format are not included in the checksum.                                                           |  |
| Product ID Code Output mode     | 9th through 18th bytes of the transferred data                                                | For details, refer to "19.11 Product ID Code".                                                                                                                        |  |
| Flash Memory Status Output mode | 9th through 12th bytes of the transferred data                                                | For details, refer to "19.12 Flash Memory Status Code"                                                                                                                |  |
| Flash Memory Erasing mode       | All data in the erased area of the flash memory (the whole or part of the flash memory)       | When the sector erase is executed, only the erased area is used to calculate the checksum. In the case of the chip erase, an entire area of the flash memory is used. |  |

### 19.9 Intel Hex Format (Binary)

- 1. After receiving the checksum of a data record, the device waits for the start mark (3AH ":") of the next data record. After receiving the checksum of a data record, the device ignores the data except 3AH transmitted by the external controller.
- 2. After transmitting the checksum of end record, the external controller must transmit nothing, and wait for the 2-byte receive data (upper and lower bytes of the checksum).
- 3. If a receiving error or Intel Hex format error occurs, the device enters the halt condition without returning an error code to the external controller. The Intel Hex format error occurs in the following case:
  - When the record type is not 00H, 01H, or 02H
  - When a checksum error occurs
  - When the data length of an extended record (record type = 02H) is not 02H
  - When the data length of the end record (record type = 01H) is not 00H

#### 19.10 Passwords

The consecutive eight or more-byte data in the flash memory area can be specified to the password. TMP88F846UG compares the data string specified to the password with the password string transmitted from the external controller. The area in which passwords can be specified is located at addresses 04000H to 05EFFH. The area from FFF00H to FFFFFH can not be specified as the passwords area.

If addresses from FFFE0H through FFFFFH are filled with "FFH", the passwords are not compared because the product is considered as a blank product. Even in this case, the password count storage addresses and password comparison start address must be specified. Table 19-16 shows the password setting in the blank product and non-blank product.

| Password                                    | Blank Product (Note 1) | Non-Blank Product          |
|---------------------------------------------|------------------------|----------------------------|
| PNSA<br>(Password count storage address)    | 04000H ≤ PNSA ≤ 05EFFH | 04000H ≤ PNSA ≤ 05EFFH     |
| PCSA<br>(Password comparison start address) | 04000H ≤ PCSA ≤ 05EFFH | 04000H ≤ PCSA ≤ 05F00H - N |
| N<br>(Password count)                       |                        | 8 ≤ N                      |
| Password string setting                     | Not required (Note 5)  | Required (Note 2)          |

#### Table 19-16 Password Setting in the Blank Product and Non-Blank Product

Note 1: When addresses from FFFE0H through FFFFFH are filled with "FFH", the product is recognized as a blank product. Note 2: The data including the same consecutive data (three or more bytes) can not be used as a password. (This causes a

password error data. TMP88F846UG transmits no data and enters the halt condition.)

Note 3: \*: Don't care.

- Note 4: When the above condition is not met, a password error occurs. If a password error occurs, the device enters the halt condition without returning the error code.
- Note 5: In the flash memory writing mode or RAM loader mode, the blank product receives the Intel Hex format data immediately after receiving PCSA without receiving password strings. In this case, the subsequent processing is performed correctly because the blank product ignores the data except the start mark (3AH ":") as the Intel Hex format data, even if the external controller transmits the dummy password string. However, if the dummy password string contains "3AH", it is detected as the start mark erroneously. The microcontroller enters the halt mode. If this causes the problem, do not transmit the dummy password strings.

Note 6: In the flash memory erasing mode, the external controller must not transmit the password string for the blank product.



#### 19.10.1 Password String

The password string transmitted from the external controller is compared with the specified data in the flash memory. When the password string is not matched to the data in the flash memory, the device enters the halt condition due to the password error.

### 19.10.2 Handling of Password Error

If a password error occurs, the device enters the halt condition. In this case, reset the device to reactivate the serial PROM mode.

### 19.10.3 Password Management during Program Development

If a program is modified many times in the development stage, confusion may arise as to the password. Therefore, it is recommended to use a fixed password in the program development stage.

Example :Specify PNSA to F000H, and the password string to 8 bytes from address F001H (PCSA becomes F001H.)

Password Section code abs = 0F000H

| DB | 08H        | : PNSA definition            |
|----|------------|------------------------------|
| DB | "CODE1234" | : Password string definition |

## 19.11 Product ID Code

The product ID code is the 21-byte data containing the start address and the end address of ROM. Table 19-17 shows the product ID code format.

| Data | Description                                                                                | In the Case of TMP88F846UG |
|------|--------------------------------------------------------------------------------------------|----------------------------|
| 1st  | Start Mark (3AH)                                                                           | 3AH                        |
| 2nd  | The number of transfer data (18 bytes from 3rd to 20th byte)                               | 12H                        |
| 3rd  | Address length (3 bytes)                                                                   | ОЗН                        |
| 4th  | Reserved data                                                                              | 3DH                        |
| 5th  | Reserved data                                                                              | Ороон                      |
| 6th  | Reserved data                                                                              | ООН                        |
| 7th  | Reserved data                                                                              | оон                        |
| 8th  | ROM block count                                                                            | 02H                        |
| 9th  | The first address of ROM block 1 (Upper byte)                                              | 00н())                     |
| 10th | The first address of ROM block 1 (Middle byte)                                             | 40H                        |
| 11th | The first address of ROM block 1 (Lower byte)                                              | 00H                        |
| 12th | The end address of ROM block 1 (Upper byte)                                                | ( OOH                      |
| 13th | The end address of ROM block 1 (Middle byte)                                               | 5EH                        |
| 14th | The end address of ROM block 1 (Lower byte)                                                | ( // ¢FFH                  |
| 15th | The first address of ROM block 2 (Upper byte)                                              | OFH                        |
| 16th | The first address of ROM block 2 (Middle byte)                                             | FFH                        |
| 17th | The first address of ROM block 2 (Lower byte)                                              | оон                        |
| 18th | The end address of ROM block 2 (Upper byte)                                                | OFH                        |
| 19th | The end address of ROM block 2 (Middle byte)                                               | FFH                        |
| 20th | The end address of ROM block 2 (Lower byte)                                                | FFH                        |
| 21th | Checksum of the transferred data (2's compliment for the sum of<br>3rd through 20th bytes) | 06H                        |

Table 19-17 Product ID Code Format

### 19.12 Flash Memory Status Code

The flash memory status code is the 7-byte data including the security program status and the status of the data from FFFE0H to FFFFFH. Table 19-18 shows the flash memory status code.

| Table 19-18 Flash Memory Status Code |      |                                                                                       |                                      |                                      |  |  |
|--------------------------------------|------|---------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------|--|--|
|                                      | Data | Description                                                                           | In the Case of TMP88F846UG           |                                      |  |  |
|                                      | 1st  | Start mark                                                                            | 3AH                                  |                                      |  |  |
|                                      | 2nd  | Transferred data count (3rd through 6th byte)                                         | 04H                                  |                                      |  |  |
| ~                                    | 3rd  | Status code                                                                           | 00H to 03H<br>(See figure below)     |                                      |  |  |
|                                      | 4th  | Reserved data                                                                         | 00H                                  |                                      |  |  |
|                                      | 5th  | Reserved data                                                                         | 00H                                  |                                      |  |  |
|                                      | 6th  | Reserved data                                                                         | 00H                                  |                                      |  |  |
|                                      | 7th  | Checksum of the transferred data (2's compliment for the sum of 3rd through 6th data) | 3rd byte<br>00H<br>01H<br>02H<br>03H | checksum<br>00H<br>FFH<br>FEH<br>FDH |  |  |

Table 19-18 Flash Memory Status Code

#### Status Code 1



Some operation commands are limited by the flash memory status code 1. If the security program is enabled, flash memory writing mode command and RAM loader mode command can not be executed. Erase all flash memory before executing these command.

| RPENA | BLANK | Flash Memory<br>Writing Mode | RAM Loader<br>Mode | Flash memory<br>SUM<br>Output Mode | Product<br>ID Code Output<br>Mode | Flash Memory<br>Status Output<br>Mode | Flash Memory<br>Erasing Mode | Security pro-<br>gram Setting<br>Mode |
|-------|-------|------------------------------|--------------------|------------------------------------|-----------------------------------|---------------------------------------|------------------------------|---------------------------------------|
| 0     | 0     | 0                            | 0                  | 0                                  |                                   | 0 7                                   |                              | ×                                     |
| 0     | 1     | Pass                         | Pass               | 0 41                               | 0                                 | 0                                     | Pass                         | Pass                                  |
| 1     | 0     | ×                            | ×                  | 0                                  | 0                                 | 0                                     | 0                            | ×                                     |
| 1     | 1     | ×                            | ×                  | 0                                  | 0                                 |                                       | Pass                         | Pass                                  |

Note: O : The command can be executed.

Pass : The command can be executed with a password.

× : The command can not be executed.

(After echoing the command back to the external controller, TMP88F846UG stops UART communication and enters the halt condition.)

### 19.13 Specifying the Erasure Area

In the flash memory erasing mode, the erasure area of the flash memory is specified by n-2 byte data.

The address of an erasure area is specified by ERAREA.

The sector erase (flash memory erasing every 4K bytes) is performed if the address data from "00H" to "1DH" is specified by ERAREA.

The chip erase (all flash memory erasing) is performed if the address data from "COH" to "FFH" is specified by ERAREA. At the same time, the security program for flash memory is also disabled.

Therefore, make sure to execute the chip erase (not sector erase) to disable the security program for flash memory. Executing the sector erase while the security program is enabled results in an infinite loop.

Erasure Area Specification Data (n-2 byte data)



Note 1: When the sector erase is executed for the area containing no flash cell, TMP88F846UG stops the UART communi cation and enters the halt condition.

Note 2: Executing the sector erase while the security program is enabled results in an infinite loop.



## 19.14 Port Input Control Register

In the serial PROM mode, the input level is fixed to the all ports except P45 and P44 ports with a hardware feature to prevent overlap current to unused ports. (All port inputs and peripheral function inputs shared with the ports become invalid.) Therefore, to access to the flash memory in the RAM loader mode without UART communication, port inputs must be valid. To make port inputs valid, set the pin of the port input control register (SPCR) to "1".

The SPCR register is not operated in the MCU mode. Port Input Control Register 6 5 3 2 SPCR (01FFEH) PIN (Initial value: \*\*\*\* \*\*\*0) 0 : Invalid port inputs (The input level is fixed with a hardware feature.) PIN Port input control in the serial PROM mode R/W 1 : Valid port inputs Note 1: The SPCR register can be read or written only in the serial PROM mode, When the write instruction is executed to the SPCR register in the MCU mode, the port input control can not be performed. When the read instruction is executed for the SPCR register in the MCU mode, read data of bit7 to 1 are unstable. Note 2: All I/O ports except P45 and P44 ports are controlled by the SPCR register.

### 19.15 Flowchart



## 19.16 UART Timing

#### Table 19-19 UART Timing-1 (VDD = 4.5 to 5.5 V, fc = 20 MHz, Topr = -10 to 40°C)

| Parameter                                                        | Symbol | Clock Frequency (fc) | Minimum Required<br>Time |
|------------------------------------------------------------------|--------|----------------------|--------------------------|
|                                                                  | -      |                      | At fc = 20 MHz           |
| Time from matching data reception to the echo back               | CMeb1  | Approx. 930          | 46.5 µs                  |
| Time from baud rate modification data reception to the echo back | CMeb2  | Approx. 980          | 49.0 μs                  |
| Time from operation command reception to the echo back           | CMeb3  | Approx. 800          | 40 µs                    |
| Checksum calculation time                                        | CKsm   | Approx. 7864500      | 0.39 s                   |
| Erasure time of an entire flash memory                           | CEall  |                      | 30 ms                    |
| Erasure time for a sector of a flash memory (in 4-kbyte units)   | CEsec  |                      | 15 ms                    |

# Table 19-20 UART Timing-2 (VDD = 4.5 to 5.5 V, fc = 20 MHz, Topr = -10 to 40°C)

| Parameter                                                                                                            | Symbol | Clock Frequency (fc) | Minimum Re-<br>quired Time<br>At fc = 20 MHz |
|----------------------------------------------------------------------------------------------------------------------|--------|----------------------|----------------------------------------------|
| Time from the reset release to the acceptance of start bit of RXD pin                                                | RXsup  | 2100                 | 105.0 ms                                     |
| Matching data transmission interval                                                                                  | CMtr1  | 28500                | 1.43 ms                                      |
| Time from the echo back of matching data to the acceptance of baud rate modification data                            | CMtr2  | 380                  | 19.0 µs                                      |
| Time from the echo back of baud rate modification data to the acceptance of an operation command                     | CMtr3  | 650                  | 32.5 µs                                      |
| Time from the echo back of operation command to the acceptance of pass-<br>word count storage addresses (Upper byte) | CMtr4  | 800                  | 40 µs                                        |



# TOSHIBA

# 20. Input/Output Circuitry

# 20.1 Control pins

The input/output circuitries of the TMP88F846UG control pins are shown below.



## 20.2 Input/output ports



Note: The NC pins of TMP88PH41UG does not have a protect diode.

# 21. Electrical Characteristics

### 21.1 Absolute Maximum Ratings

The Absolute Maximum Ratings stipulate the standards, any Parameter of which cannot be exceeded even in an instant. If the device is used under conditions exceeding the Absolute Maximum Ratings, it may break down or degrade, causing injury due to rupture or burning. Therefore, always make sure the Absolute Maximum Ratings will not be exceeded when designing your application equipment.

|                              |                     |                | <                             |                   | (V <sub>SS</sub> = 0 V)                            |
|------------------------------|---------------------|----------------|-------------------------------|-------------------|----------------------------------------------------|
| Parameter                    | Symbol              | Pins           | Standard                      | Unit              | Remarks                                            |
| Power supply voltage         | V <sub>DD</sub>     |                | -0.3 to 6.0                   | $\sum$            | $\checkmark$                                       |
| Input voltage                | V <sub>IN</sub>     |                | -0.3 to V <sub>DD</sub> + 0.3 | v                 |                                                    |
| Output voltage               | V <sub>OUT</sub>    |                | -0.3 to V <sub>DD</sub> + 0.3 | $\sim$            | $\sim$                                             |
|                              | I <sub>OH</sub>     | P1, P3, P4, P6 | -1.8                          | $\geq$            | $\langle \langle \rangle \rangle$                  |
| Output current               | I <sub>OL1</sub>    | P1, P2, P6     | 3,2                           | <                 |                                                    |
|                              | I <sub>OL2</sub>    | P3, P4         | 30                            |                   |                                                    |
|                              | Σ I <sub>OUT1</sub> | P1, P2, P6     | 60                            | mA                | Total of all ports except large-current ports      |
| Mean output current          | Σ I <sub>OUT2</sub> | P3             | 60                            | $\overline{\Box}$ | Total of 8 pins of large-current ports<br>P30 to 7 |
|                              | Σ I <sub>OUT3</sub> | P4             | 60                            |                   | Total of 8 pins of large-current ports<br>P40 to 7 |
| Power dissipation            | PD                  | TMP88F846UG    | 350                           | mW                | LQFP                                               |
| Soldering temperature (time) | Tsld                |                | 260 (10 s)                    | °C                |                                                    |
| Operating Temperature        | Topr                |                | -40 to 85                     | //                |                                                    |
| Storage temperature          | Tstg                |                | −55 to 125                    | ~                 |                                                    |

## 21.2 Operating Conditions

The Operating Conditions show the conditions under which the device be used in order for it to operate normally while maintaining its quality. If the device is used outside the range of Operating Conditions (power supply voltage, operating temperature range, or AC/DC rated values), it may operate erratically. Therefore, when designing your application equipment, always make sure its intended working conditions will not exceed the range of Operating Conditions.

### 21.2.1 MCU mode (Flash Programming or erasing)

|                  |                  |                                             |                                  |                        | (V <sub>SS</sub> = 0 | V, Topr = −10          | to 40°C) |
|------------------|------------------|---------------------------------------------|----------------------------------|------------------------|----------------------|------------------------|----------|
| Parameter        | Symbol           | Pins                                        | Ratings                          | (Min))                 | Тур                  | Max                    | Unit     |
| Supply voltage   | V <sub>DD</sub>  |                                             | NORMAL mode                      | 4.5                    | 5.0                  | 5.5                    |          |
|                  | V <sub>IH1</sub> | Normal input (P6)                           | 4                                | V <sub>DD</sub> × 0.70 | - 4                  | $\langle \rangle$      |          |
| Input High level | V <sub>IH2</sub> | Hysteresis input<br>(P1, P2, P3, P4, RESET) | V <sub>DD</sub> ≥ 4.5 V          | V <sub>DD</sub> × 0.75 | 8                    | VDD                    | v        |
|                  | V <sub>IL1</sub> | Normal input (P6)                           |                                  |                        |                      | V <sub>DD</sub> × 0.30 |          |
| Input Low level  | V <sub>IL2</sub> | Hysteresis input<br>(P1, P2, P3, P4, RESET) | $V_{DD} \ge 4.5 V$               | 0                      |                      | V <sub>DD</sub> × 0.25 |          |
| Clock Frequency  | fc               |                                             | V <sub>DD</sub> = 4.5 V to 5.5 V | - 4                    | 20.0                 | -                      | MHz      |

### 21.2.2 MCU mode (Except Flash Programming or erasing)

(V<sub>SS</sub> = 0 V, Topr = -40 to 85°C)

|                  | <i>.</i>         |                                          |                                     |                        | ( 00 | 0 v, iopi – 4          |      |
|------------------|------------------|------------------------------------------|-------------------------------------|------------------------|------|------------------------|------|
| Parameter        | Symbol           | Pins                                     | Ratings                             | Min                    | Тур  | Max                    | Unit |
| Supply voltage   | V <sub>DD</sub>  |                                          | fc=20MHz IDLE<br>modes<br>STOP mode | 4.5                    | 5.0  | 5.5                    |      |
|                  | VIH1             | Normal input (P6)                        | $\langle \langle \rangle \rangle$   | V <sub>DD</sub> × 0.70 | -    |                        |      |
| Input high level | V <sub>IH2</sub> | Hysteresis input<br>(P1,P2,P3,P4, RESET) | $V_{DD} \ge 4.5 V$                  | V <sub>DD</sub> × 0.75 | -    | V <sub>DD</sub>        | V    |
| ~                | VIL1             | Normal input (P6)                        |                                     |                        |      | V <sub>DD</sub> × 0.30 |      |
| Input low level  | VIL2             | Hysteresis input<br>(P1,P2,P3,P4, RESET) | V <sub>DD</sub> ≥ 4.5 V             | 0                      | -    | V <sub>DD</sub> × 0.25 |      |
| Clock frequency  | fc               | 41                                       | V <sub>DD</sub> = 4.5 to 5.5 V      | -                      | 20.0 | -                      | MHz  |

### 21.2.3 Serial PROM mode

|                  |                  |                                          |                                | -                      | (V <sub>SS</sub> = | 0 V, Topr = -1         | 0 to 85°C) |
|------------------|------------------|------------------------------------------|--------------------------------|------------------------|--------------------|------------------------|------------|
| Parameter        | Symbol           | Pins                                     | Ratings                        | Min                    | Тур                | Max                    | Unit       |
| Supply voltage   | V <sub>DD</sub>  |                                          | NORMAL mode                    | 4.5                    | 5.0                | 5.5                    |            |
| V <sub>IH1</sub> |                  | Normal input (P6)                        |                                | V <sub>DD</sub> × 0.70 |                    |                        |            |
| Input high level | V <sub>IH2</sub> | Hysteresis input<br>(P1,P2,P3,P4, RESET) | V <sub>DD</sub> ≥ 4.5 V        | V <sub>DD</sub> × 0.75 |                    | V <sub>DD</sub>        | v          |
|                  | V <sub>IL1</sub> | Normal input (P6)                        |                                | $\sim$ ((              | 7/^                | V <sub>DD</sub> × 0.30 |            |
| Input low level  | V <sub>IL2</sub> | Hysteresis input<br>(P1,P2,P3,P4, RESET) | V <sub>DD</sub> ≥ 4.5 V        | 0                      | $\bigcirc$         | V <sub>DD</sub> × 0.25 |            |
| Clock frequency  | fc               |                                          | V <sub>DD</sub> = 4.5 to 5.5 V |                        | 20.0               | -                      | MHz        |

## 21.3 DC Characteristics

|                                                          |                  |                                  |                                                                   | $\square$   | (Vss | = 0 V, To | pr = -40 | to 85°C) |
|----------------------------------------------------------|------------------|----------------------------------|-------------------------------------------------------------------|-------------|------|-----------|----------|----------|
| Parameter                                                | Symbol           | Pins                             | Condition                                                         | $(\bigcirc$ | Min  | Тур.      | Max      | Unit     |
|                                                          | I <sub>IN1</sub> | TEST                             |                                                                   |             | シ    |           |          |          |
| Input current                                            | I <sub>IN2</sub> | Sink open drain, Three-<br>state | V <sub>DD</sub> = 5.5 V, V <sub>IN</sub> = 5.5 V/0 V              | (//)        | -    | -         | ±2       | μA       |
|                                                          | I <sub>IN3</sub> | RESET, STOP                      |                                                                   |             |      |           |          |          |
| Input resistance                                         | R <sub>IN2</sub> | RESET                            |                                                                   |             | 90   | 220       | 510      | kΩ       |
| Output leakage current                                   | I <sub>LO</sub>  | Sink open drain, Three-<br>state | V <sub>DD</sub> = 5.5 V, V <sub>IN</sub> = 5.5 V/0 V              | /           | -    | -         | ±2       | μA       |
| High level output<br>voltage                             | V <sub>OH</sub>  | Three-state port                 | V <sub>DD</sub> = 4.5 V, I <sub>OH</sub> = -0.7 mA                |             | 4.1  | -         | -        | v        |
| Low level output                                         | I <sub>OL1</sub> | P0, P1, P2, P6                   | V <sub>DD</sub> = 4.5 V, V <sub>OL</sub> = 0.4 V                  |             | 1.6  | -         | -        | mA       |
| current                                                  | I <sub>OL2</sub> | P3, P4                           | V <sub>DD</sub> = 4.5 V, V <sub>OL</sub> = 1.0 V                  |             | -    | 20        | -        | ma       |
| NORMAL mode power supply current                         |                  |                                  | V <sub>DD</sub> = 5.5 V<br>When a progrates on flash<br>(Note4,5) |             | -    | 22.0      | 38.0     | mA       |
| IDLE mode<br>power supply current                        | I <sub>DD</sub>  |                                  | V <sub>IN</sub> = 5.3 V/0.2 V<br>fc = 20 MHz                      |             | -    | 20        | 35       |          |
| STOP mode power supply current                           | Z                |                                  | $\square$                                                         |             | -    | 2         | 100      | μA       |
| Peak current of inter-<br>mittent operation<br>(Note4,5) | IDDP-P           |                                  | V <sub>DD</sub> = 5.5 V                                           |             | -    | 10.0      | -        | mA       |

Note 1: Typical values show those at Topr =  $25^{\circ}$ C, VDD = 5V.

Note 2: Input current (IIN3); The current through pull-up or pull-down resistor is not included.

Note 3: I<sub>DD</sub> does not include I<sub>REF</sub> current.

- Note 4: When a program is executing in the flash memory or when data is being read from the flash memory, the flash memory operates in an intermittent manner, causing peak currents in the operation current, as shown in Figure 21-1. In this case, the supply current I<sub>DD</sub> (in NORMAL mode) is defined as the sum of the average peak current and MCU current.
- Note 5: When designing the power supply, make sure that peak currents can be supplied.





### 21.4 On-Chip Oscillator Characteristics

|                              |                  |                                                                        |      |     | (Topr = -4 | 0 to 85°C) |
|------------------------------|------------------|------------------------------------------------------------------------|------|-----|------------|------------|
| Parameter                    | Symbol           | Condition                                                              | Min  | Тур | Max        | Unit       |
| Normal Oscillation frequency | f <sub>NOM</sub> | V <sub>DD</sub> = 5.0V, Topr = 25°C                                    | 19.8 | 20  | 20.2       | MHz        |
| European de Sultan           | A.C.             | with respect to $f_{NOM}$<br>V <sub>DD</sub> = 5.0V, Topr = -40 to 10° | c -4 | C   | +4         | %          |
| Frequency deviation          | Δf               | with respect to $f_{NOM}$<br>V <sub>DD</sub> = 5.0V, Topr = -10 to 85° | c -4 |     | +4         | %          |

## 21.5 AD Conversion Characteristics

|                                          |        |                                                                                             |                      |      |                | (Topr = -4 | 40 to 85°C) |
|------------------------------------------|--------|---------------------------------------------------------------------------------------------|----------------------|------|----------------|------------|-------------|
| Deremeter                                | Symbol | Condition                                                                                   | Min                  | Turp | М              | ax         | Unit        |
| Parameter                                | Symbol |                                                                                             |                      | Тур  | 8 bit          | 10 bit     | Unit        |
| Analog reference voltage                 | VAREF  | $V_{SS} = 0 V, AV_{DD} = V_{DD}$                                                            | V <sub>DD</sub> -1.0 | -    | V              | DD         | V           |
| Analog Input voltage range               | VAIN   | $\neg$                                                                                      | AV <sub>SS</sub>     | -    | V <sub>A</sub> | REF        | V           |
| Analog reference power<br>supply current | IREF   | $V_{DD} = AV_{DD} = V_{AREF} = 5.0 V$<br>$V_{SS} = AV_{SS} = 0 V$                           | -                    | 0.5  | 1              | .0         | mA          |
| Nonlinearity error                       |        |                                                                                             | -                    | -    | ±1             | ±2         |             |
| Zero error                               | 2      | V <sub>DD</sub> = 5 V , V <sub>SS</sub> = 0 V<br>AV <sub>DD</sub> = V <sub>AREF</sub> = 5 V | -                    | -    | ±1             | ±2         | LSB         |
| Full scale error                         |        | AV <sub>DD</sub> = V <sub>AREF</sub> = 5 V<br>AV <sub>SS</sub> = 0 V                        | -                    | -    | ±1             | ±2         | LOB         |
| Overall error                            |        |                                                                                             | -                    | -    | ±2             | ±4         |             |

Note 1: The total error includes all errors except a quantization error, and is defined as a maximum deviation from the idea conversion line.

Note 2: Conversion time is different in recommended value by power supply voltage.

About conversion time, please refer to "Register Configuration" in the section of AD converter.

Note 3: Please use input voltage to AIN input pin in limit of V<sub>AREF</sub> - V<sub>SS</sub>. When voltage or range outside is input, conversion value becomes unsettled and gives affect to other channel conversion value.

Note 4: Analog reference voltage range;  $\Delta V_{AREF} = V_{AREF} - V_{SS}$ 

Note 5: When AD converter is not used, fix the  $AV_{DD}$  pin and  $V_{AREF}$  pin on the  $V_{DD}$  level.

## 21.6 Power On Reset circuit (POR)



Note: The power-on reset circuit may not operate properly depending on transitions/in supply voltage (VDD). When designing your application system, careful consideration must be given to ensure proper operation of the power-on reset circuit by referring to the device's electrical characteristics.

|                    |                                         |          | >    | (V <sub>SS</sub> = 0 V, To | pr = −40 to 85°C) |
|--------------------|-----------------------------------------|----------|------|----------------------------|-------------------|
| Symbol             | Parameter                               | Min      | Тур  | Max                        | Unit              |
| V <sub>PROFF</sub> | Power-on reset release voltage          | 7/2.2    | 2.4  | 2.6                        | V                 |
| V <sub>PRON</sub>  | Power-on reset detection voltage        | 2.0      | 2.2  | 2.3                        | V                 |
| t <sub>PROFF</sub> | Power-on reset release response time    | -        | 0.01 | 0.1                        |                   |
| t <sub>PRON</sub>  | Power-on reset generation response time | <u> </u> | 0.01 | 0.1                        |                   |
| t <sub>PRW</sub>   | Power-on reset minimum pulse width      | 1.0      | -    | -                          | ms                |
| t <sub>PWUP</sub>  | Warming-up time after releasing RESET   | 14.0     | -    | 30.0                       |                   |
| t <sub>VDD</sub>   | Power supply raising time               | -        | -    | 7                          |                   |

Note 1: Because the power-on reset releasing voltage and the power-on reset detecting voltage change relative to one another, the detected voltage will never become inverted.

Note 2: The input clock to the warm-up counter is derived from the oscillation circuit. Because the oscillation frequency is unstable until the oscillation circuit stabilizes, the warm-up time includes error.

Note 3: The supply voltage must be raised to satisfy the condition  $t_{VDD}$  <  $t_{PWUP}$ .

# 21.7 Voltage Detection circuit (VLTD)



### Figure 21-3 Operation timing of Voltage detection circuit

Note: The voltage detection circuit may not operate properly depending on transitions in supply voltage (VDD). When designing your application system, careful consideration must be given to ensure proper operation of the voltage detection circuit by referring to the device's electrical characteristics.

 $(V_{SS} = 0 V, Topr = -40 to 85^{\circ}C)$ 

|                     |                                         |          |          | (133 01,10 |      |
|---------------------|-----------------------------------------|----------|----------|------------|------|
| Symbol              | Parameter                               | > Min // | Тур      | Max        | Unit |
| t <sub>VLTOFF</sub> | Voltage detection release response time | - \\     | 0.01     | 0.1        | ms   |
| t <sub>VLTON</sub>  | Voltage detection response time         | -        | 0.01     | 0.1        | ms   |
| t <sub>VLTPW</sub>  | Voltage detection minimum pulse width   | 1.0      | <u> </u> | -          | ms   |

# 21.8 AC Characteristics

(V<sub>SS</sub> = 0 V, V<sub>DD</sub> = 4.5 to 5.5 V, Topr = -40 to  $85^{\circ}$ C)

| Parameter          | Symbol | Condition          | Min | Тур | Max | Unit |
|--------------------|--------|--------------------|-----|-----|-----|------|
|                    | 1      | During NORMAL mode | 0.0 |     | 0.5 |      |
| Machine cycle time | tcy    | During IDLE mode   | 0.2 | -   | 0.5 | μs   |

# 21.9 Flash Characteristics

Write Characteristics

 $(V_{SS} = 0 \text{ V}, 4.5 \text{ V} \le V_{DD} \le 5.5 \text{ V})$ 

| Parameter                                   | Condition          | Min | Тур | Max | Unit  |
|---------------------------------------------|--------------------|-----|-----|-----|-------|
| Number of guaranteed writes to flash memory | Topr = -10 to 40°C | -   | -   | 100 | Times |

Note: To rewrite data to Flash memory addresses at which data is already written, make sure to erase the existing data before rewriting data.

### 21.10 Handling Precaution

- The solderability test conditions are shown below.
  - 1. When using the Sn-37Pb solder bath

Solder bath temperature =  $230 \text{ }^{\circ}\text{C}$ 

Dipping time = 5 seconds

Number of times = once

R-type flux used

2. When using the Sn-3.0Ag-0.5Cu solder bath

Solder bath temperature =  $245 \text{ }^{\circ}\text{C}$ 

Dipping time = 5 seconds

Number of times = once

R-type flux used

Note: The pass criterion of the above test is as follows: Solderability rate until forming ≥95%

When using the device (oscillator) in places exposed to high electric fields such as cathode-ray tubes, we recommend electrically shielding the package in order to maintain normal operating condition.

21.10 Handling Precaution

# 22. Package Dimensions

LQFP44-P-1010-0.80B Rev 01



### **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 Handbock" and (b) the instructions for the application that 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, stockpling 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.

