# TOSHIBA

## 8 Bit Microcontroller TLCS-870/C Series

**TMP86FM48** 

**TOSHIBA CORPORATION** 

The information contained herein is subject to change without notice. 021023\_D

TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress.

It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property.

In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications.

Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc. 021023\_A

The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.).

These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. 021023\_B

The products described in this document shall not be used or embedded to any downstream products of which manufacture, use and/or sale are prohibited under any applicable laws and regulations.  $060106_Q$ 

The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patents or other rights of TOSHIBA or the third parties. 070122\_C

The products described in this document are subject to foreign exchange and foreign trade control laws. 060925\_E

For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions. 030619\_S

## CMOS 8-Bit Microcontroller TMP86FM48UG/FG

The TMP86FM48 is the high-speed, high-performance and low power consumption 8-bit microcomputer, including FLASH, RAM, multi-function timer/counter, serial interface (UART, SIO, I<sup>2</sup>C), a 10-bit AD converter and two clock generators on chip.

| Product No. | FLASH          | FLASH        | RAM                   | Package             | Emulation Chip |  |
|-------------|----------------|--------------|-----------------------|---------------------|----------------|--|
| TTOULCE NO. | (Program area) | (Data area)  |                       | T ackage            |                |  |
| TMP86FM48UG | 32256 × 8 bits | 5100 hite    | 2.0 K $\times$ 8 bits | LQFP64-P-1010-0.50E | TMP86C948XB    |  |
| TMP86FM48FG | 32256 × 8 bits | 512 × 8 bits |                       | QFP64-P-1414-0.80C  |                |  |

### Features

- 8-bit single chip microcomputer TLCS-870/C series ٠
- Instruction execution time: 0.25 µs (at 16 MHz) 122 µs (at 32.768 kHz)
- 132 types and 731 basic instructions
- 20 interrupt sources (External: 5, Internal: 15)
- Input/output ports (54 pins)
- 16-bit timer counter: 2 ch
  - Timer, Event counter, Pulse width measurement, External trigger timer, Window, PPG output modes
- 8-bit timer counter: 2 ch
  - Timer, Event counter, PWM output, Programmable divider output, Capture modes
- Time base timer
- Divider output function
- Watchdog timer
  - Interrupt source/internal reset generate (Programmable)



TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or



amage to property. In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc. 021023\_A

The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment, industria robotics, domestic appliances, etc.). These TOSHBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. 021023\_B

<sup>•</sup> The products described in this document shall not be used or embedded to any downstream products of which manufacture, use and/or sale are prohibited under any applicable laws and regulations. 060106\_Q

The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patents or other rights of TOSHIBA or the third parties. 070122\_C
 The products described in this document are subject to foreign exchange and foreign trade control laws. 060925\_E

<sup>•</sup> For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions. 030619\_S

- ◆ Serial interface
  - UART/SIO: 1ch
  - SIO: 1ch
  - I<sup>2</sup>C bus: 1ch
  - 10-bit successive approximation type AD converter
    - Analog input: 16 ch
- Four Key-on wake-up pins
- Dual clock operation
  - Single/dual-clock mode
- Nine power saving operating modes
  - STOP mode: Oscillation stops. Battery/capacitor back-up. Port output hold/High-impedance.
  - SLOW 1, 2 mode: Low-power consumption operation using low-frequency clock (32.768 kHz)
  - IDLE 0 mode: CPU stops, and peripherals operate using high-frequency clock of Time-Base-Timer. Release by falling edge of TBTCR<TBTCK> setting.
  - IDLE 1 mode: CPU stops, and peripherals operate using high-frequency clock. Release by interruputs.
  - IDLE 2 mode: CPU stops, and peripherals operate using high and low-frequency clock. Release by interruputs.
  - SLEEP 0 mode: CPU stops, and peripherals operate using low-frequency clock of time-base-timer. Release by falling edge of TBTCR<TBTCK> setting.
  - SLEEP 1 mode: CPU stops, and peripherals operate using low-frequency clock. Release by interrupts.
  - SLEEP 2 mode: CPU stops, and peripherals operate using high- and low-frequency clock. Release by interrupts.
- Wide operating voltage: 1.8 to 3.6 V at 8 MHz/32.768 kHz
   2.7 to 3.6 V at 16 MHz/32.768 kHz

## Pin Assignments (Top view)

LQFP64-P-1010-0.50E QFP64-P-1414-0.80C



## **Block Diagram**



## Pin Functions (1/2)

| Pin Name                    | Input/Output     | Fund                                                                                                                                                                                                          | ctions                                                             |                      |  |
|-----------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|----------------------|--|
| P07 ( SCK1 )                | I/O (I/O)        | 8-bit input/output port with latch.                                                                                                                                                                           | Serial clock input/out                                             | tput 1               |  |
| P06 (TXD, SO1)              | I/O (Output)     | When used as a serial interface output                                                                                                                                                                        | UART data output, S                                                | Serial data output 1 |  |
| P05 (RXD, SI1)              | I/O (Input)      | or UART output, respective output latch (P0DR) should be set to "1".                                                                                                                                          | UART data input, Se                                                |                      |  |
| P04                         | I/O              | When used as an input port, an serial                                                                                                                                                                         |                                                                    |                      |  |
| P03 (TC2)                   | I/O (Input)      | interface input, UART input, timer                                                                                                                                                                            | Timer counter 2 inpu                                               | it                   |  |
| P02 (INT2)                  | I/O (Input)      | counter input or an external interrupt                                                                                                                                                                        | External interrupt 2 i                                             | nput                 |  |
| P01 (INT1)                  | I/O (Input)      | input, respective output control<br>(POOUTCR) should be cleared to "0"                                                                                                                                        | External interrupt 1 i                                             | nput                 |  |
| P00 ( INT0 )                | I/O (Input)      | after setting P0DR to "1".                                                                                                                                                                                    | External interrupt 0 i                                             | nput                 |  |
| P17                         | I/O              | 8-bit input/output port with latch.                                                                                                                                                                           |                                                                    |                      |  |
| P16                         | I/O              | When used as a timer/counter output or                                                                                                                                                                        |                                                                    |                      |  |
| P15 (TC1)                   | I/O (Input)      | serial interface output, respective output latch (P1DR) should be set to                                                                                                                                      | Timer counter 1 inpu                                               | it                   |  |
| P14 (TC3,INT3)              | I/O (Input)      | "1". When used as an input port, a timer<br>counter input, an external interrupt input                                                                                                                        | Timer counter 3 inpu<br>External interrupt 3 i                     |                      |  |
| P13                         |                  | or serial interface input, respective                                                                                                                                                                         | PWM5 output, PDO                                                   | •                    |  |
| (PWM5, PDO5, TC5)           | I/O (I/O)        | output control (P1OUTCR) should be                                                                                                                                                                            | Timer/counter 5 inpu                                               | • •                  |  |
| P12 ( SCK2 )                | I/O (I/O)        | cleared to "0" after setting P1DR to "1".                                                                                                                                                                     | Serial clock input/out                                             | tput 2               |  |
| P11 (SI2)                   | I/O (Input)      |                                                                                                                                                                                                               | Serial data input 2                                                | •                    |  |
| P10 (SO2)                   | I/O (Output)     |                                                                                                                                                                                                               | Serial data output 2                                               |                      |  |
| P22 (XTOUT)                 | I/O (Output)     | 3-bit input/output port with latch.<br>When used as an input port or an                                                                                                                                       | Resonator connectin                                                |                      |  |
| P21 (XTIN)                  | I/O (Input)      | external interrupt input, respective output control (P2OUTCR) should be                                                                                                                                       | For inputting external clock, XTIN is used<br>and XTOUT is opened. |                      |  |
| P20 (INT5, STOP)            | I/O (Input)      | cleared to "0" after setting output latch (P2DR) to "1".                                                                                                                                                      | External interrupt input 5 or STOP mode release signal input       |                      |  |
| P37 to P30                  | I/O              | 8-bit input/output port with latch (N-ch<br>high-current output). When used as an<br>input port, respective output control<br>(P3OUTCR) should be cleared to "0"<br>after setting output latch (P3DR) to "1". |                                                                    |                      |  |
| P52                         | I/O              | 3-bit input/output port with latch (N-ch<br>high-current output). When used as an<br>input port or I <sup>2</sup> C bus interface                                                                             |                                                                    |                      |  |
| P51 ( <del>DVO</del> , SDA) | I/O (Output,I/O) | input/output, respective output control<br>(P5OUTCR) should be cleared to "0"<br>after setting output latch (P5DR) to "1".                                                                                    | Divider Output/I <sup>2</sup> C bus serial data input/output       |                      |  |
| P50 ( PPG , SCL)            | I/O (Output,I/O) | When used as a PPG output or divider output, respective P5DR should be set to "1".                                                                                                                            | PPG Output/l <sup>2</sup> C bus serial clock input/output          |                      |  |
| P67 (AIN07, STOP3)          | I/O (Input)      | 8-bit programmable input/output port                                                                                                                                                                          | STOP 3 input                                                       |                      |  |
| P66 (AIN06, STOP2)          | I/O (Input)      | (tri-state). Each bit of this port can be<br>individually configured as an input or an<br>output under software control. When                                                                                 | STOP 2 input                                                       |                      |  |
| P65 (AIN05, STOP1)          | I/O (Input)      | used as an input port, respective                                                                                                                                                                             | STOP 1 input                                                       |                      |  |
| P64 (AIN04, STOP0)          | I/O (Input)      | input/output control (P6CR1) should be<br>cleared to "0" after setting input control                                                                                                                          | STOP 0 input                                                       | AD converter         |  |
| P63 (AIN03)                 | I/O (Input)      | (P6CR2) to "1". When used as an analog input or key on wake up input,                                                                                                                                         |                                                                    | analog inputs        |  |
| P62 (AIN02)                 | I/O (Input)      | respective P6CR1 should be cleared to<br>"0" after clearing P6CR2 to "0".                                                                                                                                     |                                                                    |                      |  |
| P61 (AIN01)                 | I/O (Input)      | When used as a key on wake up input,                                                                                                                                                                          |                                                                    |                      |  |
| P60 (AIN00)                 | I/O (Input)      | STOPCR <stopien> should be set to<br/>"1". (i = 0 to 3)</stopien>                                                                                                                                             |                                                                    |                      |  |

## Pin Functions (2/2)

| Pin Name    | Input/Output | Functions                                                                                                                                                                                                     | Pin Name                              |  |  |
|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--|--|
| P77 (AIN17) | I/O (Input)  | 8-bit programmable input/output port                                                                                                                                                                          |                                       |  |  |
| P76 (AIN16) | I/O (Input)  | (tri-state). Each bit of this port can be individually configured as an input or an                                                                                                                           |                                       |  |  |
| P75 (AIN15) | I/O (Input)  | output under software control. When                                                                                                                                                                           |                                       |  |  |
| P74 (AIN14) | I/O (Input)  | used as an input port, respective input/output control (P7CR1) should be                                                                                                                                      | AD converter analog inputs            |  |  |
| P73 (AIN13) | I/O (Input)  | cleared to "0" after setting input control                                                                                                                                                                    |                                       |  |  |
| P72 (AIN12) | I/O (Input)  | (P7CR2) to "1". When used as an analog input, respective P7CR1 should be                                                                                                                                      |                                       |  |  |
| P71 (AIN11) | I/O (Input)  | cleared to "0" after clearing P7CR2 to                                                                                                                                                                        |                                       |  |  |
| P70 (AIN10) | I/O (Input)  | "0".                                                                                                                                                                                                          |                                       |  |  |
| P87 to P80  | I/O          | 8-bit input/output port with latch (N-ch<br>high-current output). When used as an<br>input port, respective output control<br>(P8OUTCR) should be cleared to "0"<br>after setting output latch (P8DR) to "1". |                                       |  |  |
| XIN, XOUT   | Input Output | Resonator connecting pins for high-freque<br>For inputting external clock, XIN is used a                                                                                                                      |                                       |  |  |
| RESET       | Input        | Reset signal input                                                                                                                                                                                            |                                       |  |  |
| TEST        | Input        | Test pin for out-going test. Be fixed to low.                                                                                                                                                                 |                                       |  |  |
| BOOT        | Input        | Serial prom mode control input. When wri<br>be fixed to high level.                                                                                                                                           | ting to FLASH memory, BOOT pin should |  |  |
| VDD, VSS    |              | Power supply for operation                                                                                                                                                                                    |                                       |  |  |
| VAREF       | Dower Supply | Analog reference voltage for AD conversion                                                                                                                                                                    |                                       |  |  |
| AVDD        | Power Supply | AD circuit power supply                                                                                                                                                                                       |                                       |  |  |
| AVSS/VASS   |              | AD circuit power supply/Analog reference                                                                                                                                                                      | GND for AD conversion                 |  |  |

## **Operational Description**

## 1. CPU Core Functions

The CPU core consists of a CPU, a system clock controller, and an interrupt controller. This section provides a description of the CPU core, the program memory, the data memory, the external memory interface, and the reset circuit.

## 1.1 Memory Address Map

The TMP86FM48 memory consists of 5 blocks: FLASH memory, BOOT ROM, RAM, DBR (Data buffer register) and SFR (Special function register). They are all mapped in 64-Kbyte address space. Figure 1.1.1 shows the TMP86FM48 memory address map. The general-purpose registers are not assigned to the RAM address space.



Figure 1.1.1 Memory Address Maps

## 1.2 Program Memory (FLASH)

The TMP86FM48 has a 32 K  $\times$  8 bits (Address 8000<sub>H</sub> to FFFF<sub>H</sub>) of program memory (FLASH). The area of 8000H to 81FFH can be used as a 512  $\times$  8 bits data memory of FLASH.

#### 1.3 Data Memory (RAM)

The TMP86FM48 has 2048 bytes of internal RAM. The first 192 bytes ( $0040_{\text{H}}$  to  $00FF_{\text{H}}$ ) of the internal RAM are located in the direct area; instructions with shorten operations are available against such an area.

The data memory contents become unstable when the power supply is turned on; therefore, the data memory should be initialized by an initialization routine.

Example: Clears RAM to "00H".

| Example. Clo |     |            |
|--------------|-----|------------|
|              | LD  | HL, 0040H  |
|              | LD  | А, Н       |
|              | LD  | BC, 07FFH  |
| SRAMCLR:     | LD  | (HL), A    |
|              | INC | HL         |
|              | DEC | BC         |
|              | JRS | F, SRAMCLR |
|              |     |            |

; Start address setup; Initial value (00H) setup

;

## 1.4 System Clock Controller

The system clock controller consists of a clock generator, a timing generator, and a standby controller.



Figure 1.4.1 System Clock Control

#### 1.4.1 Clock Generator

The clock generator generates the basic clock which provides the system clocks supplied to the CPU core and peripheral hardware. It contains two oscillation circuits: one for the high-frequency clock and one for the low-frequency clock. Power consumption can be reduced by switching of the standby controller to low-power operation based on the low-frequency clock.

The high-frequency (fc) and low-frequency (fs) clocks can easily be obtained by connecting a resonator between the XIN/XOUT and XTIN/XTOUT pins respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to XIN/XTIN pin with XOUT/XTOUT pin not connected.



Figure 1.4.2 Examples of Resonator Connection

Note: The function to monitor the basic clock directly at external is not provided for hardware, however, with disabling all interrupts and watchdog timers, the oscillation frequency can be adjusted by monitoring the pulse which the fixed frequency is outputted to the port by the program.

The system to require the adjustment of the oscillation frequency should create the program for the adjustment in advance.

#### 1.4.2 Timing Generator

The timing generator generates the various system clocks supplied to the CPU core and peripheral hardware from the basic clock (fc or fs). The timing generator provides the following functions.

- a. Generation of main system clock
- b. Generation of divider output  $(\overline{\text{DVO}})$  pulses
- c. Generation of source clocks for time base timer
- d. Generation of source clocks for watchdog timer
- e. Generation of internal source clocks for timer/counters and serial interface
- f. Generation of warm-up clocks for releasing STOP mode

#### (1) Configuration of timing generator

The timing generator consists of a 2-stage prescaler, a 21-stage divider, a main system clock generator, and machine cycle counters.

An input clock to the 7th stage of the divider depends on the operating mode, TBTCR<DV7CK>, that is shown in Figure 1.4.4. As reset and STOP mode started/canceled, the prescaler and the divider are cleared to "0".



Figure 1.4.3 Configuration of Timing Generator

| TBTCR                | 7         | 6         | 5                         | 4                 | 3                  | 2         | 1            | 0          | ٦                                   |           |
|----------------------|-----------|-----------|---------------------------|-------------------|--------------------|-----------|--------------|------------|-------------------------------------|-----------|
| (0036 <sub>H</sub> ) | (DVOEN)   | (DVC      | DCK)                      | DV7CK             | (TBTEN)            |           | (TBTCK)      |            | (Initial value: 0000 0000)          |           |
|                      |           |           |                           |                   |                    |           |              |            |                                     |           |
|                      | DV7CK     |           | ion of inp<br>of the divi | out to the<br>der | 7th 0: fe<br>1: fe |           |              |            |                                     | R/W       |
|                      | Note 1:   | n single  | clock moc                 | le, do not :      | set DV7C           | K to "1". |              |            |                                     |           |
|                      | Note 2:   | Do not se | et "1" on D               | V7CK whi          | le the low         | -frequen  | cy clock is  | not oper   | ated stably.                        |           |
|                      | Note 3: 1 | c: High-f | requency                  | clock [Hz]        | , fc: Low-f        | requency  | / clock [Hz  | ], *: Don  | 't care                             |           |
|                      | Note 4:   | n SLOW    | 1/2 and S                 | LEEP1/2 r         | nodes, th          | e DV7C⊧   | setting is   | ineffectiv | ve, and fs is input to the 7th stag | ge of the |
|                      | (         | divider.  |                           |                   |                    |           |              |            |                                     |           |
|                      | Note 5:   | Nhen ST   | FOP mod                   | e is enter        | ed from            | NORMAL    | 1/2 mod      | e, the D   | W7CK setting is ineffective du      | iring the |
|                      | ,         | warm-up   | period aft                | er release        | of STOP            | mode, ar  | id the 6th s | tage of tl | he divider is input to the 7th stag | e during  |
|                      | t         | his perio | d.                        |                   |                    |           |              |            |                                     |           |

| Figure 1.4.4 | <b>Timing Generate</b> | or Control Register |
|--------------|------------------------|---------------------|
| 3            | 3                      |                     |

#### (2) Machine cycle

Instruction execution and peripheral hardware operation are synchronized with the main system clock.

The minimum instruction execution unit is called an "machine cycle". There are a total of 10 different types of instructions for the TLCS-870/C series: ranging from 1-cycle instructions which require one machine cycle for execution to 10-cycle instructions which require 10 machine cycles for execution.

A machine cycle consists of 4 states (S0 to S3), and each state consists of one main system clock.



Figure 1.4.5 Machine Cycle

#### 1.4.3 Operation Mode Control Circuit

The operation mode control circuit starts and stops the oscillation circuits for the high-frequency and low-frequency clocks, and switches the main system clock. There are two operating modes: single-clock and dual-clock. These modes are controlled by the system control registers (SYSCR1 and SYSCR2).

Figure 1.4.6 shows the operating mode transition diagram and Figure 1.4.7 shows the system control registers.

#### (1) Single-clock mode

Only the oscillation circuit for the high-frequency clock is used, and P21 (XTIN) and P22 (XTOUT) pins are used as input/output ports. The main-system clock is obtained from the high-frequency clock. In the single-clock mode, the machine cycle time is 4/fc [s].

a. NORMAL1 mode

In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock.

The TMP86FM48 is placed in this mode after reset.

b. IDLE1 mode

In this mode, the internal oscillation circuit remains active. The CPU and the watchdog timer are halted; however on-chip peripherals remain active (Operate using the high-frequency clock).

IDLE1 mode is started by SYSCR2<IDLE>, and IDLE1 mode is released to NORMAL1 mode by an interrupt request from the on-chip peripherals or external interrupt inputs. When the IMF (Interrupt master enable flag) is "1" (Interrupt enable), the execution will resume with the acceptance of the interrupt, and the operation will return to normal after the interrupt service is completed. When the IMF is "0" (Interrupt disable), the execution will resume with the instruction which follows the IDLE1 mode start instruction.

c. IDLE0 mode

In this mode, all the circuit, except oscillator and the time-base-timer, stops operation.

This mode is enabled by setting "1" on bit TGHALT on the system control register 2 (SYSCR2).

When IDLE0 mode starts, the CPU stops and the timing generator stops feeding the clock to the peripheral circuits other than TBT. Then, upon detecting the falling edge of the source clock selected with TBTCR<TBTCK>, the timing generator starts feeding the clock to all peripheral circuits.

When returned from IDLE0 mode, the CPU restarts operating, entering NORMAL1 mode back again. IDLE0 mode is entered and returned regardless of how TBTCR<TBTEN> is set. When IMF = "1", EF7 (TBT interrupt individual enable flag) = "1", and TBTCR<TBTEN> = "1", interrupt processing is performed. When IDLE0 mode is entered while TBTCR<TBTEN> = "1", the INTTBT interrupt latch is set after returning to NORMAL1 mode.

#### (2) Dual-clock mode

Both the high-frequency and low-frequency oscillation circuits are used in this mode. P21 (XTIN) and P22 (XTOUT) pins cannot be used as input/output ports. The main system clock is obtained from the high-frequency clock in NORMAL2 and IDLE2 modes, and is obtained from the low-frequency clock in SLOW and SLEEP modes. The machine cycle time is 4/fc [s] in the NORMAL2 and IDLE2 modes, and 4/fs [s] (122  $\mu$ s at fs = 32.768 kHz) in the SLOW and SLEEP modes.

The TLCS-870/C is placed in the single-clock mode during reset. To use the dual-clock mode, the low-frequency oscillator should be turned on at the start of a program.

a. NORMAL2 mode

In this mode, the CPU core operates with the high-frequency clock. On-chip peripherals operate using the high-frequency clock and/or low-frequency clock.

b. SLOW2 mode

In this mode, the CPU core operates with the low-frequency clock, while both the high-frequency clock and the low-frequency clock are operated. On-chip peripherals are triggered by the low-frequency clock. As the SYSCK on SYSCR2 becomes "0", the hardware changes into NORMAL2 mode. As the XEN on SYSCR2 becomes "0", the hardware changes into SLOW1 mode. Do not clear XTEN to "0" during SLOW2 mode.

c. SLOW1 mode

This mode can be used to reduce power-consumption by turning off oscillation of the high-frequency clock. The CPU core and on-chip peripherals operate using the low-frequency clock.

Switching back and forth between SLOW1 and SLOW2 modes are performed by XEN bit on the system control register 2 (SYSCR2). In SLOW1 and SLEEP mode, the input clock to the 1st stage of the divider is stopped; output from the 1st to 6th stages is also stopped.

#### d. IDLE2 mode

In this mode, the internal oscillation circuit remain active. The CPU and the watchdog timer are halted; however, on-chip peripherals remain active (Operate using the high-frequency clock and/or the low-frequency clock). Starting and releasing of IDLE2 mode are the same as for IDLE1 mode, except that operation returns to NORMAL2 mode.

#### e. SLEEP1 mode

In this mode, the internal oscillation circuit of the low-frequency clock remains active. The CPU, the watchdog timer, and the internal oscillation circuit of the high-frequency clock are halted; however, on-chip peripherals remain active (Operate using the low-frequency clock). Starting and releasing of SLEEP mode are the same as for IDLE1 mode, except that operation returns to SLOW mode. In SLOW and SLEEP mode, the input clock to the 1st stage of the divider is stopped; output from the 1st to 6th stages is also stopped. f. SLEEP2 mode

The SLEEP2 mode is the IDLE mode corresponding to the SLOW2 mode. The status under the SLEEP2 mode is same as that under the SLEEP1 mode, except for the oscillation circuit of the high-frequency clock.

g. SLEEP0 mode

In this mode, all the circuit, except oscillator and the time-base-timer, stops operation.

This mode is enabled by setting "1" on bit TGHALT on the system control register 2 (SYSCR2).

When SLEEP0 mode starts, the CPU stops and the timing generator stops feeding the clock to the peripheral circuits other than TBT. Then, upon detecting the falling edge of the source clock selected with TBTCR<TBTCK>, the timing generator starts feeding the clock to all peripheral circuits.

When returned from SLEEP0 mode, the CPU restarts operating, entering SLOW1 mode back again. SLEEP0 mode is entered and returned regardless of how TBTCR<TBTEN> is set. When IMF = "1", EF7 (TBT interrupt individual enable flag) = "1", and TBTCR<TBTEN> = "1", interrupt processing is performed. When SLEEP0 mode is entered while TBTCR<TBTEN> = "1", the INTTBT interrupt latch is set after returning to SLOW1 mode.

(3) STOP mode

In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with a lowest power consumption during STOP mode.

STOP mode is started by the system control register 1 (SYSCR1), and STOP mode is released by a inputting (either level-sensitive or edge-sensitive can be programmably selected) to the  $\overline{\text{STOP}}$  pin or key on wake up pin input which is enabled by STOPCR. After the warm-up period is completed, the execution resumes with the instruction which follows the STOP mode start instruction.

- Note 1: When the IDLE0/1/2 and SLEEP0/1/2 modes are started with the EEPCR<ATPWDW> = "0", the CPU wait period for stabilizing of the power supply of Flash control circuit is executed after being released from these mode.
- Note 2: When the STOP mode is started with the EEPCR<MNPWDW> = "1", the CPU wait period for stablizing of the power supply of Flash control circuit is executed after in the STOP warm-up time.



Note 1: NORMAL1 and NORMAL2 modes are generically called NORMAL; SLOW1 and SLOW2 are called SLOW; IDLE0, IDLE1 and IDLE2 are called IDLE; SLEEP0, SLEEP1 and SLEEP2 are called SLEEP. Note 2: The mode is released by falling edge of TBTCR<TBTCK> setting.

| Operating Mode |         | Oscillator<br>High Frequency Low Frequency |             |                             | трт     | Other       | Machine    |
|----------------|---------|--------------------------------------------|-------------|-----------------------------|---------|-------------|------------|
|                |         |                                            |             | CPU Core                    | TBT     | Peripherals | Cycle Time |
|                | RESET   |                                            |             | Reset                       | Reset   | Reset       |            |
| Single         | NORMAL1 | Oscillation                                |             | Operate                     |         | Oporato     | 4/fc [s]   |
| Clock          | IDI F1  | Oscillation                                | Stop        |                             | Operate | Operate     |            |
| CIOCK          | IDLE0   |                                            |             | Halt                        |         | Halt        |            |
|                | STOP    | Stop                                       |             |                             | Halt    | Tlait       | _          |
|                | NORMAL2 |                                            |             | Operate with high frequency |         | Operate     | 4/fc [s]   |
|                | IDLE2   | Oscillation                                |             | Halt                        |         |             |            |
|                | SLOW2   | Oscillation                                |             | Operate with low frequency  |         |             |            |
| Dual           | SLEEP2  |                                            | Oscillation | Halt                        | Operate | Operate     | 4/fo [o]   |
| Clock          | SLOW1   |                                            |             | Operate with low frequency  |         |             | 4/fs [s]   |
|                | SLEEP1  | 01                                         |             |                             |         |             |            |
|                | SLEEP0  | Stop                                       |             | Halt                        |         |             |            |
|                | STOP    |                                            | Stop        |                             | Halt    | Halt        | =          |

Figure 1.4.6 Operating Mode Transition Diagram

## TOSHIBA

| YSCR1<br>1038 <sub>H</sub> )              | 7<br>STOP                                                                                                                                                                   | 6 5 4 3<br>RELM RETM OUTEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2 1 0<br>WUT (Initial value: 0000 00**)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                |  |  |  |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|--|
| 030H)                                     | 310F                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |  |  |  |
|                                           | STOP STOP mode start                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0: CPU core and peripherals remain active<br>1: CPU core and peripherals are halted (Start STOP mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                |  |  |  |
|                                           | RELM                                                                                                                                                                        | Release method for STOP pin (P20)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0: Edge-sensitive release<br>1: Level-sensitive release                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                |  |  |  |
|                                           | RETM                                                                                                                                                                        | Operating mode after STOP mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0: Return to NORMAL1/2 mode<br>1: Return to SLOW1 mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                |  |  |  |
|                                           | OUTEN                                                                                                                                                                       | Port output during STOP mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0: High impedance<br>1: Output kept                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W            |  |  |  |
|                                           | WUT                                                                                                                                                                         | Warm-up time at releasing<br>STOP mode (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | $\begin{tabular}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                |  |  |  |
|                                           | tr<br>Note 2: V                                                                                                                                                             | ansiting from SLOW mode to STO<br>/hen STOP mode is released wi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | iting from NORMAL mode to STOP mode. Always set RETM to "1<br>DP mode.<br>th $\overline{\text{RESET}}$ pin input, a return is made to NORMAL1 regardless                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                |  |  |  |
|                                           | Note 3: fo<br>Note 4: B<br>Note 5: A                                                                                                                                        | its 1 and 0 in SYSCR1 are read a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ow-frequency clock [Hz], *: Don't care<br>as undefined data when a read instruction is executed.<br>mode under OUTEN = "0", input value is fixed to "0"; therefore                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | it may         |  |  |  |
|                                           | Note 6: V<br>Note 7: P<br>P                                                                                                                                                 | /hen the key-on wake-up input (S<br>ort P20 is used as STOP pin. The<br>20 becomes High-Z mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | TOP0 to STOP3) is used, RELM should be set to "1".<br>erefore, when stop mode is started, OUTEN does not affect to P2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                |  |  |  |
|                                           | tł                                                                                                                                                                          | ne power supply of Flash control of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ith the EEPCR <mnpwdw> = "1", the CPU wait period for stabil<br/>circuit is executed after in the STOP warm-up time.<br/>s shown in parentheses)</mnpwdw>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | izing of       |  |  |  |
| YSCR2                                     | th<br>(*<br>trol Register 2                                                                                                                                                 | ne power supply of Flash control of<br>The CPU wait period for FLASH is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | sircuit is executed after in the STOP warm-up time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | izing of       |  |  |  |
| YSCR2                                     | th<br>(*<br>trol Register 2                                                                                                                                                 | ne power supply of Flash control of<br>The CPU wait period for FLASH is<br>2<br>6 5 4 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | circuit is executed after in the STOP warm-up time.<br>s shown in parentheses)<br><u>2</u> <u>1</u> <u>0</u><br><u>TGHALT</u> (Initial value: 1000 *0**)<br>0: Turn off oscillation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | izing of       |  |  |  |
| YSCR2                                     | th<br>(*<br>trol Register 2<br>7<br>XEN                                                                                                                                     | ne power supply of Flash control of<br>The CPU wait period for FLASH is<br>6 5 4 - 3<br>XTEN SYSCK IDLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 2       1       0         TGHALT       0       (Initial value: 1000 *0**)         0       1: Turn off oscillation         0: Turn off oscillation       0: Turn off oscillation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | izing of       |  |  |  |
| ystem Con<br>YSCR2<br>1039 <sub>H</sub> ) | tf<br>(*<br>trol Register 2<br>7<br>XEN<br>XEN                                                                                                                              | he power supply of Flash control of<br>The CPU wait period for FLASH is<br><u>6 5 4 - 3</u><br><u>XTEN SYSCK IDLE</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2       1       0         TGHALT       (Initial value: 1000 *0**)         0:       Turn off oscillation         1:       Turn off oscillation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                |  |  |  |
| YSCR2                                     | trol Register 2<br>7<br>XEN<br>XEN<br>XEN<br>XTEN                                                                                                                           | he power supply of Flash control of<br>The CPU wait period for FLASH is<br><u>6 5 4 3</u><br><u>XTEN SYSCK IDLE</u><br>High-frequency oscillator control<br>Low-frequency oscillator control<br>Main system clock select (write                                                                                                                                                                                                                                                                                                                                                      | 2       1       0         TGHALT       (Initial value: 1000 *0**)         0       Turn off oscillation         1       Turn on oscillation         0       Turn off oscillation         1       Turn on oscillation         1       Turn off oscillation         1       1         0: Turn off oscillation         1       1         1       0: Turn off oscillation         1       1         1       0: Turn off oscillation         1       1         1       0: Turn off oscillation         1       1         1       0: Turn off oscillation         1       1         1       0: Turn off oscillation         1       1         1       0: High-frequency clock         1       1         0: CPU and watchdog timer remain active                                                                                                                                                                                                                                                                                                                                                     | R/W            |  |  |  |
| YSCR2                                     | ttol Register 2<br>7<br>XEN<br>XEN<br>XEN<br>XTEN<br>SYSCK                                                                                                                  | he power supply of Flash control of The CPU wait period for FLASH is         6       5       4       3         XTEN       SYSCK       IDLE       -       3         High-frequency oscillator control       Low-frequency oscillator control       4       10         Main system clock select (write system clock monitor (read)       CPU and watchdog timer control                                                                                                                                                                                                                | 2       1       0         TGHALT       0       (Initial value: 1000 *0**)         0       Turn off oscillation<br>1: Turn on oscillation<br>1: CPU and watchdog timer remain active<br>1: CPU and watchdog timer are stopped                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                |  |  |  |
| YSCR2                                     | ttol Register 2<br>7<br>XEN<br>XEN<br>XEN<br>XTEN<br>SYSCK<br>IDLE<br>TGHALT<br>Note 1: A                                                                                   | he power supply of Flash control of The CPU wait period for FLASH is         6       5       4       3         XTEN       SYSCK       IDLE       -       -         High-frequency oscillator control       Low-frequency oscillator control       Main system clock select (write system clock monitor (read)         CPU and watchdog timer control       (IDLE1/2, SLEEP1/2 mode)       TG control         TG control       (IDLE0, SLEEP0 mode)       -                                                                                                                           | 2       1       0         TGHALT       (Initial value: 1000 *0**)         0:       Turn off oscillation         1:       Turn on oscillation         0:       Turn off oscillation         1:       Turn on oscillation         1:       Turn off oscillation         1:       Turn off oscillation         1:       Turn off oscillation         1:       Turn on oscillation         1:       Turn off oscillation         1:       Turn on oscillation         1:       Turn off oscillation         1:       Turn off oscillation         1:       Turn off oscillation         1:       Turn off oscillation         1:       CPU and watchdog timer remain acti | R/W            |  |  |  |
| YSCR2                                     | ttrol Register 2<br>7<br>XEN<br>XEN<br>XEN<br>XTEN<br>SYSCK<br>IDLE<br>TGHALT<br>Note 1: A<br>X<br>Note 2: *                                                                | he power supply of Flash control of The CPU wait period for FLASH is         6       5       4       - 3         XTEN       SYSCK       IDLE                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2       1       0         TGHALT       (Initial value: 1000 *0**)         0       0: Turn off oscillation<br>1: Turn on oscillation<br>1: Turn on oscillation<br>1: Turn on oscillation<br>1: Turn on oscillation<br>0: High-frequency clock<br>1: Low-frequency clock<br>0: CPU and watchdog timer remain active<br>1: CPU and watchdog timer are stopped<br>(start IDLE1/2, SLEEP1/2 mode)<br>0: Feeding clock to all peripherals from TG<br>1: Stop feeding clock to peripherals except TBT from<br>TG. (Start IDLE0, SLEEP0 mode)         XTEN are cleared to "0", XEN is cleared to "0" when SYSCK =<br>CK = "1".                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W            |  |  |  |
| YSCR2                                     | trol Register 2<br>7<br>XEN<br>XEN<br>XEN<br>XTEN<br>SYSCK<br>IDLE<br>TGHALT<br>Note 1: A<br>Note 2: *<br>Note 2: *<br>Note 3: B<br>Note 4: D                               | e power supply of Flash control of<br>The CPU wait period for FLASH is<br><u>6</u> <u>5</u> <u>4</u> <u>-3</u> .<br><u>XTEN SYSCK IDLE</u> <u>3</u><br>High-frequency oscillator control<br>Low-frequency oscillator control<br>Main system clock select (write<br>system clock monitor (read)<br>CPU and watchdog timer control<br>(IDLE1/2, SLEEP1/2 mode)<br>TG control<br>(IDLE0, SLEEP0 mode)<br>reset is applied if both XEN and<br>TEN is cleared to "0" when SYSC<br>Don't care, TG: Timing generato<br>its 3, 1and 0 in SYSCR2 are alwas<br>o not set IDLE and TGHALT to "1 | 2       1       0         TGHALT       (Initial value: 1000 *0**)         0       0: Turn off oscillation<br>1: Turn on oscillation<br>1: Turn on oscillation<br>1: Turn on oscillation<br>1: Turn on oscillation<br>0: High-frequency clock<br>1: Low-frequency clock<br>0: CPU and watchdog timer remain active<br>1: CPU and watchdog timer are stopped<br>(start IDLE1/2, SLEEP1/2 mode)<br>0: Feeding clock to all peripherals from TG<br>1: Stop feeding clock to peripherals except TBT from<br>TG. (Start IDLE0, SLEEP0 mode)         XTEN are cleared to "0", XEN is cleared to "0" when SYSCK =<br>CK = "1".                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W            |  |  |  |
| YSCR2                                     | trol Register 2<br>7<br>XEN<br>XEN<br>XEN<br>XEN<br>XTEN<br>SYSCK<br>IDLE<br>TGHALT<br>Note 1: A<br>X<br>Note 2: *<br>Note 3: B<br>Note 4: D<br>Note 5: B<br>C<br>Note 6: V | ae power supply of Flash control of The CPU wait period for FLASH is         a         6       5       4       - 3         XTEN       SYSCK       IDLE                                                                                                                                                                                                                                                                                                                                                                                                                               | 2       1       0         TGHALT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R/W<br>"0", or |  |  |  |

## Figure 1.4.7 System Control Registers

#### 1.4.4 Operating Mode Control

#### (1) STOP mode

STOP mode is controlled by the system control register 1, the STOP pin input and key-on wake-up input (STOP0 to STOP3) which is controlled by the STOP mode release control register (STOPCR).

The  $\overline{\text{STOP}}$  pin is also used both as a port P20 and an  $\overline{\text{INT5}}$  (External interrupt input 5) pin.

STOP mode is started by setting SYSCR1<STOP> to "1". During STOP mode, the following status is maintained.

- a. Oscillations are turned off, and all internal operations are halted.
- b. The data memory, registers, the program status word and port output latches are all held in the status in effect before STOP mode was entered.
- c. The prescaler and the divider of the timing generator are cleared to "0".
- d. The program counter holds the address 2 ahead of the instruction (e.g. [SET (SYSCR1).7]) which started STOP mode.

STOP mode includes a level-sensitive mode and an edge-sensitive mode, either of which can be selected with the SYSCR1<RELM>. Do not use any STOPx (x: 0 to 3) pin input for releasing STOP mode in edge-sensitive mode.

When the STOP mode is started with the EEPCR<MNPWDW> = "1", the CPU wait period for stabilizing of the power supply of Flash control circuit is executed after in the STOP warming-up time.

- Note 1: The STOP mode can be released by either the STOP or key-on wake-up pin (STOP0 to STOP3). However, because the STOP pin is different from the key-on wake-up and can not inhibit the release input, the STOP pin must be used for releasing STOP mode.
- Note 2: During stop period (from start of STOP mode to end of warm-up), due to changes in the external interrupt pin signal, interrupt latches may be set to "1" and interrupts may be accepted immediately after STOP mode is released. Before starting STOP mode, therefore, disable interrupts. Also, before enabling interrupts after STOP mode is released, clear unnecessary interrupt latches.

a. Level-sensitive release mode (RELM = "1")

In this mode, STOP mode is released by setting the  $\overline{\text{STOP}}$  pin high or setting the STOPx (x: 0 to 3) pin input which is enabled by STOPCR. This mode is used for capacitor back-up when the main power supply is cut off and long term battery back-up.

When the **STOP** pin input is high, executing an instruction which starts STOP mode will not place in STOP mode but instead will immediately start the release sequence (Warm-up). Thus, to start STOP mode in the level-sensitive release mode, it is necessary for the program to first confirm that the **STOP** pin input is low. The following two methods can be used for confirmation.

- a. Testing a port P20.
- b. Using an external interrupt input  $\overline{INT5}$  ( $\overline{INT5}$  is a falling edge-sensitive input).



Figure 1.4.8 Level-sensitive Release Mode

- Note 1: Even if the STOP pin input is low after warming up start, the STOP mode is not restarted.
- Note 2: In this case of changing to the level-sensitive mode from the edge-sensitive mode, the release mode is not switched until a rising edge of the STOP pin input is detected.

#### b. Edge-sensitive release mode (RELM = "0")

In this mode, STOP mode is released by a rising edge of the  $\overline{\text{STOP}}$  pin input. This is used in applications where a relatively short program is executed repeatedly at periodic intervals. This periodic signal (For example, a clock from a low-power consumption oscillator) is input to the  $\overline{\text{STOP}}$  pin. In the edge-sensitive release mode, STOP mode is started even when the  $\overline{\text{STOP}}$  pin input is high level. Do not use any STOPx (x: 0 to 3) pin input for releasing STOP mode in edge-sensitive release mode.

```
Example: Starting STOP mode from NORMAL mode
LD (SYSCR1), 10010000B ; Starts after specified to the edge-sensitive
```





STOP mode is released by the following sequence.

- a. In the dual-clock mode, when returning to NORMAL2, both the high-frequency and low-frequency clock oscillators are turned on; when returning to SLOW1 mode, only the low-frequency clock oscillator is turned on. In the single-clock mode, only the high-frequency clock oscillator is turned on.
- b. A STOP warm-up period is inserted to allow oscillation time to stabilize. During STOP warm-up, all internal operations remain halted. Four different STOP warm-up times can be selected with the SYSCR1<WUT> in accordance with the resonator characteristics.
- c. When the EEPCR<MNPWDW> is "1", the CPU wait period is inserted to stabilize the power supply of Flash control circuit. During CPU wait, though CPU operations remain halted, the peripheral function operation is resumed, and the counting of the timing generator is restarted. After the CPU wait is finished, normal operation resumes with the instruction following the STOP mode start instruction.
- d. When the EEPCR<MNPWDW> is "0", normal operation resumes with the instruction following the STOP mode start instruction after the STOP Warm-up.
- Note 1: When the STOP mode is released, the start is made after the prescaler and the divider of the timing generator are cleared to "0".
- Note 2: STOP mode can also be released by inputting low level on the RESET pin, which immediately performs the normal reset operation.
- Note 3: When STOP mode is released with a low hold voltage, the following cautions must be observed.

The power supply voltage must be at the operating voltage level before releasing STOP mode. The RESET pin input must also be "H" level, rising together with the power supply voltage. In this case, if an external time constant circuit has been connected, the RESET pin input voltage will increase at a slower pace than the power supply voltage. At this time, there is a danger that a reset may occur if input voltage level of the RESET pin drops below the non-inverting high-level input voltage (Hysteresis input).

|     | Warm-up Time [ms] (Note 2) |                     |  |  |  |
|-----|----------------------------|---------------------|--|--|--|
| WUT | Return to NORMAL Mode      | Return to SLOW Mode |  |  |  |
| 00  | 12.288 + (0.064)           | 750 + (0.244)       |  |  |  |
| 01  | 4.096 + (0.064)            | 250 + (0.244)       |  |  |  |
| 10  | 3.072 + (0.064)            | 5.85 + (0.244)      |  |  |  |
| 11  | 1.024 + (0.064)            | 1.95 + (0.244)      |  |  |  |

Table 1.4.1 Warm-up Time Example (at fc = 16.0 MHz, fs = 32.768 kHz)

Note 1: The warm-up time is obtained by dividing the basic clock by the divider: therefore, the warm-up time may include a certain amount of error if there is any fluctuation of the oscillation frequency when STOP mode is released. Thus, the warm-up time must be considered an approximate value.

Note 2: The CPU wait period for FLASH is shown in parentheses.





(2) IDLE1/2 mode, SLEEP1/2 mode

IDLE1/2 and SLEEP1/2 modes are controlled by the system control register 2 (SYSCR2) and maskable interrupts. The following status is maintained during these modes.

- a. Operation of the CPU and watchdog timer (WDT) is halted. On-chip peripherals continue to operate.
- b. The data memory, CPU registers, program status word and port output latches are all held in the status in effect before these modes were entered.
- c. The program counter holds the address 2 ahead of the instruction which starts these modes.



Figure 1.4.12 IDLE1/2, SLEEP1/2 Modes

- Start the IDLE1/2 and SLEEP1/2 modes When IDLE1/2 and SLEEP1/2 modes start, set SYSCR2<IDLE> to "1".
  - Release the IDLE1/2 and SLEEP1/2 modes

IDLE1/2 and SLEEP1/2 modes include a normal release mode and an interrupt release mode. These modes are selected by interrupt master enable flag (IMF).

After releasing IDLE1/2 and SLEEP1/2 modes, the SYSCR2<IDLE> is automatically cleared to "0" and the operation mode is returned to the mode preceding IDLE1/2 and SLEEP1/2 modes.

When the IDLE1/2 and SLEEP1/2 modes are started with the EEPCR<ATPWDW> = "0", the CPU wait period for stabilizing of the power supply of Flash control circuit is added before the operation mode is returned to the preceding modes. The CPU wait time of IDLE1/2 is  $2^{10}$ /fc [s] and that of SLEEP1/2 mode is  $2^{3}$ /fs [s].

 $\rm IDLE1/2$  and SLEEP1/2 modes can also be released by inputting low level on the  $\rm \overline{RESET}\,$  pin. After releasing reset, the operation mode is started from NORMAL1 mode.

- Note: During CPU wait, though CPU operations remain halted, but the peripheral function operation is resumed. Therefore in this time, though the interrupt latch might be set, interrupt operation is not executed until the CPU wait is finished.
- (a) Normal release mode (IMF = "0")

IDLE1/2 and SLEEP1/2 modes are released by any interrupt source enabled by the individual interrupt enable flag (EF). After the interrupt is generated, the program operation is resumed from the instruction following the IDLE1/2 and SLEEP1/2 modes start instruction. Normally, the interrupt latches (IL) of the interrupt source used for releasing must be cleared to "0" by load instructions.

(b) Interrupt release mode (IMF = "1")

IDLE1/2 and SLEEP1/2 modes are released by any interrupt source enabled with the individual interrupt enable flag (EF). After the interrupt is processed, the program operation is resumed from the instruction following the instruction, which starts IDLE1/2 and SLEEP1/2 modes.

Note: When a watchdog timer interrupts is generated immediately before IDLE1/2 and SLEEP1/2 mode are started, the watchdog timer interrupt will be processed but IDLE1/2 and SLEEP1/2 mode will not be started.



Figure 1.4.13 IDLE1/2, SLEEP1/2 Mode Start/Release

(3) IDLE0, SLEEP0 mode (IDLE0, SLEEP0)

IDLE0 and SLEEP0 modes are controlled by the system control register 2 (SYSCR2) and the time base timer control register (TBTCR). The following status is maintained during IDLE0 and SLEEP0 modes.

- a. Timing generator stops feeding clock to peripherals except TBT.
- b. The data memory, CPU registers, program status word and port output latches are all held in the status in effect before IDLE0 and SLEEP0 modes were entered.
- c. The program counter holds the address 2 ahead of the instruction which starts IDLE0 and SLEEP0 modes.

Note: Before starting IDLE0 or SLEEP0 mode, be sure to stop (Disable) periperals.



Figure 1.4.14 IDLE0, SLEEP0 Mode

• Start the IDLE0 and SLEEP0 modes

Stop (Disable) peripherals such as a timer counter.

When IDLE0 and SLEEP0 modes start, set SYSCR2<TGHALT> to "1".

• Release the IDLE0 and SLEEP modes

IDLE0 and SLEEP0 modes include a normal release mode and an interrupt release mode.

These modes are selected by interrupt master flag (IMF), individual interrupt enable-flag (EF7) for INTTBT and TBTCR<TBTEN>.

After releasing IDLE0 and SLEEP0 modes, the SYSCR2<TGHALT> is automatically cleared to "0" and the operation mode is returned to the mode preceding IDLE0 and SLEEP0 modes. Before starting the IDLE0 or SLEEP0 mode, when the TBTCR<TBTEN> is set to "1", INTTBT interrupt latch is set to "1".

When the IDLE0 and SLEEP0 modes are started with the EEPCR<ATPWDW> = "0", the CPU wait period for stabilizing of the power supply of Flash control circuit is added before the operation mode is returned to the preceding modes. The CPU wait time of IDLE0 is  $2^{10}$ /fc [s] and that of SLEEP0 mode is  $2^{3}$ /fs [s].

IDLE0 and SLEEP0 modes can also be released by inputting low level on the  $\overline{\text{RESET}}\,$  pin. After releasing reset, the operation mode is started from NORMAL1 mode.

- Note 1: IDLE0 and SLEEP0 modes start/release without reference to TBTCR<TBTEN> setting.
- Note 2: During CPU wait, though CPU operations remain halted, but the peripheral function operation is resumed. Therefore in this time, though the interrupt latch might be set, interrupt operation is not executed until the CPU wait is finished.

<u>a.</u> Normal release mode (IMF•EF7•TBTCR<TBTEN> = "0")

IDLE0 and SLEEP0 modes are released by the source clock falling edge, which is setting by the TBTCR<TBTCK>. After the falling edge is detected, the program operation is resumed from the instruction following the IDLE0 and SLEEP0 modes start instruction.

#### b. Interrupt release mode (IMF•EF7•TBTCR<TBTEN> = "1")

IDLE0 and SLEEP0 modes are released by the source clock falling edge, which is setting by the TBTCR<TBTCK> and INTTBT interrupt processing is started.

- Note 1: Because returning from IDLE0, SLEEP0 to NORMAL1, SLOW1 is executed by the asynchronous internal clock, the period of IDLE0, SLEEP0 mode might be the shorter than the period setting by TBTCR<TBTCK>.
- Note 2: When a watchdog timer interrupt is generated immediately before IDLE0/SLEEP0 mode is started, the watchdog timer interrupt will be processed but IDLE0/SLEEP0 mode will not be started.



#### (4) SLOW mode

SLOW mode is controlled by the system control register 2 (SYSCR2).

The following is the methods to switch the mode with the warm-up counter (TC2).

#### a. Switching from NORMAL2 mode to SLOW1 mode

First, set SYSCR2<SYSCK> to switch the main system clock to the low-frequency clock for SLOW2 mode.

Next, clear SYSCR2<XEN> to turn off high-frequency oscillation.

Note: The high-frequency clock oscillation can be continued to return quickly to NORMAL2 mode. But starting STOP mode while SLOW mode, the high-frequency oscillation must be stopped.

When the low-frequency clock oscillation is unstable, wait until oscillation stabilizes before performing the above operations. The timer/counter 2 (TC2) can conveniently be used to confirm that low-frequency clock oscillation has stabilized.

| Example 1: Sv | vitching from   | NORMAL2 mode to SLOW1 n    | node | ).                                                          |
|---------------|-----------------|----------------------------|------|-------------------------------------------------------------|
|               | SET             | (SYSCR2). 5                | ;    | $SYSCR2{<}SYSCK{>} \leftarrow 1$                            |
|               |                 |                            |      | (Switches the main system clock to the                      |
|               |                 |                            |      | low-frequency clock for SLOW2)                              |
|               | CLR             | (SYSCR2). 7                |      | $SYSCR2 < XEN > \leftarrow 0$                               |
|               |                 |                            |      | (Turns off high-frequency oscillation)                      |
| Example2: Sw  | ritching to the | SLOW1 mode after low-frequ | ency | v clock has stabilized.                                     |
|               | SET             | (SYSCR2). 6                | ;    | SYSCR2 <xten> <math>\leftarrow</math> 1</xten>              |
|               | LD              | (TC2CR), 14H               | ;    | Sets mode for TC2                                           |
|               | LDW             | (TC2DRL), 8000H            | ;    | Sets warm-up time                                           |
|               |                 |                            |      | (Depend on oscillator accompanied)                          |
|               | DI              |                            | ;    | $IMF \leftarrow 0$                                          |
|               | SET             | (EIRE). 4                  | ;    | Enables INTTC2                                              |
|               | EI              |                            | ;    | $IMF \leftarrow 1$                                          |
|               | SET             | (TC2CR). 5                 | ;    | Starts TC2                                                  |
| PINTTC2:      | CLR             | (TC2CR). 5                 | ;    | Stops TC2                                                   |
|               | SET             | (SYSCR2). 5                | ;    | SYSCR2 <sysck> <math>\leftarrow</math> 1</sysck>            |
|               |                 |                            |      | (Switches the main system clock to the low-frequency clock) |
|               | CLR             | (SYSCR2). 7                | ;    | SYSCR2 <xen> <math>\leftarrow 0</math></xen>                |
|               |                 |                            |      | (Turns off high-frequency oscillation)                      |
|               | RETI            |                            |      |                                                             |
| VINTTC2:      | ЬŅ              | PINTTC2                    | ;    | INTTC2 vector table                                         |

#### Example 1: Switching from NORMAL2 mode to SLOW1 mode.

b. Switching from SLOW1 mode to NORMAL2 mode

First, set SYSCR2<XEN> to turn on the high-frequency oscillation. When time for stabilization (Warm-up) has been taken by the timer/counter 2 (TC2), clear SYSCR2<SYSCK> to switch the main system clock to the high-frequency clock.

Note 1: After SYSCK is cleared to "0", executing the instructions is continued by the low-frequency clock for the period synchronized with low-frequency and high-frequency clocks.



Note 2: SLOW mode can also be released by inputting low level on the RESET pin, which immediately performs the reset operation. After reset, the TMP86FM48 is placed in NORMAL1 mode.

#### Example: Switching from the SLOW1 mode to the NORMAL2 mode

| (fo      | c = 16 MHz, v | warm-up time is = 4.0 ms). |   |                                        |
|----------|---------------|----------------------------|---|----------------------------------------|
|          | SET           | (SYSCR2). 7                | ; | $SYSCR2 < XEN > \leftarrow 1$          |
|          |               |                            |   | (Starts high-frequency oscillation)    |
|          | LD            | (TC2CR), 10H               | ; | Sets mode for TC2                      |
|          |               |                            |   | (Timer mode, fc for source)            |
|          | LD            | (TC2DRH), 0F8H             | ; | Sets warm-up time                      |
|          |               |                            |   | (Depend on oscillator accompanied)     |
|          | DI            |                            | ; | $IMF \leftarrow 0$                     |
|          | SET           | (EIRE). 4                  | ; | Enables INTTC2                         |
|          | EI            |                            | ; | $IMF \leftarrow 1$                     |
|          | SET           | (TC2CR). 5                 | ; | Starts TC2                             |
| PINTTC2: | CLR           | (TC2CR). 5                 | ; | Stops TC2                              |
|          | CLR           | (SYSCR2). 5                | ; | $SYSCR2{<}SYSCK{>} \leftarrow 0$       |
|          |               |                            |   | (Switches the main system clock to the |
|          |               |                            |   | high-frequency clock)                  |
|          | RETI<br>¦     |                            |   |                                        |
| VINTTC2: | ЪŅ            | PINTTC2                    | ; | INTTC2 vector table                    |



## TOSHIBA

#### 1.5 Interrupt Control Circuit

The TMP86FM48 has a total (Reset is excluded) of 20 interrupt source: 5 externals and 15 internals. 4 of the internal sources are non-maskable interrupts, and the rest of them are maskable interrupts.

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.

|                   | Ir          | nterrupt Factors                               | Enable<br>Condition       | Interrupt<br>Latch | Vector<br>Address | Priority |
|-------------------|-------------|------------------------------------------------|---------------------------|--------------------|-------------------|----------|
| Internal/External | (Reset)     |                                                | Non-maskable              | _                  | FFFE <sub>H</sub> | High 1   |
| Internal          | INTSWI      | (Software interrupt)                           | Non-maskable              | _                  | FFFCH             | 2        |
| Internal          | INTUNDEF    | (Executed the undefined instruction interrupt) | Non-maskable              | -                  | FFFC <sub>H</sub> | 2        |
| Internal          | INTATRAP    | (Address trap interrupt)                       | Non-maskable              | IL <sub>2</sub>    | FFFA <sub>H</sub> | 2        |
| Internal          | INTWDT      | (Watchdog timer interrupt)                     | Non-maskable              | IL <sub>3</sub>    | FFF8 <sub>H</sub> | 2        |
| External          | <b>INTO</b> | (External interrupt 0)                         | $IMF \bullet EF_4 = 1$    | IL <sub>4</sub>    | FFF6 <sub>H</sub> | 5        |
| Internal          | INTTC1      | (TC1 interrupt)                                | $IMF \bullet EF_5 = 1$    | IL <sub>5</sub>    | FFF4 <sub>H</sub> | 6        |
| External          | INT1        | (External interrupt 1)                         | $IMF \bullet EF_6 = 1$    | IL <sub>6</sub>    | FFF2 <sub>H</sub> | 7        |
| Internal          | INTTBT      | (Time base timer interrupt)                    | $IMF \bullet EF_7 = 1$    | IL <sub>7</sub>    | FFF0 <sub>H</sub> | 8        |
| External          | INT2        | (External interrupt 2)                         | IMF•EF <sub>8</sub> = 1   | IL <sub>8</sub>    | FFEEH             | 9        |
| Internal          | INTTC3      | (TC3 interrupt)                                | IMF•EF <sub>9</sub> = 1   | IL <sub>9</sub>    | FFECH             | 10       |
| Internal          | INTSIO1     | (Serial interface 1 interrupt)                 | $IMF \bullet EF_{10} = 1$ | IL <sub>10</sub>   | FFEA <sub>H</sub> | 11       |
| Internal          | INTSIO2     | (Serial interface 2 interrupt)                 | IMF•EF <sub>11</sub> = 1  | IL <sub>11</sub>   | FFE8 <sub>H</sub> | 12       |
| Internal          | INTTC5      | (TC5 interrupt)                                | $IMF \bullet EF_{12} = 1$ | IL <sub>12</sub>   | FFE6 <sub>H</sub> | 13       |
| External          | INT3        | (External interrupt 3)                         | $IMF \bullet EF_{13} = 1$ | IL <sub>13</sub>   | FFE4 <sub>H</sub> | 14       |
| Internal          | INTADC      | (AD converter interrupt)                       | $IMF \bullet EF_{14} = 1$ | IL <sub>14</sub>   | FFE2 <sub>H</sub> | 15       |
|                   | Reserved    |                                                | IMF•EF <sub>15</sub> = 1  | IL <sub>15</sub>   | FFE0 <sub>H</sub> | 16       |
|                   | Reserved    |                                                | $IMF \bullet EF_{16} = 1$ | IL <sub>16</sub>   | FFBE <sub>H</sub> | 17       |
| Internal          | INTSBI      | (Serial bus interface interrupt)               | IMF•EF <sub>17</sub> = 1  | IL <sub>17</sub>   | FFBC <sub>H</sub> | 18       |
| Internal          | INTRXD      | (UART received interrupt)                      | IMF•EF <sub>18</sub> = 1  | IL <sub>18</sub>   | FFBA <sub>H</sub> | 19       |
| Internal          | INTTXD      | (UART transmitted interrupt)                   | IMF•EF <sub>19</sub> = 1  | IL <sub>19</sub>   | FFB8 <sub>H</sub> | 20       |
| Internal          | INTTC2      | (TC2 interrupt)                                | $IMF \bullet EF_{20} = 1$ | IL <sub>20</sub>   | FFB6 <sub>H</sub> | 21       |
| External          | INT5        | (External interrupt 5)                         | $IMF \bullet EF_{21} = 1$ | IL <sub>21</sub>   | FFB4 <sub>H</sub> | 22       |
|                   | Reserved    |                                                | IMF•EF <sub>22</sub> = 1  | IL <sub>22</sub>   | FFB2 <sub>H</sub> | 23       |
|                   | Reserved    |                                                | $IMF \bullet EF_{23} = 1$ | IL <sub>23</sub>   | FFB0 <sub>H</sub> | 24       |

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). For details, see 2.4 Watchdog Timer.

Note 2: To use the address trap interrupt (INTATRAP), clear WDTCR1<ATOUT> to "0" (It is set for the "Reset request" after reset is released). For details, see 2.4.5 Address Trap.



86FM48-33

(1) Interrupt latches (IL<sub>24</sub> to IL<sub>2</sub>)

An interrupt latch is provided for each interrupt source, except for a software 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. All interrupt latches are initialized to "0" during reset.

The interrupt latches are located on address  $002E_{\rm H}$ ,  $003C_{\rm H}$  and  $003D_{\rm H}$  in SFR area. Except for IL<sub>3</sub> and IL<sub>2</sub>, each latch can be cleared to "0" individually by instruction. (However, the read-modify-write instructions such as bit manipulation or operation instructions cannot be used. Interrupt request would be cleared inadequately if interrupt is requested while such instructions are executed.) Thus interrupt request can be canceled/initialized by software.

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

Note: When manipulating IL, clear IMF (to disable interrupts) beforehand.

| latches                  |                                                                                              |                                                                                                                |
|--------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
|                          | ;                                                                                            | $IMF \leftarrow 0$                                                                                             |
| (ILE), 11110011B         | ;                                                                                            | IL <sub>19</sub> , IL <sub>18</sub> ← 0                                                                        |
| (ILL), 1110100000111111B | ;                                                                                            | IL <sub>12</sub> , IL <sub>10</sub> to IL <sub>6</sub> $\leftarrow$ 0                                          |
|                          | ;                                                                                            | $IMF \leftarrow 1$                                                                                             |
| latches                  |                                                                                              |                                                                                                                |
| WA, (ILL)                | ;                                                                                            | $W \leftarrow IL_H, A \leftarrow IL_L$                                                                         |
| pt latches               |                                                                                              |                                                                                                                |
| (IL).7                   | ;                                                                                            | IL <sub>7</sub> = 1 then jump                                                                                  |
| F, SSET                  |                                                                                              |                                                                                                                |
|                          | (ILE), 11110011B<br>(ILL), 1110100000111111B<br>latches<br>WA, (ILL)<br>pt latches<br>(IL).7 | ;<br>(ILE), 11110011B ;<br>(ILL), 1110100000111111B ;<br>;<br>latches<br>WA, (ILL) ;<br>pt latches<br>(IL).7 ; |

#### (2) Interrupt enable register (EIR)

The interrupt enable register (EIR) enables and disables the acceptance of interrupts, except for the non-maskable interrupts (Software interrupt, undefined instruction interrupt, address trap interrupt and watchdog interrupt). 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  $002C_{H}$ ,  $003A_{H}$  and  $003B_{H}$  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).

a. 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. By executing return interrupt instruction [RETI/RETN], the stacked data, which was the status before interrupt acceptance, is loaded on IMF again.

The IMF is located on bit0 in EIRL (Address:  $003A_{\rm H}$  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", and maskable interrupts are not accepted until it is set to "1".

b. Individual interrupt enable flags ( $EF_{23}$  to  $EF_4$ )

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. The individual interrupt enable flags ( $EF_{23}$  to  $EF_4$ ) are located on EIRE, EIRL to EIRH (address: 002CH, 003AH to 003BH in SFR), and can be read and written by an instruction. During reset, all the individual interrupt enable flags ( $EF_{23}$  to  $EF_4$ ) are not accepted until they are set to "1".

Note: Before manipulating EF, be sure to clear IMF (Interrupt disabled). Then set IMF newly again after operating on the interrupt enables flag (EF). Normally, IMF is clear to "0" automatically on service routine. When IMF is set to "1" for using a multiple interrupt on service routine, be sure to process as is the case with EF.

Example 1: Enables interrupts individually and sets IMF

|                | DI            |                    | ; | $IMF \leftarrow 0$                                                                               |
|----------------|---------------|--------------------|---|--------------------------------------------------------------------------------------------------|
|                | LD            | (EIRE), 00001100B  | ; | EF <sub>19</sub> , EF <sub>18</sub> ← "1"                                                        |
|                | LDW           | (EIRL),            | ; | EF <sub>14</sub> , EF <sub>13</sub> , EF <sub>11</sub> , EF <sub>7</sub> , EF <sub>5</sub> ← "1" |
|                | 1             | 0110100010100000B  |   | Note: IMF is not set.                                                                            |
|                | Εİ            |                    | ; | $IMF \leftarrow "1"$                                                                             |
| Example 2: C o | compiler desc | cription example   |   |                                                                                                  |
|                | unsigned i    | nt _io (3AH) EIRL; | ; | /* 3AH shows EIRL address */                                                                     |
|                | _DI ( );      |                    |   |                                                                                                  |
|                | EIRL = 101    | 00000B;            |   |                                                                                                  |
|                |               |                    |   |                                                                                                  |
|                | _ĖI();        |                    |   |                                                                                                  |
|                |               |                    |   |                                                                                                  |



Figure 1.5.2 Interrupt Latch (IL), Interrupt Enable Registers (EIR)

#### 1.5.1 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 8-machine cycles (4  $\mu$ s at 8.0 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 1.5.3 shows the timing chart of interrupt acceptance processing.

(1) Interrupt acceptance processing is packaged as follows.

- 1. The interrupt master enable flag (IMF) is cleared to "0" in order to disable the acceptance of any following interrupt.
- 2. The interrupt latch (IL) for the interrupt source accepted is cleared to "0".
- 3. 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 PSW + IMF, PCH, PCL. Meanwhile, the stack pointer (SP) is decremented by 3.
- 4. The entry address (Interrupt vector) of the corresponding interrupt service program, loaded on the vector table, is transferred to the program counter.
- 5. 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.



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



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.

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 shorter compared with length between interrupt requests; otherwise the status cannot be recovered as non-maskable interrupt would simply nested.

(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 methods are used to save/restore the general-purpose registers.

a. Using PUSH and POP instructions

To save only a specific register, PUSH and POP instructions are available.



b. Using data transfer instructions

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





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

(3) Interrupt return

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



As for Address Trap interrupt (INTARTAP), it is required to alter stacked data for program counter (PC) to restarting address, during interrupt service program. Otherwise returning interrupt causes INTATRAP again. When interrupt acceptance processing has completed, stacked data for PC<sub>L</sub> and PC<sub>H</sub> are located on address (SP + 1) and (SP + 2) respectively.

Note: If [RETN] is executed with the above data unaltered, the program returns to the address trap area and INTATRAP occurs again.

| Example 1: Re | eturning from  | address trap interrupt (INTAT    | RAP   | ) service program                     |
|---------------|----------------|----------------------------------|-------|---------------------------------------|
| PINTxx:       | POP            | WA                               | ;     | Recover SP by 2                       |
|               | LD             | WA, Return Address               | ;     |                                       |
|               | PUSH           | WA                               | ;     | Alter stacked data                    |
|               | (interrupt p   | rocessing)                       |       |                                       |
|               | RETN           |                                  | ;     | RETURN                                |
|               |                |                                  |       |                                       |
| Example 2: Re | estarting with | out returning interrupt (In this | case, | , PSW (includes IMF) before interrupt |
| ac            | ceptance is c  | liscarded.)                      |       |                                       |
| PINTxx        | INC            | SP                               | ;     | Recover SP by 3                       |
|               | INC            | SP                               | ;     |                                       |
|               | INC            | SP                               | ;     |                                       |
|               | (interrupt p   | rocessing)                       |       |                                       |
|               | LD             | EIRL, data                       | ;     | Set IMF to "1" or clear it to "0"     |
|               | JP             | Restart Address                  | ;     | Jump into restarting address          |
|               |                |                                  |       |                                       |

Note: It is recommended that stack pointer be return to rate before INTATRAP (increment 3 times), if return interrupt instruction [RETN] is not utilized during interrupt service program under INTATRAP (such as Example 2).

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.

## 1.5.2 Software Interrupt (INTSW)

Executing the [SWI] instruction generates a software interrupt and immediately starts interrupt processing (INTSW is highest prioritized interrupt).

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

(1) Address error detection

 $FF_H$  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  $FF_H$  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  $FF_H$  to unused areas of the program memory. Address trap reset is generated in case that an instruction is fetched from RAM or SFR areas.

(2) Debugging

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

## 1.5.3 Undefined Instruction Interrupt (INTUNDEF)

Taking code which is not defined as authorized instruction for instruction causes INTUNDEF. INTUNDEF is generated when the CPU fetches such a code and tries to execute it. INTUNDEF is accepted even if non-maskable interrupt is in process. Contemporary process is broken and INTUNDEF interrupt process starts, soon after it is requested.

Note: The undefined instruction interrupt (INTUNDEF) forces CPU to jump into vector address, as software interrupt (SWI) does.

## 1.5.4 Address Trap Interrupt (INTATRAP)

Fetching instruction from unauthorized area for instructions (Address trapped area) causes reset-output or address trap interrupt (INTATRAP). INTATRAP is accepted even if non-maskable interrupt is in process. Contemporary process is broken and INTATRAP interrupt process starts, soon after it is requested.

Note: The operating mode under address trapped, whether to be reset-output or interrupt processing, is selected on watchdog timer control register (WDTCR).

## 1.5.5 External Interrupts

The TMP86FM48 has five 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 INT3. INT0/P00 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, noise reject control and  $\overline{INT0}$  /P00 pin function selection are performed by the external interrupt control register (EINTCR).

| Source | Pin  | Secondary<br>Function Pin | Enable Conditions                           | Edge              | Digital Noise Reject                                                                                                                                                                                                                                                                                  |
|--------|------|---------------------------|---------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INTO   | ĪNTO | P00                       | IMF = 1, EF <sub>4</sub> = 1,<br>INT0EN = 1 | Falling edge      | Pulses of less than 2/fc [s] are eliminated as<br>noise. Pulses of 7/fc [s] or more are<br>considered to be signals. In the SLOW or the<br>SLEEP mode, pulses of less than 1/fs [s] are<br>eliminated as noise. Pulses of 3.5/fs [s] or<br>more are considered to be signals.                         |
| INT1   | INT1 | P01                       | IMF•EF <sub>6</sub> = 1                     | Falling edge      | Pulses of less than 15/fc or 63/fc [s] are<br>eliminated as noise. Pulses of 49/fc or 193/fc<br>[s] or more are considered to be signals.<br>In the SLOW or the SLEEP mode, pulses of<br>less than 1/fs [s] are eliminated as noise.<br>Pulses of 3.5/fs [s] or more are considered to<br>be signals. |
| INT2   | INT2 | P02                       | IMF∙EF <sub>8</sub> = 1                     | or<br>Rising edge | Pulses of less than 7/fc [s] are eliminated as<br>noise. Pulses of 25/fc [s] or more are<br>considered to be signals.                                                                                                                                                                                 |
| INT3   | INT3 | P14/TC3                   | IMF•EF <sub>13</sub> = 1                    |                   | In the SLOW or the SLEEP mode, pulses of<br>less than 1/fs [s] are eliminated as noise.<br>Pulses of 3.5/fs [s] or more are considered to<br>be signals.                                                                                                                                              |
| INT5   | ĪNT5 | P20/ STOP                 | IMF•EF <sub>21</sub> = 1                    | Falling edge      | Pulses of less than 2/fc [s] are eliminated as<br>noise. Pulses of 7/fc [s] or more are<br>considered to be signals. In the SLOW or the<br>SLEEP mode, pulses of less than 1/fs [s] are<br>eliminated as noise. Pulses of 3.5/fs [s] or<br>more are considered to be signals.                         |

| Table 1.5.2 | External | Interrupts |
|-------------|----------|------------|
|-------------|----------|------------|

Note 1: If a noiseless signal is input to the external interrupt pin in the NORMAL 1/2 or IDLE 1/2 mode, the maximum time from the edge of input signal until the IL is set is as follows:

- (1) INT1 pin 55/fc [s] (INT1NC = 1), 199/fc [s] (INT1NC = 0)
- (2) INT2, INT3 pin 31/fc [s]

Note 2: Even if the falling edge of  $\overline{INT0}$  pin input is detected at INT0EN = 0, the interrupt latch IL<sub>4</sub> is not set.

Note 3: When data changed and did a change of I/O when used external interrupt ports as a normal ports, interrupt request signal occurs incorrectly. Handling of prohibition of interrupt enable register (EIR) is necessary.

Note 4: The maximum time from modifying INT1NC until a noise reject time is changed is  $2^{6}$ /fc.

| External interr<br>EINTCR<br>(0037 <sub>H</sub> ) | Tupt control re<br>7<br>INT1NC IN                                                                                                                                                  | <u>6 5 4 3</u>                    | 2 1 0                                                                                                                |         |  |  |  |
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------|---------|--|--|--|
|                                                   | INT1NC                                                                                                                                                                             | 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 |         |  |  |  |
|                                                   | INT0EN                                                                                                                                                                             | P00/INT0 pin configuration        | 0: P00 input/output port<br>1: INTO pin (Port P00 should be set to an input mode)                                    | R/W     |  |  |  |
|                                                   | INT3ES<br>INT2ES<br>INT1ES                                                                                                                                                         | INT3 to INT1 edge select          | 0: Rising edge<br>1: Falling edge                                                                                    |         |  |  |  |
|                                                   | Note 1: fc                                                                                                                                                                         | : High-frequency clock [Hz], *: D | on't care                                                                                                            |         |  |  |  |
|                                                   | Note 2: W                                                                                                                                                                          | hen the system clock frequency    | is switched between high and low or 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). |                                   |                                                                                                                      |         |  |  |  |

#### Figure 1.5.5 External Interrupt Control Register

## 1.6 Reset Circuit

The TMP86FM48 has four types of reset generation procedures: an external reset input, an address trap reset, a watchdog timer reset and a system clock reset. Table 1.6.1 shows on-chip hardware initialization by reset action.

Since the reset circuit has an 11-stage counter for generation of flash reset, which is the reset counter for stabilizing of the power supply for Flash, the reset period is  $2^{10}$ /fc [s] (64 µs at 16.0 MHz).

Because the malfunction reset circuit such as watchdog timer reset, address trap reset and system clock reset is not initialized when power is turned on, the reset operation occur for the maximum 24/fc [s] (1.5  $\mu$ s at 16.0 MHz).

Therefore, the maximum reset period is  $24/\text{fc} [s] + 2^{10}/\text{fc} [s]$  (65.5 µs at 16.0 MHz). Table 1.6.1 shows on-chip hardware initialization by reset action.

| On-chip Hardware                                  |               | Initial Value        | On-chip Hardware                | Initial Value                  |  |
|---------------------------------------------------|---------------|----------------------|---------------------------------|--------------------------------|--|
| Program counter                                   | (PC)          | (FFFE <sub>H</sub> ) |                                 |                                |  |
| Stack pointer                                     | (SP)          | Not initialized      | Prescaler and Divider of timing | 0                              |  |
| General-purpose registers<br>(W, A, B, C, D, E, H | H, L, IX, IY) | Not initialized      | generator                       | 0                              |  |
| Jump status flag                                  | (JF)          | Not initialized      | Watchdog timer                  | Enable                         |  |
| Zero flag                                         | (ZF)          | Not initialized      |                                 |                                |  |
| Carry flag                                        | (CF)          | Not initialized      |                                 | Refer to I/O port<br>circuitry |  |
| Half carry flag                                   | (HF)          | Not initialized      |                                 |                                |  |
| Sign flag                                         | (SF)          | Not initialized      | Output latches of I/O ports     |                                |  |
| Overflow flag                                     | (VF)          | Not initialized      |                                 |                                |  |
| Interrupt master enable flag                      | (IMF)         | 0                    |                                 |                                |  |
| Interrupt individual enable flags                 | (EF)          | 0                    | Control registers               | Refer to each of               |  |
| Interrupt latches                                 | (IL)          | 0                    | Control registers               | control register               |  |
|                                                   |               |                      | RAM                             | Not initialized                |  |

Table 1.6.1 Initializing Internal Status by Reset Action

## 1.6.1 External Reset Input

The RESET pin contains a Schmitt trigger (Hysteresis) with an internal pull-up resistor. When the RESET pin is held at "L" level for at least 3 machine cycles (12/fc [s]) with the power supply voltage within the operating voltage range and oscillation stable, a reset is applied and the internal state is initialized.

When  $2^{10}/\text{fc}$  (65.5 µs at 16 MHz) period passes after the RESET pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFE<sub>H</sub> to FFFF<sub>H</sub>.





## 1.6.2 Address-Trap-Reset

If the CPU should start looping for some cause such as noise and an attempt be made to fetch an instruction from the on-chip RAM (when WDTCR1<ATAS> is set to "1") or the SFR area, address-trap-reset and the Flash reset will be generated. The reset time is maximum 24/fc [s] +  $2^{10}$ /fc [s] (65.5 µs at 16.0 MHz).



Figure 1.6.2 Address-Trap-Reset

Note: The operating mode under address trapped is alternative of reset or interrupt. Address trap or no address trap can be selected by WDTCR1<ATAS> for the internal RAM.

## 1.6.3 Watchdog Timer Reset

Refer to Section "2.4 Watchdog Timer".

## 1.6.4 System-Clock-Reset

If the condition as follows is detected, the system clock reset occurs automatically to prevent dead lock of the CPU. (The oscillation is continued without stopping.)

- In case of clearing SYSCR2<XEN> and SYSCR2<XTEN> simultaneously to "0".
- In case of clearing SYSCR2<XEN> to "0", when the SYSCR2<SYSCK> is "0".
- In case of clearing SYSCR2<XTEN> to "0", when the SYSCR2<SYSCK> is "1".

When the system clock reset is generated, the flash reset is also generated. Therefore, the maximum reset period is 24/fc [s] +  $2^{10}$ /fc [s] (65.5 µs at 16.0 MHz).

# 2. On-Chip Peripherals Functions

# 2.1 Special Function Register (SFR)

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

#### Figure 2.1.1 to

Figure 2.1.2 indicate the special function register (SFR) and data buffer register (DBR) for TMP86FM48.

| Address | Read                           | Write                | Address       | Read                          | Write                          |  |
|---------|--------------------------------|----------------------|---------------|-------------------------------|--------------------------------|--|
| 0000н   | P0DR (P0 Port outpu            | ut latch)            | 0020H         | TC1DRAL (Time                 | er register 1A)                |  |
| 01      | P1DR (P1 Port output latch)    |                      |               | TC1DRAH (Time                 | er register 1A)                |  |
| 02      | P2DR (P2 Port output           | ut latch)            | 22            | TC1DRBL (Time                 | er register 1B)                |  |
| 03      | P3DR (P3 Port outpu            | ut latch)            | 23            | TC1DRBH (Timer register 1B)   |                                |  |
| 04      | Reserved                       |                      | 24            | TC2DRL (Timer register 2)     |                                |  |
| 05      | P5DR (P5 Port output           | ut latch)            | 25            | TC2DRH (Timer register 2)     |                                |  |
| 06      | P6DR (P6 Port output           | ut latch)            | 26            | ADCDR2 (AD result register 2) |                                |  |
| 07      | P7DR (P7 Port output           | ut latch)            | 27            | ADCDR1 (AD result register 1) |                                |  |
| 08      | P8DR (P8 Port outpu            | ut latch)            | 28            | P6CR2 (P6 Port                | input control)                 |  |
| 09      | Reserved                       |                      | 29            | Reser                         | ved                            |  |
| 0A      | P0OUTCR (P0 Port out           | out control)         | 2A            | P3OUTCR (P3 Po                | rt output control)             |  |
| 0B      | P1OUTCR (P1 Port out           | out control)         | 2B            | Reser                         | ved                            |  |
| 0C      | P6CR1 (P6 Port input/ou        | tput control)        | 2C            | EIRE (Interrupt e             | nable register)                |  |
| 0D      | P5OUTCR (P5 Port out           | out control)         | 2D            | Reser                         | ved                            |  |
| 0E      | ADCCR1 (AD control register 1) |                      | 2E            | IL <sub>E</sub> (Interru      | pt latch)                      |  |
| 0F      | ADCCR2 (AD control register 2) |                      | 2F            | Reserved                      |                                |  |
| 10      | TC3DRA (Timer register 3A)     |                      | 30            | Reser                         | ved                            |  |
| 11      | C3DRB (Timer register 3B)      |                      | 31            | Reser                         | ved                            |  |
| 12      | TC3CR (Timer Counter           | 3 control)           | 32            | Reserved                      |                                |  |
| 13      | TC2CR (Timer Counter           | 2 control)           | 33            | Reserved                      |                                |  |
| 14      | TC5CR (Timer Counter           | 5 control)           | 34            |                               | NDTCR1 (Watchdog timer control |  |
| 15      | TC5DR (Timer regi              | ster 5)              | 35            |                               | NDTCR2 (Watchdog timer control |  |
| 16      | Reserved                       |                      | 36            | TBTCR (TBT/TG                 | /DVO control)                  |  |
| 17      | SIO1CR (SIO1 co                | ntrol)               | 37            | EINTCR (External              | interrupt control)             |  |
| 18      | SIO1SR (SIO1 status)           |                      | 38            | SYSCR1 (Syste                 | em control 1)                  |  |
| 19      | SIO1BUF (SIO1 data             | a buffer)            | 39            | SYSCR2 (Syste                 | em control 2)                  |  |
| 1A      | Reserved                       |                      | 3A            | EIRL (Interrupt e             | nable register)                |  |
| 1B      | SIO2CR (SIO2 co                | ntrol)               | 3В            | EIRH (Interrupt e             | nable register)                |  |
| 1C      | SIO2SR (SIO2 status)           |                      | зC            | ILL (Interru                  | pt latch)                      |  |
| 1D      | SIO2BUF (SIO2 data             | a buffer)            | 3D            | IL <sub>H</sub> (Interru      | ipt latch)                     |  |
| 1E      | Reserved                       |                      | 3E            | Reser                         | ved                            |  |
| 1F      | TC1CR (Timer counter           | 1 control)           | 3F            | PSW (Program                  | status word)                   |  |
|         | Note 1: Do not access rese     | erved areas by the   | orogram.      |                               |                                |  |
|         | Note 2: -: Cannot be acces     | ssed.                |               |                               |                                |  |
|         | Note 3: Write-only registers   | s and interrupt late | hes cannot us | e the read-modify-write instr | uctions (Bit manipulation      |  |
|         | , ,                            |                      |               | ation instructions such as AN | · ·                            |  |

Figure 2.1.1 The Special Function Register (SFR) for TMP86FM48 (1/2)

| Address   | Deed                                                   | 10/-21-                         |
|-----------|--------------------------------------------------------|---------------------------------|
| 1F80H     | Read                                                   | Write                           |
| 1 30H     | Kesen                                                  | veu                             |
| ı<br>D8   | Reserv                                                 |                                 |
| D9        |                                                        | SBICRA (SBI control 1)          |
| D3<br>DA  | -<br>SBIDBR (S <u>B</u> I                              |                                 |
| DB        |                                                        | I2CAR (I2C address)             |
| DC        | SBISR (SBI status)                                     |                                 |
| DD        |                                                        | UARTCR1 (UART control 1)        |
| DE        |                                                        | UARTCR2 (UART control 2)        |
| DE        | RDBUF                                                  |                                 |
| 51        | (UART received data buffer)                            | -                               |
| E0        |                                                        | SH control)                     |
| =0<br>E1  | EEPSR (FLASH status)                                   | _                               |
| E2        | EEPEVA (FLASH write e                                  | mulation time control)          |
| E3        |                                                        | /ed                             |
| E4        | P2OUTCR (P2 Por                                        |                                 |
| = .<br>E5 | P7CR1 (P7 Port inp                                     |                                 |
| E6        | P7CR2 (P7 Port                                         |                                 |
| E7        | P8CR (P8 Port inpu                                     |                                 |
| E8        | Reserv                                                 |                                 |
| E9        |                                                        | /ed                             |
| EA        | Resen                                                  |                                 |
| EB        | Reserv                                                 |                                 |
| EC        |                                                        | /ed                             |
| ED        | P0PRD (P0 Terminal input)                              |                                 |
| EE        | DADDD (D4 Terrein el insurt)                           |                                 |
| EF        |                                                        |                                 |
| F0        | P2PRD (P2 Terminal input)<br>P3PRD (P3 Terminal input) |                                 |
| F1        |                                                        |                                 |
| F1<br>F2  | P5PRD (P5 Terminal input)                              | /ed                             |
| F2<br>F3  |                                                        |                                 |
| F3<br>F4  |                                                        | ved                             |
| F4<br>F5  | Resen                                                  |                                 |
| F5<br>F6  | Resen                                                  |                                 |
| F0<br>F7  | Reserve                                                |                                 |
| F7<br>F8  | Resen                                                  |                                 |
| F8<br>F9  | Reserve                                                |                                 |
| F9<br>FA  | Resen                                                  |                                 |
|           | Reserve                                                |                                 |
| FB        | Reserve                                                |                                 |
| FC        | Reserv                                                 |                                 |
| FD        | Reserved                                               |                                 |
| FE        |                                                        | STOPCR (Key-on wake-up control) |
| FF        | Reserv                                                 | /ed                             |

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



# 2.2 I/O Ports

The TMP86FM48 has 8 parallel input/output ports (54 pins) as follows.

|         | Primary Function | Secondary Functions                                                                                 |
|---------|------------------|-----------------------------------------------------------------------------------------------------|
| Port P0 | 8-bit I/O port   | External interrupt input, serial interface input/output, UART input/output and Timer/Counter input. |
| Port P1 | 8-bit I/O port   | External interrupt input, serial interface input/output and Timer/Counter input/output.             |
| Port P2 | 3-bit I/O port   | Low-frequency resonator connections, external interrupt input, STOP mode release signal input.      |
| Port P3 | 8-bit I/O port   |                                                                                                     |
| Port P5 | 3-bit I/O port   | Divider output, Timer/Counter output and Serial Bus Interface input/output.                         |
| Port P6 | 8-bit I/O port   | Analog input and STOP mode release signal input.                                                    |
| Port P7 | 8-bit I/O port   | Analog input.                                                                                       |
| Port P8 | 8-bit I/O port   |                                                                                                     |

Each output port contains a latch, which holds the output data. All input ports do not have latches, so the external input data should be externally held until the input data is read from outside or reading should be performed several times before processing. Figure 2.2.1 shows input/output timing examples.

External data is read from an I/O port in the S1 state of the read cycle during execution of the read instruction. This timing cannot be recognized from outside, so that transient input such as chattering must be processed by the program.

Output data changes in the S2 state of the write cycle during execution of the instruction which writes to an I/O port.



Figure 2.2.1 Input/Output Timing (Example)

## 2.2.1 Port P0 (P07 to P00)

Port P0 is an 8-bit input/output port which is also used as an external interrupt input, serial interface input/output, timer/counter input and UART input/output. It can be selected whether output circuit of P0 port is CMOS output or a sink open drain individually, by setting the output circuit control (POOUTCR). When a corresponding bit of POOUTCR is cleared to "0", the output circuit is selected to a sink open drain and when a corresponding bit of POOUTCR is set to "1", the output circuit is selected to a CMOS output.

When used as an input port or a secondary function input (External interrupt input, serial interface input, timer/counter input or UART input), the respective output latch (PODR) should be set to "1" and its corresponding POOUTCR bit should be cleared to "0".

When used as a secondary function output (Serial interface output or UART output), the respective P0DR should be set to "1".

During reset, the P0DR is initialized to "1" and P0OUTCR is initialized to "0".

P0 port output latch (P0DR) and P0 port terminal input (P0PRD) are located on their respective address. When read the output latch data, the P0DR should be read and when read the terminal input data, the P0PRD register should be read.



Figure 2.2.2 Port 0

#### 2.2.2 Port P1 (P17 to P10)

Port P1 is a 8-bit input/output port which is also used as an external interrupt input, serial interface input/output and timer/counter input/output. It can be selected whether output circuit of P1 port is CMOS output or a sink open drain individually, by setting the output circuit control (P1OUTCR). When a corresponding bit of P1OUTCR is cleared to "0", the output circuit is selected to a sink open drain and when a corresponding bit of P1OUTCR is set to "1", the output circuit is selected to a CMOS output.

When used as an input port or a secondary function input (External interrupt input, serial interface input, timer/counter input), the respective output latch (P1DR) should be set to "1" and its corresponding P1OUTCR bit should be cleared to "0".

When used as a secondary function output (Serial interface output or timer/counter output), the respective P1DR should be set to "1".

During reset, the P1DR is initialized to "1" and P1OUTCR is initialized to "0".

P1 port output latch (P1DR) and P1 port terminal input (P1PRD) are located on their respective address. When read the output latch data, the P1DR should be read and when read the terminal input data, the P1PRD register should be read.



Figure 2.2.3 Port 1

## 2.2.3 Port P2 (P22 to P20)

Port P2 is a 3-bit input/output port. It is also used as an external interrupt, a STOP mode release signal input, and low-frequency crystal oscillator connection pins. It can be selected whether output circuit of P2 port is CMOS (P21 and P22 have a pull-up resistor) output or a sink open drain individually, by setting the output circuit control (P2OUTCR). When a corresponding bit of P2OUTCR is cleared to "0", the output circuit is selected to a sink open drain and when a corresponding bit of P2OUTCR is set to "1", the output circuit is selected to a CMOS output. (In case of P21 and P22, the pull-up resistor is connected.)

When used as an input port or an external interrupt input, the respective output latch (P2DR) should be set to "1".

During reset, the P2DR initialized to "1" and P2OUTCR is initialized to "0".

A low-frequency crystal oscillator (32.768 kHz) is connected to pins P21 (XTIN) and P22 (XTOUT) in the dual-clock mode. In the single-clock mode, pins P21 and P22 can be used as normal input/output ports.

It is recommended that pin P20 should be used as an external interrupt input, a STOP mode release signal input, or an input port. If it is used as an output port, the interrupt latch is set on the falling edge of the output pulse.

P2 port output latch (P2DR) and P2 port terminal input (P2PRD) are located on their respective address. When read the output latch data, the P2DR should be read and when read the terminal input data, the P2PRD register should be read.

If a read instruction is executed for port P2DR, P2OUTCR and P2PRD, read data of bits 7 to 3 are unstable.



Figure 2.2.4 Port 2 (P21 and P22)



Figure 2.2.5 Port 2 (P20)

## 2.2.4 Port P3 (P37 to P30)

Port P3 is an 8-bit input/output port. It can be selected whether output circuit of P3 port is CMOS output or a sink open drain individually, by setting P3OUTCR. (N-ch high current output) When a corresponding bit of P3OUTCR is cleared to "0", the output circuit is selected to a sink open drain and when a corresponding bit of P3OUTCR is set to "1", the output circuit is selected to a CMOS output.

When used as an input port, the respective output latch (P3DR) should be set to "1" and its corresponding P3OUTCR bit should be cleared to "0".

During reset, the P3DR is initialized to "1", and the P3OUTCR is initialized to "0".

P3 port output latch (P3DR) and P3 port terminal input (P3PRD) are located on their respective address. When read the output latch data, the P3DR should be read and when read the terminal input data, the P3PRD register should be read.



Figure 2.2.6 Port 3

## 2.2.5 Port P5 (P52 to P50)

Port P5 is an 3-bit input/output port which is also used as a timer/counter output, divider output and serial bus interface input/output. (N-ch high current output) It can be selected whether output circuit of P5 port is CMOS output or a sink open drain individually, by setting the output circuit control (P5OUTCR). When a corresponding bit of P5OUTCR is cleared to "0", the output circuit is selected to a sink open drain and when a corresponding bit of P5OUTCR is set to "1", the output circuit is selected to a CMOS output.

When used as an input port or a serial bus interface input/output, the respective output latch (P5DR) should be set to "1" and its corresponding P5OUTCR bit should be cleared to "0".

When used as a secondary function output (Timer/counter output or divider output), the respective P5DR should be set to "1".

When used as a serial bus interface input/output, P5DR of P50 and P51 should be set to "1" and P50UTCR of P50 and P51 should be cleared to "0" as a sink open drain output.

During reset, the P5DR is initialized to "1" and P5OUTCR is initialized to "0".

P5 port output latch (P5DR) and P5 port terminal input (P5PRD) are located on their respective address. When read the output latch data, the P5DR should be read and when read the terminal input data, the P5PRD register should be read.

If a read instruction is executed for P5DR, P5OUTCR and P5PRD, read data of bits 7 to 3 are unstable.



Figure 2.2.7 Port 5

#### 2.2.6 Port P6 (P67 to P60)

Port P6 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit. Port P6 is also used as an analog input and key-on wake-up input. Input/output mode is specified by the P6 control register (P6CR1). P6 port input is controlled by the input control register (P6CR2).

When used as an output port, respective P6CR1 should be set to "1".

When used as an input port, respective P6CR1 should be cleared to "0" and respective P6CR2 should be set to "1".

When used as an analog input, respective P6CR2 should be cleared to "0" after respective P6CR1 is cleared to "0".

When used as a key on wake up input, respective STOP kEN<STOPCR> should be set to "1". (k = 3 to 0)

During reset, the P6CR1 and P6DR are initialized to "0", and the P6CR2 is initialized to "1". Table 2.2.1 and Table 2.2.2 show a P6 state.

| P6CR1 | P6CR2 | P6DR | P6DR Read          | Output | Remark      |
|-------|-------|------|--------------------|--------|-------------|
| 0     | 0     | *    | "0"                | High-Z | _           |
| 0     | 1     | *    | Terminal input     | High-Z | Input mode  |
| 1     | *     | 0    | "0" (Output latch) | Low    | Output mode |
| 1     | *     | 1    | "1" (Output latch) | High   | Output mode |

Table 2.2.1 P63 to P60 State

\*: Don't care.

| Table 222 | P67 to P64 State |
|-----------|------------------|
|           |                  |

| STOPkEN | P6CR1 | P6CR2 | P6DR | P6DR read          | Output | Remark         |
|---------|-------|-------|------|--------------------|--------|----------------|
| 0       | 0     | 0     | *    | "0"                | High-Z | _              |
| 0       | 0     | 1     | *    | Terminal input     | High-Z | Input mode     |
| 0       | 1     | *     | 0    | "0" (Output latch) | Low    | Output mode    |
| 0       | 1     | *     | 1    | "1" (Output latch) | High   | Output mode    |
| 1       | *     | *     | *    | Terminal input     | High-Z | Key on wake up |

\*: Don't care.

Note: STOPkEN is bit7 to 4 in STOPCR.





| Analog input<br>AINDS<br>SAIN<br>STOPKEN<br>P6CR2j D Q P6CR2j input<br>P6CR1j D Q P6CR1j input<br>P6CR1j input<br>STOPk input<br>STOPk input<br>Data input (P6DR)<br>Data output (P6DR)                                                                                                                                                                                                                                                           | in ADCCR1 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| 7         6         5         4         3         2         1         0           P6DR         P67         P66         P65         P64         P63         P62         P61         P60           (0006H)         AIN07         AIN06         AIN05         AIN04         AIN03         AIN02         AIN01         AIN00         (Initial value: 0000 C           R/W         STOP3         STOP2         STOP1         STOP0 </td <td>0000)</td> | 0000)     |
| P6CR1<br>(000C <sub>H</sub> ) (Initial value: 0000 C                                                                                                                                                                                                                                                                                                                                                                                              | 0000)     |
| P6CR1         Port P6 I/O control         0: Input mode or Analog input           (Set for each bit individually)         1: Output mode                                                                                                                                                                                                                                                                                                          | R/W       |
| P6CR2<br>(0028 <sub>H</sub> ) (Initial value: 1111 /                                                                                                                                                                                                                                                                                                                                                                                              | 1111)     |
| P6CR2         Port P6 input control         0: Input disable           (Set for each bit individually)         1: Input enable                                                                                                                                                                                                                                                                                                                    | R/W       |
| Note 1: Do not set output mode to pin which is used for an analog input.<br>Note 2: If both P6CR1 and P6CR2 are cleared to "0", the read value of P6DR is always "0".                                                                                                                                                                                                                                                                             |           |

Figure 2.2.9 Port 6 (P67 to P64)

## 2.2.7 Port P7 (P77 to P70)

Port P7 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit. Port P7 is also used as an analog input. Input/output mode is specified by the P7 control register (P7CR1). P7 port input is controlled by the input control register (P7CR2).

When used as an output port, respective P7CR1 should be set to "1".

When used as an input port, respective P7CR1 should be cleared to "0" and respective P7CR2 should be set to "1".

When used as an analog input, respective P7CR2 should be cleared to "0" after respective P7CR1 is cleared to "0".

During reset, the P7CR1 and P7DR are initialized to "0", and the P7CR2 is initialized to "1". Table 2.2.3 shows a P7 state.

| P7CR1 | P7CR2 | P7DR | P7DR Read          | Output | Remark      |
|-------|-------|------|--------------------|--------|-------------|
| 0     | 0     | *    | "0"                | High-Z | _           |
| 0     | 1     | *    | Terminal input     | High-Z | Input mode  |
| 1     | *     | 0    | "0" (Output latch) | Low    | Output mode |
| 1     | *     | 1    | "1" (Output latch) | High   | Output mode |

Table 2.2.3 P7 Port State

\*: Don't care.



Figure 2.2.10 Port 7

## 2.2.8 Port P8 (P87 to P80)

Port P8 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit. Input/output mode is specified by the P8 control register (P8CR).

When used as an output port, respective P8CR should be set to "1".

When used as an input port, respective  $\ensuremath{\text{P8CR}}$  should be cleared to "0".

During reset, the P8CR and P8DR are initialized to "0". Table 2.2.4 shows a P8 state.

| P8CR | P8DR | P8DR read          | Output | Remark      |  |  |  |
|------|------|--------------------|--------|-------------|--|--|--|
| 0    | *    | Terminal input     | High-Z | Input mode  |  |  |  |
| 1    | 0    | "0" (Output latch) | Low    | Output mode |  |  |  |
| 1    | 1    | "1" (Output latch) | High   | Output mode |  |  |  |
|      |      |                    |        |             |  |  |  |

Table 2.2.4 P8 Port State

\*: Don't care.



Figure 2.2.11 Port 8

# 2.3 Time Base Timer (TBT)

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

An INTTBT is generated on the first falling edge of source clock (The divider output of the timing generator) after the 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 2.3.1 (b)).

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



Figure 2.3.1 Time Base Timer

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

| LD  | (TBTCR), 00000010B | ; TBTCK ← 010          |
|-----|--------------------|------------------------|
| LD  | (TBTCR), 00001010B | ; TBTEN $\leftarrow$ 1 |
| DI  |                    | ; IMF ← 0              |
| SET | (EIRL). 6          |                        |

| TBTCR                | 7                                                                                | 6 5             | 4       | 3     | 2       | 1                  | 0                  |          |                       |     |                  |  |
|----------------------|----------------------------------------------------------------------------------|-----------------|---------|-------|---------|--------------------|--------------------|----------|-----------------------|-----|------------------|--|
| (0036 <sub>H</sub> ) | (DVOEN)                                                                          | (DVOCK)         | (DV7CK) | TBTEN |         | TBTCK              | 1                  | (Init    | ial value: 0000 0000) |     |                  |  |
|                      |                                                                                  |                 |         |       |         |                    |                    |          |                       |     |                  |  |
|                      | TBTEN                                                                            | Time base time  | r       | 0:    | Disable |                    |                    |          |                       |     |                  |  |
|                      | IDILIN                                                                           | enable/disable  |         | 1:    | Enable  |                    |                    |          |                       |     |                  |  |
|                      |                                                                                  |                 |         |       | NO      | RMAL1/2,           | IDLE1/2 M          | ode      | SLOW, SLEEP Mode      |     |                  |  |
|                      |                                                                                  |                 |         |       |         |                    | V DV               | /7CK = 0 | DV7CK :               | = 1 | SLOW, SLEEP MODE |  |
|                      |                                                                                  |                 |         | 00    |         | fc/2223            | fs/215             |          | fs/2 <sup>15</sup>    |     |                  |  |
|                      |                                                                                  |                 |         | 00    |         | fc/2 <sup>21</sup> | fs/2 <sup>13</sup> |          | fs/2 <sup>13</sup>    | R/W |                  |  |
|                      | твтск                                                                            | Time base time  | •       | 01    |         | fc/2 <sup>16</sup> | fs/2 <sup>8</sup>  |          | -                     |     |                  |  |
|                      |                                                                                  | frequency selec | rt [Hz] | 01    |         | fc/2 <sup>14</sup> | fs/2 <sup>6</sup>  |          | -                     |     |                  |  |
|                      |                                                                                  |                 |         | 10    |         | fc/2 <sup>13</sup> | fs/2 <sup>5</sup>  |          | -                     |     |                  |  |
|                      |                                                                                  |                 |         | 10    |         | fc/2 <sup>12</sup> | fs/2 <sup>4</sup>  |          | -                     |     |                  |  |
|                      |                                                                                  |                 |         | 11    | 0       | fc/2 <sup>11</sup> | fs/2 <sup>3</sup>  |          | -                     |     |                  |  |
|                      |                                                                                  |                 |         | 11    | 1       | fc/29              | fs/2               |          | _                     |     |                  |  |
|                      | Note: fc: High-frequency clock [Hz], fs: Low-frequency clock [Hz], *: Don't care |                 |         |       |         |                    |                    |          |                       |     |                  |  |

Figure 2.3.2 Time Base Timer Control Register

| Table 2.3.1 | Time Base | Timer Interrupt | Frequency | (Example: fc : | = 16 MHz, fs = | 32.768 kHz) |
|-------------|-----------|-----------------|-----------|----------------|----------------|-------------|
|-------------|-----------|-----------------|-----------|----------------|----------------|-------------|

|       | Time Base Timer Interrupt Frequency [Hz] |              |             |  |  |  |
|-------|------------------------------------------|--------------|-------------|--|--|--|
| твтск | NORMAL1/2,                               | IDLE1/2 Mode | SLOW, SLEEP |  |  |  |
|       | DV7CK = 0                                | DV7CK = 1    | Mode        |  |  |  |
| 000   | 1.91                                     | 1            | 1           |  |  |  |
| 001   | 7.63                                     | 4            | 4           |  |  |  |
| 010   | 244.14                                   | 128          | -           |  |  |  |
| 011   | 976.56                                   | 512          | _           |  |  |  |
| 100   | 1953.13                                  | 1024         | _           |  |  |  |
| 101   | 3906.25                                  | 2048         | -           |  |  |  |
| 110   | 7812.5                                   | 4096         | _           |  |  |  |
| 111   | 31250                                    | 16384        | _           |  |  |  |

# 2.4 Watchdog Timer (WDT)

The watchdog timer is a fail-safe system to rapidly detect the CPU malfunctions such as endless looping caused by noise or the like, or deadlock and resume the CPU to the normal state.

The watchdog timer signal for detecting malfunction can be selected either a "reset request" or a non-maskable "interrupt request". However, selection is possible only once after reset. At first the "reset request" is selected.

When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals.

Note: Care must be given in system design so as to protect the watchdog timer from disturbing noise. Otherwise the Watchdog Timer may not fully exhibit its functionality.



# 2.4.1 Watchdog Timer Configuration

Figure 2.4.1 Watchdog Timer Configuration

#### 2.4.2 Watchdog Timer Control

Figure 2.4.2 shows the watchdog timer control registers (WDTCR1, WDTCR2). The watchdog timer is automatically enabled after reset.

(1) Malfunction detection methods using the watchdog timer

The CPU malfunction is detected as follows.

- 1. Setting the detection time, selecting output, and clearing the binary counter.
- 2. Repeatedly clearing the binary counter within the setting detection time

If the CPU malfunctions such as endless looping or deadlock occur for any cause, the watchdog timer output will become active at the rising of an overflow from the binary counters unless the binary counters are cleared. At this time, when WDTCR1 < WDTOUT > = "1", a reset is generated and the internal hardware is reseted. When WDTCR1 < WDTOUT > = "0", a watchdog timer interrupt (INTWDT) is generated.

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

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

| Example. Se                            |    |                     | // [5] 6 | and resets the GFO manufation.                                                             |
|----------------------------------------|----|---------------------|----------|--------------------------------------------------------------------------------------------|
| SYSCR1                                 | LD | (WDTCR2), 4EH       | ;        | Clears the binary counters                                                                 |
|                                        | LD | (WDTCR1), 00001101B | ;        | WDTT $\leftarrow$ 10, WDTOUT $\leftarrow$ 1                                                |
| Within 3/4 of<br>WDT detectior<br>time |    | (WDTCR2), 4EH       | ;        | Clears the binary counters (Always clear<br>immediately before and after changing<br>WDTT) |
| Within 3/4 of WDT detectior            |    | (WDTCR2), 4EH       | ,        | Clears the binary counters                                                                 |
| time                                   |    | (WDTCR2), 4EH       | ;        | Clears the binary counters                                                                 |

Example: Sets the watchdog timer detection time to  $2^{21}$ /fc [s] and resets the CPU malfunction.

| -                    | mer Register                                                                                                             |                                                                                                          |                                   |                                                                            |                     |                     |         |  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------|---------------------|---------------------|---------|--|--|
| WDTCR1               | 7                                                                                                                        | $-\frac{6}{1}$ $\frac{5}{1}$ $\frac{4}{1}$                                                               | 3 2                               | 1 0                                                                        | 1                   |                     |         |  |  |
| (0034 <sub>H</sub> ) | ! <i>!</i>                                                                                                               | (ATAS) (ATOUT) V                                                                                         | VDTEN WPT                         | T WDTOUT                                                                   | (Initial value: *   | *11 1001)           |         |  |  |
|                      | WDTEN                                                                                                                    | Watchdog timer<br>enable/disable                                                                         | 0: Disable (It is n<br>1: Enable  | ecessary to write                                                          | e the disable cod   | e to WDTCR2)        |         |  |  |
|                      |                                                                                                                          |                                                                                                          |                                   | NORMAI                                                                     | 1/2 mode            | SLOW                |         |  |  |
|                      |                                                                                                                          |                                                                                                          |                                   | DV7CK = 0                                                                  | DV7CK = 1           | mode                |         |  |  |
|                      |                                                                                                                          | Watchdog timer                                                                                           | 00                                | 2 <sup>25</sup> /fc                                                        | 2 <sup>17</sup> /fs | 2 <sup>17</sup> /fs | Write   |  |  |
|                      | WDTT                                                                                                                     | detection time [s]                                                                                       | 01                                | 2 <sup>23</sup> /fc                                                        | 2 <sup>15</sup> /fs | 2 <sup>15</sup> /fs | only    |  |  |
|                      |                                                                                                                          |                                                                                                          | 10                                | 2 <sup>21</sup> /fc                                                        | 2 <sup>13</sup> /fs | 2 <sup>13</sup> /fs |         |  |  |
|                      |                                                                                                                          |                                                                                                          | 11                                | 2 <sup>19</sup> /fc                                                        | 2 <sup>11</sup> /fs | 2 <sup>11</sup> /fs |         |  |  |
|                      | WDTOUT                                                                                                                   | Watchdog timer                                                                                           | 0: Interrupt reque                |                                                                            |                     |                     |         |  |  |
|                      |                                                                                                                          | output select                                                                                            | 1: Reset request                  |                                                                            |                     |                     |         |  |  |
|                      | Note 1: W                                                                                                                | DTOUT cannot be set to "1"                                                                               | by program after cl               | earing WDTOUT                                                              | to "0".             |                     |         |  |  |
|                      | Note 2: fc:                                                                                                              | : High-frequency clock [Hz], t                                                                           | fs: Low-frequency c               | lock [Hz], *: Don                                                          | 't care             |                     |         |  |  |
|                      | Note 3: W                                                                                                                | Note 3: WDTCR1 is a write-only register and must not be used with any of read-modify-write instructions. |                                   |                                                                            |                     |                     |         |  |  |
|                      | Note 4: Th                                                                                                               | ne watchdog timer must be o                                                                              | disabled or the cour              | nter must be clea                                                          | ared immediately    | before entering     | to the  |  |  |
|                      |                                                                                                                          | TOP mode. When the counter                                                                               |                                   |                                                                            |                     |                     |         |  |  |
|                      |                                                                                                                          |                                                                                                          |                                   |                                                                            |                     |                     | loading |  |  |
|                      | the STOP mode.                                                                                                           |                                                                                                          |                                   |                                                                            |                     |                     |         |  |  |
|                      | Note 5: To disable the watchdog timer, always write "4E <sub>H</sub> " (Clear code) to WDTCR2 for clearing the binary co |                                                                                                          |                                   |                                                                            |                     |                     |         |  |  |
|                      | be                                                                                                                       | efore writing "0" to WDTEN, a                                                                            | and then write "B1 <sub>H</sub> " | ' (Disable code)                                                           | to WDTCR2.          |                     |         |  |  |
|                      | AI                                                                                                                       | so, immediately before these                                                                             | e procedure, disable              | the interrupt ma                                                           | ter flag (IMF) by   | DI instruction.     |         |  |  |
|                      |                                                                                                                          |                                                                                                          |                                   |                                                                            |                     |                     |         |  |  |
| -                    | mer Register                                                                                                             | 2                                                                                                        |                                   |                                                                            |                     |                     |         |  |  |
| WDTCR2               | 7                                                                                                                        | 6 5 4                                                                                                    | 3 2                               | 1 0                                                                        | 1                   |                     |         |  |  |
| (0035 <sub>H</sub> ) |                                                                                                                          | <u>i i i</u>                                                                                             | <u>i</u> i                        |                                                                            | (Initial value: *   | *** ****)           |         |  |  |
|                      |                                                                                                                          | <b></b>                                                                                                  |                                   |                                                                            |                     |                     |         |  |  |
|                      |                                                                                                                          |                                                                                                          | 4E <sub>H</sub> : Watch           | dog timer binary                                                           | counter clear (Cl   | ear code)           |         |  |  |
|                      | WDTCR2                                                                                                                   | Watchdog timer control                                                                                   | B1 <sub>H</sub> : Watch           | dog timer disable                                                          | e (Disable code)    |                     | Write   |  |  |
|                      | THE FOLL                                                                                                                 | code write register                                                                                      | D2 <sub>H</sub> : Enable          | assigning addre                                                            | ess trap area       |                     | only    |  |  |
|                      |                                                                                                                          |                                                                                                          | Others: Invalid                   |                                                                            |                     |                     |         |  |  |
|                      |                                                                                                                          |                                                                                                          | Others: Invalid                   |                                                                            |                     |                     | 0.1.9   |  |  |
|                      | Note 1: Th                                                                                                               | ne disable code is invalid unl                                                                           | •                                 | DTCR1 <wdten< td=""><td><b>l&gt;</b> = 0.</td><td></td><td></td></wdten<>  | <b>l&gt;</b> = 0.   |                     |         |  |  |
|                      |                                                                                                                          | ne disable code is invalid unl<br>Don't care                                                             | •                                 | DTCR1 <wdten< td=""><td><b>I&gt;</b> = 0.</td><td></td><td>,</td></wdten<> | <b>I&gt;</b> = 0.   |                     | ,       |  |  |
|                      | Note 2: *:                                                                                                               | Don't care                                                                                               | less written when W               |                                                                            |                     |                     |         |  |  |
|                      | Note 2: *:<br>Note 3: Th                                                                                                 |                                                                                                          | less written when W               | t be cleared by th                                                         | ne interrupt task.  |                     |         |  |  |

Figure 2.4.2 Watchdog Timer Control Registers

(2) Watchdog timer enable

The watchdog timer is enabled by setting WDTCR1<WDTEN> to "1".

WDTCR1<WDTEN> is initialized to "1" during reset, so the watchdog timer operates immediately after reset is released.

(3) Watchdog timer disable

To disable the watchdog time, write "4EH" (Clear code) to WDTCR2 for clearing the binary counter before writing "0" to WDTCR1<WDTEN>, and then write "B1H" (Disable code) to WDTCR2. The watchdog timer is not disabled if this procedure is reversed and the disable code is written to WDTCR2 before WDTCR1<WDTEN> is cleared to "0". Also, immediately before these procedure, disable the interrupt master flag (IMF) by DI instruction. During disabling the watchdog timer, the binary counters are cleared to "0".

Example: Disables watchdog timer

|     | 5                |   |                                                        |
|-----|------------------|---|--------------------------------------------------------|
| DI  |                  | ; | $IMF \leftarrow 0$                                     |
| LD  | (WDTCR2), 4EH    | ; | Clear the binary counter                               |
| LDW | (WDTCR1), 0B101H | ; | WDTEN $\leftarrow$ 0, WDTCR2 $\leftarrow$ Disable code |

| Table 2.4.1 | Watchdog Ti | mer Detection 7 | lime (Exam | ple: fc = 16 MH | z, fs = 32.768 kHz) |
|-------------|-------------|-----------------|------------|-----------------|---------------------|
|-------------|-------------|-----------------|------------|-----------------|---------------------|

|      | Watchdo             | īme [s] |           |
|------|---------------------|---------|-----------|
| WDTT | NORMAL              |         |           |
|      | DV7CK = 0 DV7CK = 1 |         | SLOW Mode |
| 00   | 2.097               | 4       | 4         |
| 01   | 524.288 m           | 1       | 1         |
| 10   | 131.072 m           | 250 m   | 250 m     |
| 11   | 32.768 m            | 62.5 m  | 62.5 m    |

## 2.4.3 Watchdog Timer Interrupt (INTWDT)

This is a non-maskable interrupt which can be accepted regardless of the contents of the EIR. If a watchdog timer interrupt or a software interrupt is already accepted, however, the new watchdog timer interrupt waits until the previous interrupt processing is completed (The end of the [RETN] instruction execution).

The stack pointer (SP) should be initialized before using the watchdog timer output as an interrupt source with WDTOUT.

| Example: Watchdog timer in | terrupt setting up  |   |                        |
|----------------------------|---------------------|---|------------------------|
| LD                         | SP, 023FH           | ; | Sets the stack pointer |
| LD                         | (WDTCR1), 00001000B | ; | WDTOUT $\leftarrow 0$  |

## 2.4.4 Watchdog Timer Reset

If the watchdog timer reset request occur, a reset is generated and the internal hardware is reseted. When the watchdog timer reset is generated, the flash reset is also generated. Therefore, the maximum reset period is  $24/\text{fc} [s] + 2^{10}/\text{fc} [s] (65.5 \,\mu\text{s} \text{ at } 16.0 \text{ MHz}).$ 

Note: The high-frequency clock oscillator also immediately turns on when a watchdog timer reset is generated in SLOW mode. In this case, the reset time may include a certain amount of error if there is any fluctuation of the oscillation frequency at starting the high-frequency clock oscillation. Therefore, the reset time must be considered an approximated value.





## 2.5 Address Trap

The watchdog timer control register 1, 2 shares its addresses with the control registers in case of address trap. These control registers for address trap are shown on Figure 2.5.1.



Figure 2.5.1 Watchdog Timer Control Registers

(1) Selection of address trap in internal RAM (ATAS)

Using WDTCR1<ATAS>, address trap or no address trap can be selected for the internal RAM area. To execute an instruction in the internal RAM area, set "0" in WDTCR1<ATAS>. Setting in WDTCR1<ATAS> becomes valid after control code D2H is written in WDTCR2. Executing an instruction in the SFR/DBR area generates an address trap unconditionally regardless of the setting in WDTCR1<ATAS>.

(2) Selection of operation at address trap (ATOUT)

As the operation at address trap either interrupt request or reset request can be selected by WDTCR1<ATOUT>.

## 2.6 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 pin P51 ( $\overline{\text{DVO}}$ ). The P51 output latch should be set to "1".

# Note: Selection of divider output frequency must be made while divider output is disabled. Also, in other words, when changing the state of the divider output frequency from enabled to disable, do not change the setting of the divider output frequency.

| (0036 <sub>H</sub> ) | DVOEN | DVQCK (DV7CK)(TB              | IEN)             | <u>,(</u> TBTCK),  | (Initial value    | : 0000 0000)      |       |
|----------------------|-------|-------------------------------|------------------|--------------------|-------------------|-------------------|-------|
|                      | DVOEN | Divider output enable/disable | 0: Dis<br>1: Ena |                    |                   |                   |       |
|                      |       |                               |                  | NORMAI             | 1/2 Mode          | SLOW, SLEEP       |       |
|                      |       |                               |                  | DV7CK = 0          | DV7CK = 1         | Mode              | R/W   |
|                      | DVOCK | Divider output ( DVO )        | 00               | fc/2 <sup>13</sup> | fs/2 <sup>5</sup> | fs/2 <sup>5</sup> | 1.7.1 |
|                      |       | frequency selection [Hz]      | 01               | fc/212             | fs/2 <sup>4</sup> | fs/2 <sup>4</sup> |       |
|                      |       |                               | 10               | fc/2 <sup>11</sup> | fs/2 <sup>3</sup> | fs/2 <sup>3</sup> |       |
|                      |       |                               | 11               | fc/2 <sup>10</sup> | fs/2 <sup>2</sup> | fs/2 <sup>2</sup> |       |

#### Figure 2.6.1 Divider Output Control Register

| Example: | 1.95 kHz pulse output (at fc = 16.0 MHz) |                    |   |                                   |
|----------|------------------------------------------|--------------------|---|-----------------------------------|
|          | SET                                      | (P5DR).1           | ; | P51 output latch $\leftarrow$ "1" |
|          | LD                                       | (TBTCR), 0000000B  | ; | DVOCK ← "00"                      |
|          | LD                                       | (TBTCR), 10000000B | ; | DVOEN ← "1"                       |

#### Table 2.6.1 Divider Output Frequency (Example: at fc = 16.0 MHz, fs = 32.768 kHz)

|       | Divider Output Frequency [Hz] |             |         |  |  |
|-------|-------------------------------|-------------|---------|--|--|
| DVOCK | NORMAL1/2,                    | SLOW, SLEEP |         |  |  |
|       | DV7CK = 0                     | DV7CK = 1   | Mode    |  |  |
| 00    | 1.953 k                       | 1.024 k     | 1.024 k |  |  |
| 01    | 3.906 k                       | 2.048 k     | 2.048 k |  |  |
| 10    | 7.813 k                       | 4.096 k     | 4.096 k |  |  |
| 11    | 15.625 k                      | 8.192 k     | 8.192 k |  |  |



#### Figure 2.6.2 Divider Output







## 2.7.2 Control

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



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.

Figure 2.7.2 Timer Registers and TC1 Control Register

#### 2.7.3 Function

Timer/counter 1 has six operating modes: timer, external trigger timer, event counter, window, pulse width measurement, programmable pulse generator output mode.

(1) Timer mode

In this mode, counting up is performed using the internal clock. The contents of TC1DRA are compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0". Counting up resumes after the counter is cleared. The current contents of up counter can be transferred to TC1DRB by setting TC1CR<ACAP1> to "1" (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.

|       |                    | NORMAL1/2,                     | SLOW1/2, SL        | EEP1/2 Mode                    |                    |                     |
|-------|--------------------|--------------------------------|--------------------|--------------------------------|--------------------|---------------------|
|       | DV7CK = 0          |                                | DV7CK = 1          |                                |                    | Maximum             |
| TC1CK | Resolution<br>[µs] | Maximum<br>Time Setting<br>[s] | Resolution<br>[µs] | Maximum<br>Time Setting<br>[s] | Resolution<br>[μs] | Time Setting<br>[s] |
| 00    | 128                | 8.39                           | 244.14             | 16.0                           | 244.14             | 16.0                |
| 01    | 8.0                | 0.524                          | 8.0                | 0.524                          | -                  | -                   |
| 10    | 0.5                | 32.77 m                        | 0.5                | 32.77 m                        | -                  | _                   |

Table 2.7.1 Source Clock (internal clock) for Timer/Counter 1 (Example: at fc = 16 MHz, fs = 32.768kHz)

Example 1: Sets the timer mode with source clock fc/2<sup>11</sup> [Hz] and generates an interrupt 1 second later

|            | (at fc = 16 MHz | z, DV7CK = 0)      |   |                                                                                            |
|------------|-----------------|--------------------|---|--------------------------------------------------------------------------------------------|
|            | LDW             | (TC1DRA), 1E84H    | ; | Sets the timer register                                                                    |
|            |                 |                    |   | $(1 \text{ s} \div 2^{11}/\text{fc} = 1\text{E}84\text{H})$                                |
|            | DI              |                    | ; | IMF = "0"                                                                                  |
|            | SET             | (EIRL). 5          | ; | Enable INTTC1                                                                              |
|            | EI              |                    | ; | IMF = "1"                                                                                  |
|            | LD              | (TC1CR), 0000000B  | ; | $TFF1 \leftarrow \text{``0", TC1CK} \leftarrow \text{``00", TC1M} \leftarrow \text{``00"}$ |
|            | LD              | (TC1CR), 00010000B | ; | Starts TC1                                                                                 |
| Example 2: | Auto-capture    |                    |   |                                                                                            |
|            | LD              | (TC1CR), 01010000B | ; | ACAP1 ← "1" (Capture)                                                                      |
|            | LD              | WA, (TC1DRB)       | ; | Reads the capture value                                                                    |
|            |                 |                    |   |                                                                                            |

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

|                     | Command start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Source<br>clock     | mpunn "nn nn nn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Up counter          | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| TC1DRA              | ? X n Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| INTTC1<br>interrupt | Match detect Counter clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| (a) Timer mode      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Source<br>clock     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Up counter          | $\frac{1}{2} \times \frac{m-2}{m-1} \times \frac{m}{m} \times \frac{m+1}{m+2} \times \frac{m+2}{m+2} \times \frac{m-1}{m} \times \frac{m+1}{m+2} \times \frac{m+1}{m+2$ |  |  |  |
| TC1DRB              | $\begin{array}{c c} \hline \\ \hline $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| ACAP1               | (b) Auto capture                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |

Figure 2.7.3 Timer Mode Timing Chart

(2) External trigger timer mode

In this mode, counting up is started by an external trigger. This trigger is the edge of the TC1 pin input. Either the rising or falling edge can be selected with TC1S. Source clock is an internal clock. The contents of TC1DRA is compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0" and halted. The counter is restarted by the selected edge of the TC1 pin input.

When TC1CR<METT1> is "1", inputting the edge to the reverse direction of the trigger edge to start counting clears the counter, and the counter is stopped. Inputting a constant pulse width can generate interrupts. When TC1CR<METT1> is "0", the reverse directive edge input is ignored. The TC1 pin input edge before a match detection is also ignored.

The TC1 pin input has the noise rejection; therefore, pulses of 4/fc [s] or less are rejected as noise. A pulse width of 12/fc [s] or more is required for edge detection in NORMAL1/2 or IDLE1/2 mode. The noise rejection circuit is turned off in SLOW1/2 and SLEEP1/2 modes. But, a pulse width of one machine cycle or more is required.

Example 1: Detects rising edge in TC1 pin input and generates an interrupt 100  $\mu s$  later.

|            | (at fc = 16 MHz | z, DV7CK = 0)                    |        |                                                  |
|------------|-----------------|----------------------------------|--------|--------------------------------------------------|
|            | DI              |                                  | ;      | IMF = "0"                                        |
|            | LDW             | (TC1DRA), 00C8H                  | ;      | $100 \ \mu s \div 2^{3}/fc = C8H$                |
|            | SET             | (EIRL). 5                        | ;      | INTTC1 interrupt enable                          |
|            | EI              |                                  | ;      | IMF = "1"                                        |
|            | LD              | (TC1CR), 00001000B               | ;      | TFF1 = "0", TC1CK = "10", TC1M = "00"            |
|            | LD              | (TC1CR), 00101000B               | ;      | TC1 external trigger start, METT1 ="0"           |
| Example 2: | Generates an i  | nterrupt, inputting "L" level pu | lse (p | oulse width: 4 ms or more) to the TC1 pin.       |
|            | (at fc = 16 MHz | :)                               |        |                                                  |
|            | DI              |                                  | ;      | IMF = "0"                                        |
|            | LDW             | (TC1DRA), 1F40H                  | ;      | $4 \text{ ms} \div 2^3/\text{fc} = 1\text{F40H}$ |
|            | SET             | (EIRL). 5                        | ;      | INTTC1 interrupt enable                          |
|            | EI              |                                  | ;      | IMF = "1"                                        |
|            | LD              | (TC1CR), 01001000B               | ;      | TFF1 = "0", TC1CK = "10", TC1M = "00"            |
|            | LD              | (TC1CR), 01111000B               | ;      | TC1 external trigger start, METT1 = 1            |



Figure 2.7.4 External Trigger Timer Mode Timing Chart

(3) Event counter mode

In this mode, events are counted at the edge of the TC1 pin input (either the rising or falling edge can be selected with the external trigger TC1CR<TC1S>). The contents of TC1DRA are compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. After the counter is cleared, the up counter starts counting by TC1 input edge. Match detect is executed on other edge of count-up. A match can not be detected and INTTC1 is not generated when the pulse is still in same state. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width.

Setting TC1CR<ACAP1> to "1" transfers the current contents of up counter to TC1DRB (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.



Figure 2.7.5 Event Counter Mode Timing Chart

|           | Minimum Input Pulse Width [s] |                        |  |  |  |
|-----------|-------------------------------|------------------------|--|--|--|
|           | NORMAL1/2, IDLE1/2 Mode       | SLOW1/2, SLEEP1/2 Mode |  |  |  |
| "H" width | 2 <sup>3</sup> /fc            | 2 <sup>3</sup> /fs     |  |  |  |
| "L" width | 2 <sup>3</sup> /fc            | 2 <sup>3</sup> /fs     |  |  |  |

| Table 2.7.2 Timer/Counter 1 External Clock Source |
|---------------------------------------------------|
|---------------------------------------------------|

### (4) Window mode

In this mode, counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC1 pin input (Window pulse) and an internal clock. The contents of TC1DRA are compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. It is possible to select either positive logic or negative logic for the TC1 pin input (by using the TC1 start control TC1CR<TC1S>).

The maximum frequency that can be applied to the pin must be such that the related count can be analyzed by program. To put another way, the frequency of the applied pulse must be sufficiently low, compared with that of the internally set source clock.



Figure 2.7.6 Window Mode Timing Chart

(5) Pulse width measurement mode

In this mode, counting is started by the external trigger (Set to external trigger start by TC1CR<TC1S>). The trigger can be selected either the rising or falling edge of the TC1 pin input. The source clock is used an internal clock. On the next falling (Rising) edge, the counter contents are transferred to TC1DRB and an INTTC1 interrupt is generated. The counter is cleared when the single edge capture mode (TC1CR<MCAP> = "1") is set. When double edge capture (TC1CR<MCAP> = "0") is set, the counter continues and, at the next rising (Falling) edge, the counter contents are again transferred to TC1DRB. If a falling (Rising) edge capture value is required, it is necessary to read out TC1DRB contents until a rising (Falling) edge is detected. Falling or rising edge is selected with the external trigger TC1CR<TC1S>, and single edge or double edge is selected with TC1CR<MCAP1>.

- Note 1: Be sure to read the captured value from TC1DRB before the next trigger edge is detected. If fail to read it, it becomes undefined. It is recommended that a 16-bit access instruction be used to read from TC1DRB.
- Note 2: If either the falling or rising edge is used in capturing values, the counter stops at "1" after a value has been captured until the next edge is detected. So, the value captured next will become "1" larger than the value captured right after capturing starts.
- Note 3: The first captured value after the timer starts may be read incorrectively, therefore, ignore the first captured value.

| Example: D | uty measure | ment (resolution fc/2' [Hz]) |    |                                                     |
|------------|-------------|------------------------------|----|-----------------------------------------------------|
|            | CLR         | (INTTC1SW). 0                | ;  | INTTC1 service switch initial setting               |
|            | LD          | (TC1CR), 00000110B           | ;  | Sets the TC1 mode and source clock                  |
|            | DI          |                              | ;  | IMF = "0"                                           |
|            | SET         | (EIRL). 5                    | ;  | Enables INTTC1                                      |
|            | EI          |                              | ;  | IMF = "1"                                           |
|            | LD          | (TC1CR), 00100110B           | ;  | Starts TC1 with an external trigger at<br>MCAP1 = 0 |
| PINTTC1:   | CPL         | (INTTC1SW). 0                | ;  | Inverts INTTC1 service switch                       |
|            | JRS         | F, SINTTC1                   |    |                                                     |
|            | LD          | A, (TC1DRBL)                 | ;  | Reads TC1DRB ("H" level pulse width)                |
|            | LD          | W, (TC1DRBH)                 |    |                                                     |
|            | RETI        |                              |    |                                                     |
| SINTTC1:   | LD          | L, (TC1DRBL)                 | ;  | Reads TC1DRB (Period)                               |
|            | LD          | H, (TC1DRBH)                 |    |                                                     |
|            |             |                              | ;  | Duty calculation                                    |
|            | RETI        | ·                            |    |                                                     |
|            |             |                              |    |                                                     |
| VINTTC1:   | DW          | PINTTC1                      |    |                                                     |
|            |             |                              |    |                                                     |
|            |             |                              |    |                                                     |
|            | <u>ن</u>    | WIDTH                        | →¦ |                                                     |
|            | ¦← HPU      | LSE→                         | -  |                                                     |
| TC1 pin    |             |                              |    |                                                     |
| - TCT pin  |             |                              |    |                                                     |
|            |             |                              |    | -                                                   |
| INTTC1SW   |             |                              |    |                                                     |
| -          |             |                              |    | L                                                   |
|            |             |                              |    |                                                     |

Example: Duty measurement (resolution  $fc/2^7$  [Hz])



Figure 2.7.7 Pulse Measurement Mode Timing Chart

(6) Programmable pulse generate (PPG) output mode

The PPG output mode is intended to output pulses having an arbitrary duty cycle selected using two timer registers.

The timer starts at an edge (Rising or falling edge, that is, the same edge type as selected with the external trigger edge select bits (TC1CR<TC1S>) or on a command. Its source clock is an internal clock. Once the timer starts running, the timer F/F1 is inverted when the counter matches TC1DRB, generating the INTTC1 interrupt. The counter keeps up-counting, and when counter matches TC1DRA, the timer F/F1 is inverted, generating an INTTC1 interrupt. If TC1CR<MPPG1> was previously set to "1" (One shot), TC1S is cleared to "00" automatically, causing the timer to stop. If TC1CR<MPPG1> was previously cleared to "0" (Continuous pulse generation), the counter is cleared, resulting in the counter keeping to run and the PPG output being continued. If TC1CR<TC1S> is reset to "00" (One-shot-based automatic stop is included) during PPG output, the P50 (PPG) pin holds the same level that it does just before the counter stops. In PPG output mode, set the output latch of port P50 to "1". The timer F/F1 is cleared to "0" at a reset. In addition, a positive or negative pulse can be output because the output level can be set up at a start, using TC1CR<TFF1>. The P50 (PPG) pin outputs an inversion of the timer F/F1 output level. It is impossible to write to TC1DRB unless the PPG output mode is set.

- Note 1: To change the content of the timer register when the timer is running, change it to a sufficiently large value, compared with the current count. If the timer register content is changed to a value smaller than the current count when the timer is running, it is likely that unintended pulses may be output.
- Note 2: Do not change TC1CR<TFF1> when the timer is running.

Example:

TC1CR<TFF1> can be set correctly only at initialization (after a reset). When the timer is stopped during PPG output, if the PPG output is at a logic state opposite to the PPG that when the timer starts, it will become impossible to set TC1CR<TFF1> correctly (An attempt to program TC1CR<TFF1> will cause a state opposite to the programmed one to be set in the bit). Once the timer has stopped, putting the PPG output securely on an arbitrary level requires initializing the timer F/F1. To initialize it, put TC1CR<TC1M> in the timer mode again (It is unnecessary to start the timer mode), and then put it in the PPG output mode again. At the same time, set TC1CR<TFF1>.

Note 3: In the PPG output mode, a value set in the timer register must satisfy: TC1DRA > TC1DRB

| Pulse output | Pulse output "H" level 800 $\mu$ s, "L" level 200 $\mu$ s (at tc = 16 MHz, DV7CK = 0) |   |                                                          |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------|---|----------------------------------------------------------|--|--|--|--|
| SET          | (P5DR). 0                                                                             | ; | P50 output latch $\leftarrow$ 1                          |  |  |  |  |
| LD           | (TC1CR), 10001011B                                                                    | ; | Sets the PPG output mode                                 |  |  |  |  |
| LDW          | (TC1DRA), 07D0H                                                                       | ; | Sets the period (1 ms $\div$ 2 <sup>3</sup> /fc = 07D0H) |  |  |  |  |
| LDW          | (TC1DRB), 0190H                                                                       | ; | Sets "L" level pulse width                               |  |  |  |  |
|              |                                                                                       |   | (200 μs ÷ 2 <sup>3</sup> /fc = 0190H)                    |  |  |  |  |
| LD           | (TC1CR), 10011011B                                                                    | ; | Starts                                                   |  |  |  |  |







Figure 2.7.9 PPG Output Mode Timing Chart

# 2.8 16-Bit Timer/Counter 2

2.8.1 Configuration



Figure 2.8.1 Timer/Counter 2 (TC2A)

## 2.8.2 Control

The timer/counter 2 is controlled by a timer/counter 2 control register (TC2CR) and a 16-bit timer register 2 (TC2DR). Reset does not affect TC2DR.

| TC2DR<br>(0025, 0024H)<br>R/W | 15 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | - <u>13 12 11 10</u><br>_ TC2DRH (0025H) _                              | 9                                                    | 8 7                                                    | 65<br>, ŢC                                     | <u>4 3</u><br>C2DRĻ (0024 | <u>2 1</u><br>H) , | 0          |  |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------|------------------------------------------------|---------------------------|--------------------|------------|--|
| TC2CR<br>(0013H)              | 7 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 5 4 3 2<br>TC2S TC2CK                                                   | 1                                                    | 0<br>TC2M (Initial                                     | value: **00 00*                                | <sup>«</sup> 0)           |                    |            |  |
|                               | TC2M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TC2 operating mode select                                               | 0:<br>1:                                             | Timer/event co<br>Window mode                          | unter mode                                     |                           |                    |            |  |
|                               | TC2CK TC2 source clock select [Hz]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                         | 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111 | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ |                                                |                           |                    | R/W        |  |
|                               | TC2S TC2 start control<br>Note 1: fc: High-frequency clock [Hz], fs: L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                         |                                                      | Stop and count<br>Start<br>quency clock [H             |                                                | •                         |                    |            |  |
|                               | Note 2: When writing to the Timer Register 2 (TC2DR), always write to the lower side (TC2DRL) and then the upper side (TC2DRH) in that order. Writing to only the lower side (TC2DRL) or the upper side (TC2DRH) has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                         |                                                      |                                                        |                                                |                           |                    | •••        |  |
|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ne timer register 2 (TC2DR) uses<br>the upper side (TC2DRH) after       |                                                      |                                                        |                                                |                           | tion until data    | is written |  |
|                               | Note 4: Set the mode and source clock who to the time results of the loaded to the time results of the time results and the time results are the time results of the time results are the time results and the time results are the time results |                                                                         |                                                      |                                                        | register must satisfy the following condition. |                           |                    |            |  |
|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | a read instruction is executed for<br>ne high-frequency clock(fc) can b |                                                      | •                                                      |                                                |                           | ode is selecte     | ed.        |  |
|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | n entering STOP mode, the TC2<br>nce the STOP mode has been re          |                                                      |                                                        |                                                |                           | -                  | ner stops. |  |

# Figure 2.8.2 Timer Register 2 and TC2 Control Register

## 2.8.3 Function

The timer/counter 2 has three operating modes: timer, event counter and window modes.

(1) Timer mode

In this mode, the internal clock is used for counting up. The contents of TC2DR are compared with the contents of up counter. If a match is found, a timer/counter 2 interrupt (INTTC2) is generated, and the counter is cleared. Counting up is resumed after the counter is cleared.

When fc is selected for source clock at SLOW2 mode, lower 11-bits of TC2DR are ignored and generated a interrupt by matching upper 5-bits. Though, in this situation, it is necessary to set TC2DRH only.

|       | NORMAL1/2, IDLE1/2 Mode |                            |            | SLOW1/2 Mode               |                | SLEEP1/2 Mode              |            |                            |
|-------|-------------------------|----------------------------|------------|----------------------------|----------------|----------------------------|------------|----------------------------|
|       | DV7CK = 0               |                            | DV7CK = 1  |                            |                | Maria                      |            | Maria                      |
| TC2CK | Resolution              | Maximum<br>Time<br>Setting | Resolution | Maximum<br>Time<br>Setting | Resolution     | Maximum<br>Time<br>Setting | Resolution | Maximum<br>Time<br>Setting |
| 000   | 524.29 ms               | 9.54 h                     | 1.00 s     | 18.20 h                    | 1.00 s         | 18.20 h                    | 1.00 s     | 18.20 h                    |
| 001   | 512.00 μs               | 33.55 s                    | 0.98 ms    | 1.07 min                   | 0.98 ms        | 1.07 min                   | 0.98 ms    | 1.07 min                   |
| 010   | 16.00 μs                | 1.05 s                     | 16.00 μs   | 1.05 s                     | -              | -                          | -          | -                          |
| 011   | 0.50 μs                 | 32.77 ms                   | 0.50 μs    | 32.77 ms                   | -              | _                          | -          | -                          |
| 100   | -                       | -                          | -          | -                          | 62.5 ns (Note) | _                          | -          | -                          |
| 101   | 30.52 μs                | 2.00 s                     | 30.52 μs   | 2.00 s                     | -              | _                          | _          | -                          |

Table 2.8.1 Source Clock (Internal clock) for Timer/Counter 2 (at fc = 16 MHz)

Note: When fc is selected as the source clock in timer mode, it is used at warm-up for switching from SLOW2 mode to NORMAL2 mode.

Example: Sets the timer mode with source clock fc/2<sup>3</sup> [Hz] and generates an interrupt every 25 ms (at fc = 16 MHz).

| LDW | (TC2DR), 0C350H    | ; | Sets TC2DR (25 ms $\div$ 2 <sup>3</sup> /fc = C350H) |
|-----|--------------------|---|------------------------------------------------------|
| DI  |                    | ; | IMF = "0"                                            |
| SET | (EIRE). 4          | ; | Enables INTTC2 interrupt                             |
| EI  |                    | ; | IMF = "1"                                            |
| LD  | (TC2CR), 00001100B | ; | TC2CK ← "011", TC2M ← "0"                            |
| LD  | (TC2CR), 00101100B | ; | Starts TC2                                           |

(2) Event counter mode

In this mode, events are counted on the rising edge of the TC2 pin input. The contents of TC2DR are compared with the contents of the up counter. If a match is found, an INTTC2 interrupt is generated, and the counter is cleared. The minimum input pulse width of TC2 pin is shown in Table 2.8.2. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width. Match detect is executed on the falling edge of the TC2 pin. A match can not be detected and INTTC2 is not generated when the pulse is still in a falling state.

| Example: Se | ts the event c | ounter mode and generates an | INT | TC2 interrupt 640 counts later. |
|-------------|----------------|------------------------------|-----|---------------------------------|
|             | LDW            | (TC2DR), 640                 | ;   | Sets TC2DR                      |
|             | DI             |                              | ;   | IMF = "0"                       |
|             | SET            | (EIRE). 4                    | ;   | Enables INTTC2 interrupt        |
|             | EI             |                              | ;   | IMF = "1"                       |
|             | LD             | (TC2CR), 00011100B           | ;   | TC2CK ← "111", TC2M ← "0"       |
|             | LD             | (TC2CR), 00111100B           | ;   | Starts TC2                      |

| Table 2.8.2 Timer/Counter 2 External Clock Sou | irce |
|------------------------------------------------|------|
|------------------------------------------------|------|

|           | Minimum Input Pulse Width [s] |                        |  |  |  |
|-----------|-------------------------------|------------------------|--|--|--|
|           | NORMAL1/2, IDLE1/2 Mode       | SLOW1/2, SLEEP1/2 Mode |  |  |  |
| "H" width | 2 <sup>3</sup> /fc            | 2 <sup>3</sup> /fs     |  |  |  |
| "L" width | 2 <sup>3</sup> /fc            | 2 <sup>3</sup> /fs     |  |  |  |

### (3) Window mode

In this mode, counting up performed on the rising edge of an internal clock during TC2 external pin input (Window pulse) is "H" level. The contents of TC2DR are compared with the contents of up counter. If a match found, an INTTC2 interrupt is generated, and the up-counter is cleared.

The maximum applied frequency (TC2 input) must be considerably slower than the selected internal clock.

Note: In the window mode, before the SLOW/SLEEP mode is entered, the timer should be halted by setting TC2CR<TC2S> to "0".



Figure 2.8.3 Window Mode Timing Chart

# 2.9 8-Bit Timer/Counter 3





Figure 2.9.1 Timer/Counter 3 (TC3)

### 2.9.2 Control

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



Figure 2.9.2 Timer Register 3 and TC3 Control Register

## 2.9.3 Function

The timer/counter 3 has three operating modes: timer, event counter, and capture mode.

(1) Timer mode

In this mode, the internal clock is used for counting up. The contents of TC3DRA are compared with the contents of up counter. If a match is found, a timer/counter 3 interrupt (INTTC3) is generated, and the up counter is cleared.

The current contents of up counter are loaded into TC3DRB by setting TC3CR<ACAP> to "1" (Auto-capture function). The contents of up counter can be easily confirmed by executing the read instruction (RD instruction) of TC3DRB. Loading the contents of up counter is not synchronized with counting up. The contents of over flow (FFH) and 00H can not be loaded correctly. It is necessary to consider the count cycle.



Table 2.9.1 Source Clock (Internal clock) for Timer/Counter 3 (Example: at fc = 16 MHz)

|       | N                  | ORMAL1/2,                          | SLOW1/2 Mode                       |        |                    |                         |
|-------|--------------------|------------------------------------|------------------------------------|--------|--------------------|-------------------------|
|       | DV7C               | CK = 0                             | DV7C                               | CK = 1 |                    | Maximum                 |
| ТСЗСК | Resolution<br>[µs] | Maximum<br>Time<br>Setting<br>[ms] | Resolution<br>[μs]<br>[μs]<br>[ms] |        | Resolution<br>[µs] | Time<br>Setting<br>[ms] |
| 000   | 512.0              | 130.6                              | 976.6                              | 249.0  | 976.6              | 249.0                   |
| 001   | 256.0              | 65.3                               | 488.3                              | 124.5  | 488.3              | 124.5                   |
| 010   | 128.0              | 32.6                               | 244.1                              | 62.3   | 244.1              | 62.3                    |
| 011   | 64.0               | 16.3                               | 122.0                              | 31.1   | 122.0              | 31.1                    |
| 100   | 32.0               | 8.2                                | 61.0                               | 15.6   | 61.0               | 15.6                    |
| 101   | 16.0               | 4.1                                | 16.0                               | 4.1    | -                  | -                       |
| 110   | 8.0                | 2.0                                | 8.0                                | 2.0    | -                  | -                       |

(2) Event counter mode

In this mode, events are counted on the edge of the TC3 pin input. The counter counts up on the rising edge of the TC3 pin input and when its value matches the TC3DRA set value, it is cleared while at the same time generating an INTTC3 interrupt.

The detection of match is executed at the falling edge of the TC3 pin. Therefore, if the TC3 pin keeps high level after the rising, the detection of match is not executed and INTTC3 is not generated until the level of TC3 pin becomes low.

The minimum input pulse width of the TC3 pin is shown in Table 2.9.2. One or more machine cycles are required for both the "H" and "L" levels of the pulse width.

The current contents of up counter are loaded into TC3DRB by setting TC3CR<ACAP> to "1" (Auto-capture function).

The contents of up counter can be easily confirmed by executing the read instruction (RD instruction) of TC3DRB. Loading the contents of up counter is not synchronized with counting up. The contents of over flow (FFH) and 00H can not be loaded correctly. It is necessary to consider the count cycle.

|           | Minimum Input           | Pulse Width [s]        |
|-----------|-------------------------|------------------------|
|           | NORMAL1/2, IDLE1/2 Mode | SLOW1/2, SLEEP1/2 Mode |
| "H" width | 2 <sup>2</sup> /fc      | 2 <sup>2</sup> /fs     |
| "L" width | 2 <sup>2</sup> /fc      | 2 <sup>2</sup> /fs     |

Table 2.9.2 Source Clock (External clock) for Timer/Counter

(3) Capture mode

In this mode, the pulse width, period and duty of the TC3 pin input are measured in this mode, which can be used in decoding the remote control signals or distinguishing AC 50/60 Hz, etc.

Once command operation has started, the counter free-runs on an internal source clock.

When the falling edge of the TC3 pin input is detected, the counter value is loaded into TC3DRB. When the rising edge is detected, the counter value is loaded into TC3DRA, and the counter is cleared, generating an INTTC3 interrupt.

If the rising edge is detected right after command operation has started, no capture to TC3DRB and an INTTC3 interrupt occurs only on capture to TC3DRA. If a read instruction is executed for TC3DRB, the value that exists at the end of the previous capture (Immediately after a reset, "FF") is read.

The minimum acceptable input pulse width is equal to the length of one source clock period selected by TC3CR<TC3CK>.

| Capture into<br>TC3DRB | Capture into<br>TC3DRA | INTTC3 Interrupt |
|------------------------|------------------------|------------------|
| Falling edge           | Rising                 | edge             |

Table 2.9.3 Capture Input Edges

When the overflow occurs before detecting the edge, the INTTC3 interrupt is generated, setting "FFH" to TC3DRA and clearing the counter. It is possible to confirm whether the overflow has occurred or not by reading TC3DRA in interrupt routine. After generating of interrupt, the capture function and overflow detection stop until the TC3DRA is read, but the counting is continued. Because the capture function and overflow detection are restarted by reading TC3DRA, read the TC3DRB before the reading TC3DRA.



Figure 2.9.3 Capture Mode Timing Chart

# 2.10 8-Bit Timer/Counter 5

2.10.1 Configuration



Figure 2.10.1 Timer/Counter 5 (TC5)

### 2.10.2 Control

The timer/counter 5 is controlled by a timer/counter 5 control register (TC5CR) and an 8-bit timer register 5 (TC5DR). Reset does not affect TC5DR.



Figure 2.10.2 Timer Register 5 and TC5 Control Register

## 2.10.3 Function

The timer/counter 5 has four operating modes: timer, event counter, programmable divider output, and PWM output mode.

(1) Timer mode

In this mode, the internal clock is used for counting up. The contents of TC5DR is compared with the contents of up counter. If a match is found, an INTTC5 interrupt is generated and the up-counter is cleared to "0". Counting up resumes after the up-counter is cleared.

| Table 2 10 1 | Source Clock | (Internal clock) | ) for Timer/Counter 5 ( | (Example: at fc = 16 MHz)                |
|--------------|--------------|------------------|-------------------------|------------------------------------------|
| 10010 2.10.1 |              |                  |                         | $\sum \alpha \sin \beta = 10 \sin \beta$ |

|       |                    | NORMAL1/2,                         | IDLE1/2 Mode       |                                    | SLOW1              | /2 Mode                            |
|-------|--------------------|------------------------------------|--------------------|------------------------------------|--------------------|------------------------------------|
|       | DV70               | CK = 0                             | DV70               | CK = 1                             |                    | Maria                              |
| TC5CK | Resolution<br>[μs] | Maximum<br>Time<br>Setting<br>[ms] | Resolution<br>[μs] | Maximum<br>Time<br>Setting<br>[ms] | Resolution<br>[μs] | Maximum<br>Time<br>Setting<br>[ms] |
| 000   | 128.0              | 32.6                               | 244.14             | 62.3                               | 244.14             | 62.3                               |
| 001   | 8.0                | 2.0                                | 8.0                | 2.0                                | -                  | -                                  |
| 010   | 2.0                | 0.510                              | 2.0                | 0.510                              | -                  | -                                  |
| 011   | 0.5                | 0.128                              | 0.5                | 0.128                              | -                  | -                                  |

### (2) Event counter mode

In this mode, events are counted on the rising edge of the TC5 pin input (External clock).

The contents of the TC5DR is compared with the contents of the up counter. If a match is found, an INTTC5 interrupt is generated and the counter is cleared. Counting up resumes after the up counter is cleared. The minimum input pulse width of the TC5 pin is shown in Table 2.10.2. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width.

Match detect is executed on the falling edge of the TC5 pin. A match can not be detected and INTTC5 interrupt is not generated when the pulse is still in a falling state.

|           | Minimum Input           | Pulse Width [s]        |
|-----------|-------------------------|------------------------|
|           | NORMAL1/2, IDLE1/2 Mode | SLOW1/2, SLEEP1/2 Mode |
| "H" width | 2 <sup>3</sup> /fc      | 2 <sup>3</sup> /fs     |
| "L" width | 2 <sup>3</sup> /fc      | 2 <sup>3</sup> /fs     |

Table 2.10.2 Timer/Counter 5 External Clock Source

(3) Programmable divider output (PDO) mode

The programmable divider output (PDO) mode is intended to output a pulse having a duty cycle of about 50%. The counter counts up on an internal source clock. If the timer value matches TC5DR, the timer F/F5 is inverted, and the counter is cleared, generating an INTTC5 interrupt. The counter keeps counting up, and the timer F/F5 is inverted each time the timer value matches TC5DR. The P13 ( $\overline{PDO5}$ ) pin outputs an inversion of the timer F/F5 output level.

At a reset or when the timer stops, the timer F/F5 is cleared to "0". So, stopping the timer when the PDO output is low may cause the duty cycle to become smaller than the set value.

To use the programmable divider output mode, set the output latch of the P13 port to "1".



Figure 2.10.3 PDO Mode Timing Chart

(4) Pulse width modulation (PWM) output mode

The pulse width modulation (PWM) output mode is intended to output pulses at constant intervals with a resolution of 8 bits. The counter counts up on the internal source clock. If the timer value matches TC5DR, the timer F/F5 is inverted, and the counter keeps-up counting. If an overflow is detected, the timer F/F5 is inverted again, generating an INTTC5 interrupt. The P13 ( $\overline{PWM5}$ ) pin outputs an inversion of the timer F/F5 output level.

At a reset or when the timer stops, the timer F/F5 is cleared to "0". So, stopping the timer when the PWM output is low may cause one cycle to become smaller than the set value.

To use the pulse width modulation (PWM) output mode, set the output latch of the P13 port to "1".

TC5DR is configured a 2-stage shift register and, during pulse width, will not switch until one output cycle is completed even if TC5DR is overwritten; therefore, pulse width can be altered continuously. Also, the first time, TC5DR is shifted by setting TC5CR<TC5S> to "1" after data are loaded to TC5DR.

Note: In PWM mode, writing to the timer register TC5DR should be performed only right after an INTTC5 interrupt occurs (Usually, within the INTTC5 interrupt service routine). If writing to the timer register TC5DR occurs at the same timing as the INTTC5 interrupt, pulses having a value other than the set value may be output before another INTTC5 interrupt occurs, because an unstable value that is being written is shifted.



Figure 2.10.4 PWM Output Mode Timing Chart

| тогои | NORMAL1/2,      | IDLE1/2 Mode      |
|-------|-----------------|-------------------|
| TC5CK | Resolution [ns] | Repeat Cycle [µs] |
| 000   | _               | -                 |
| 001   | _               | -                 |
| 010   | _               | -                 |
| 011   | 500             | 128               |
| 100   | 250             | 64                |
| 101   | 125             | 32                |
| 110   | 62.5            | 16                |

#### Table 2.10.3 PWM Output Mode (Example: fc = 16 MHz)

# 2.11 UART (Asynchronous serial interface)

The TMP86FM48 has 1 channel of UART (Asynchronous serial interface).

The UART is connected to external devices via RXD and TXD. RXD is also used as P05; TXD, as P06. To use P05 or P06 as the RXD or TXD pin, set P0 port output latches to "1".

## 2.11.1 Configuration



Figure 2.11.1 UART

## 2.11.2 Control

# UART is controlled by the UART control registers (UARTCR1, UARTCR2). The operating status can be monitored using the UART status register (UARTSR).

| JART control re                         | aister                                       |                                                                                                                                   |                                                                                                                                                                                                                                                                                          |                            |
|-----------------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| UARTCR1                                 | 7 6                                          | 5 4 3                                                                                                                             | 2 1 0                                                                                                                                                                                                                                                                                    |                            |
| (1FDD <sub>H</sub> )                    | TXE RXE                                      | STBT EVEN PE                                                                                                                      | BRG (Initial value: 0000 0000)                                                                                                                                                                                                                                                           |                            |
|                                         |                                              |                                                                                                                                   | 0. Disable                                                                                                                                                                                                                                                                               |                            |
|                                         | TXE                                          | Transfer operation                                                                                                                | 0: Disable<br>1: Enable                                                                                                                                                                                                                                                                  |                            |
|                                         | RXE                                          | Receive operation                                                                                                                 | 0: Disable<br>1: Enable                                                                                                                                                                                                                                                                  |                            |
|                                         | STBT                                         | Transmit stop bit length                                                                                                          | 0: 1 bit<br>1: 2 bits                                                                                                                                                                                                                                                                    |                            |
|                                         | EVEN                                         | Even-numbered parity                                                                                                              | 0: Odd-numbered parity<br>1: Even-numbered parity                                                                                                                                                                                                                                        | -                          |
|                                         | PE                                           | Parity addition                                                                                                                   | 0: No parity<br>1: Parity                                                                                                                                                                                                                                                                | Write<br>only              |
|                                         | BRG                                          | Transmit clock select                                                                                                             | 000: fc/13 [Hz]<br>001: fc/26<br>010: fc/52<br>011: fc/104<br>100: fc/208<br>101: fc/416<br>110: TC5 (INTTC5)<br>111: fc/96                                                                                                                                                              |                            |
| 1                                       | transı<br>transı<br>curren<br>Note 2: The ti | mit or receive complete. When the mitted. Even if data transmit is not data are not transmitted. ransmit clock and the parity are | etting TXE and RXE bit to "0", the setting becomes valid<br>he transmit data is stored in the transmit data buffer, the d<br>enabled, until new data are written to the transmit data<br>common to transmit and receive.<br>XE> should be set to "0" before UARTCR1 <brg> is chang</brg> | ata are not<br>buffer, the |
| JARTCR2<br>1FDE <sub>H</sub> ) <u> </u> | 6                                            | <u>5</u> 4 <u>3</u>                                                                                                               | 2     1     0       RXDNC     STOPBR     (Initial value: **** *000)                                                                                                                                                                                                                      |                            |
|                                         | RxDNC                                        | Selection of RXD input noise rejection time                                                                                       | 00: No noise rejection (Hysteresis input)<br>01: Rejects pulses shorter than 31/fc [s] as noise<br>10: Rejects pulses shorter than 63/fc [s] as noise<br>11: Rejects pulses shorter than 127/fc [s] as noise                                                                             | Write                      |
|                                         | STOPBR                                       | Receive stop bit length                                                                                                           | 0: 1 bit<br>1: 2 bits                                                                                                                                                                                                                                                                    |                            |
| 1                                       |                                              |                                                                                                                                   | ses longer than 96/fc [s] are always regarded as signals; w<br>n 192/fc [s]; and when UARTCR2 <rxdnc> = "11", longer t</rxdnc>                                                                                                                                                           |                            |

| Figure 2.11.2 | UART Control Register |
|---------------|-----------------------|
|---------------|-----------------------|

| UARTSR -                      | 7         | 6       | 5           | 4         | 3            |          | 1                         |            |                                          |      |
|-------------------------------|-----------|---------|-------------|-----------|--------------|----------|---------------------------|------------|------------------------------------------|------|
| (1FDD <sub>H</sub> )          | PERR      | FERF    | OERR        | RBFL      | TEND         | TBEP     | <u></u>                   |            | (Initial value: 0000 11**)               |      |
|                               | PEF       | RR      | Parity erro | or flag   |              |          | ): No pari<br>1: Parity e | -          |                                          |      |
|                               | FEF       | R       | Framing e   | rror flag |              |          | 0: No fram<br>1: Framing  | •          |                                          |      |
|                               | OEF       | RR      | Overrun e   | rror flag |              |          | ): No ove<br>1: Overrur   |            |                                          | Read |
|                               | RBI       | =L      | Receive d   | ata buffe | er full flag |          | 0: Receive<br>1: Receive  |            | ffer empty<br>ffer full                  | only |
|                               | TEN       | ١D      | Transmit e  | end flag  |              |          | ): Transm<br>1: Transm    | •          |                                          |      |
|                               | TBE       | ΕP      | Transmit o  | data buff | er empty     | flan     | ): Transm<br>1: Transm    |            | ıffer full<br>ıffer empty                |      |
| Ν                             | Note: W   | 'hen ar | INTTXD is   | s genera  | ted TBEF     | o is set | to "1" auto               | omatically | <i>.</i>                                 |      |
| UART receive d                | lata buff | er      |             |           |              |          |                           |            |                                          |      |
| RDBUF<br>(1FDF <sub>H</sub> ) | 7         | 6       | 5           | 4         | 3            | 2        | . 1                       | 0          | Read only<br>(Initial value: 0000 0000)  |      |
| UART transmit                 | data buf  | fer     |             |           |              |          |                           |            |                                          |      |
| TDBUF<br>(1FDF <sub>H</sub> ) | 7         | 6       | 5           | 4         | 3            | 2        | 1                         | 0          | Write only<br>(Initial value: 0000 0000) |      |



### 2.11.3 Transfer Data Format

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

| PE | STBT | Frame Length           1         2         3          8         9         10         11         12         1 |
|----|------|--------------------------------------------------------------------------------------------------------------|
| 0  | 0    | Start Bit0 Bit1 C Bit6 Bit7 Stop 1                                                                           |
| 0  | 1    | Start Bit0 Bit1 C Bit6 Bit7 Stop 1 Stop 2                                                                    |
| 1  | 0    | Start Bit0 Bit1 C Bit6 Bit7 Parity Stop 1                                                                    |
| 1  | 1    | Start Bit0 Bit1 C Bit6 Bit7 Parity Stop 1 Stop 2                                                             |

Table 2.11.1 Transfer Data Format

Note: In order to switch the transmit data format, perform transmit operations in the following sequence except for the initial setting.



# 2.11.4 Transfer Rate

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

| BRG  |              | Source Clock |              |
|------|--------------|--------------|--------------|
| BING | 16 MHz       | 8 MHz        | 4 MHz        |
| 000  | 76800 [baud] | 38400 [baud] | 19200 [baud] |
| 001  | 38400        | 19200        | 9600         |
| 010  | 19200        | 9600         | 4800         |
| 011  | 9600         | 4800         | 2400         |
| 100  | 4800         | 2400         | 1200         |
| 101  | 2400         | 1200         | 600          |

| Table 2.11.2 Transfer Rate |
|----------------------------|
|----------------------------|

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

Transfer clock = TC5 source clock TTREG5 set value

Transfer rate =  $\frac{\text{Transfer clock}}{16}$ 

## 2.11.5 Data Sampling

The UART receiver keeps sampling input using the clock selected by UARTCR1<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 2.11.4 Data Sampling

## 2.11.6 STOP Bit Length

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

## 2.11.7 Parity

Set parity/no parity by UARTCR1<PE>; set parity type (odd- or even-numbered) by UARTCR1<EVEN>.

## 2.11.8 Transmit/Receive

(1) Data transmit

Set UARTCR1<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 UARTCR1<STBT> and a parity bit if parity addition is specified. Select the data transfer baud rate using bits 0 to 2 in UARTCR1. When data transmit starts, transmit buffer empty flag UARTSR<TBEP> is set to "1" and an INTTXD interrupt is generated.

While UARTCR1<TXE> = "0" and from when "1" is written to UARTCR1<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.

(2) Data receive

Set UARTCR1<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 include 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 bits 0 to 2 in UARTCR1.

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

### 2.11.9 Status Flag/Interrupt Signal

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



Figure 2.11.5 Generation of Parity Error

(2) Framing error

When "0" is sampled as the stop bit in the receive data, framing error flag UARTSR<FERR> is set to "1". The UARTSR<FERR> is cleared to "0" when the RDBUF is read after reading the UARTSR.



Figure 2.11.6 Generation of Framing Error

(3) Overrun error

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.



Figure 2.11.7 Generation of Overrun Error

(4) Receive data buffer full

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



Figure 2.11.8 Generation of Receive Buffer Full

(5) Transmit data buffer empty

When no data is in the transmit buffer TDBUF, UARTSR<TBEP> is set to "1", 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.



Figure 2.11.9 Generation of Transmit Buffer Empty

(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" the data transmit is stated after writing the TDBUF.



Figure 2.11.10 Generation of Transmit Buffer Empty

# 2.12 Serial Bus Interface (SBI-ver. D)

The TMP86FM48 has a 1-channel serial bus interface which employs an  $I^2C$  bus (A bus system by Philips).

The serial interface is connected to external devices through P51 (SDA) and P50 (SCL). The serial bus interface pins are also used for the P5 port. When used for serial bus interface pins, set the P5 output latches of these pins to "1". When not used as serial bus interface pins, the P5 port is used as a normal I/O port.

- Note 1: When P5 is used as serial bus interface pins, P50 and P51 should be set as a sink open drain output by clearing P5OUTCR to "0".
- Note 2: The serial bus interface can be used only in NORMAL1/2 and IDLE1/2 mode. It can not be used in IDLE0, SLOW1/2 and SLEEP0/1/2 mode.
- Note 3: The I<sup>2</sup>C of TMP86FM48 can be used only in the Standard mode of I<sup>2</sup>C. The fast mode and the high-speed mode can not be used.



### 2.12.1 Configuration

Figure 2.12.1 Serial Bus Interface (SBI)

## 2.12.2 Control

The following registers are used for control the serial bus interface and monitor the operation status.

- Serial bus interface control register A (SBICRA)
- Serial bus interface control register B (SBICRB)
- Serial bus interface data buffer register (SBIDBR)
- I<sup>2</sup>C bus address register (I2CAR)
- Serial bus interface status register (SBISR)

## 2.12.3 Software Reset

A serial bus interface circuit has a software reset function, when a serial bus interface circuit is locked by an external noise, etc.

To reset the serial bus interface circuit, write "01", "10" into the SWRST (Bit1, 0 in SBICRB).

# 2.12.4 The Data Format of the I<sup>2</sup>C Bus

The data format of the I<sup>2</sup>C bus is shown in as below.



Figure 2.12.2 Data Format of I<sup>2</sup>C Bus

# 2.12.5 I<sup>2</sup>C Bus Control

The following registers are used to control the serial bus interface (SBI) and monitor the operation status of the  $\rm I^2C$  bus.

| Serial Bus Inte            | erface Cont                                                                                                                  | rol Register A                                        |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------|--------------|-------------------------------------------------------|-------------------------------------------|------------------|----------------------------------------------------|------------------------------|----------------------------|----------------|--|
| SBICRA<br>(1FD9H)          | 7                                                                                                                            | 6 5<br>BC                                             | 3-         | - 2          | 2 1 0                                                 |                                           |                  | (Initial value: 0000 *000)                         |                              |                            |                |  |
| (16090)                    | <u>ر المعام الم</u>        |                                                       | ACK        |              |                                                       |                                           |                  |                                                    | ,<br>,                       | ,                          | · · · · ·      |  |
|                            |                                                                                                                              |                                                       | вс         | Num          | ACK = 0<br>Number of                                  |                                           |                  | ACK = 1                                            |                              | -                          |                |  |
|                            |                                                                                                                              |                                                       |            |              |                                                       | ber of<br>bock                            | Bits             |                                                    | Number of<br>Clock           | Bits                       |                |  |
|                            |                                                                                                                              |                                                       |            | 000          | 8                                                     | 3                                         | 8                |                                                    | 9                            | 8                          |                |  |
|                            | BC                                                                                                                           | Number of transfe                                     | erred bits | 001<br>010   |                                                       | 1<br>2                                    | 1<br>2           |                                                    | 2<br>3                       | 1<br>2                     | Write          |  |
|                            |                                                                                                                              |                                                       |            | 011          | 3                                                     | 3                                         | 3                |                                                    | 4                            | 3                          | only           |  |
|                            |                                                                                                                              |                                                       |            | 100<br>101   |                                                       | 1<br>5                                    | 4<br>5           |                                                    | 5<br>6                       | 4<br>5                     |                |  |
|                            |                                                                                                                              |                                                       |            | 110          |                                                       | 5                                         | 6                |                                                    | 7                            | 6                          |                |  |
|                            |                                                                                                                              |                                                       |            | 111          | -                                                     | 7                                         | 7                |                                                    | 8                            | 7                          |                |  |
|                            |                                                                                                                              |                                                       |            | ACK          |                                                       | Master                                    |                  | e for                                              |                              | ve mode                    | -              |  |
|                            | ACK                                                                                                                          | Acknowledgemer                                        | nt mode    | 0:           | Not generate a clock pulse for<br>an acknowledgement. |                                           |                  | Not count a clock pulse for<br>an acknowledgement. |                              | R/W                        |                |  |
|                            |                                                                                                                              | specification                                         |            | 1:           | Genera                                                | nerate a clock pulse for an Count a clock |                  |                                                    |                              |                            | k pulse for an |  |
|                            |                                                                                                                              |                                                       |            |              |                                                       | vledgem                                   |                  | ٨٠                                                 | acknowledge                  |                            |                |  |
|                            |                                                                                                                              | Serial clock (fscl) selection                         |            | SCK<br>000:  | n<br>4                                                |                                           | 16 MHz<br>served |                                                    | fc = 8 MHz<br>Reserved       | At fc = 4 MHz<br>100.0 kHz |                |  |
|                            |                                                                                                                              |                                                       |            | 0001:        | 5                                                     |                                           | served           |                                                    | Reserved                     | 55.6 kHz                   |                |  |
|                            |                                                                                                                              | (Output on SCL p                                      |            | 010:         | 6                                                     |                                           | served           |                                                    | 58.8 kHz                     | 29.4 kHz                   | Write          |  |
|                            | SCK                                                                                                                          | (                                                     | ,          | 011:<br>100: | 7<br>8                                                |                                           | .6 kHz<br>.8 kHz |                                                    | 30.3 kHz<br>15.4 kHz         | 15.2 kHz<br>7.7 kHz        | only           |  |
|                            |                                                                                                                              | $[fscl = 1/(2^{n+1}/fc)]$                             | : + 8/fc)] | 100.         | 9                                                     |                                           | .5 kHz           |                                                    | 7.8 kHz                      | 3.9 kHz                    | -              |  |
|                            |                                                                                                                              |                                                       | 110:       | 10           |                                                       | .8 kHz                                    |                  | 3.9 kHz                                            | 1.9 kHz                      |                            |                |  |
|                            |                                                                                                                              |                                                       |            | 111:         |                                                       |                                           |                  | Rese                                               | erved                        |                            |                |  |
|                            |                                                                                                                              | c: High-frequency o                                   |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|                            |                                                                                                                              | Set the BC to "000"                                   |            |              | •                                                     |                                           |                  |                                                    | ich ac hit man               | inulation ato              |                |  |
|                            |                                                                                                                              | SBICRA cannot be<br>This I <sup>2</sup> C bus circuit |            | -            |                                                       | -                                         |                  |                                                    |                              |                            |                |  |
|                            |                                                                                                                              | ous circuit itself allo                               |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|                            |                                                                                                                              | s not guaranteed in                                   |            | -            |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|                            |                                                                                                                              |                                                       |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
| Serial Bus Inte            | erface Data                                                                                                                  | Buffer Register                                       |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
| SBIDBR                     | 7                                                                                                                            | 6 5                                                   | 4          | 3            | 2                                                     | 1                                         | 0                | 1                                                  |                              |                            |                |  |
| (1FDAH)                    |                                                                                                                              |                                                       | <u> </u>   |              |                                                       | <u> </u>                                  | <u>ı</u>         |                                                    | (Initial value: <sup>•</sup> | **** ****) R/W             |                |  |
|                            |                                                                                                                              | For writing transmit                                  |            |              |                                                       |                                           |                  | ~ ~ w                                              | rita data buffa              | ar and a road buff         | or oro         |  |
|                            |                                                                                                                              | ndependent in SBI                                     |            |              |                                                       |                                           | ,                |                                                    |                              |                            |                |  |
|                            |                                                                                                                              | such as bit manipula                                  |            |              | , ODIDDI                                              | ( canno                                   |                  | with                                               |                              | ioury write motio          | 010113         |  |
|                            |                                                                                                                              | : Don't care                                          |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
| I <sup>2</sup> C bus Addre | ee Rogisto                                                                                                                   |                                                       |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|                            | 55 Register<br>7                                                                                                             | 6 5                                                   | 4          | 3            | 2                                                     | 1                                         | 0                |                                                    |                              |                            |                |  |
| I2CAR                      | ,<br>                                                                                                                        |                                                       | ve addres  |              |                                                       |                                           | ALS              |                                                    | (Initial value: (            |                            |                |  |
| (1FDBH)                    | SA6                                                                                                                          | SA5 SA4                                               | SA3        | SA2          | SA1                                                   | <u> </u>                                  | <u>0 1 720</u>   | ,                                                  | (Initial value. )            | 0000 0000)                 |                |  |
|                            | SA                                                                                                                           | Slave address se                                      | election   |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|                            |                                                                                                                              | Address recog                                         | nition m   | ode          | 0: Slave                                              | address                                   | recognitio       | n                                                  |                              |                            | Write<br>only  |  |
|                            | ALS                                                                                                                          | specification                                         |            |              | 1: Non s                                              | lave add                                  | lress recog      | gnitior                                            | ١                            |                            | Only           |  |
|                            |                                                                                                                              | 2CAR is write-only                                    | register,  | which        | cannot b                                              | e used                                    | with any o       | f read                                             | d-modify-write               | instruction such           | as bit         |  |
|                            |                                                                                                                              | nanipulation, etc.                                    | "OOL!"     |              |                                                       |                                           |                  |                                                    | alama and be d               |                            | :              |  |
|                            | Note 2: Do not set I2CAR to "00H" to avoid the incorrect response of acknowledgment in slave mode. If "00H" is set           |                                                       |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|                            | to I2CAR as the Slave Address and received "01H" in slave mode, the device might transmit the<br>acknowledgment incorrectly. |                                                       |            |              |                                                       |                                           |                  |                                                    |                              |                            |                |  |
|                            |                                                                                                                              |                                                       | -          | -            | Carta                                                 | I D ='                                    | tor A C          | a de l                                             | Due latert                   | Data D. "                  | -              |  |
|                            | riuure 2                                                                                                                     | 2.12.3 Serial                                         | DUS INC    | пасе         | CONTRO                                                | n reals                                   | SIGI A. 30       | enal                                               | DUS INTERIS                  | ace Data Bulle             | 1              |  |

Register and I<sup>2</sup>C Bus Address Register

| Serial Bus Inte | erface Cont                                                                                                                   | rol Register B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |  |  |  |  |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|--|--|--|--|
| SBICRB          | 7                                                                                                                             | 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |  |  |  |  |  |  |
| (1FDCH)         | MST                                                                                                                           | TRX BB PIN SBIM SWRST1SWRST0 (Initial value: 0001 0000)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |  |  |  |  |  |  |
|                 | MST                                                                                                                           | Master/slave selection 0: Slave<br>1: Master                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |  |  |  |  |  |  |
|                 | TRX                                                                                                                           | Transmitter/receiver selection 0: Receiver<br>1: Transmitter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |  |  |  |  |  |  |
|                 | BB                                                                                                                            | Start/stop generation         0: Generate a stop condition when MST, TRX and PIN are "1"           1: Generate a start condition when MST, TRX and PIN are "1"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ,             |  |  |  |  |  |  |
|                 | PIN                                                                                                                           | Cancel interrupt service request 0: -<br>1: Cancel interrupt service request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Write<br>only |  |  |  |  |  |  |
|                 | SBIM                                                                                                                          | Serial bus interface operating mode selection       00: Port mode (Serial bus interface output disable)         01: Reserved       10: I <sup>2</sup> C bus mode         11: Reserved       11: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |  |  |  |  |  |  |
|                 | SWRST1<br>SWRST0                                                                                                              | Software reset start bit Software reset starts by first writing "10" and next writing "01"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |  |  |  |  |  |  |
|                 | Note 1: S                                                                                                                     | Switch a mode to port after confirming that the bus is free.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |  |  |  |  |  |  |
|                 | Note 2: Switch a mode to I <sup>2</sup> C bus mode after confiming that the port is high level.                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               |  |  |  |  |  |  |
|                 | Note 3: S                                                                                                                     | BICRB has write-only register and must not be used with any of read-modify-write instructions such a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |  |  |  |  |  |  |
|                 | n                                                                                                                             | nanipulation, etc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               |  |  |  |  |  |  |
|                 | Note 4: When the SWRST (Bit1, 0 in SBICRB) is written to "01", "10" in I <sup>2</sup> C bus mode, software reset is occurred. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               |  |  |  |  |  |  |
|                 | NOLE 4. V                                                                                                                     | When the SWRST (Bit1, 0 in SBICRB) is written to "01", "10" in I C bus mode, software reset is o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | .currea.      |  |  |  |  |  |  |
|                 |                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               |  |  |  |  |  |  |
|                 | li                                                                                                                            | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |  |  |  |  |  |  |
|                 | li                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               |  |  |  |  |  |  |
|                 | lı<br>S                                                                                                                       | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |  |  |  |  |  |  |
|                 | lı<br>S<br>erface Statu                                                                                                       | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>us Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |  |  |  |  |  |  |
| SBISR           | erface Statu                                                                                                                  | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>us Register<br><u>6 5 4 3 2 1 0</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |  |  |  |  |  |  |
|                 | lı<br>S<br>erface Statu                                                                                                       | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>us Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST                                                                                                      | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>us Register<br><u>6 5 4 3 2 1 0</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |  |  |  |  |  |  |
| SBISR           | erface Statu                                                                                                                  | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>us Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST                                                                                               | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status 0: Slave                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST                                                                                                      | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>us Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX                                                                                        | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection 0: Receiver<br>status monitor 1: Transmitter<br>Bus status monitor 0: Bus free                                                                                                                                                                                                                                                                                                                                                                                                                         |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST                                                                                               | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection<br>status monitor 0: Receiver<br>status monitor 1: Transmitter<br>Bus status monitor 0: Bus free<br>1: Bus busy                                                                                                                                                                                                                                                                                                                                                                                        |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX<br>BB                                                                                  | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection 0: Receiver<br>status monitor 1: Transmitter<br>Bus status monitor 0: Bus free                                                                                                                                                                                                                                                                                                                                                                                                                         |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX                                                                                        | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection<br>status monitor 0: Receiver<br>status monitor 1: Transmitter<br>Bus status monitor 0: Bus free<br>1: Bus busy                                                                                                                                                                                                                                                                                                                                                                                        |               |  |  |  |  |  |  |
|                 | erface Statu<br>7<br>MST<br>MST<br>TRX<br>BB                                                                                  | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection<br>status monitor 0: Receiver<br>status monitor 1: Transmitter<br>Bus status monitor 0: Bus free<br><u>1: Bus busy</u><br>Interrupt service requests 0: Requesting interrupt service                                                                                                                                                                                                                                                                                                                   |               |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX<br>BB<br>PIN<br>AL                                                                     | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection<br>status monitor 0: Receiver<br>status monitor 1: Transmitter<br>Bus status monitor 0: Bus free<br>1: Bus busy<br>Interrupt service requests 0: Requesting interrupt service<br>status monitor 1: Releasing interrupt service request<br>Arbitration lost detection 0: –                                                                                                                                                                                                                              | Read          |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX<br>BB<br>PIN                                                                           | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>US Register<br>6 5 4 3 2 1 0<br>TRX BB PIN AL AAS AD0 LRB (Initial value: 0001 0000)<br>Master/slave selection status 0: Slave<br>monitor 1: Master<br>Transmitter/receiver selection 0: Receiver<br>status monitor 1: Transmitter<br>Bus status monitor 1: Transmitter<br>Bus status monitor 0: Bus free<br>1: Bus busy<br>Interrupt service requests 0: Requesting interrupt service<br>status monitor 1: Releasing interrupt service request<br>Arbitration lost detection 0: –<br>monitor 1: Arbitration lost detected                                                                                                                                                                        | Read          |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX<br>BB<br>PIN<br>AL<br>AAS                                                              | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Read          |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX<br>BB<br>PIN<br>AL                                                                     | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>USRegister<br>6 5 4 3 2 1 0<br>TRX BB PIN AL AAS AD0 LRB (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection<br>status monitor 1: Transmitter<br>Bus status monitor 1: Transmitter<br>Bus status monitor 0: Bus free<br>1: Bus busy<br>Interrupt service requests 0: Requesting interrupt service<br>status monitor 1: Releasing interrupt service request<br>Arbitration lost detection 0: -<br>monitor 1: Arbitration lost detected<br>Slave address match detection 0: Not detect slave address match or "GENERAL CALL"<br>monitor 1: Detect slave address match or "GENERAL CALL"                                              | Read          |  |  |  |  |  |  |
| SBISR           | erface Statu<br>7<br>MST<br>MST<br>TRX<br>BB<br>PIN<br>AL<br>AAS                                                              | n this case, the SBICRA, I2CAR and SBISR registers are initialized and the bits of SBICRB ex<br>SBIM (Bit3, 2 in SBICRB) are also initialized.<br>As Register<br><u>6 5 4 3 2 1 0</u><br><u>TRX BB PIN AL AAS AD0 LRB</u> (Initial value: 0001 0000)<br>Master/slave selection status<br>monitor 1: Master<br>Transmitter/receiver selection<br>status monitor 0: Receiver<br>Transmitter/receiver selection<br>status monitor 1: Transmitter<br>Bus status monitor 1: Transmitter<br>Bus status monitor 1: Releasing interrupt service<br>status monitor 1: Releasing interrupt service request<br>Arbitration lost detection<br>Slave address match detection<br>Slave address match detection<br>Slave address match detection<br>Mater 1: Detect slave address match or "GENERAL CALL"<br>"GENERAL CALL" detection 0: Not detect "GENERAL CALL" | Read          |  |  |  |  |  |  |

Figure 2.12.4 Serial Bus Interface Control Register B and Serial Bus Interface Status Register

- (1) Acknowledgement mode specification
  - a. Acknowledgment mode (ACK = "1")

To set the device as an acknowledgment mode, the ACK (Bit4 in SBICRA) should be set to "1". When a serial bus interface circuit is a master mode, an additional clock pulse is generated for an acknowledge signal. In a slave mode, a clock is counted for the acknowledge signal.

In the master transmitter mode, the SDA pin is released in order to receive an acknowledge signal from the receiver during additional clock pulse cycle. In the master receiver mode, the SDA pin is set to low level generation an acknowledge signal during additional clock pulse cycle.

In a slave mode, when a received slave address matches to a slave address which is set to the I2CAR or when a "GENERAL CALL" is received, the SDA pin is set to low level generating an acknowledge signal. After the matching of slave address or the detection of "GENERAL CALL", in the transmitter, the SDA pin is released in order to receive an acknowledge signal from the receiver during additional clock pulse cycle. In a receiver, the SDA pin is set to low level generation an acknowledge signal during additional clock pulse cycle after the matching of slave address or the detection of "GENERAL CALL"

The Table 2.12.1 shows the SCL and SDA pins status in acknowledgment mode.

| Mode   |     | Pin                                                         | Transmitter                                         | Receiver                                             |  |
|--------|-----|-------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------|--|
|        |     | SCL                                                         | An additional clock pulse is generated.             |                                                      |  |
| Master |     | SDA                                                         | Released in order to receive an acknowledge signal. | Set to low level generating an<br>acknowledge signal |  |
|        |     | SCL                                                         | A clock is counted for the acknowledge signal.      |                                                      |  |
| Slave  | 004 | When slave address matches<br>or a general call is detected | _                                                   | Set to low level generating an acknowledge signal.   |  |
|        | SDA | After matching of slave<br>address or general call          | Released in order to receive an acknowledge signal. | Set to low level generating an acknowledge signal.   |  |

Table 2.12.1 SCL and SDA Pins Status in Acknowledgement Mode

b. Non-acknowledgment mode (ACK = "0")

To set the device as a non-acknowledgement mode, the ACK should be cleared to "0".

In the master mode, a clock pulse for an acknowledge signal is not generated.

In the slave mode, a clock for a acknowledge signal is not counted.

(2) Number of transfer bits

The BC (Bits7 to 5 in SBICRA) is used to select a number of bits for next transmitting and receiving data.

Since the BC is cleared to "000" as a start condition, a slave address and direction bit transmissions are always executed in 8 bits. Other than these, the BC retains a specified value.

- (3) Serial clock
  - a. Clock source

The SCK (Bits2 to 0 in SBICRA) is used to select a maximum transfer frequency output from the SCL pin in the master mode. Set a communication baud rate that meets the I<sup>2</sup>C bus specification, such as the shortest pulse width of  $t_{LOW}$ , based on the equations shown below.

Four or more machine cycles are required for both high and low levels of pulse width in the external clock which is input from SCL pin.

Note: Since the I<sup>2</sup>C of TMP86FM48 can not be used as the fast mode and the high-speed mode, do not set SCK as the frequency that is over 100 kHz.



Figure 2.12.5 Clock Source

#### b. Clock synchronization

In the I<sup>2</sup>C bus, in order to drive a bus with a wired AND, a master device which pulls down a clock pulse to low will, in the first place, invalidate a clock pulse of another master device which generates a high-level clock pulse.

The serial bus interface circuit has a clock synchronization function. This function ensures normal transfer even if there are two or more masters on the same bus.

The example explains clock synchronization procedures when two masters simultaneously exist on a bus.



Figure 2.12.6 Clock Synchronization

As Master 1 pulls down the SCL pin to the low level at point "a", the SCL line of the bus becomes the low level. After detecting this situation, Master 2 resets counting a clock pulse in the high level and sets the SCL pin to the low level.

Master 1 finishes counting a clock pulse in the low level at point "b" and sets the SCL pin to the high level. Since Master 2 holds the SCL line of the bus at the low level, Master 1 waits for counting a clock pulse in the high level. After Master 2 sets a clock pulse to the high level at point "c" and detects the SCL line of the bus at the high level, Master 1 starts counting a clock pulse in the high level. Then, the master, which has finished the counting a clock pulse in the high level, pulls

down the SCL pin to the low level.

The clock pulse on the bus is determined by the master device with the shortest high-level period and the master device with the longest low-level period from among those master devices connected to the bus.

(4) Slave address and address recognition mode specification

When the serial bus interface circuit is used with an addressing format to recognize the slave address, clear the ALS (Bit0 in I2CAR) to "0", and set the SA (Bits7 to 1 in I2CAR) to the slave address.

When the serial bus interface circuit is used with a free data format not to recognize the slave address, set the ALS to "1". With a free data format, the slave address and the direction bit are not recognized, and they are processed as data from immediately after start condition.

(5) Master/slave selection

To set a master device, the MST (Bit7 in SBICRB) should be set to "1". To set a slave device, the MST should be cleared to "0".

When a stop condition on the bus or an arbitration lost is detected, the MST is cleared to "0" by the hardware.

(6) Transmitter/receiver selection

To set the device as a transmitter, the TRX (Bit6 in SBICRB) should be set to "1". To set the device as a receiver, the TRX should be cleared to "0". When data with an addressing format is transferred in the slave mode, the TRX is set to "1" by a hardware if the direction bit  $(R/\overline{W})$  sent from the master device is "1", and is cleared to "0" by a hardware if the bit is "0". In the master mode, after an acknowledge signal is returned from the slave device, the TRX is cleared to "0" by a hardware if a transmitted direction bit is "1", and is set to "1" by a hardware if it is "0". When an acknowledge signal is not returned, the current condition is maintained.

When a stop condition on the bus or an arbitration lost is detected, the TRX is cleared to "0" by the hardware. Table 2.12.2 shows TRX changing conditions in each mode and TRX value after changing.

| Mode   | Direction Bit | Conditions                      | TRX after Changing |
|--------|---------------|---------------------------------|--------------------|
| Slave  | "0"           | A received slave address is the | "0"                |
| mode   | "1"           | same value set to I2CAR         | "1"                |
| Master | "0"           |                                 | "1"                |
| mode   | "1"           | ACK signal is returned          | "O"                |

Table 2.12.2 TRX changing conditions in each mode

When a serial bus interface circuit operates in the free data format, a slave address and a direction bit are not recognized. They are handled as data just after generating a start condition. The TRX is not changed by a hardware. (7) Start/stop condition generation

When the BB (Bit5 in SBISR) is "0", a slave address and a direction bit which are set to the SBIDBR are output on a bus after generating a start condition by writing "1" to the MST, TRX, BB and PIN. It is necessary to set transmitted data to the SBIDBR and set ACK to "1" beforehand.



Figure 2.12.7 Start Condition Generation and Slave Address Generation

When the BB is "1", sequence of generating a stop condition is started by writing "1" to the MST, TRX and PIN, and "0" to the BB. Do not modify the contents of MST, TRX, BB and PIN until a stop condition is generated on a bus.



Figure 2.12.8 Stop Condition Generation

When a stop condition is generated and the SCL line on a bus is pulled-down to low level by another device, a stop condition is generated after releasing the SCL line.

The bus condition can be indicated by reading the contents of the BB (Bit5 in SBISR). The BB is set to "1" when a start condition on a bus is detected and is cleared to "0" when a stop condition is detected.

(8) Interrupt service request and cancel

When a serial bus interface circuit is in the master mode and transferring a number of clocks set by the BC and the ACK is complete, a serial bus interface interrupt request (INTSBI) is generated.

In the slave mode, the conditions of generating INTSBI are follows:

- At the end of acknowledge signal when the received slave address matches to the value set by the I2CAR
- At the end of acknowledge signal when a "GENERAL CALL" is received
- At the end of transferring or receiving after matching of slave address or receiving of "GENERAL CALL"

When a serial bus interface interrupt request occurs, the PIN (Bit4 in SBISR) is cleared to "0". During the time that the PIN is "0", the SCL pin is pulled-down to low level.

Either writing data to SBIDBR or reading data from the SBIDBR sets the PIN to "1".

The time from the PIN being set to "1" until the SCL pin is released takes  $t_{LOW}$ .

Although the PIN (Bit4 in SBICRB) can be set to "1" by the program, the PIN can not be cleared to "0" by the program.

Note: If the arbitration lost occurs, when the slave address does not match, the PIN is not cleared to "0" even though INTSBI is generated.

(9) Setting of I<sup>2</sup>C bus mode

The SBIM (Bit3 and 2 in SBICRB) is used to set I<sup>2</sup>C bus mode.

Set the SBIM to "10" in order to set  $I^2C$  bus mode. Before setting of  $I^2C$  bus mode, confirm serial bus interface pins in a high level, and then, write "10" to SBIM. And switch a port mode after confirming that a bus is free.

(10) Arbitration lost detection monitor

Since more than one master device can exist simultaneously on a bus, a bus arbitration procedure is implemented in order to guarantee the contents of transferred data.

Data on the SDA line is used for bus arbitration of the  $\mathrm{I^2C}$  bus.

The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on a bus. Master 1 and Master 2 output the same data until point "a". After that, when Master 1 outputs "1" and Master 2 outputs "0", since the SDA line of a bus is wired AND, the SDA line is pulled-down to the low level by Master 2. When the SCL line of a bus is pulled-up at point "b", the slave device reads data on the SDA line, that is data in Master 2. Data transmitted from Master 1 becomes invalid. The state in Master 1 is called "arbitration lost". A master device which loses arbitration releases the SDA pin and the SCL pin in order not to effect data transmitted from other masters with arbitration. When more than one master sends the same data at the first word, arbitration occurs continuously after the second word.



Figure 2.12.9 Arbitration Lost

The serial bus interface circuit compares levels of a SDA line of a bus with its SDA pin at the rising edge of the SCL line. If the levels are unmatched, arbitration is lost and the AL (Bit3 in SBISR) is set to "1".

When the AL is set to "1", the MST and TRX are cleared to "0" and the mode is switched to a slave receiver mode. Thus, the serial bus interface circuit stops output of clock pulses during data transfer after the AL is set to "1".

The AL is cleared to "0" by writing data to the SBIDBR, reading data from the SBIDBR or writing data to the SBICRB.

| Master | SCL pin           |                                                   | 8 9 1 2 3                            |  |
|--------|-------------------|---------------------------------------------------|--------------------------------------|--|
| A (    | SDA pin           | D7A X D6A X D5A X D4A X D3A X D2A X D1/           | A X D0A / D7A' X D6A' X D5A'         |  |
| Master | SCL pi <u>n</u>   | 1 2 3 4 7 7 7 $F 3 7 7 7$ $F 3 7 7 7$ $F 3 7 7 7$ | · _ / 8 · _ / 9 · _ /                |  |
| В      | SDA pin           |                                                   | to high level as losing arbitration. |  |
|        | AL                | \\                                                |                                      |  |
|        | MST               | ť)                                                |                                      |  |
|        | TRX               |                                                   | )                                    |  |
|        | Accesse<br>SBIDBR | d to                                              | ŕ                                    |  |
|        | INTSBI            |                                                   | Î                                    |  |

Figure 2.12.10 Example of when a Serial Bus Interface Circuit is a Master B

(11) Slave address match detection monitor

In the slave mode, the AAS (Bit2 in SBISR) is set to "1" when the received data is "GENERAL CALL" or the received data matches the slave address setting by I2CAR with an address recognition mode (ALS = 0).

When a serial bus interface circuit operates in the free data format (ALS = 1), the AAS is set to "1" after receiving the first 1-word of data.

The AAS is cleared to "0" by writing data to the SBIDBR or reading data from the SBIDBR.

#### (12) GENERAL CALL detection monitor

The AD0 (Bit1 in SBISR) is set to "1" when all 8-bit received data is "0" immediately after a start condition in a slave mode. The AD0 is cleared to "0" when a start or stop condition is detected on a bus.

#### (13) Last received bit monitor

The SDA value stored at the rising edge of the SCL is set to the LRB (Bit0 in SBISR). In the acknowledge mode, immediately after an INTSBI interrupt request is generated, an acknowledge signal is read by reading the contents of the LRB.

- 2.12.6 Data Transfer of I<sup>2</sup>C Bus
  - (1) Device initialization

For initialization of device, set the ACK in SBICRA to "1" and the BC to "000". Specify the data length to 8 bits to count clocks for an acknowledge signal. Set a transfer frequency to the SCK in SBICRA.

Next, set the slave address to the SA in I2CAR and clear the ALS to "0" to set an addressing format.

After confirming that the serial bus interface pin is high level, for specifying the default setting to a slave receiver mode, clear "0" to the MST, TRX and BB in SBICRB, set "1" to the PIN, "10" to the SBIM, and "00" to bits SWRST1 and SWRST0.

- Note: The initialization of a serial bus interface circuit must be complete within the time from all devices which are connected to a bus have initialized to and device does not generate a start condition. If not, the data can not be received correctly because the other device starts transferring before an end of the initialization of a serial bus interface circuit.
- (2) Start condition and slave address generation

Confirm a bus free status (BB = 0).

Set the ACK to "1" and specify a slave address and a direction bit to be transmitted to the SBIDBR.

By writing "1" to the MST, TRX, BB and PIN, the start condition is generated on a bus and then, the slave address and the direction bit which are set to the SBIDBR are output. An INTSBI interrupt request occurs at the 9th falling edge of a SCL clock cycle, and the PIN is cleared to "0". The SCL pin is pulled-down to the low level while the PIN is "0". When an interrupt request occurs, the TRX changes by the hardware according to the direction bit only when an acknowledge signal is returned from the slave device.

- Note 1: Do not write a slave address to be output to the SBIDBR while data is transferred. If data is written to the SBIDBR, data to been outputting may be destroyed.
- Note 2: The bus free must be confirmed by software within 98.0  $\mu$ s (The shortest transmitting time according to the I<sup>2</sup>C bus standard) after setting of the slave address to be output. Only when the bus free is confirmed, set "1" to the MST, TRX, BB, and PIN to generate the start conditions. If the writing of slave address and setting of MST, TRX, BB and PIN doesn't finish within 98.0  $\mu$ s, the other masters may start the transferring and the slave address data written in SBIDBR may be broken.



Figure 2.12.11 Start Condition Generation and Slave Address Transfer

(3) 1-word data transfer

Check the MST by the INTSBI interrupt process after an 1-word data transfer is completed, and determine whether the mode is a master or slave.

a. When the MST is "1" (Master mode)

Check the TRX and determine whether the mode is a transmitter or receiver.

1. When the TRX is "1" (Transmitter mode)

Test the LRB. When the LRB is "1", a receiver does not request data. Implement the process to generate a stop condition (Described later) and terminate data transfer.

When the LRB is "0", the receiver requests next data. When the next transmitted data is other than 8 bits, set the BC, set the ACK to "1", and write the transmitted data to the SBIDBR. After writing the data, the PIN becomes "1", a serial clock pulse is generated for transferring a next 1 word of data from the SCL pin, and then the 1 word of data is transmitted. After the data is transmitted, and an INTSBI interrupt request occurs. The PIN become "0" and the SCL pin is set to low level. If the data to be transferred is more than one word in length, repeat the procedure from the LRB test above.



Figure 2.12.12 Example of when BC = "000", ACK = "1"

2. When the TRX is "0" (Receiver mode)

When the next transmitted data is other than of 8 bits, set the BC again. Set the ACK to "1" and read the received data from the SBIDBR (Reading data is undefined immediately after a slave address is sent). After the data is read, the PIN becomes "1". A serial bus interface circuit outputs a serial clock pulse to the SCL to transfer next 1-word of data and sets the SDA pin to "0" at the acknowledge signal timing.

An INTSBI interrupt request occurs and the PIN becomes "0". Then a serial bus interface circuit outputs a clock pulse for 1-word of data transfer and the acknowledge signal each time that received data is read from the SBIDBR.



Figure 2.12.13 Example of when BC = "000", ACK = "1"

To make the transmitter terminate transmit, clear the ACK to "0" before reading data which is 1-word before the last data to be received. A serial bus interface circuit does not generate a clock pulse for the acknowledge signal by clearing ACK. In the interrupt routine of end of transmission, when the BC is set to "001" and read the data, PIN is set to "1" and generates a clock pulse for a 1-bit data transfer. In this case, since the master device is a receiver, the SDA line on a bus keeps the high-level. The transmitter receives the high-level signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete.

After 1-bit data is received and an interrupt request has occurred, generates the stop condition to terminate transmit, generate the stop condition to terminate data transfer.



Figure 2.12.14 Termination of Data Transfer in Master Receiver Mode

b. When the MST is "0" (Slave mode)

In the slave mode, a serial bus interface circuit operates either in normal slave mode or in slave mode after losing arbitration.

In the slave mode, the conditions of generating INTSBI are follows:

- When the received slave address matches to the value set by the I2CAR
- When a "GENERAL CALL" is received
- At the end of transferring or receiving after matching of slave address or receiving of "GENERAL CALL"

A serial bus interface circuit changes to a slave mode if arbitration is lost in the master mode. And an INTSBI interrupt request occurs when word data transfer terminates after losing arbitration. The behavior of INTSBI and PIN after losing arbitration are shown in Table 2.12.3.

|        | When the Arbitration Lost Occurs during<br>Transmission of Slave Address as a Master                                                                                                      | When the Arbitration Lost Occurs during<br>Transmission of Data as a Master Transmit Mode |  |  |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|
| INTSBI | INTSBI is generated at the termination of word data.                                                                                                                                      |                                                                                           |  |  |
| PIN    | When the slave address matches the value set by I2CAR, the PIN is cleared to "0" by generating of INTSBI. When the slave address doesn't match the value set by I2CAR, the PIN keeps "1". | PIN keeps "1".                                                                            |  |  |

Table 2.12.3 The Behavior of INTSBI and PIN after Losing Arbitration

Check the AL (Bit3 in the SBISR), the TRX (Bit6 in the SBISR), the AAS (Bit2 in the SBISR), and the AD0 (Bit1 in the SBISR) and implements processes according to conditions listed in Table 2.12.4.

| TRX | AL | AAS | AD0 | Conditions                                                                                                                                                                                                                         | Process                                                                                                                                                                                                                                                                                                                         |
|-----|----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | 1  | 1   | 0   | A serial bus interface circuit loses arbitration<br>when transmitting a slave address. And<br>receives a slave address of which the value<br>of the direction bit sent from another master<br>is "1".                              | Set the number of bits in 1 word to the BC and write transmitted data to the SBIDBR.                                                                                                                                                                                                                                            |
|     | 0  | 1   | 0   | In the slave receiver mode, a serial bus interface circuit receives a slave address of which the value of the direction bit sent from the master is "1".                                                                           |                                                                                                                                                                                                                                                                                                                                 |
|     |    | 0   | 0   | In the slave transmitter mode, 1-word data is transmitted.                                                                                                                                                                         | Test the LRB. If the LRB is set to "1", set the<br>PIN to "1" since the receiver does not<br>request next data. Then, clear the TRX to "0"<br>to release the bus. If the LRB is set to "0", set<br>the number of bits in 1 word to the BC and<br>write transmitted data to the SBIDBR since<br>the receiver requests next data. |
| 0   | 1  | 1   | 1/0 | A serial bus interface circuit loses arbitration<br>when transmitting a slave address. And<br>receives a slave address of which the value<br>of the direction bit sent from another master<br>is "0" or receives a "GENERAL CALL". | Read the SBIDBR for setting the PIN to "1"<br>(Reading dummy data) or write "1" to the<br>PIN.                                                                                                                                                                                                                                  |
|     |    | 0   | 0   | A serial bus interface circuit loses arbitration<br>when transmitting a slave address or data.<br>And terminates transferring word data.                                                                                           | A serial bus interface circuit is changed to<br>slave mode. To clear AL to "0", read the<br>SBIDBR or write the data to SBIDBR.                                                                                                                                                                                                 |
|     | 0  | 1   | 1/0 | In the slave receiver mode, a serial bus<br>interface circuit receives a slave address of<br>which the value of the direction bit sent from<br>the master is "0" or receives "GENERAL<br>CALL".                                    | Read the SBIDBR for setting the PIN to "1" (Reading dummy data) or write "1" to the PIN.                                                                                                                                                                                                                                        |
|     |    | 0   | 1/0 | In the slave receiver mode, a serial bus interface circuit terminates receiving of 1-word data.                                                                                                                                    | Set the number of bits in 1-word to the BC and read received data from the SBIDBR.                                                                                                                                                                                                                                              |

Note: In the slave mode, if the slave address set in I2CAR is "00000000B", the TRX changes to "1" by receiving the start byte data "00000001B".

(4) Stop condition generation

When the BB is "1", a sequence of generating a stop condition is started by setting "1" to the MST, TRX and PIN, and clear "0" to the BB. Do not modify the contents of the MST, TRX, BB, PIN until a stop condition is generated on a bus.

When a SCL line on a bus is pulled down by other devices, a serial bus interface circuit generates a stop condition after they release a SCL line.





#### (5) Restart

Restart is used to change the direction of data transfer between a master device and a slave device during transferring data. The following explains how to restart a serial bus interface circuit.

Clear "0" to the MST, TRX and BB and set "1" to the PIN. The SDA pin retains the high-level and the SCL pin is released. Since a stop condition is not generated on a bus, a bus is assumed to be in a busy state from other devices. Test the BB until it becomes "0" to check that the SCL pin a serial bus interface circuit is released. Test the LRB until it becomes "1" to check that the SCL line on a bus is not pulled-down to the low level by other devices. After confirming that a bus stays in a free state, generate a start condition with procedure (2).

In order to meet setup time when restarting, take at least  $4.7 \ \mu s$  of waiting time by software from the time of restarting to confirm that a bus is free until the time to generate a start condition.

Note: When restarting after receiving in master recever mode, because the device doesn't send an acknowledgment as a last data, the level of SCL line can not be confirmed by reading LRB. Therefore, confirm the status of SCL line by reading P5PRD register.



Figure 2.12.16 Timing Diagram when Restarting

# 2.13 SIO (Synchronous Serial Interface)

The TMP86FM48 contains two channels of SIO (Synchronous serial interface). These serial interfaces connect to an external device via SI1, SI2, SO1, SO2,  $\overline{\text{SCK1}}$  and  $\overline{\text{SCK2}}$  pins. The SI1, SI2, SO1, SO2,  $\overline{\text{SCK1}}$  and  $\overline{\text{SCK2}}$  pins respectively are shared with P05, P11, P06, P10, P07 and P12. When these pins are used as serial interface, the output latches for each port of P0 and P1 must be set to "1".

Because SIO1 and SIO2 are the same except that the registers and the function pin for each SIO are assigned as different specification, explanation here is made of only SIO1. The registers for SIO1 and SIO2 are listed in Table below.

|                              | SIO1     |         | SIO2     |         |
|------------------------------|----------|---------|----------|---------|
|                              | Register | Address | Register | Address |
| SIO control register         | SIO1CR   | 0017H   | SIO2CR   | 001BH   |
| SIO status register          | SIO1SR   | 0018H   | SIO2SR   | 001CH   |
| SIO receive buffer register  | SIO1RDB  | 0019H   | SIO2RDB  | 001DH   |
| SIO transmit buffer register | SIO1TDB  | 0019H   | SIO2TDB  | 001DH   |

Table 2.13.1 The Registers for SIO1 and SIO2

## 2.13.1 Configuration



Figure 2.13.1 Synchronous Serial Interface

## 2.13.2 Control

The SIO is controlled using the serial interface control register (SIO1CR). The operating status of the serial interface can be inspected by reading the status register (SIO1SR).

| Serial Interface Control Register 1 |             |                                         |          |                         |                           |                                |                                |      |  |
|-------------------------------------|-------------|-----------------------------------------|----------|-------------------------|---------------------------|--------------------------------|--------------------------------|------|--|
|                                     | 7 6         | 5 4 3 2                                 | 1        | 0                       |                           |                                |                                |      |  |
| SIO1CR<br>(0017H)                   | SIOS SIOI   | NH SIQM SIODIR                          | SCK      | (Initial valu           | ie: 0000 0000)            |                                |                                |      |  |
| (,                                  |             |                                         |          |                         |                           |                                |                                |      |  |
|                                     | SIOS        | Specify start/stop of transfer          | 0: St    | ор                      |                           |                                |                                |      |  |
|                                     | 3103        | Specify start/stop of transfer          | 1: St    | art                     |                           |                                |                                |      |  |
|                                     | SIOINH      | Forcibly stops transfer                 | 0: –     |                         |                           |                                |                                |      |  |
|                                     |             | (Note 1)                                | 1: Fo    | orcibly stop (Autom     | atically cleared to       | "0" after stopping)            |                                |      |  |
|                                     |             |                                         |          | ansmit mode             |                           |                                |                                |      |  |
|                                     | SIOM        | Selects transfer mode                   | -        | eceive mode             |                           |                                |                                |      |  |
|                                     |             |                                         | -        | ansmit/receive mo       | de                        |                                |                                |      |  |
|                                     |             |                                         |          | eserved                 |                           |                                |                                |      |  |
|                                     | SIODIR      | Selects direction of transfer           |          | SB (Transfer begir      | •                         |                                |                                |      |  |
|                                     |             |                                         | 1: LS    | B (Transfer begin       | <b>2</b> /                |                                | R/W                            |      |  |
|                                     |             |                                         |          |                         | r IDLE 1/2 mode           | SLOW/SLEEP                     | 10,00                          |      |  |
|                                     |             | CK Selects serial clock                 |          |                         |                           | TBTCR<br><dv7ck> = "0"</dv7ck> | TBTCR<br><dv7ck> = "1"</dv7ck> | mode |  |
|                                     |             |                                         | 000      | $fc/2^{12}$             | $\frac{1}{\text{fs/2}^4}$ | fs/2 <sup>4</sup>              |                                |      |  |
|                                     |             |                                         | 001      | $fc/2^8$                | fc/2 <sup>8</sup>         | Reserved                       |                                |      |  |
|                                     | SCK         |                                         | 010      | $fc/2^7$                | $fc/2^7$                  | Reserved                       |                                |      |  |
|                                     |             |                                         | 011      | fc/2 <sup>6</sup>       | fc/2 <sup>6</sup>         | Reserved                       |                                |      |  |
|                                     |             |                                         | 100      | fc/2 <sup>5</sup>       | fc/2 <sup>5</sup>         | Reserved                       |                                |      |  |
|                                     |             |                                         | 101      | fc/2 <sup>4</sup>       | fc/2 <sup>4</sup>         | Reserved                       |                                |      |  |
|                                     |             |                                         | 110      | fc/2 <sup>3</sup>       | fc/2 <sup>3</sup>         | Reserved                       |                                |      |  |
|                                     |             |                                         | 111      | External                | clock (input from         | SCK1 pin)                      |                                |      |  |
|                                     | Note 1: W   | /hen SIO1CR <sioinh> is set to</sioinh> | "1", SIO | 1CR <sios>, SIO1</sios> | ISR register, SIO1        | RDB register and S             | TOTDB                          |      |  |
|                                     | re          | gister are initialized.                 |          |                         |                           |                                |                                |      |  |
|                                     | Note 2: T   | ransfer mode, direction of transf       | er and s | erial clock must be     | e select durina the       | transfer is stopping           | a (when                        |      |  |
|                                     |             | IO1SR <siof> = "0").</siof>             |          |                         |                           |                                |                                |      |  |
|                                     |             | :: High frequency clock [Hz], fs: I     | ow frequ | iency clock *· Dor      | n't care                  |                                |                                |      |  |
|                                     | 14010 0. 10 |                                         |          |                         | i i ouro                  |                                |                                |      |  |

Figure 2.13.2 Serial Interface Control Register

# TOSHIBA

| Serial Interface<br>SIO1SR<br>(0018H) | ce Status Reg<br>7 6<br>SIOF SEF                                                                                                                                                                                                              | 5 4 3 2                       | 0<br>R (Initial value: 0010 00**)                                                                                                                                                                                               |              |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
|                                       | SIOF         Serial transfer operation<br>status monitor           SEF         Number of clocks monitor                                                                                                                                       |                               | 0: Transfer finished<br>1: Transfer in progress<br>0: 8 clocks<br>1: 1 to 7 clocks                                                                                                                                              |              |
|                                       | TXF                                                                                                                                                                                                                                           | Transmit buffer empty flag    | <ul><li>0: Data exists in transmit buffer</li><li>1: No data exists in transmit buffer</li></ul>                                                                                                                                | Read<br>only |
|                                       | RXF                                                                                                                                                                                                                                           | Receive buffer full flag      | <ul><li>0: No data exists in receive buffer</li><li>1: Data exists in receive buffer</li></ul>                                                                                                                                  |              |
|                                       | TXERR                                                                                                                                                                                                                                         | Transfer operation error flag | <ul> <li>Read</li> <li>0: - (No error exist)</li> <li>1: Transmit buffer under run occurs in an external clock mode.</li> <li>Write</li> <li>0: Clear the flag</li> <li>1: - (A write of "1" to this bit is ignored)</li> </ul> | R/W          |
|                                       | RXERR                                                                                                                                                                                                                                         | Receive operation error flag  | Read<br>0: – (No error exist)<br>1: Receive buffer over run occurs in an external clock mode.<br>Write<br>0: Clear the flag<br>1: – (A write of "1" to this bit is ignored)                                                     |              |
|                                       | Note 1: The operation error flag (TXERR and RXERR) are not automatically cleared by stopping transfer with SIO1CR <sios> = "0". Therefore, set these bits to "0" for clearing these error flag. Or set SIO1CR<sioinh> to "1".</sioinh></sios> |                               |                                                                                                                                                                                                                                 |              |
|                                       | Note 2: *:                                                                                                                                                                                                                                    |                               |                                                                                                                                                                                                                                 |              |







## 2.13.3 Functional Description

- (1) Serial clock
  - a. Clock source

The serial clock can be selected by using SIO1CR<SCK>. When the serial clock is changed, the writing instruction to SIO1CR<SCK> should be executed while the transfer is stopped (when SIO1SR<SIOF> = "0").

1. Internal clock

Setting the SIO1CR<SCK> to other than "111" outputs the clock (Shown in Table 2.8.2) as serial clock outputs from  $\overline{\text{SCK1}}$  pin. At the before beginning or finishing of a transfer,  $\overline{\text{SCK1}}$  pin is kept in high level.

When writing (in the transmit mode) or reading (in the receive mode) data can not follow the serial clock rate, an automatic-wait function is executed to stop the serial clock automatically and hold the next shift operation until reading or writing is completed. The maximum time from releasing the automatic-wait function by reading or writing a data is 1 cycle of the selected serial clock until the serial clock comes out from  $\overline{SCK1}$  pin.



Figure 2.13.5 Automatic-wait Function (Example of transmit mode)

|     |                   |                       |                   |                       |                   | ,        |
|-----|-------------------|-----------------------|-------------------|-----------------------|-------------------|----------|
|     |                   | NORMAL1/2,            | SLOW1/2, SLEEP1/2 |                       |                   |          |
|     | <b>TBTCR</b>      | <dv7ck> = "0"</dv7ck> | TBTCR-            | <dv7ck> = "1"</dv7ck> |                   | Mode     |
|     | Serial<br>Clock   | Baud Rate Baud Rate   |                   | Serial<br>Clock       | Baud Rate         |          |
| 000 | fc/212            | 3.906 kbps            | fs/2 <sup>4</sup> | 2048 bps              | fs/2 <sup>4</sup> | 2048 bps |
| 001 | fc/2 <sup>8</sup> | 62.5 kbps             | fc/2 <sup>8</sup> | 62.5 kbps             | Reserved          | -        |
| 010 | fc/27             | 125 kbps              | fc/27             | 125 kbps              | Reserved          | -        |
| 011 | fc/2 <sup>6</sup> | 250 kbps              | fc/2 <sup>6</sup> | 250 kbps              | Reserved          | -        |
| 100 | fc/2 <sup>5</sup> | 500 kbps              | fc/2 <sup>5</sup> | 500 kbps              | Reserved          | -        |
| 101 | fc/24             | 1.00 Mbps             | fc/24             | 1.00 Mbps             | Reserved          | -        |
| 110 | fc/2 <sup>3</sup> | 2.00 Mbps             | fc/2 <sup>3</sup> | 2.00 Mbps             | Reserved          | -        |

Table 2.13.2 Serial Clock Rate (fc = 16 MHz, fs = 32.768kHz)

2. External clock

When an external clock is selected by setting SIO1CR<SCK> to "111", the clock via the  $\overline{\text{SCK1}}$  pin from an external source is used as the serial clock.

To ensure shift operation, the serial clock pulse width must be 4/fc or more for both "H" and "L" levels.





## b. Shift edges

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

1. Leading edge shift

Data is shifted on leading edges of the serial clock (Falling edges of the  $\overline{\rm SCK1}$  pin input/output).

2. Trailing edge shift

Data is shifted on trailing edges of the serial clock (Rising edges of the  $\overline{\text{SCK1}}$  pin input/output).



### Figure 2.13.7 Shift Edge

(2) Transfer bit direction

Transfer data direction can be selected by using SIO1CR<SIODIR>. The transfer data direction can't be set individually for transmit and receive operations.

When the data direction is changed, the writing instruction to SIO1CR<SIODIR> should be executed while the transfer is stopped (when SIO1SR<SIOF> = "0").



#### Figure 2.13.8 Transfer Bit Direction (Example of transmit mode)

- a. Transmit mode
  - 1. MSB transmit mode

MSB transmit mode is selected by setting SIO1CR<SIODIR> to "0", in which case the data is transferred sequentially beginning with the most significant bit (Bit7).

2. LSB transmit mode

LSB transmit mode is selected by setting SIO1CR<SIODIR> to "1", in which case the data is transferred sequentially beginning with the least significant bit (Bit0).

- b. Receive mode
  - 1. MSB receive mode

MSB receive mode is selected by setting SIO1CR<SIODIR> to "0", in which case the data is received sequentially beginning with the most significant bit (Bit7).

2. LSB receive mode

LSB receive mode is selected by setting SIO1CR<SIODIR> to "1", in which case the data is received sequentially beginning with the least significant bit (Bit0).

- c. Transmit/receive mode
  - 1. MSB transmit/receive mode

MSB transmit/receive mode are selected by setting SIO1CR<SIODIR> to "0" in which case the data is transferred sequentially beginning with the most significant bit (Bit7) and the data is received sequentially beginning with the most significant (Bit7).

2. LSB transmit/receive mode

LSB transmit/receive mode are selected by setting SIO1CR<SIODIR> to "1", in which case the data is transferred sequentially beginning with the least significant bit (Bit0) and the data is received sequentially beginning with the least significant (Bit0).

(3) Transfer modes

Transmit, receive and transmit/receive mode are selected by using SIO1CR<SIOM>.

- a. Transmit mode
  - Transmit mode is selected by writing "00" to SIO1CR<SIOM>.
  - 1. Starting the transmit operation

Transmit mode is selected by setting "00" to SIO1CR<SIOM>. Serial clock is selected by using SIO1CR<SCK>. Transfer direction is selected by using SIO1CR<SIODIR>.

When a transmit data is written to the transmit buffer register (SIO1TDB), SIO1SR<TXF> is cleared to "0".

After SIO1CR<SIOS> is set to "1", SIO1SR<SIOF> is set synchronously to "1" the falling edge of  $\overline{\text{SCK1}}$  pin.

The data is transferred sequentially starting from SO1 pin with the direction of the bit specified by SBIDIR<SIODIR>, synchronizing with the  $\overline{\text{SCK1}}$  pin's falling edge.

SIO1SR<SEF> is kept in high level, between the first clock falling edge of  $\overline{SCK1}$  pin and eighth clock falling edge.

SIO1SR<TXF> is set to "1" at the rising edge of  $\overline{\text{SCK1}}$  pin after the data written to the SIO1TDB is transferred to shift register, then the INTSIO1 interrupt request is generated, synchronizing with the next falling edge on  $\overline{\text{SCK1}}$  pin.

- Note 1: In internal clock operation, when SIO1CR<SIOS> is set to "1", transfer mode does not start without writing a transmit data to the transmit buffer register (SIO1TDB).
- Note 2: In internal clock operation, when the SIO1CR<SIOS> is set to "1", SIO1TDB is transferred to shift register after maximum 1-cycle of serial clock frequency, then a serial clock is output from SCK1 pin.
- Note 3: In external clock operation, when the falling edge is input from SCK1 pin after SIO1CR<SIOS> is set to "1", SIO1TDB is transferred to shift register immediately.
- 2. During the transmit operation

When data is written to SIO1TDB, SIO1SR<TXF> is cleared to "0".

In internal clock operation, in case a next transmit data is not written to SIO1TDB, the serial clock stops to "H" level by an automatic-wait function when all of the bit set in the SIO1TDB has been transmitted. Automatic-wait function is released by writing a transmit data to SIO1TDB. Then, transmit operation is restarted after maximum 1-cycle of serial clock.

When the next data is written to the SIO1TDB before termination of previous 8-bit data with SIO1SR<TXF> = "1", the next data is continuously transferred after transmission of previous data.

In external clock operation, after SIO1SR<TXF> is set to "1", the transmit data must be written to SIO1TDB before the shift operation of the next data begins.

If the transmit data is not written to SIO1TDB, transmit error occurs immediately after shift operation is started. Then, INTSIO1 interrupt request is generated after SIO1SR<TXERR> is set to "1".

3. Stopping the transmit operation

There are two ways for stopping transmits operation.

• The way of clearing SIO1CR<SIOS>.

When SIO1CR<SIOS> is cleared to "0", transmit operation is stopped after all transfer of the data is finished. When transmit operation is finished, SIO1SR<SIOF> is cleared to "0" and SO1 pin is kept in high level.

In external clock operation, SIO1CR<SIOS> must be cleared to "0" before SIO1SR<SEF> is set to "1" by beginning next transfer.

• The way of setting SIO1CR<SIOINH>.

Transmit operation is stopped immediately after SIO1CR<SIOINH> is set to "1". In this case, SIO1CR<SIOS>, SIO1SR register, SIO1RDB register and SIO1TDB register are initialized.



Figure 2.13.9 Example of Internal Clock and MSB Transmit Mode



Figure 2.13.10 Example of External Clock and MSB Transmit Mode



Figure 2.13.11 Hold Time of the End of Transmit Mode

4. Transmit error processing

Transmit errors occur on the following situation.

• Shift operation starts before writing next transmit data to SIO1TDB in external clock operation.

If transmit errors occur during transmit operation, SIO1SR<TXERR> is set to "1" immediately after starting shift operation. Synchronizing with the next serial clock falling edge, INTSIO1 interrupt request is generated.

If shift operation starts before writing data to SIO1TDB after SIO1CR <SIOS> is set to "1", SIO1SR<TXERR> is set to "1" immediately after shift operation is started and then INTSIO1 interrupt request is generated.

SO1 pin is kept in high level when SIO1SR<TXERR> is set to "1". When transmit error occurs, transmit operation must be forcibly stop by writing SIO1CR<SIOINH> to "1". In this case, SIO1CR<SIOS>, SIO1SR register, SIO1RDB register and SIO1TDB register are initialized.



Figure 2.13.12 Example of Transmit Error Processing

#### b. Receive mode

The receive mode is selected by writing "01" to SIO1CR<SIOM>.

1. Starting the receive operation

Receive mode is selected by setting "01" to SIO1CR<SIOM>. Serial clock is selected by using SIO1CR<SCK>. Transfer direction is selected by using SIO1CR<SIODIR>.

After SIO1CR<SIOS> is set to "1", SIO1SR<SIOF> is set synchronously to "1" the falling edge of  $\overline{\text{SCK1}}$  pin.

Synchronizing with the  $\overline{\text{SCK1}}$  pin's rising edge, the data is received sequentially from SI1 pin with the direction of the bit specified by SBIDIR<SIODIR>.

SIO1SR < SEF > is kept in high level, between the first clock falling edge of  $\overline{SCK1}$  pin and eighth clock falling edge.

When 8-bit data is received, the data is transferred to SIO1RDB from shift register. INTSIO1 interrupt request is generated and SIO1SR<RXF> is set to "1".

- Note: In internal clock operation, when the SIO1CR<SIOS> is set to "1", the serial clock is generated from SCK1 pin after maximum 1-cycle of serial clock frequency.
- 2. During the receive operation

The SIO1SR<RXF> is cleared to "0" by reading a data from SIO1RDB.

In the internal clock operation, the serial clock stops to "H" level by an automatic-wait function when the all of the 8-bit data has been received. Automatic-wait function is released by reading a received data from SIO1RDB. Then, receive operation is restarted after maximum 1-cycle of serial clock.

In external clock operation, after SIO1SR<RXF> is set to "1", the received data must be read from SIO1RDB before the next data shift-in operation is finished.

If received data is not read out from SIO1RDB, receive error occurs immediately after shift operation is finished. Then INTSIO interrupt request is generated after SIO1SR<RXERR> is set to "1".

3. Stopping the receive operation

There are two ways for stopping the receive operation.

• The way of clearing SIO1CR<SIOS>.

When SIO1CR<SIOS> is cleared to "0", receive operation is stopped after all of the data is finished to receive. When receive operation is finished, SIO1SR<SIOF> is cleared to "0".

In external clock operation, SIO1CR<SIOS> must be cleared to "0" before SIO1SR<SEF> is set to "1" by starting the next shift operation.

- The way of setting SIO1CR<SIOINH>.
  - Receive operation is stopped immediately after SIO1CR<SIOINH> is set to "1". In this case, SIO1CR<SIOS>, SIO1SR register, SIO1RDB register and SIO1TDB register are initialized.



Figure 2.13.13 Example of Internal Clock and MSB Receive Mode



Figure 2.13.14 Example of External Clock and MSB Receive Mode

4. Receive error processing

Receive errors occur on the following situation. To protect SIO1RDB and the shift register contents, the received data is ignored while the SIO1SR<RXERR> is "1".

• Shift operation is finished before reading out received data from SIO1RDB at SIO1SR<RXF> is "1" in an external clock operation.

If receive error occurs, set the SIOCR1<SIOS> to "0" for reading the data that received immediately before error occurence. And read the data from SIO1RDB. Data in shift register (at errors occur) can be read by reading the SIO1RDB again.

When SIO1SR<RXERR> is cleared to "0" after reading the received data, SIO1SR<RXF> is cleared to "0".

After clearing SIO1CR<SIOS> to "0", when 8-bit serial clock is input to  $\overline{\text{SCK1}}$  pin, receive operation is stopped. To restart the receive operation, confirm that SIO1SR<SIOF> is cleared to "0".

If the receive error occurs, set the SIOCR1<SIOINH> to "1" for stopping the receive operation immediately. In this case, SIO1CR<SIOS>, SIO1SR register, SIO1RDB register and SIO1TDB register are initialized.



Figure 2.13.15 Example of Receive Error Processing

Note: If receive error is not corrected, an interrupt request does not generate after the error occurs.

c. Transmit/receive mode

The transmit/receive mode are selected by writing "10" to SIO1CR<SIOM>.

1. Starting the transmit/receive operation

Transmit/receive mode is selected by writing "10" to SIO1CR<SIOM>. Serial clock is selected by using SIO1CR<SCK>. Transfer direction is selected by using SIO1CR<SIODIR>.

When a transmit data is written to the transmit buffer register (SIO1TDB), SIO1SR<TXF> is cleared to "0".

After SIO1CR<SIOS> is set to "1", SIO1SR<SIOF> is set synchronously to the falling edge of  $\overline{\text{SCK1}}$  pin.

The data is transferred sequentially starting from SO1 pin with the direction of the bit specified by SIO1CR<SIODIR>, synchronizing with the  $\overline{\text{SCK1}}$  pin's falling edge. And receiving operation also starts with the direction of the bit specified by SIO1CR<SIODIR>, synchronizing with the  $\overline{\text{SCK1}}$  pin's rising edge.

SIO1SR < SEF > is kept in high level between the first clock falling edge of  $\overline{SCK1}$  pin and eighth clock falling edge.

SIO1SR<TXF> is set to "1" at the rising edge of  $\overline{\text{SCK1}}$  pin after the data written to the SIO1TDB is transferred to shift register. When 8-bit data has been received, the received data is transferred to SIO1RDB from shift register, then the INTSIO1 interrupt request occurs, synchronizing with setting SIO1SR<RXF> to "1".

- Note 1: In internal clock operation, when the SIO1CR<SIOS> is set to "1", SIO1TDB is transferred to shift register after maximum 1-cycle of serial clock frequency, then a serial clock is output from SCK1 pin.
- Note 2: In external clock operation, when the falling edge is input from SCK1 pin after SIO1CR<SIOS> is set to "1", SIO1TDB is transferred to shift register immediately. When the rising edge is input from SCK1 pin, receive operation also starts.

#### 2. During the transmit/receive operation

When data is written to SIO1TDB, SIO1SR<TXF> is cleared to "0" and when a data is read from SIO1RDB, SIO1SR<RXF> is cleared to "0".

In internal clock operation, in case of the condition described below, the serial clock stops to "H" level by an automatic-wait function when all of the bit set in the data has been transmitted.

- Next transmit data is not written to SIO1TDB after reading a received data from SIO1RDB
- Received data is not read from SIO1RDB after writing a next transmit data to SIO1TDB
- Neither SIO1TDB nor SIO1RDB is accessed after transmission.

The automatic wait function is released by writing the next transmit data to SIO1TDB after reading the received data from SIO1RDB, or reading the received data from SIO1RDB after writing the next data to SIO1TDB. Then, transmit/receive operation is restarted after maximum 1 cycle of serial clock. In external clock operation, reading the received data from SIO1RDB and writing the next data to SIO1TDB must be finished before the shift operation of the next data begins.

If the transmit data is not written to SIO1TDB after SIO1SR<TXF> is set to "1", transmit error occurs immediately after shift operation is started. When the transmit error occurred, SIO1SR<TXERR> is set to "1".

If received data is not read out from SIO1RDB before next shift operation starts after setting SIO1SR<RXF> to "1", receive error occurs immediately after shift operation is finished. When the receive error has occurred, SIO1SR<RXERR> is set to "1".

3. Stopping the transmit/receive operation

There are two ways for stopping the transmit/receive operation.

• The way of clearing SIO1CR<SIOS>.

When SIO1CR<SIOS> is cleared to "0", transmit/receive operation is stopped after all transfer of the data is finished. When transmit/receive operation is finished, SIO1SR<SIOF> is cleared to "0" and SO1 pin is kept in high level.

In external clock operation, SIO1CR<SIOS> must be cleared to "0" before SIO1SR<SEF> is set to "1" by beginning next transfer.

• The way of setting SIO1CR<SIOINH>.

Transmit/receive operation is stopped immediately after SIO1CR <SIOINH> is set to "1". In this case, SIO1CR<SIOS>, SIO1SR register, SIO1RDB register and SIO1TDB register are initialized.



Figure 2.13.16 Example of Internal Clock and MSB Transmit/Receive Mode



Figure 2.13.17 Example of External Clock and MSB Transmit/Receive Mode

4. Transmit/receive error processing

Transmit/receive errors occur on the following situation. Corrective action is different, which errors occur transmits or receives.

<u>Transmit errors</u>

Transmit errors occur on the following situation.

• Shift operation starts before writing next transmit data to SIO1TDB in external clock operation.

If transmit errors occur during transmit operation, SIO1SR<TXERR> is set to "1" immediately after starting shift operation. And INTSIO1 interrupt request is generated after all of the 8-bit data has been received.

If shift operation starts before writing data to SIO1TDB after SIO1CR <SIOS> is set to "1", SIO1SR<TXERR> is set immediately after starting shift operation. And INTSIO1 interrupt request is generated after all of the 8-bit data has been received.

SO1 pin is kept in high level when SIO1SR<TXERR> is set to "1". When transmit error occurs, transmit operation must be forcibly stop by writing SIO1CR<SIOINH> to "1" after the received data is read from SIO1RDB. In this case, SIO1CR<SIOS>, SIO1SR register, SIO1RDB register and SIO1TDB register are initialized.



Figure 2.13.18 Example of Transmit/Receive (Transmit) Error Processing

#### <u>Receive errors</u>

Receive errors occur on the following situation. To protect SIO1RDB and the shift register contents, the received data is ignored while the SIO1SR<RXERR> is "1".

• Shift operation is finished before reading out received data from SIO1RDB at SIO1SR<RXF> is "1" in an external clock operation.

If receive error occurs, set the SIO1CR<SIOS> to "0" for reading the data that received immediately before error occurence. And read the data from SIO1RDB. Data in shift register (at errors occur) can be read by reading the SIO1RDB again.

When SIO1SR<RXERR> is cleared to "0" after reading the received data, SIO1SR<RXF> is cleared to "0".

After clearing SIO1CR<SIOS> to "0", when 8-bit serial clock is input to  $\overline{\text{SCK1}}$  pin, receive operation is stopped. To restart the receive operation, confirm that SIO1SR<SIOF> is cleared to "0".

If the received error occurs, set the SIO1CR<SIOINH> to "1" for stopping the receive operation immediately. In this case, SIO1CR<SIOS>, SIO1SR register, SIO1RDB register and SIO1TDB register are initialized.



Figure 2.13.19 Example of Transmit/Receive (Receive) Error Processing

Note: If receive error is not corrected, an interrupt request does not generate after the error occurs.



Figure 2.13.20 Hold Time of the End of Transmit/Receive Mode

## 2.14 Key-On Wake-Up (KWU)

In the TMP86FM48, the STOP mode must be released by not only P20 ( $\overline{INT5} / \overline{STOP}$ ) pin but also P64 to P67 pins.

When the STOP mode is released by P64 to P67 pins, the P20  $(\overline{INT5} / \overline{STOP})$  pin needs to be used.

## 2.14.1 Configuration



Figure 2.14.1 Key-On Wake-Up Circuit

Note1: STOP pin doesn't have the control register such as STOPCR, so when STOP mode is released by STOPx (x: 0 to 3), STOP pin should be used as STOP function.

2.14.2 Control

P64 to P67 (STOP0 to STOP3) pin can controlled by key-on wake-up control register (STOPCR). It can be configured as enable/disable in 1-bit unit.

STOP mode can be entered by setting up the system control register1 (SYSCR1), and can be exited by detecting low level of STOP0 to STOP3 pins, which are enabled by STOPCR, for releasing STOP mode (Note 1). Also, because each level of the STOP0 to STOP3 can be confirmed by reading P6DR, check all STOP0 to STOP3 pins that is enabled by STOPCR before the STOP mode is started (Note 2, 3).

- Note 1: When the STOP mode is used by edge-sensitive mode (SYSCR1<RELM> = "0"), all bit of STOPCR (STOP3EN to STOP0EN) should be cleared to "0".
- Note 2: When the STOP pin input is high or STOP0 to STOP3 pin input which is enabled by STOPCR is low, executing an instruction which starts STOP mode will not place in STOP mode but instead will immediately start the release sequence (Warm-up).
- Note 3: When confirms the level of STOP0 to STOP3 pin which is enabled by STOPCR, the corresponding bit of P6CR1 should be cleared to "0" before reading P6DR.

| Terminal name | As both terminal | SYSCR1 <relm> = "1"</relm> | SYSCR1 <relm> = "0"</relm> |
|---------------|------------------|----------------------------|----------------------------|
| Terminar name | As both terminal | Release eo                 | dge (Level)                |
| STOP          | P20/ INT5        | "H" level (Note2)          | Rising edge                |
| STOP0         | P64/AIN04        | "L" level                  | Do not use key on          |
| STOP1         | P65/AIN05        | (Note 2)                   | wake up function           |
| STOP2         | P66/AIN06        |                            | (Note 1)                   |
| STOP3         | P67/AIN07        |                            |                            |

| Table 2.14.1 | Input Edge (Level) of Stop Mode Release |
|--------------|-----------------------------------------|
|--------------|-----------------------------------------|

| Key-On Wake-Up Control Register |                 |                                       |                           |       |
|---------------------------------|-----------------|---------------------------------------|---------------------------|-------|
| STOPCR<br>(1FFE <sub>H</sub> )  | 7<br>STOP0EN ST | <u>6 5 4 - 3</u>                      | 20 (Initial value: 0000 * | ***)  |
|                                 |                 | · · · · · · · · · · · · · · · · · · · |                           | ·     |
|                                 | STOP0EN         | Stop mode released by P64 port        | 0: Disable<br>1: Enable   |       |
|                                 | STOP1EN         | Stop mode released by P65 port        | 0: Disable<br>1: Enable   | Write |
|                                 | STOP2EN         | Stop mode released by P66 port        | 0: Disable<br>1: Enable   | only  |
|                                 | STOP3EN         | Stop mode released by P67 port        | 0: Disable<br>1: Enable   |       |

Figure 2.14.2 Key-On Wake-Up Control Register

## 2.15 10-Bit AD Converter (ADC)

The TMP86FM48 has a 10-bit successive approximation type AD converter.

#### 2.15.1 Configuration

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

It consists of control registers ADCCR1 and ADCCR2, registers ADCDR1 and ADCDR2, a DA converter, a sample-and-hold circuit, a comparator, and a successive comparison circuit.



Figure 2.15.1 AD Converter (ADC)

#### 2.15.2 Register Configuration

The AD converter consists of the following four registers:

- AD converter control register 1 (ADCCR1)
- AD converter control register 2 (ADCCR2)
- AD conversion result register 1/2 (ADCDR1/ADCDR2)
- (1) AD converter control register 1 (ADCCR1)

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 (ADCCR2)

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

(3) AD conversion result register (ADCDR1)

This register is used to store the digital value (Bit9 to bit2) after being converted by the AD converter.

(4) AD conversion result register (ADCDR2)

This register is used to store the digital value (Bit1 and bit0) after being converted by the AD converter, and then this register is also used to monitor the operating status of the AD converter.

The AD converter control register configurations are shown in Figure 2.15.2 and Figure 2.15.3.

| AD Converte<br>ADCCR1                         | r Control Reg<br>7                        | ister 1<br>6 5 4 3                                                                                                                                                                                                               | 2                                                      | 1                                                                                                                                    | 0                                      |                                                                                                                                                                                      |                                     |                          |         |
|-----------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------|---------|
| (000E <sub>H</sub> )                          | ADRS                                      | AMD AINDS                                                                                                                                                                                                                        |                                                        | SĄIN ,                                                                                                                               |                                        | (Initial val                                                                                                                                                                         | ue: 0001                            | 0000)                    |         |
|                                               | ADRS                                      | AD conversion start                                                                                                                                                                                                              | 0: –<br>1: S                                           |                                                                                                                                      |                                        |                                                                                                                                                                                      |                                     |                          |         |
|                                               | AMD                                       | AD operating mode                                                                                                                                                                                                                | 01: S<br>10: R                                         | AD operation d<br>Software start<br>Reserved<br>Repeat mode                                                                          |                                        |                                                                                                                                                                                      |                                     |                          |         |
|                                               | AINDS                                     | Analog input control                                                                                                                                                                                                             | 0: A                                                   | Analog input ei<br>Analog input di                                                                                                   |                                        |                                                                                                                                                                                      |                                     |                          | R/W     |
|                                               | SAIN                                      | IN Analog input channel select                                                                                                                                                                                                   |                                                        | Selects AIN00<br>Selects AIN01<br>Selects AIN02<br>Selects AIN03<br>Selects AIN04<br>Selects AIN05<br>Selects AIN06<br>Selects AIN07 | 10<br>10<br>10<br>11<br>11<br>11       | 1000: Selects AIN10<br>1001: Selects AIN11<br>1010: Selects AIN12<br>1011: Selects AIN13<br>1100: Selects AIN14<br>1101: Selects AIN15<br>1110: Selects AIN16<br>1111: Selects AIN17 |                                     |                          |         |
|                                               | Note 2: W<br>Note 3: D<br>to<br>Note 4: T | elect analog input when AD convert<br>/hen the analog input is all use disa<br>uring conversion, do not perform ou<br>analog input, do not input intense<br>he ADRS is automatically cleared to<br>o not set ADRS newly again of | abling, the<br>utput instr<br>signaling<br>to "0" afte | e AINDS shou<br>ruction to main<br>of change.<br>er starting conv                                                                    | ld be set t<br>ntain a pre<br>version. | o "1".<br>cision for                                                                                                                                                                 |                                     |                          |         |
| AD Converte<br>ADCCR2<br>(000F <sub>H</sub> ) | ge<br>Note 6: A<br>TI                     |                                                                                                                                                                                                                                  | outine).<br>ted, AD c                                  | converter contr<br>r exiting these                                                                                                   | rol registe<br>modes.                  | r 1 (ADCC                                                                                                                                                                            |                                     | initialized.             | NDC) is |
|                                               | IREFON                                    | DA converter (Ladder resistor)<br>connection control                                                                                                                                                                             | 0: C                                                   | g current to th                                                                                                                      | y during A                             |                                                                                                                                                                                      | sion                                |                          |         |
|                                               |                                           |                                                                                                                                                                                                                                  | АСК<br>000                                             | Always connect<br>Conversion<br>time<br>39/fc                                                                                        | fc =<br>16 MHz<br>-                    | fc =<br>8 MHz<br>-                                                                                                                                                                   | fc =<br>4 MHz<br>-                  | fc =<br>1 MHz<br>39.0 μs |         |
|                                               | ACK                                       | AD conversion time select                                                                                                                                                                                                        | 001<br>010<br>011<br>100<br>101                        | 78/fc<br>156/fc<br>312/fc<br>624/fc                                                                                                  | -<br>-<br>39.0 μs                      | eserved<br>-<br>39.0 μs<br>78.0 μs                                                                                                                                                   | _<br>39.0 μs<br>78.0 μs<br>156.0 μs | 78.0 μs<br>156.0 μs<br>– | R/W     |
|                                               |                                           |                                                                                                                                                                                                                                  | 110<br>111                                             | 1248/fc                                                                                                                              |                                        | 156.0 μs<br>eserved                                                                                                                                                                  | _                                   | -                        |         |
|                                               |                                           | ettings for "_" in the above table ar<br>et conversion time by analog refere<br>V <sub>AREF</sub> = 2.7 to 3.6 V (31.2<br>V <sub>AREF</sub> = 1.8 to 3.6 V (124                                                                  | ence volta<br>2 μ or mo                                | age (V <sub>AREF</sub> ) a<br>re)                                                                                                    | is follows.                            |                                                                                                                                                                                      |                                     |                          |         |
|                                               | Note 4: W<br>Note 5: fc                   | lways set bit0 in ADCCR2 to "0" ar<br>/hen a read instruction for ADCCR:<br>: High-frequency clock [Hz]                                                                                                                          | nd set bit4<br>2, bit6 to                              | in ADCCR2 t<br>7 in ADCCR2                                                                                                           | read in as                             |                                                                                                                                                                                      |                                     |                          |         |
|                                               |                                           | fter STOP or SLOW mode are star<br>herefore, set the ADCCR2 newly a                                                                                                                                                              |                                                        |                                                                                                                                      | -                                      | r 2 (ADCC                                                                                                                                                                            | CR2) is all                         | initialized.             |         |

Figure 2.15.2 AD Converter Control Register

# TOSHIBA

| AD Conversion        | n Result R | egister    |                        |            |            |                                 |            |              |                                 |            |
|----------------------|------------|------------|------------------------|------------|------------|---------------------------------|------------|--------------|---------------------------------|------------|
| ADCDR1               | 7          | 6          | 5                      | 4          | 3          | 2                               | 1          | 0            |                                 |            |
| (0027 <sub>H</sub> ) | AD09       | AD08       | AD07                   | AD06       | AD05       | AD04                            | AD03       | AD02         | (Initial value: 0000 0000)      |            |
|                      |            |            |                        |            |            |                                 |            |              |                                 |            |
| ADCDR2               | 7          | 6          | 5                      | 4          | 3          | 2                               | 1          | 0            |                                 |            |
| (0026 <sub>H</sub> ) | AD01       | AD00       | EOCF                   | ADBF       |            | 2                               |            |              | (Initial value: 0000 ****)      |            |
|                      |            |            |                        |            |            |                                 |            |              |                                 |            |
|                      | EOCF       |            | AD conversion end flag |            |            |                                 | ore or dur | ring conve   | ersion                          |            |
|                      | LOOP       | AD CC      |                        | enu nay    |            | 1: Conversion completed Re      |            |              |                                 |            |
|                      | ADBF       | AD co      | nversion               | busv flag  |            | 0: During stop of AD conversion |            |              |                                 |            |
|                      | 1.001      | /12/00     |                        | oudy hug   |            | 1: Du                           | ing AD co  | onversion    |                                 |            |
|                      | Note 1:    | The EOC    | F is clear             | ed to "0"  | when rea   | ding the A                      | DCDR1.     |              |                                 |            |
|                      |            | Therefore  | e, the AD              | conversio  | n result s | hould be r                      | ead to AD  | CDR2 mo      | ore first than ADCDR1.          |            |
|                      | Note 2:    | ADBF is    | set to "1" v           | when AD o  | conversio  | n starts ar                     | nd cleared | to "0" whe   | en the AD conversion is finishe | d. It also |
|                      |            | is cleared | d upon en              | tering STO | OP or SLO  | OW mode.                        |            |              |                                 |            |
|                      | Note 3:    | lf a read  | instructior            | n is execu | ted for AD | DCDR2, re                       | ad data o  | f bit 3 to 0 | are unstable.                   |            |

Figure 2.15.3 AD Converter Result Register

### 2.15.3 AD Converter Operation

(1) Set up the AD converter control register 1 (ADCCR1) 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 (ADCCR2) as follows:
  - Set the AD conversion time using AD conversion time (ACK). For details on how to set the conversion time, refer to Note 2 for 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 (ADCCR1) to "1".
- (4) After an elapse of the specified AD conversion time, the AD converted value is stored in AD conversion result register 1 (ADCDR1), AD conversion result register (ADCDR2) and then the AD conversion end flag (EOCF) of AD conversion result register 2 (ADCDR2) is set to "1", upon which time AD conversion interrupt INTADC is generated.
- (5) 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.

## 2.15.4 AD Converter Operation Modes

There are following two AD converter operation modes:

- Software start: AD conversion is performed once by setting AMD to "01B" and ADRS to "1".
- Repeat mode: AD conversion is performed repeatedly by setting AMD to "11B" and ADRS to "1".

#### (1) Software start mode

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

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

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



Figure 2.15.4 Operation in Software Start Mode

Example: After selecting the conversion time of 39.0 µs at 16 MHz and the analog input channel AIN3 pin, perform AD conversion once. After checking EOCF, read the converted value, store the lower 2 bits in address 009EH and store the upper 8 bits in address 009F<sub>H</sub> on RAM. The operation mode is software start mode.

|        | ; AIN SEI | _ECT                |   |                                                    |
|--------|-----------|---------------------|---|----------------------------------------------------|
|        | LD        | (P6CR1), 0000000B   | ; | P6CR1 bit 3 = 0                                    |
|        | LD        | (P6CR2), 0000000B   | ; | P6CR2 bit 3 = 0                                    |
|        | LD        | (ADCCR1), 00100011B | ; | Select AIN3                                        |
|        | LD        | (ADCCR2), 11011010B | ; | Select conversion time (624/fc) and operation mode |
|        | ; AD CON  | IVERT START         |   |                                                    |
|        | SET       | (ADCCR1). 7         | ; | ADRS = 1                                           |
| SLOOP: | TEST      | (ADCDR2). 5         | ; | EOCF = 1 ?                                         |
|        | JRS       | T, SLOOP            |   |                                                    |
|        | ; RESUL   | T DATA READ         |   |                                                    |
|        | LD        | A, (ADCDR2)         |   |                                                    |
|        | LD        | (9EH), A            |   |                                                    |
|        | LD        | A, (ADCDR1)         |   |                                                    |
|        | LD        | (9FH), A            |   |                                                    |

(2) Repeat mode

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

After completion of the AD conversion, the conversion result is stored in AD conversion result registers (ADCDR1, ADCDR2) and at the same time ADCDR2<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 ADCCR1<AMD> to "00B" (Disable mode). The AD convert operation is stopped immediately. The converted value at this time is not stored in the AD conversion result register.

| ADCCR1 <amd></amd>   | "11"                                                                                   |
|----------------------|----------------------------------------------------------------------------------------|
| ADCCR1 <adrs></adrs> | AD conversion start                                                                    |
| Convert              | First conversion Second conversion Third conversion Conversion result is not stored.   |
| ADCDR1, ADCDR2       | Indeterminate First conversion result Second conversion result Third conversion result |
| ADCDR2 <eocf></eocf> |                                                                                        |
| INTADC request       |                                                                                        |
| Reading ADCDR1       | Conversion Conversion Conversion<br>result read result read result read                |
| Reading ADCDR2       |                                                                                        |

Figure 2.15.5 Operation in Repeat Mode

## 2.15.5 STOP and SLOW Modes during AD Conversion

When the STOP or SLOW mode is entered forcibly during AD conversion, the AD convert operation is suspended and the AD converter is initialized (ADCCR1 and ADCCR2 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 STOP or SLOW mode.) When released from STOP or SLOW mode, AD conversion is not automatically restarted. Therefore, when the AD converter is used again, it is necessary to restart AD conversion (Set ADCCR1<ADRS> to "1"). Note that since the analog reference voltage is automatically disconnected, there is no possibility of current flowing into the analog reference voltage.

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



Figure 2.15.6 Analog Input Voltage and AD Conversion Result (typ.)

- 2.15.7 Precautions about AD Converter
  - (1) Analog input pin voltage range

Make sure the analog input pins (AIN00 to AIN17) are used at voltages within VSS below VAREF. 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.

(2) Analog input shared pins

The analog input pins (AIN00 to AIN17) 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.

(3) Noise countermeasure

The internal equivalent circuit of the analog input pins is shown in Figure 2.15.7. 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.



Figure 2.15.7 Analog Input Equivalent Circuit and Example of Input Pin Processing

# 2.16 FLASH Memory

## 2.16.1 Outline

The TMP86FM48 incorporates 32768 bytes of FLASH memory (Address 8000H to FFFFH). Of these bytes, 512 bytes (Address 8000H to 81FFH) can be used as data memory. When these 512 bytes (Address 8000H to 81FFH) are used as data memory, the 32256 bytes (Address 8200H to FFFFH) can be used as program memory. The writing to FLASH memory is controlled by FLASH control register (EEPCR), FLASH status register (EEPSR) and FLASH write emulate time control register (EEPEVA).

The FLASH memory of the TMP86FM48 features:

- The FLASH memory is constructed of 512 pages FLASH memory and one page size is 64 bytes (512 pages × 64 bytes = 32768 bytes).
- The TMP86FM48 incorporates a 64-byte temporary data buffer. The data written to FLASH memory is temporarily stored in this data buffer. After 64 bytes data have been written to the temporary data buffer, the writing to FLASH memory automatically starts by page writing (The 64 bytes data are written to specified page of FLASH simultaneously). At the same time, page-by-page erasing occurs automatically. So, it is unnecessary to erase individual pages in advance.
- The FLASH control circuit incorporates an oscillator dedicated to the FLASH. So FLASH writing time is independent of the system clock frequency (fc). In addition, because an FLASH control circuit controls writing time for each FLASH memory cell, the writing time varies in each page (Typically 4 ms per page).
- Controlling the power for the FLASH control circuit (regulator and voltage step-up circuit) achieves low power consumption if the FLASH is not in use (Example: When the program is executed in RAM area).

## 2.16.2 Conditions for Accessing the FLASH Areas

The conditions for accessing the FLASH areas vary depending on each operation mode. The following tables shows FLASH are access conditions.

|                | Area           | Operation Mode    |                                |  |  |  |
|----------------|----------------|-------------------|--------------------------------|--|--|--|
|                | Area           | MCU mode (Note 1) | Serial PROM mode (Note 2)      |  |  |  |
| Data Memory    | 8000H to 81FFH | Write/read/fetc   | h <sup>(Note3)</sup> supported |  |  |  |
| Program Memory | 8200H to FFFFH | Read/fetch only   | Write/read/fetch supported     |  |  |  |

| Table 2.16.1 | FLASH Area Access Conditions |
|--------------|------------------------------|
|--------------|------------------------------|

Note 1: "MCU mode" shows NORMAL1/2 and SLOW1/2 modes.

Note 2: "Serial PROM mode" shows the FLASH controlling mode. For details, refer to "2.19 Serial PROM mode".

Note 3: "Fetch" means reading operation of FLASH data as an instruction by CPU.

# 2.16.3 Differences among Product Series

The specifications of the FLASH product (TMP86FM48) are different from those of the emulation chip (TMP86C948) as listed below. See 2.17.2 "Control" for explanations about the control registers.

|                                                                                                                                                                                     |                     | FLASH Product                                                                                                                                                                                                    | Emulation Chip                                                                                                                                                            |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                                                                                                                                                                                     |                     | (TMP86FM48)                                                                                                                                                                                                      | (TMP86C948)                                                                                                                                                               |  |  |  |
| Rewriting the EEPCR register <e< td=""><td></td><td>It is possible to rewrite the EEPCR regist<br/>execution area in use is RAM/BOOT-RO</td><td>ter only when the program</td></e<> |                     | It is possible to rewrite the EEPCR regist<br>execution area in use is RAM/BOOT-RO                                                                                                                               | ter only when the program                                                                                                                                                 |  |  |  |
| MNPWDW>                                                                                                                                                                             | EFMD, EEFK3,        |                                                                                                                                                                                                                  | In the debugger memory<br>window, it is impossible to<br>rewrite the EEPCR register.                                                                                      |  |  |  |
| Accessing the EEPEVA register                                                                                                                                                       |                     | It is possible only to write- and<br>read-access the EEPEVA register.<br>The writing to this register does not<br>affect the function.                                                                           | The time required to emulate<br>FLASH writing is put under<br>control.                                                                                                    |  |  |  |
| FLASH write time<br>(The emulation chip is written to of<br>memory instead of FLASH)                                                                                                | emulation           | Typically 4 ms<br>(Independent of the system clock)                                                                                                                                                              | The FLASH write time is set up<br>using the EEPEVA register<br>(Dependent on the system<br>clock).                                                                        |  |  |  |
| Executing a read instruction/fetch                                                                                                                                                  |                     | If EEPSR <bfbusy> = "1", executing a read instruction/fetch to the FLASH area causes FFH to be read regardless of what the current ROM data is. Fetching FFH results in a software interrupt occurring.</bfbusy> |                                                                                                                                                                           |  |  |  |
|                                                                                                                                                                                     | 501/- 1             |                                                                                                                                                                                                                  | The debugger memory window always displays ROM data.                                                                                                                      |  |  |  |
| Executing a write instruction to                                                                                                                                                    | MCU mode            |                                                                                                                                                                                                                  |                                                                                                                                                                           |  |  |  |
| the 8000H to 81FFH area when<br>EEPCR <eepmd> = "0011",<br/>EEPSR<ewupen> = "1" and<br/>EEPSR<bfbusy> = "0".</bfbusy></ewupen></eepmd>                                              | Serial PROM mode    | The EEPSR <bfbusy> is set to "1" (Write enabled).</bfbusy>                                                                                                                                                       |                                                                                                                                                                           |  |  |  |
|                                                                                                                                                                                     |                     | The EEPSR <bfbusy> stays at "0" (Write disabled).</bfbusy>                                                                                                                                                       |                                                                                                                                                                           |  |  |  |
| Executing a write instruction to<br>the 8200H to FFFFH area<br>when EEPCR <eepmd> =<br/>"0011", EEPSR<ewupen> =<br/>"1" and EEPSR<bfbusy> =</bfbusy></ewupen></eepmd>               | MCU mode            |                                                                                                                                                                                                                  | In the debugger memory<br>window, it is possible to rewrite<br>the 8200H to FFFFH area (The<br>EEPSR <bfbusy> remains<br/>unchanged).</bfbusy>                            |  |  |  |
| "0".                                                                                                                                                                                | Serial PROM<br>mode | The EEPSR <bfbusy> is set to "1" (writ</bfbusy>                                                                                                                                                                  | e enabled).                                                                                                                                                               |  |  |  |
| Data memory (8000H to 81FFH)                                                                                                                                                        |                     | 512 bytes of FLASH are included in the 8000H to 81FFH area.                                                                                                                                                      | 512 bytes of emulation memory<br>are included in the 8000H to<br>81FFH area. (Turning off the<br>power for the emulation chip<br>erases data in the emulation<br>memory.) |  |  |  |
| BOOT-ROM                                                                                                                                                                            |                     | 2 Kbytes are included in the 3800H to 3F                                                                                                                                                                         | FFH area.                                                                                                                                                                 |  |  |  |
| Operating voltage                                                                                                                                                                   |                     | VDD = 1.8 to 3.6 V                                                                                                                                                                                               | VDD = 1.8 to 3.3 V                                                                                                                                                        |  |  |  |

# 2.16.4 FLASH Memory Configuration

64 consecutive bytes in the FLASH area are treated as one group, which is defined as a page. The TMP86FM48 incorporates a one-page temporary data buffer. Writing data to FLASH is temporarily stored in this 64-byte data buffer. After 64 bytes data have been written to the temporary data buffer, these data are written to specified page of FLASH at a time. However, data can be read from any address byte by byte.

## 2.16.4.1 Page Configuration

The FLASH area has a page configuration of 64 bytes/page as shown below. The total number of bytes in it is  $512 \text{ pages} \times 64 \text{ bytes}$  (= 32768 bytes). The writeable area is 8000H to FFFFH in Serial PROM mode.

Note: The program memory (8200H to FFFFH) can be written only in the Serial PROM mode. For details of the Serial PROM mode, refer to "2.19 Serial PROM mode".

| Address | 0  | 1 | 2        | 3 | 4 | 5        | 6        | 7        | 8   | 9        | А | В | С    | D        | E | F |
|---------|----|---|----------|---|---|----------|----------|----------|-----|----------|---|---|------|----------|---|---|
| 8000H   |    |   | ĺ        |   |   |          |          | ,<br>,   |     |          |   |   |      |          |   |   |
| 8010H   |    |   | ļ        | ! | ļ | ¦        | <u></u>  | Page     | 0_  | ļ<br>ļ   |   |   | <br> | ļ        | ļ |   |
| 8020H   |    |   | ¦        | ! |   |          |          | ÷        |     |          |   |   |      | <u> </u> |   | [ |
| 8030H   |    |   | i        |   |   |          |          |          |     |          |   |   |      | i        |   |   |
| 8040H   |    |   |          |   |   |          |          |          |     |          |   |   |      |          |   |   |
| 8050H   |    |   | ļ        |   | L |          |          | Page     | 1   |          |   |   | !    | ļ        |   |   |
| 8060H   |    |   | ¦        |   |   |          |          | +        |     |          |   |   |      | ļ        | ¦ |   |
| 8070H   |    |   | <u>.</u> |   |   | <u> </u> | <u> </u> | <u> </u> |     | <u> </u> |   |   |      | <u>i</u> |   |   |
| 8080H   |    |   |          |   |   |          |          | ;<br>+   |     |          |   |   |      | ;<br>;   |   |   |
| 8090H   |    |   | L        | ; | L |          |          | Page     | 2 _ | L        |   |   | !    |          |   | ! |
| 80A0H   |    |   | ļ        |   |   | !        |          | +        |     | ¦        |   |   |      |          |   | ! |
| 80B0H   |    |   | <u> </u> |   |   |          |          |          |     |          |   |   |      |          |   |   |
| 80C0H   |    |   |          |   |   |          |          | ;<br>+   |     |          |   |   |      |          |   |   |
| 80D0H   |    |   |          |   |   |          |          | Page     | 3   |          |   |   |      |          |   |   |
| 80E0H   |    |   | l        |   | L |          | L        |          |     | ¦        |   | L |      |          |   |   |
| 80F0H   |    |   |          |   |   | <u> </u> |          | <u> </u> |     | <u> </u> |   |   |      |          |   |   |
|         |    |   | ¦        |   |   |          |          | ¦        |     |          |   |   |      |          |   |   |
|         |    |   | !        |   |   |          |          |          |     |          |   |   |      |          |   |   |
|         | 1  |   |          |   |   |          |          |          |     |          |   |   |      |          |   |   |
|         | Ι. | _ |          |   |   |          |          |          |     |          | _ |   |      |          |   |   |
|         |    |   | ¦        |   |   |          |          | Page 5   | 11  |          |   |   |      |          |   |   |
| FFE0H   |    |   | ¦        |   |   |          |          | +        |     |          |   |   |      | ļ        |   |   |
| FFF0H   |    |   | i        | 1 | I | 1        | 1        | 1        |     | 1        |   | 1 |      | 1        |   |   |

Figure 2.16.1 Page Configuration

# 2.17 Data Memory of FLASH(address 8000H to 81FFH)

The TMP86FM48 incorporates 512 bytes (8000H to 81FFH) of data memory of FLASH, which features:

- In the MCU mode, user-created programs can rewrite the data memory of FLASH in page (64 bytes) units. (It can be used to save application last keys and preset data.)
- In the serial PROM mode, it is possible to perform serial writing to the data memory of FLASH in the same manner as for the program memory. So, initial values can be factory-set in the data memory of FLASH.
- Using support programs incorporated in the BOOT-ROM makes it easy to write to the FLASH.



## 2.17.1 Configuration

Figure 2.17.1 Data Memory

## 2.17.2 Control

The FLASH is controlled by FLASH control register (EEPCR), FLASH status register (EEPSR) and FLASH write emulate time control register (EEPEVA).

|                    | EEPMD                                                                                                                                                                 | EEPRS ATPWDW MNPWDW                                                                                                                                                                                                                     | / (Initial value                                                                                                       | : 1100 *01                           |  |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|--|--|
| 1FE0H)             |                                                                                                                                                                       |                                                                                                                                                                                                                                         |                                                                                                                        |                                      |  |  |  |  |
|                    |                                                                                                                                                                       | 1100: FLASH write disable                                                                                                                                                                                                               | Program Exe                                                                                                            | cution Area                          |  |  |  |  |
| EEPMD              | FLASH write enable control<br>(Write protect)                                                                                                                         | 0011: FLASH write enable<br>Other values: Reserved                                                                                                                                                                                      | RAM/<br>BOOT                                                                                                           | FLASH                                |  |  |  |  |
| EEPRS              | FLASH write forcible stop                                                                                                                                             | <ul> <li>0: -</li> <li>1: FLASH writing is forced to stop.<br/>(The write data counter is initialized.)</li> <li>* After writing "1" to EEPRS, it is<br/>automatically cleared to "0".</li> </ul>                                       |                                                                                                                        | Read<br>only                         |  |  |  |  |
| ATPWDW             | Automatic power control for the<br>FLASH control circuit in the<br>IDLE0/1/2, SLEEP0/1/2 modes.<br>(This bit is available only when<br>MNPWDW is set to "1".)         | <ul> <li>0: Automatic power shut down is executed in IDLE0/1/2 and SLEEP0/1/2 modes.</li> <li>1: Automatic power shut down is not executed in IDLE0/1/2 and SLEEP0/1/2 modes. (The power is always supplied in these modes.)</li> </ul> | R/W                                                                                                                    | R/W                                  |  |  |  |  |
| MNPWDW             | Software-based power control for the FLASH control circuit                                                                                                            | <ol> <li>The power for the FLASH control circuit is<br/>turned off.</li> <li>The power for the FLASH control circuit is<br/>turned on</li> </ol>                                                                                        |                                                                                                                        | Read<br>only                         |  |  |  |  |
| Note 1:            | The EEPMD, EEPRS, and MNP                                                                                                                                             | NDW can be rewritten only when a program fetch is                                                                                                                                                                                       | s taking place i                                                                                                       | n the RAM                            |  |  |  |  |
|                    | BOOT-ROM area. If an attempt is                                                                                                                                       | s made to rewrite the EEPCR register when a progr                                                                                                                                                                                       | am is being ex                                                                                                         | ecuted in th                         |  |  |  |  |
|                    | FLASH area, the EEPMD, EEPR                                                                                                                                           | S, and MNPWDW keep holding the previous data;                                                                                                                                                                                           | they are not re                                                                                                        | written.                             |  |  |  |  |
| Note 2:            | To write to the FLASH, set the EE                                                                                                                                     | EPMD with "0011B" in advance when a program fetc                                                                                                                                                                                        | h is taking plac                                                                                                       | e in the RA                          |  |  |  |  |
|                    | area. However, this processing is                                                                                                                                     | s not required if a support program in the BOOT-RC                                                                                                                                                                                      | M is used.                                                                                                             |                                      |  |  |  |  |
| Note 3:            | To forcibly stop writing of FLASH                                                                                                                                     | l, set the EEPRS to "1" when a program fetch is taki                                                                                                                                                                                    | ing place in the                                                                                                       | RAM area                             |  |  |  |  |
| Note 4:            | The ATPWDW functions only if t                                                                                                                                        | he MNPWDW is "1". If the MNPWDW is "0", the p                                                                                                                                                                                           | ower for the F                                                                                                         | LASH conti                           |  |  |  |  |
|                    | circuit is kept turned off regardles                                                                                                                                  | ss of the setting of the ATPWDW.                                                                                                                                                                                                        |                                                                                                                        |                                      |  |  |  |  |
|                    | When a STOP mode is executed                                                                                                                                          | , the power for the FLASH control circuit is turned of                                                                                                                                                                                  | f regardless of                                                                                                        | the setting                          |  |  |  |  |
| Note 5:            | the ATPWDW. If the MNPWDW is "0", entering/exiting the STOP mode allows the power for the FLASH contro                                                                |                                                                                                                                                                                                                                         |                                                                                                                        |                                      |  |  |  |  |
| Note 5:            | the ATPWDW. If the MNPWDW                                                                                                                                             | is "0", entering/exiting the STOP mode allows the p                                                                                                                                                                                     | ower for the F                                                                                                         | LASH conti                           |  |  |  |  |
| Note 5:            | the ATPWDW. If the MNPWDW i circuit to be kept turned off.                                                                                                            | is "0", entering/exiting the STOP mode allows the p                                                                                                                                                                                     | ower for the F                                                                                                         | LASH conti                           |  |  |  |  |
| Note 5:<br>Note 6: | circuit to be kept turned off.                                                                                                                                        | is "0", entering/exiting the STOP mode allows the p<br>e EEPCR register results in bit3 being read as unde                                                                                                                              |                                                                                                                        |                                      |  |  |  |  |
|                    | circuit to be kept turned off.                                                                                                                                        |                                                                                                                                                                                                                                         |                                                                                                                        |                                      |  |  |  |  |
|                    | circuit to be kept turned off.<br>Executing a read instruction to the<br>"0".                                                                                         |                                                                                                                                                                                                                                         |                                                                                                                        |                                      |  |  |  |  |
| Note 6:            | circuit to be kept turned off.<br>Executing a read instruction to the<br>"0".<br>The following attention is necessa                                                   | e EEPCR register results in bit3 being read as unde ary when the MNPWDW is set or cleared.                                                                                                                                              | fined. Bit2 is al                                                                                                      | ways read a                          |  |  |  |  |
| Note 6:            | circuit to be kept turned off.<br>Executing a read instruction to the<br>"0".<br>The following attention is necessar<br>When the MNPWDW is<br>changed from "1" to "0" | e EEPCR register results in bit3 being read as under<br>ary when the MNPWDW is set or cleared.<br>Clear the interrupt master enable flag (IMF) to "0" in<br>nterrupt. After that, do not set IMF to "1" during EEF                      | fined. Bit2 is al<br>advance to dis<br>PSR <ewupen< td=""><td>ways read a<br/>sable an<br/>I&gt; = "0".</td></ewupen<> | ways read a<br>sable an<br>I> = "0". |  |  |  |  |
| Note 6:            | circuit to be kept turned off.<br>Executing a read instruction to the<br>"0".<br>The following attention is necessar<br>When the MNPWDW is<br>changed from "1" to "0" | e EEPCR register results in bit3 being read as unde<br>ary when the MNPWDW is set or cleared.<br>Clear the interrupt master enable flag (IMF) to "0" in                                                                                 | fined. Bit2 is al<br>advance to dis<br>2SR <ewupen<br>r the binary cou</ewupen<br>                                     | ways read a<br>sable an<br>I> = "0". |  |  |  |  |

Figure 2.17.2 FLASH Control Register

|                               | 7                                                                      | 6                                                                                                                                                                                     | 5                                                                      | 4                                                                                                                                        | 3 2                                                                                                                                                                                             | 1                                                                                                                                                                         | 0                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |  |
|-------------------------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--|
| EPSR<br>FE1H)                 |                                                                        |                                                                                                                                                                                       |                                                                        |                                                                                                                                          | WIN                                                                                                                                                                                             | IT EWUPEN                                                                                                                                                                 | BFBUSY                                                                                                                                                     | (Initial value: **                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | *** *010)                                                                     |  |
| - <b>L</b> 11 1)              |                                                                        |                                                                                                                                                                                       |                                                                        |                                                                                                                                          |                                                                                                                                                                                                 |                                                                                                                                                                           |                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |  |
|                               |                                                                        |                                                                                                                                                                                       |                                                                        |                                                                                                                                          | 0: Not detected                                                                                                                                                                                 |                                                                                                                                                                           |                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |  |
| WIN                           | т                                                                      | Interrupt detection                                                                                                                                                                   | n durii                                                                | ng a write to                                                                                                                            | 1: Detected (Interrupt occurred)                                                                                                                                                                |                                                                                                                                                                           |                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |  |
|                               |                                                                        | the FLASH                                                                                                                                                                             |                                                                        |                                                                                                                                          | * WINT is automatically cleared to "0" when read<br>instruction is executed to EEPSR.                                                                                                           |                                                                                                                                                                           |                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |  |
|                               |                                                                        |                                                                                                                                                                                       | (                                                                      | Control circuit                                                                                                                          |                                                                                                                                                                                                 |                                                                                                                                                                           | Halt (power of                                                                                                                                             | off) or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Read                                                                          |  |
|                               |                                                                        |                                                                                                                                                                                       |                                                                        | status                                                                                                                                   | Operating (                                                                                                                                                                                     | power on)                                                                                                                                                                 | warm-up                                                                                                                                                    | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | only                                                                          |  |
| EWUP                          | ΡEΝ                                                                    | N FLASH control circuit status monitor                                                                                                                                                |                                                                        | FLASH status                                                                                                                             | Temporary data                                                                                                                                                                                  | Writing                                                                                                                                                                   | Dis                                                                                                                                                        | sable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                               |  |
|                               |                                                                        |                                                                                                                                                                                       |                                                                        | buffer empty                                                                                                                             |                                                                                                                                                                                                 |                                                                                                                                                                           |                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |  |
| DEDU                          |                                                                        |                                                                                                                                                                                       |                                                                        |                                                                                                                                          | 1                                                                                                                                                                                               | 1                                                                                                                                                                         |                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                               |  |
| BFBUSY                        |                                                                        | ELASH write busy                                                                                                                                                                      | / flag                                                                 |                                                                                                                                          | 0                                                                                                                                                                                               | 1                                                                                                                                                                         |                                                                                                                                                            | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | -                                                                             |  |
| BFBU                          | SY                                                                     | FLASH write busy                                                                                                                                                                      | / flag                                                                 |                                                                                                                                          | 0                                                                                                                                                                                               | 1                                                                                                                                                                         |                                                                                                                                                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | _                                                                             |  |
| Note 1:                       | -                                                                      | FLASH write busy<br>nonmaskable int                                                                                                                                                   | 0                                                                      | t occurs durir                                                                                                                           | -                                                                                                                                                                                               |                                                                                                                                                                           | INT is set to                                                                                                                                              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | writing is                                                                    |  |
|                               | lf a                                                                   |                                                                                                                                                                                       | errup                                                                  |                                                                                                                                          | ng a write to the                                                                                                                                                                               | FLASH, the W                                                                                                                                                              |                                                                                                                                                            | 1<br>9 "1" and the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                             |  |
|                               | lf a<br>dise                                                           | nonmaskable int                                                                                                                                                                       | errup<br>n war                                                         | m-up (CPU w                                                                                                                              | ng a write to the ait) for the control                                                                                                                                                          | FLASH, the W<br>circuit of Flash                                                                                                                                          | memory is ex                                                                                                                                               | 1<br>"1" and the vecuted. (The v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | vrite data                                                                    |  |
|                               | lf a<br>diso<br>cou                                                    | nonmaskable int continued, and the                                                                                                                                                    | errup<br>n war<br>If W                                                 | m-up (CPU w<br>/INT = "1" is                                                                                                             | ng a write to the<br>ait) for the control<br>detected in the no                                                                                                                                 | FLASH, the W<br>circuit of Flash<br>onmaskable inte                                                                                                                       | memory is ex<br>errupt service                                                                                                                             | 1<br>"1" and the v<br>ecuted. (The v<br>routine, a wr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | vrite data<br>ite is no                                                       |  |
|                               | lf a<br>disc<br>cou<br>con                                             | n nonmaskable int<br>continued, and the<br>inter is initialized.)                                                                                                                     | errup<br>n war<br>If W<br>ly. So                                       | m-up (CPU w<br>′INT = "1" is<br>, it is necessa                                                                                          | ng a write to the<br>ait) for the control<br>detected in the no<br>ry to try a write aga                                                                                                        | FLASH, the W<br>circuit of Flash<br>onmaskable inte<br>ain. The content                                                                                                   | memory is ex<br>errupt service<br>of the page to                                                                                                           | 1<br>v "1" and the v<br>ecuted. (The v<br>e routine, a wri<br>o which a write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | vrite data<br>ite is no                                                       |  |
|                               | If a<br>disc<br>cou<br>con<br>plac                                     | nonmaskable int<br>continued, and the<br>inter is initialized.)<br>npleted successfull                                                                                                | errup<br>n war<br>If W<br>ly. So<br>d to a                             | m-up (CPU w<br>/INT = "1" is<br>, it is necessa<br>n unexpected                                                                          | ng a write to the<br>ait) for the control<br>detected in the no<br>ry to try a write aga<br>value depending o                                                                                   | FLASH, the W<br>circuit of Flash<br>onmaskable inte<br>ain. The content<br>n the timing wh                                                                                | memory is ex<br>errupt service<br>of the page to<br>en the WINT b                                                                                          | 1<br>"1" and the v<br>ecuted. (The v<br>e routine, a write<br>o which a write<br>becomes "1".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | vrite data<br>ite is no<br>is taking                                          |  |
| Note 1:                       | If a<br>disc<br>cou<br>con<br>plac<br>Eve                              | n nonmaskable int<br>continued, and the<br>inter is initialized.)<br>npleted successfull<br>ce may be changed                                                                         | errup<br>n war<br>If W<br>ly. So<br>d to a                             | m-up (CPU w<br>/INT = "1" is<br>, it is necessa<br>n unexpected                                                                          | ng a write to the<br>ait) for the control<br>detected in the no<br>ry to try a write aga<br>value depending o                                                                                   | FLASH, the W<br>circuit of Flash<br>onmaskable inte<br>ain. The content<br>n the timing wh                                                                                | memory is ex<br>errupt service<br>of the page to<br>en the WINT b                                                                                          | 1<br>"1" and the v<br>ecuted. (The v<br>e routine, a write<br>o which a write<br>becomes "1".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | vrite data<br>ite is no<br>is taking                                          |  |
| Note 1:                       | If a<br>disc<br>cou<br>con<br>plac<br>Eve                              | a nonmaskable int<br>continued, and the<br>inter is initialized.)<br>npleted successful<br>ce may be changed<br>en if a nonmaskabl                                                    | errup<br>n war<br>If W<br>ly. So<br>d to a<br>e inte                   | m-up (CPU w<br>/INT = "1" is<br>, it is necessa<br>n unexpected<br>rrupt occurs c                                                        | ng a write to the<br>ait) for the control<br>detected in the no<br>ry to try a write aga<br>value depending o<br>luring an FLASH w                                                              | FLASH, the W<br>circuit of Flash<br>onmaskable inte<br>ain. The content<br>n the timing wh<br>rarm-up, the CF                                                             | memory is ex<br>errupt service<br>of the page to<br>en the WINT to<br>PU stays at a h                                                                      | 1<br>"1" and the v<br>eccuted. (The v<br>routine, a write<br>becomes "1".<br>halt until the wa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | vrite data<br>ite is no<br>is taking                                          |  |
| Note 1:<br>Note 2:            | If a<br>disc<br>cou<br>con<br>plac<br>Eve<br>finis                     | n nonmaskable int<br>continued, and the<br>inter is initialized.)<br>npleted successfull<br>ce may be changed<br>en if a nonmaskabl<br>shed.                                          | errup<br>n war<br>If W<br>ly. So<br>d to a<br>e inte                   | m-up (CPU w<br>/INT = "1" is<br>, it is necessa<br>n unexpected<br>rrrupt occurs c<br>cleared to "0"                                     | ng a write to the<br>ait) for the control<br>detected in the no<br>ry to try a write aga<br>value depending o<br>luring an FLASH w                                                              | FLASH, the W<br>circuit of Flash<br>onmaskable intr<br>ain. The content<br>n the timing wh<br>arm-up, the CF<br>ction is execute                                          | memory is ex<br>errupt service<br>of the page to<br>en the WINT b<br>U stays at a h<br>d to the EEPS                                                       | 1<br>"1" and the v<br>ecuted. (The v<br>e routine, a write<br>o which a write<br>becomes "1".<br>halt until the wa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | vrite data<br>ite is no<br>is taking<br>arm-up is                             |  |
| Note 1:<br>Note 2:<br>Note 3: | If a<br>disc<br>cou<br>con<br>plac<br>Eve<br>finis<br>The<br>Wh        | a nonmaskable int<br>continued, and the<br>inter is initialized.)<br>npleted successful<br>ce may be changed<br>en if a nonmaskabl<br>shed.<br>e WINT is automati                     | errup<br>n war<br>If W<br>ly. So<br>d to a<br>e inte                   | m-up (CPU w<br>/INT = "1" is<br>, it is necessa<br>n unexpected<br>errupt occurs of<br>cleared to "0"<br>ed from "0" to "                | ng a write to the<br>ait) for the control<br>detected in the no<br>ry to try a write aga<br>value depending o<br>luring an FLASH w<br>when a read instru-<br>1", EWUPEN beco                    | FLASH, the W<br>circuit of Flash<br>onmaskable intr<br>ain. The content<br>n the timing wh<br>rarm-up, the CF<br>ction is execute<br>mes "1" after ta                     | memory is ex<br>errupt service<br>of the page to<br>en the WINT b<br>PU stays at a h<br>d to the EEPS<br>king 2 <sup>10</sup> /fc [s] (                    | 1<br>vecuted. (The vecuted. (The vecuted. (The vecuted. (The vecuted. a write o which a write becomes "1".<br>halt until the was the compared of the vecuted of th | vrite data<br>ite is no<br>is taking<br>arm-up is                             |  |
| Note 1:<br>Note 2:<br>Note 3: | If a<br>disc<br>cou<br>con<br>plac<br>Eve<br>finis<br>The<br>Wh<br>[s] | a nonmaskable int<br>continued, and the<br>inter is initialized.)<br>npleted successfull<br>ce may be changed<br>en if a nonmaskabl<br>shed.<br>e WINT is automati<br>en MNPWDW is ch | errup<br>n war<br>If W<br>ly. So<br>d to a<br>e inte<br>cally<br>hange | m-up (CPU w<br>/INT = "1" is<br>, it is necessa<br>n unexpected<br>rrupt occurs c<br>cleared to "0"<br>ed from "0" to '<br>accessing the | ng a write to the<br>ait) for the control<br>detected in the no<br>ry to try a write aga<br>value depending o<br>luring an FLASH w<br>when a read instru-<br>1", EWUPEN beco<br>PFLASH, make su | FLASH, the W<br>circuit of Flash<br>onmaskable intra<br>ain. The content<br>in the timing wh<br>arm-up, the CF<br>ction is execute<br>mes "1" after ta<br>re that the EWU | memory is ex<br>errupt service<br>of the page to<br>en the WINT b<br>U stays at a h<br>d to the EEPS<br>king 2 <sup>10</sup> /fc [s] (<br>IPEN is "1" in t | 1<br>"1" and the vector of the v     | vrite data<br>ite is no<br>is taking<br>arm-up is<br>") or 2 <sup>3</sup> /fs |  |

Figure 2.17.3 FLASH Status Register

|                                                                           | 7                                                                                                | 6 5                                                                                                                     | 4                                                                                                  | 3 2                                                                                          | 2 1                                                                                                            | 0                                                                                         |                                                                                 |
|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| EPEVA<br>1FE2H)                                                           |                                                                                                  | 6 5                                                                                                                     |                                                                                                    |                                                                                              | EEPSUCR                                                                                                        | (Init                                                                                     | ial value: **** *                                                               |
| IFEZH)                                                                    |                                                                                                  |                                                                                                                         |                                                                                                    |                                                                                              |                                                                                                                |                                                                                           |                                                                                 |
|                                                                           |                                                                                                  |                                                                                                                         |                                                                                                    |                                                                                              | ulation Chip<br>/IP86C948)                                                                                     | FLASH<br>(TMP86                                                                           |                                                                                 |
|                                                                           |                                                                                                  |                                                                                                                         |                                                                                                    | NORMAL1/2SLOW1/2IDLE1/2SLEEP1/2modemode                                                      |                                                                                                                | All operat<br>modes                                                                       | ion                                                                             |
| EEPSUCR                                                                   | Controll                                                                                         | ing the FLASH w                                                                                                         | rite 000                                                                                           | 2 <sup>16</sup> /fc                                                                          | 2 <sup>7</sup> /fs                                                                                             |                                                                                           |                                                                                 |
|                                                                           | CR emulatio                                                                                      | on time [s] for                                                                                                         | 001                                                                                                | 2 <sup>15</sup> /fc                                                                          | 2 <sup>6</sup> /fs                                                                                             |                                                                                           | R                                                                               |
|                                                                           | emulatio                                                                                         | on chip                                                                                                                 | 010                                                                                                | 2 <sup>14</sup> /fc                                                                          | 2 <sup>5</sup> /fs                                                                                             | Typ. 4 ms                                                                                 |                                                                                 |
|                                                                           |                                                                                                  |                                                                                                                         | 011                                                                                                | 2 <sup>13</sup> /fc                                                                          | 2 <sup>4</sup> /fs                                                                                             | (regardles<br>register s                                                                  |                                                                                 |
|                                                                           |                                                                                                  |                                                                                                                         | 100                                                                                                | 2 <sup>12</sup> /fc                                                                          | 2 <sup>3</sup> /fs                                                                                             | and the s                                                                                 | 0                                                                               |
|                                                                           |                                                                                                  |                                                                                                                         | 101                                                                                                | Reserved                                                                                     | Reserved                                                                                                       | clock)                                                                                    |                                                                                 |
|                                                                           |                                                                                                  |                                                                                                                         | 110                                                                                                | Reserved                                                                                     | Reserved                                                                                                       |                                                                                           |                                                                                 |
|                                                                           |                                                                                                  | 111 Reserved                                                                                                            |                                                                                                    | Reserved                                                                                     |                                                                                                                |                                                                                           |                                                                                 |
| Note 1: Only in the emulation chip, the read-access the register. It does |                                                                                                  |                                                                                                                         |                                                                                                    |                                                                                              | the FLASH produ                                                                                                |                                                                                           | e only to write-                                                                |
|                                                                           |                                                                                                  | U                                                                                                                       |                                                                                                    |                                                                                              |                                                                                                                | H product incorp                                                                          | porates a dedic                                                                 |
| Note                                                                      | oscillator,                                                                                      | its write time is in                                                                                                    | dependent of th                                                                                    | e system clock                                                                               |                                                                                                                |                                                                                           |                                                                                 |
|                                                                           | oscillator, i<br>2: Executing                                                                    | its write time is in<br>a read instruction                                                                              | dependent of the to the the tepeorem                                                               | ne system clock<br>A register result                                                         | s in bit7 to 3 being                                                                                           | read as undefir                                                                           | ned.                                                                            |
|                                                                           | oscillator, i<br>2: Executing<br>3: The follow                                                   | its write time is in<br>a read instruction<br>ing table lists the                                                       | dependent of the to the EEPEV, write emulation                                                     | e system clock<br>A register result<br>time specified                                        |                                                                                                                | read as undefir                                                                           | ned.<br>elect an approp                                                         |
|                                                                           | oscillator, i<br>2: Executing<br>3: The follow                                                   | its write time is in<br>a read instruction<br>ing table lists the                                                       | dependent of th<br>n to the EEPEV<br>write emulation<br>ating frequency                            | e system clock<br>A register result<br>time specified                                        | s in bit7 to 3 being<br>by the setting of th<br>ding indicates reco                                            | read as undefir                                                                           | ned.<br>elect an approp                                                         |
|                                                                           | oscillator,<br>2: Executing<br>3: The follow<br>value acco                                       | its write time is in<br>a read instruction<br>ing table lists the                                                       | dependent of th<br>n to the EEPEV<br>write emulation<br>ating frequency                            | e system clock<br>A register result<br>time specified<br>used. The shar                      | s in bit7 to 3 being<br>by the setting of th<br>ding indicates reco                                            | read as undefir                                                                           | ned.<br>elect an approp<br>ngs.                                                 |
|                                                                           | oscillator, i<br>2: Executing<br>3: The follow<br>value acco<br>EEPSUCR                          | its write time is in<br>a read instruction<br>ing table lists the<br>ording to the oper                                 | dependent of th<br>n to the EEPEV,<br>write emulation<br>ating frequency                           | A register clock<br>A register result<br>time specified<br>used. The shar                    | s in bit7 to 3 being<br>by the setting of th<br>ding indicates reco<br>nde                                     | read as undefin<br>the EEPSUCR. S<br>the settin                                           | ned.<br>elect an approp<br>ngs.<br>SLOW1/2 Mo                                   |
|                                                                           | oscillator, i<br>2: Executing<br>3: The follow<br>value acco<br>EEPSUCR<br>Setting               | its write time is in<br>a read instruction<br>ing table lists the<br>ording to the oper<br>fc = 16 MHz                  | dependent of the to the EEPEV<br>write emulation<br>ating frequency<br>fc = 8 MHz                  | A register result<br>time specified<br>used. The shar<br>NORMAL1/2 Mo<br>fc = 4 MHz          | s in bit7 to 3 being<br>by the setting of th<br>ding indicates reco<br>de<br>fc = 2 MHz                        | read as undefin<br>te EEPSUCR. S<br>ommended settin<br>fc = 1 MHz                         | ned.<br>elect an approp<br>ngs.<br>SLOW1/2 Mo<br>fs = 32.768 ki                 |
| Note                                                                      | oscillator, i<br>2: Executing<br>3: The follow<br>value acco<br>EEPSUCR<br>Setting<br>000        | ts write time is in<br>a read instruction<br>ing table lists the<br>ording to the oper<br>fc = 16 MHz<br>4.10           | dependent of the to the EEPEV,<br>write emulation<br>ating frequency<br>fc = 8 MHz<br>8.19         | A register result<br>time specified<br>used. The shar<br>NORMAL1/2 Mo<br>fc = 4 MHz<br>16.38 | s in bit7 to 3 being<br>by the setting of th<br>ding indicates reco<br>de<br>fc = 2 MHz<br>32.77               | read as undefin<br>te EEPSUCR. S<br>ommended settin<br>fc = 1 MHz<br>65.54                | ned.<br>elect an approp<br>ngs.<br>SLOW1/2 Mo<br>fs = 32.768 ki<br>3.91         |
| Write                                                                     | oscillator, i<br>2: Executing<br>3: The follow<br>value acco<br>EEPSUCR<br>Setting<br>000<br>001 | its write time is in<br>a read instruction<br>ing table lists the<br>ording to the oper<br>fc = 16  MHz<br>4.10<br>2.05 | dependent of the to the EEPEV,<br>write emulation<br>ating frequency<br>fc = 8 MHz<br>8.19<br>4.10 | NORMAL1/2 Mc<br>fc = 4 MHz<br>16.38<br>8.19                                                  | s in bit7 to 3 being<br>by the setting of the<br>ding indicates reconnected<br>by fc = 2 MHz<br>32.77<br>16.38 | fread as undefine<br>the EEPSUCR. S<br>frommended settine<br>fc = 1 MHz<br>65.54<br>32.77 | ned.<br>elect an approp<br>ngs.<br>SLOW1/2 Mo<br>fs = 32.768 kl<br>3.91<br>1.95 |

Figure 2.17.4 FLASH Control Register and FLASH Status Register

## 2.17.3 FLASH Write Enable Control (EEPCR<EEPMD>)

In the FLASH product, the control register can be used to disable a write to the FLASH (Write protect) in order to prevent a write to the FLASH from occurring by mistake because of a program error or microcontroller malfunction. To enable a write to the FLASH, set the EEPCR<EEPMD> with 0011B. To disable a write to the FLASH, set the EEPCR<EEPMD> with 1100B. A reset initializes the EEPCR<EEPMD> to 1100B to disable a write to the FLASH. Usually, set the EEPCR<EEPMD> with 1100B, except when it is necessary to write to the FLASH.

Note: The EEPCR<EEPMD> can be rewritten only when a program is being executed in the RAM area. Executing a write instruction to the EEPCR<EEPMD> in the FLASH area does not change its setting.

## 2.17.4 FLASH Write Forcible Stop (EEPCR<EEPRS>)

To forcibly stop a write to the FLASH, set the EEPCR<EEPRS> to "1". Setting the EEPCR<EEPRS> to "1" initializes the write data counter of data buffer and forcibly stops a write, and then a warm-up (CPU wait) for the control circuit of Flash memory is executed. After warm-up period, the EEPSR<BFBUSY> is cleared to "0". The warm-up period is  $2^{10}$ /fc (SYSCK = "0") or  $2^{3}$ /fs (SYSCK = "1"). After this, if writing to FLASH starts again, data is stored as the first byte of the temporary data buffer and sets the EEPSR<BFBUSY> to "1". Therefore, it is necessary to write 64 bytes data to the temporary data buffer.

- After 1 to 63 bytes are saved to the temporary data buffer, if the EEPCR<EEPRS> is set to "1" the specified page of FLASH is not written. (It keeps previous data.)
- Note 1: After 64 bytes are written to the temporary data buffer, the setting the EEPCR<EEPRS> to "1" may cause the writing the page of FLASH to an unexpected value.
- Note 2: The EEPCR<EEPRS> can be rewritten only when a program is being executed in the RAM area. In the FLASH area, executing a write instruction to the EEPCR<EEPRS> does not affect its setting.
- Note 3: During the warm-up period for Flash memory (CPU wait), the peripheral circuits continue operating, but the CPU stays at a halt until the warm-up is finished. Even if an interrupt latch is set to "1" by generating of interrupt request, an interrupt sequence doesn't start till the end of warm-up. If interrupts occur during a warm-up period with IMF = "1", the interrupt sequence which depends on interrupt priority will start after warm-up period.
- Note 4: When the EEPCR<EEPRS> is set to "1" with EEPSR<BFBUSY> = "0", a warm-up is not executed.
- Note 5: If executed a write or read instruction to the Flash area immediately after setting EEPCR<EEPRS>, insert one or more machine cycle instructions after setting EEPCR<EEPRS>.

Example: Reads the Flash memory data immediately after setting EEPCR<EEPRS> to "1"

| LD  | HL,8000H    |                                                       |
|-----|-------------|-------------------------------------------------------|
| LD  | (EEPCR),3FH | ; Set EEPCR <eeprs> to "1"</eeprs>                    |
| NOP |             | ; NOP                                                 |
|     |             | (Do not execute write or read instruction immediately |
|     |             | after setting EEPCR <eeprs>.)</eeprs>                 |
| LD  | A,(HL)      | ; Reads the data of address 8000H                     |
|     |             | (Write or read instruction to the Flash memory)       |
|     |             |                                                       |



Figure 2.17.5 Write Data Counter Initialization and Write Forcible Stop

## 2.17.5 Power Control for the FLASH Control Circuit

For the FLASH product, it is possible to turn off the power for FLASH control circuit (such as a regulator) to suppress power consumption if the FLASH area is not accessed. For the emulation chip (TMP86C948), the register setting and the CPU wait functions behave in the same manner as for the FLASH product to maintain compatibility; however, power consumption is not suppressed.

The EEPCR<MNPWDW> and EEPCR<ATPWDW> are used to control the power for the FLASH control circuit. If the power for the FLASH control circuit is turned off according to the setting of these registers, starting to use the circuits again needs to allow warm-up time for the power supply.

| NORMAL1/2               | SLOW1/2                | STOP Mode (when EEP                         | CR <mnpwdw> = "1")</mnpwdw>                |
|-------------------------|------------------------|---------------------------------------------|--------------------------------------------|
| IDLE0/1/2 Mode          | SLEEP0/1/2 Mode        | To Return to a NORMAL Mode                  | To Return to a SLOW Mode                   |
| 2 <sup>10</sup> /fc [s] | 2 <sup>3</sup> /fs [s] | STOP warm-up time + 2 <sup>10</sup> /fc [s] | STOP warm-up time + 2 <sup>3</sup> /fs [s] |
| (64 µs @16 MHz)         | (244 µs @32.768 kHz)   |                                             |                                            |

#### Table 2.17.1 Power Supply Warm-up Time (CPU wait) for the FLASH Control Circuit

#### 2.17.5.1 Software-based Power Control for the FLASH Control Circuit (EEPCR<MNPWDW>)

The EEPCR<MNPWDW> is a software-based power control bit for the FLASH control circuit. When a program is being executed in the RAM area, setting this bit enables software-based power control. Clearing the EEPCR<MNPWDW> to "0" immediately turns off the power for the FLASH control circuit. Once the EEPCR<MNPWDW> is switched from "0" to "1", before attempting a read or fetch from the FLASH area, it is necessary to insert a warm up period by software until the power supply is stabilized. In this case, because the CPU wait is not executed, any other instructions except accessing to Flash (write or read) are available. When MNPWDW is changed from "0" to "1", EWUPEN becomes "1" after taking  $2^{10}/fc$  [s] (SYSCK = "0") or  $2^3/fs$  [s] (SYSCK = "1"). Usually software-based polling should be performed until the EEPSR<EWUPEN> becomes "1". An example of setting is given below.

- (1) Example of controlling the EEPCR<MNPWDW>
  - 1. Transfer a program for controlling the EEPCR<MNPWDW> to the RAM area.
  - 2. Release an address trap in the RAM area (Setup the WDTCR1 and WDTCR2 registers).
  - 3. Jump to the control program transferred to the RAM area.
  - 4. Clear the interrupt master enable flag (IMF  $\leftarrow$  "0").
  - 5. Clear the binary counter if the watchdog timer is in use.
  - 6. To turn off the power for the FLASH control circuit, clear the EEPCR<MNPWDW> to "0".
  - 7. Perform CPU processing as required.
  - 8. To access the FLASH area again, set the EEPCR<MNPWDW> to "1".
  - Keep program polling until the EEPSR<EWUPEN> becomes "1".
     (Upon completion of an FLASH warming-up, the EEPSR<EWUPEN> is set to "1". It takes 2<sup>10</sup>/fc (SYSCK = "0") or 2<sup>3</sup>/fs (SYSCK = "1") until EWUPEN becomes "1".)

This procedure enables the FLASH area to be accessed.

If the EEPCR<MNPWDW> is "1", entering a STOP mode forcibly turns off the power for the FLASH control circuit. When the STOP mode is released, a STOP mode oscillation warm-up is carried out, and then the CPU wait period (Warm-up for stabilizing of FLASH power supply circuit) is automatically performed. If the EEPCR<MNPWDW> is "0", entering/exiting the STOP mode keeps the power for the FLASH control circuit turned off.

- Note 1: If the EEPSR<EWUPEN> is "0", do not access (Fetch, read, or write) the FLASH area. Executing a read instruction or fetch to the FLASH area causes FFH to be read. Fetching FFH results in a software interrupt occurring.
- Note 2: To clear the EEPCR<MNPWDW> to "0", clear the interrupt master enable flag (IMF) to "0" in advance to disable an interrupt. After that, do not set IMF to "1" during EEPSR<EWUPEN> = "0".
- Note 3: If the EEPCR<MNPWDW> is "0", generating a nonmaskable interrupt automatically rewrites the MNPWDW to "1" to warm up the FLASH control circuit (CPU wait). That time, the peripheral circuits continue operating, but the CPU stays at a halt until the warm-up is finished.
- Note 4: The EEPCR<MNPWDW> can be rewritten only when a program is being executed in the RAM area. In the FLASH area, executing a write instruction to the EEPCR<MNPWDW> does not affect its setting.
- Note 5: If a watchdog timer is used as interrupt request, clear the binary counter for the watchdog timer just before MNPWDW is changed from "1" to "0".
- Note 6: During the warm-up period with a software polling of EEPSR<EWUPEN>, if a nonmaskable interrupt occurs, the CPU stays at a halt until the warm-up is finished.

| Spec                         | tify MNPWDW = 0  |                 | Specify MNPWDW = 1                   |
|------------------------------|------------------|-----------------|--------------------------------------|
| EEPCR <mnpwdw></mnpwdw>      |                  |                 | ſ                                    |
| EEPSR <ewupen></ewupen>      |                  |                 |                                      |
| EEPSR <bfbusy></bfbusy>      | Ĺ                |                 |                                      |
| Program execution area       | FLASH area       | RAM area        | ▼ ▼ ▼ ▼ ▼ ▼ ¥ FLASH area             |
| FLASH warm-up counter        | 0                |                 |                                      |
| FLASH control circuit status | Normal operation | Power-off state | Warm-up in progress Normal operation |

Figure 2.17.6 Software-based Power Control for the FLASH Control Circuit (EEPCR<MNPWDW>)

| sRAMAREA: |      |              |   |                                                          |
|-----------|------|--------------|---|----------------------------------------------------------|
|           | DI   |              | ; | Disable an interrupt (IMF $\leftarrow$ "0")              |
|           | LD   | (WDTCR2),4Eh | ; | Clear the binary counter if the watchdog timer is in use |
|           | CLR  | (EEPCR).0    | ; | Clear the EEPCR <mnpwdw> to "0".</mnpwdw>                |
|           | SET  | (EEPCR).0    | ; | Set the EEPCR <mnpwdw> to "1"</mnpwdw>                   |
| sLOOP1:   | TEST | (EEPSR).1    | ; | Monitor the EEPSR <ewupen> register.</ewupen>            |
|           | JRS  | T,sLOOP1     | ; | Jump to sLOOP1 if EEPSR <ewupen> = "0".</ewupen>         |
|           | JP   | MAIN         | ; | Jump to the FLASH area.                                  |

Example: Performing software-based power control for the FLASH control circuit

2.17.5.2 Automatic Power Control for the FLASH Control Circuit (EEPCR<ATPWDW>)

The EEPCR<ATPWDW> is an automatic power control bit for the FLASH control circuit. It is possible to suppress power consumption by automatically shutting down the power for the FLASH control circuit when an operation mode is changed to IDLE0/1/2 and SLEEP0/1/2 modes. This bit can be specified regardless of the area in which a program is being executed.

After the EEPCR<ATPWDW> is cleared to "0", entering an operation mode (IDLE0/1/2 or SLEEP0/1/2) where the CPU is at a halt automatically turns off the power for the FLASH control circuit. Once the operation mode is released, the warm-up time (CPU wait) is automatically counted to resume normal processing. The CPU wait period is either  $2^{10}$ /fc (SYSCK = "0") or  $2^{3}$ /fs (SYSCK = "1"). If the EEPCR<ATPWDW> is "1", releasing the operation mode does not cause the CPU wait.

If EEPCR<MNPWDW> = "1", executing a STOP mode forcibly turns off the power for the FLASH control circuit regardless of the setting of the EEPCR<ATPWDW>. When the STOP mode is released, a STOP mode oscillation warm-up is carried out, and then an FLASH control circuit warm-up (CPU wait) is automatically performed. If the EEPCR<MNPWDW> is "0", entering/exiting a STOP mode allows the power for the FLASH control circuit to be kept turned off.

- Note 1: The EEPCR<ATPWDW> functions only if the EEPCR<MNPWDW> is "1". If the EEPCR<MNPWDW> is "0", the power for the FLASH control circuit is kept turned off when an operation mode is executed or released.
- Note 2: During an FLASH warm-up (CPU wait), the peripheral circuits continue operating, but the CPU stays at a halt. Even if an interrupt latch is set under this condition, no interrupt process occurs until the CPU wait is completed. If the IMF is "1" when the interrupt latch is set, interrupt process takes place according to the interrupt priority after the CPU has started operating.



Figure 2.17.7 Automatic Power Control for the FLASH Control Circuit (EEPCR<ATPWDW>)

## 2.17.6 Accessing the FLASH Data Memory Area

During the writing to the data memory of FLASH area, neither a read nor fetch can be performed for the 8000H to FFFFH area. Therefore, to write the data memory of FLASH, the program being executed should be jumped to RAM area or should be jumped to the support program in BOOT-ROM. For details about the support program in BOOT-ROM, refer to "2.17.6.2 Method of Using Support Programs in the BOOT-ROM".

An LD instruction can be used to read data from the data memory of FLASH area byte by byte. The support program incorporated in the BOOT-ROM can also be used to read data from the data memory of FLASH area.

If a nonmaskable interrupt occurs during a write to the FLASH (EEPSR<BFBUSY> = "1"), the WINT is set to "1" and the writing is discontinued, and then the warm-up (CPU wait) for control circuit of Flash memory is executed (The write data counter is also initialized). If WINT = "1" is detected in the nonmaskable interrupt service routine, a write is not completed successfully. So, it is necessary to try a write again. The warm-up period is  $2^{10}$ /fc (SYSCK = "0") or  $2^{3}$ /fs (SYSCK = "1"). After 1 to 63 bytes are saved to the temporary data buffer, if an interrupt generates, the specified page of FLASH is not written. (It keeps previous data.)

- Note 1: After 64 bytes are written to the temporary data buffer, the generating of an interrupt may cause the writing the page of FLASH to an unexpected value.
- Note 2: During the warm-up period for Flash memory (CPU wait), the peripheral circuits continue operating, but the CPU stays at a halt until the warm-up is finished. Even if an interrupt latch is set to "1" by generating of interrupt request, an interrupt sequence doesn't start till the end of warm-up. If interrupts occur during a warm-up period with IMF = "1", the interrupt sequence which depends on interrupt priority will start after warm-up period.
- Note 3: When write the data to Flash memory from RAM area, disable all the nonmaskable interrupt by clearing interrupt master enable flag (IMF) to "0" beforehand. However, in support program of BOOT-ROM, there is no need to clear the IMF because BOOT-ROM already has a DI (Disable Interrupt) instruction.

## 2.17.6.1 Method of Developing the Control Program in the RAM Area

To develop the program in RAM, the write control program should be stored in FLASH beforehand or should load from external device by using peripheral function (Example: UART, SIO etc). Given below is an example of developing the control program in the RAM area.

- (1) Example of developing and writing the control program to the RAM area
  - 1. For the emulation chip, set the EEPEVA register with an optimum time value according to the operating frequency.
  - 2. Transfer the write control program to the RAM area.
  - 3. Release an address trap in the RAM area (Set up the WDTCR1 and WDTCR2 registers).
  - 4. Jump to the RAM area.
  - 5. Monitor the EEPSR<EWUPEN>. If it is "0", set the EEPCR<MNPWDW> to "1", and then start and keep polling until the EEPSR<EWUPEN> becomes "1".
  - 6. Clear the interrupt master enable flag (IMF  $\leftarrow$  "0").
  - 7. Set the EEPCR with "3BH" (to enable a write to the FLASH).
  - 8. Execute a write instruction for 64 bytes to the FLASH area.
  - 9. Start and keep polling by software until the EEPSR<BFBUSY> becomes "0". (Upon completion of an erase and write to the FLASH cells, the EEPSR<BFBUSY> is set to "1". For the FLASH product, the required write time is typically 4 ms. For the emulation chip, it is the value specified in the EEPEVA register.)
  - 10. Set the EEPCR with "CBH" (to disable a write to the FLASH).
  - 11. Jump to the FLASH area (Main program).
  - Note: See (2), "Method of specifying an address for a write to the FLASH," for a description about the FLASH address to be specified at step 8 above.

(2) Method of specifying an address for a write to the FLASH

The FLASH page to be written is specified by the 10 high-order bits of the address of the first-byte data. The first-byte data is stored at the first address of the temporary data buffer. If the data to be written is, for example, 8040H, page 1 is selected, and the data is stored at the first address of the temporary data buffer. Even if the 6 low-order bits of the specified address is not 000000B, the first-byte data is always stored at the first address of the data buffer.

Any address can be specified as the second and subsequent address within FLASH area (for the MCU mode, 8000 to 81FFH and, for the serial PROM mode, 8000H to FFFFH). The write data bytes are stored in the temporary data buffer in the sequence they are written, regardless of what address is specified. Usually, the address that is the same as the first-byte is specified for the second and subsequent address. A 16-bit transfer instruction (LDW) can also be used for writing to the temporary data buffer.

| Example: D | Data bytes 00H  | to 3FH are written to | page 1.        |                                                                                                           |
|------------|-----------------|-----------------------|----------------|-----------------------------------------------------------------------------------------------------------|
| (          | Figure 2.17.8 s | hows the example of   | data buffer an | d pages.)                                                                                                 |
|            | DI              |                       | ;              | Disable an interrupt (IMF $\leftarrow$ "0")                                                               |
|            | LD              | C,00H                 |                |                                                                                                           |
|            | LD              | HL,EEPCR              | ;              | Specify the EEPCR register address.                                                                       |
|            | LD              | IX,8040H              | ;              | Specify a write address.                                                                                  |
|            | LD              | (HL),3BH              | ;              | Specify the EEPCR                                                                                         |
| sLOOP1:    |                 |                       |                |                                                                                                           |
|            | LD              | (IX),C                | ;              | Store data to the temporary data buffer.<br>(A write page is selected when the first<br>byte is written.) |
|            | INC             | С                     | ;              | C = C + 1                                                                                                 |
|            | CMP             | C,40H                 | ;              | Jump to sLOOP1 if C is not 40H                                                                            |
|            | JR              | NZ,sLOOP1             |                |                                                                                                           |
| sLOOP2:    |                 |                       |                |                                                                                                           |
|            | TEST            | (EEPSR).0             |                |                                                                                                           |
|            | JRS             | F,sLOOP2              | ;              | Jump to sLOOP2 if EEPSR <bfbusy> = "1".</bfbusy>                                                          |
|            | LD              | (HL),0CBH             | ;              | Specify the EEPCR                                                                                         |

Note: If the BFBUSY is "1", executing a read instruction or fetch to the FLASH area causes "FFH" to be read. Fetching "FFH" results in a software interrupt occurring.

|         | 0   | 1   | 2   | 3   | 4   | 5   | 6   | 7    | 8      | 9   | А   | В   | С   | D   | Е   | F   |     |
|---------|-----|-----|-----|-----|-----|-----|-----|------|--------|-----|-----|-----|-----|-----|-----|-----|-----|
|         | 00H | 01H | 02H | 03H | 04H | 05H | 06H |      |        |     |     |     |     |     |     |     | ٦   |
|         | 10H | 11H | 12H | 13H | 14H | 15H | 16H | Temp | orary  | 19H | 1AH | 1BH | 1CH | 1DH | 1EH | 1FH | 5   |
|         | 20H | 21H | 22H | 23H | 24H | 25H | 26H |      | ouffer |     | 2AH |     |     |     |     |     |     |
|         | 30H | 31H | 32H | 33H | 34H | 35H | 36H | 37H  | 38H    | 39H | 3AH | 3BH | 3CH | 3DH | 3EH | 3FH | J   |
|         | •   |     |     |     | •   |     | •   |      |        |     |     |     |     |     |     |     | -   |
| Address | 0   | 1   | 2   | 3   | 4   | 5   | 6   | 7    | 8      | 9   | А   | В   | С   | D   | Е   | F   |     |
| 8030H   |     | 1   | 1   |     |     |     |     |      | 1      | 1   |     | 1   | 1   |     |     |     |     |
| 8040H   | 00H | 01H | 02H | 03H | 04H | 05H | 06H | 07H  | 08H    | 09H | 0AH | 0BH | 0CH | 0DH | 0EH | 0FH | ר ו |
| 8050H   | 10H | 11H | 12H | 13H | 14H | 15H | 16H | Pac  | e 1    | 19H | 1AH | 1BH | 1CH | 1DH | 1EH | 1FH | 4   |
| 8060H   | 20H | 21H | 22H | 23H | 24H | 25H | 26H |      |        | 29H | 2AH | 2BH | 2CH | 2DH | 2EH | 2FH |     |
| 8070H   | 30H | 31H | 32H | 33H | 34H | 35H | 36H | 37H  | 38H    | 39H | 3AH | 3BH | 3CH | 3DH | 3EH | 3FH | J   |
|         |     |     |     |     |     |     |     |      |        |     |     |     |     |     |     |     |     |

Figure 2.17.9 Data Buffer and Write Page (Example)

| Buffer 0                               | ? X Data 0 0                                          |
|----------------------------------------|-------------------------------------------------------|
| Buffer 1                               | ? <u>X</u> Data 1 0                                   |
| Buffer 2                               | 64 bytes are written at a time.       ?               |
| Buffer 63                              | ?XData 63 O                                           |
| FLASH cell                             | Data before writeing K Erasing Writing Data after     |
| Write instruction to the<br>FLASH area |                                                       |
| Write data counter                     | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ |
| EEPSR <bfbusy></bfbusy>                | Write completed                                       |
| EEPSR <ewupen></ewupen>                |                                                       |

Figure 2.17.10 Write to the FLASH Data Memory Area (In case of FLASH product)

| Buffer 0                            | ? X Data 0            | 0<br>                                  |
|-------------------------------------|-----------------------|----------------------------------------|
| Buffer 1                            | ? X Data 1            |                                        |
|                                     |                       | 64 bytes are written at a time.        |
| Buffer 2                            | ?                     |                                        |
| Buffer 63                           | ?                     | Data 63                                |
| Emulation memory                    |                       | Data before writing                    |
| Write instruction to the FLASH area | h_ii                  |                                        |
| Write data counter                  | <u>0 X 1 X 2 X3 6</u> | 3 0                                    |
| EEPSR <bfbusy></bfbusy>             |                       | Write time<br>(Set by EEPEVA register) |
| EEPSR <ewupen></ewupen>             |                       |                                        |

Figure 2.17.11 Write to the FLASH Data Memory Area (In case of emulation chip)

Note 1: The emulation chip is written to emulation memory instead of FLASH cell.

Note 2: In case of emulation chip, the data stacked to data buffer is written to emulation memory just before EEPSR<BFBUSY> is changed from "1" to "0". Therefore, if the writing of FLASH is stopped forcibly after the write data counter becomes overflow, the memory value on the page subjected to a write may be different from FLASH product.

2.17.6.2 Method of Using Support Programs in the BOOT-ROM

The BOOT-ROM of TMP86FM48 has Support Program to simplify writing/reading of FLASH. This program supports three subroutines.

- 1. Writing to data FLASH from RAM
- 2. Reading from data FLASH to RAM
- 3. Reading from program FLASH to RAM

In addition to a program for controlling a write in the serial PROM mode, the BOOT-ROM incorporates support programs for simplifying a write to the data memory of FLASH in the MCU mode. The support programs take the form of a subroutine. After setting general-purpose registers with the necessary data, just execute a CALL instruction for a support program. It enables a write to and a read from the FLASH. There are two subroutines in BOOT-ROM. The Table 2.17.2 shows the function of these subroutines.

Table 2.17.2 Support Program (Subroutines) in BOOT-ROM

| Program           | CALL address | Function                                                                                                            |
|-------------------|--------------|---------------------------------------------------------------------------------------------------------------------|
| Support program 1 | 3E00H        | Writing to data memory of FLASH (8000H to 81FFH) from RAM area is available. 64-byte data can be written at a time. |
| Support program 2 | 3E2CH        | Reading from FLASH memory (8000H to FFFFH) into RAM area is available. 64-byte data can be read at a time.          |

When using the support program, it is unnecessary to prepare an FLASH write program in advance or develop it in the RAM area.

Support program 1 enables 64 consecutive data bytes to be transferred from the RAM area to any data memory of FLASH page in block. (Only data memory of FLASH is available.) Support program 2 enables data to be transferred from any FLASH memory page (Both data memory of FLASH and program memory are available.) to a specified 64-byte consecutive RAM area in block.

How to use the support programs in the BOOT-ROM is explained below. See (3), "Support program 1," and (4), "Support program 2," for the source code of the support programs.

- Example of using support program 1 to write data to the FLASH data area (Block transfer from the RAM area to the FLASH data area)
  - 1. For the emulation chip, set the EEPEVA register with the optimum time according to the operating frequency.
  - 2. Set data in the transfer-source RAM area.
  - 3. Set the RAM area start address (Transfer source) in the HL register.
  - 4. Set the FLASH data area start address (Transfer destination) in the DE register.
  - 5. Set "1FH" in the B register. (Be sure to set 1FH (Half of the number of bytes to be written.))
  - 6. Clear the binary counter if the watchdog timer is in use.
  - 7. Execute a CALL instruction to "3E00H".
  - 8. Data is transferred from the RAM area to the FLASH data area in block. After several milliseconds, program control is returned to the main routine.

- Note 1: Steps 1 to 6 above are executed in the FLASH area.
- Note 2: Support program 1 rewrites the HL, DE, B, and WA registers. If the existing data in them are necessary, save it in advance.
- Note 3: If the EEPCR<MNPWDW> is "0", executing support program 1 rewrites it to "1" before performing a block transfer.
- Note 4: Executing a CALL instruction for support program 1 consumes two bytes of stack.
- Note 5: If the watchdog timer is in use, be sure to clear the binary counter for it before executing a CALL instruction to 3E00H.
- Note 6: Do not specify the address from 8200H to FFFFH as a transfer destination address in MCU mode.
- Example) Setting up HL = 0050H, DE = 8100H, and B = 1FH, and executing a CALL instruction for support program 1 (3E00H)



Figure 2.17.12 Example of Using Support Program 1 to Write Data to the FLASH Data Area

- (2) Using support program 2 to read data from the FLASH area (Block transfer from the FLASH area to the RAM area)
  - 1. Set the RAM area start address (Transfer destination) in the HL register.
  - 2. Set the FLASH area start address (Transfer source) in the DE register.
  - 3. Set "1FH" in the B register. (Be sure to set 1FH (Half of the number of bytes to be read.))
  - 4. Execute a CALL instruction to "3E2CH".
  - 5. Data is transferred from the FLASH area to the RAM area in block. Upon completion of processing, program control is returned to the main routine.
  - Note 1: A LD instruction can be used to read data from the FLASH area in byte units without using support program 2.
  - Note 2: Steps 1 to 4 above are executed in the FLASH area.
  - Note 3: Support program 2 rewrites the HL, DE, B, and WA registers. If the existing data in them are necessary, save it in advance.
  - Note 4: Executing a CALL instruction for support program 2 consumes two bytes of stack.







(3) Support program 1 (Block transfer from the RAM area to the FLASH data area) Shown below is the support program source code for writing data to the FLASH.

| S | USER_main1:  |      |                  |   |                                                           |
|---|--------------|------|------------------|---|-----------------------------------------------------------|
|   |              | TEST | (EEPSR).1        |   |                                                           |
|   |              | JRS  | f,sRAM_to_EEP    | ; | Jump sRAM_to_EEP if the<br>EEPSR <ewupen> is "1"</ewupen> |
| S | EEP_warming  | up:  |                  |   |                                                           |
|   |              | SET  | (EEPCR).0        | ; | Set the EEPCR <mnpwdw> to "1".</mnpwdw>                   |
|   |              | TEST | (EEPSR).1        | ; | Wait until a warm-up is completed.                        |
|   |              | JRS  | t,sEEP_warmingup |   |                                                           |
| s | RAM_to_EEP:  |      |                  |   |                                                           |
|   |              | DI   |                  | ; | Disable an interrupt.                                     |
|   |              | AND  | DE,0FFC0H        | ; | Mask the 6 low-order bits.                                |
|   |              | LD   | (EEPCR),3BH      | ; | Enable a write to the FLASH.                              |
| s | BFBUSY_loop  | :    |                  |   |                                                           |
|   |              | LD   | WA,(HL)          | ; | Read data from the RAM.                                   |
|   |              | LD   | (DE),WA          | ; | Write data to the FLASH.                                  |
|   |              | INC  | HL               |   |                                                           |
|   |              | INC  | HL               |   |                                                           |
|   |              | DEC  | В                |   |                                                           |
|   |              | JRS  | F,sBFBUSY_loop   |   |                                                           |
| S | EEP_write_en | d:   |                  |   |                                                           |
|   |              | TEST | (EEPSR).0        | ; | Perform polling on the BFBUSY flag.                       |
|   |              | JRS  | F,sEEP_write_end |   |                                                           |
|   |              | LD   | (EEPCR),0CBH     | ; | Disable a write to the FLASH.                             |
|   |              | RET  |                  |   |                                                           |
|   |              |      |                  |   |                                                           |

USER\_SUB\_WRITE section code abs = 3E00H

(4) Support program 2 (Block transfer from the FLASH area to the RAM area)

Shown below is the support program source code for reading data from the FLASH.

USER\_SUB\_READ section code abs = 3E2CH sUSER\_main2: AND DE,0FFC0 Mask the 6 low-order bits. ; LD (EEPCR),0CBH ; Disable a write to the FLASH. sEEP\_read\_loop: LD WA,(DE) LD (HL),WA INC HL INC HL DE INC DE INC DEC В JRS F,sEEP\_read\_loop RET

# 2.18 FLASH Program Memory

The TMP86FM48 incorporates 32256 bytes (8200H to FFFFH) of program memory. If the data memory of FLASH is not in use, the TMP86FM48 can be used as an FLASH product with 32768 full bytes. To write data to the program memory (Data memory of FLASH), execute the serial PROM mode.

## 2.18.1 Configuration

The program memory has the same configuration as for the data memory of FLASH. See Section 2.17.1 "Configuration".

### 2.18.2 Control

The program memory is controlled in the same manner as for the data memory of FLASH. See Section 2.17.2 "Control".

## 2.18.3 FLASH Write Enable Control (EEPCR<EEPMD>)

The FLASH write enable control register for the program memory behaves in the same manner as for the data memory of FLASH. See Section 2.17.3 "FLASH Write Enable Control (EEPCR<EEPMD>)".

# 2.18.4 FLASH Write Forcible Stop (EEPCR<EEPRS>)

The FLASH write forcible stop register for the program memory behaves in the same manner as for the data memory of FLASH. See Section 2.17.4 "FLASH Write Forcible Stop (EEPCR<EEPRS>)".

## 2.18.5 Power Control for the FLASH Control Circuit

The power for the program memory control circuit is controlled in the same manner as for the data memory of FLASH. See Section 2.17.5 "Power Control for the FLASH Control Circuit".

## 2.18.6 Accessing the FLASH Program Memory Area

Basically, a write to the program memory area is carried out using UART communication after the serial PROM mode is entered. For explanations about what control is performed in the serial PROM mode, see the following descriptions.

# 2.19 Serial PROM Mode

## 2.19.1 Outline

The TMP86FM48 has a 2 Kbytes BOOT-ROM for programming to FLASH memory. This BOOT-ROM is a mask ROM that contains a program to write the FLASH memory on-board. The BOOT-ROM is available in a serial PROM mode and it is controlled by BOOT pin and RESET pin, and is communicated via TXD (P06) and RXD (P05) pins. There are four operation modes in a serial PROM mode: FLASH memory writing mode, RAM loader mode, FLASH memory SUM output mode and Product discrimination code output mode. Operating area of serial PROM mode differs from that of MCU mode. The operating area of serial PROM mode shows in Table 2.19.1.

| Parameter             | Min | Max | Unit |
|-----------------------|-----|-----|------|
| Operating voltage     | 2.7 | 3.6 | V    |
| High frequency (Note) | 2   | 16  | MHz  |
| Temperature           | 25  | °C  |      |

Table 2.19.1 Operating Area of Serial PROM Mode

Note: Even though included in above operating area, part of frequency can not be supported in serial PROM mode. For details, refer to.

## 2.19.2 Memory Mapping

The BOOT-ROM is mapped in address 3800<sub>H</sub> to 3FFF<sub>H</sub>. The Figure 2.19.1 shows a memory mapping.



Figure 2.19.1 Memory Address Maps

#### 2.19.3 Serial PROM Mode Setting

#### 2.19.3.1 Serial PROM Mode Control Pins

To execute on-board programming, start the TMP86FM48 in serial PROM mode. Setting of a serial PROM mode is shown in Table 2.19.2.

Table 2.19.2 Serial PROM Mode Setting

|           | i nem mede eetang |
|-----------|-------------------|
| Pin       | Setting           |
| BOOT pin  | High              |
| RESET pin |                   |

### 2.19.3.2 Pin Function

In the serial PROM mode, TXD (P06) and RXD (P05) pins are used as a serial interface pin.

| Pin Name<br>(Serial PROM Mode)                                                                                   | Input/<br>Output | Function                                         |              | Pin Name<br>(MCU Mode) |
|------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------|--------------|------------------------|
| TXD                                                                                                              | Output           | Serial data output                               |              | P06                    |
| RXD                                                                                                              | Input            | Serial data input                                | (Note 1)     | P05                    |
| BOOT                                                                                                             | Input            | Serial PROM mode control                         | (NOLE I)     | воот                   |
| RESET                                                                                                            | Input            | Serial PROM mode control                         |              | RESET                  |
| TEST                                                                                                             | Input            | 0V                                               |              | TEST                   |
| VDD, AVDD<br>VSS, AVSS/VASS<br>VAREF                                                                             | Power<br>Supply  | 2.7 V to 3.6 V<br>0V<br>Open or equal with VDD   |              |                        |
| P00 to P04,P07<br>P10 to P17<br>P20 to P22<br>P30 to P37<br>P50 to P52<br>P60 to P67<br>P70 to P77<br>P80 to P87 | I/O              | Placed in High-Z state during serial PROM mode   | 2.           |                        |
| XIN                                                                                                              | Input            | Resonator connecting pins for high-frequency clo | ock.         | (Note 2)               |
| XOUT                                                                                                             | Output           | For inputting external clock, XIN is used and XO | UT is opened |                        |

Note 1: When the device is used as on-board writing and other parts are already mounted in place, be careful no to affect these communication control pins.

Note 2: Operating area of high frequency in serial PROM mode is from 2 MHz to 16 MHz.

To set a serial PROM mode, connect device pins as shown in Figure 2.19.2.



Figure 2.19.2 Serial PROM Mode Port Setting

#### 2.19.3.3 Activating Serial PROM Mode

The following is a procedure of setting of serial PROM mode. Figure 2.19.3 shows a serial PROM mode timing.

- (1) Turn on the power to the VDD pin.
- (2) Set the  $\overline{\text{RESET}}$  and  $\overline{\text{TEST}}$  pins to low level.
- (3) Set the BOOT pin to high level.
- (4) Wait until the power supply and clock sufficiently stabilize.
- (5) Release the  $\overline{\text{RESET}}$ . (Set to high level)
- (6) Input a matching data (5AH) to RXD pin after waiting for setup sequence. For details of the setup timing, refer to "2.19.14 UART Timing"



Figure 2.19.3 Serial PROM Mode Timing

#### 2.19.4 Interface Specifications for UART

The following shows the UART communication format used in serial PROM mode.

Before on-board programming can be executed, the communication format on the external controller side must also be set up in the same way as for this product.

Note that although the default baud rate is 9600 bps, it can be changed to other values as shown in Table 2.19.3. The Table 2.19.4 shows an operating frequency and baud rate in serial PROM mode. Except frequency which is not described in Table 2.19.4 can not use in serial PROM mode.

Baud rate (Default): 9600 bps Data length: 8 bits Parity addition: None Stop bit length: 1 bit

| Baud rate modification data | 04H   | 05H   | 06H   | 07H   | 0AH   | 18H   | 28H  |
|-----------------------------|-------|-------|-------|-------|-------|-------|------|
| Baud rate (bps)             | 76800 | 62500 | 57600 | 38400 | 31250 | 19200 | 9600 |

Table 2.19.3 Baud Rate Modification Data

|          |                            | Baud Rate<br>ps)    | 768                   | 300   | 625   | 500   | 576   | 500   | 384   | 400   | 312   | 250   | 192   | 200   | 96    | 00    |
|----------|----------------------------|---------------------|-----------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| (Note 3) |                            | l Rate<br>tion Data | 04                    | ΙH    | 05    | iΗ    | 06    | βH    | 07    | 7H    | 0A    | λH    | 18    | ЗH    | 28    | 3H    |
|          | Ref.<br>Frequency<br>(MHz) | Area<br>(MHz)       | Baud<br>rate<br>(bps) | (%)   | (bps) | (%)   |
| 1        | 2                          | 1.91~2.10           | -                     | -     | -     | -     | -     | -     | -     | -     | -     | -     | -     | -     | 9615  | +0.16 |
| 0        | 4                          | 3.82~4.19           | -                     | -     | -     | -     | -     | -     | -     | -     | 31250 | 0.00  | 19231 | +0.16 | 9615  | +0.16 |
| 2        | 4.19                       | 3.82~4.19           | -                     | -     | -     | -     | -     | -     | -     | -     | 32734 | +4.75 | 20144 | +4.92 | 10072 | +4.92 |
| 3        | 4.9152                     | 4.70~5.16           | -                     | -     | -     | -     | -     | _     | 38400 | 0.00  | -     | _     | 19200 | 0.00  | 9600  | 0.00  |
| 3        | 5                          | 4.70~5.16           | -                     | -     | -     | -     | -     | _     | 39063 | +1.73 | -     | _     | 19531 | +1.73 | 9766  | +1.73 |
| 4        | 6                          | 5.87~6.45           | -                     | -     | -     | -     | -     | _     | -     | _     | -     | _     | -     | -     | 9375  | -2.34 |
| 4        | 6.144                      | 5.87~6.45           | -                     | -     | -     | -     | -     | _     | -     | _     | -     | _     | -     | -     | 9600  | 0.00  |
| 5        | 7.3728                     | 7.05~7.74           | -                     | -     |       | -     | 57600 | 0.00  | -     | _     | -     | _     | 19200 | 0.00  | 9600  | 0.00  |
| 6        | 8                          | 7.64~8.39           | -                     | -     | 62500 | 0.00  | -     | _     | 38462 | +0.16 | 31250 | 0.00  | 19231 | +0.16 | 9615  | +0.16 |
| 7        | 9.8304                     | 9.40~10.32          | 76800                 | 0.00  | -     | _     | -     | _     | 38400 | 0.00  | -     | _     | 19200 | 0.00  | 9600  | 0.00  |
| /        | 10                         | 9.40~10.32          | 78125                 | +1.73 | -     | -     | -     | _     | 39063 | +1.73 | -     | _     | 19531 | +1.73 | 9766  | +1.73 |
|          | 12                         | 11.75~12.90         | -                     | _     | -     | _     | 57692 | +0.16 | -     | _     | 31250 | 0.00  | 18750 | -2.34 | 9375  | -2.34 |
| 8        | 12.288                     | 11.75~12.90         | -                     | -     | -     | -     | 59077 | +2.56 | -     | -     | 32000 | +2.40 | 19200 | 0.00  | 9600  | 0.00  |
|          | 12.5                       | 11.75~12.90         | -                     | -     | 60096 | -3.85 | 60096 | +4.33 | -     | -     | 30048 | -3.85 | 19531 | +1.73 | 9766  | +1.73 |
| 9        | 14.7456                    | 14.10~15.48         | -                     | -     | -     | -     | 57600 | 0.00  | 38400 | 0.00  | -     | -     | 19200 | 0.00  | 9600  | 0.00  |
| 10       | 16                         | 15.27~16.77         | 76923                 | +0.16 | 62500 | 0.00  | -     | _     | 38462 | +0.16 | 31250 | 0.00  | 19231 | +0.16 | 9615  | +0.16 |

Table 2.19.4 Operating Frequency and Baud Rate in Serial PROM Mode

- Note 1: "Ref.Frequency" and "Area" show the high frequency area supported in serial PROM mode. Except the above frequency can not be supported in serial PROM mode even though the high frequency is included in area from 2 MHz to 16 MHz.
- Note 2: The total error of frequency must be kept within +/-3% so that the auto-detection of frequency is executed correctly.
- Note 3: An external controller should transmit a matching data repeatedly till the TMP86FM48 transmit an echo back data. Above number indicates a transmission number of times of matching data till transmission of echo back data.

## 2.19.5 Command

There are five commands in serial PROM mode. After reset release, the TMP86FM48 waits a matching data (5AH).

| Command Data | Operation Mode                     | Remarks                                                                                                          |  |  |  |
|--------------|------------------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|
| 5AH          | Setup                              | Matching data. Always start with this command after reset release.                                               |  |  |  |
| 30H          | FLASH memory writing               | Writing to area from 8000H to FFFFH is enable.                                                                   |  |  |  |
| 60H          | RAM loader                         | Writing to area from 0050H to 082FH is enable.                                                                   |  |  |  |
| 90H          | FLASH memory SUM output            | The checksum of entire FLASH area (from 8000H to FFFFH) is output in order of the upper byte and the lower byte. |  |  |  |
| СОН          | Product discrimination code output | Product discrimination code, that is expressed by 13 bytes data, is output.                                      |  |  |  |

| Table 2.19.5 Cor | nmand in Serial | PROM Mode |
|------------------|-----------------|-----------|
|------------------|-----------------|-----------|

## 2.19.6 Operation Mode

There are four operating modes in serial PROM mode: FLASH memory writing mode, RAM loader mode, FLASH memory SUM output mode and Product discrimination code output mode. For details about these modes, refer to "(1) FLASH memory writing mode" through "(4) Product discrimination code output mode".

(1) FLASH memory writing mode

The data are written to the specified FLASH memory addresses. The controller should send the write data in the Intel Hex format (Binary). For details of writing data format, refer to "2.19.7 FLASH memory Writing Data Format".

If no errors are encountered till the end record, the SUM of 32 Kbytes of FLASH memory is calculated and the result is returned to the controller.

To execute the FLASH memory writing mode, the TMP86FM48 checks the passwords except a blank product. If the passwords did not match, the program is not executed.

(2) RAM loader mode

The RAM loader transfers the data into the internal RAM that has been sent from the controller in Intel Hex format. When the transfer has terminated normally, the RAM loader calculates the SUM and sends the result to the controller before it starts executing the user program. After sending of SUM, the program jumps to the start address of RAM in which the first transferred data has been written. This RAM loader function provides the user's own way to control on-board programming.

To execute the RAM loader mode, the TMP86FM48 checks the passwords except a blank product. If the passwords did not match, the program is not executed.

(3) FLASH memory SUM output mode

The SUM of 32 Kbytes of FLASH memory is calculated and the result is returned to the controller.

The BOOT ROM does not support the reading function of the FLASH memory. Instead, it has this SUM command to use. By reading the SUM, it is possible to manage Revisions of application programs.

## (4) Product discrimination code output mode

The product discrimination code is output as a 13-byte data, that includes the start address and the end address of ROM (In case of TMP86FM48, the start address is 8000H and the end address is FFFFH). Therefore, the controller can recognize the device information by using this function.

## 2.19.6.1 FLASH Writing Mode (Operation command: 30H)

Table 2.19.6 shows FLASH memory writing mode process.

|             | Number of Bytes<br>Transferred      | Transfer Data from External<br>Controller to TMP86FM48             | Baud Rate                                      | Transfer Data from TMP86FM48 to<br>External Controller                                                           |  |
|-------------|-------------------------------------|--------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--|
| BOOT<br>ROM | 1st byte<br>2nd byte                | Matching data (5Ah)<br>-                                           | 9600 bps<br>9600 bps                           | <ul> <li>– (Baud rate auto set)</li> <li>OK: Echo back data (5AH)</li> <li>Error: Nothing transmitted</li> </ul> |  |
|             | 3rd byte                            | Baud rate modification data<br>(See Table 2.19.3)                  | 9600 bps                                       | _                                                                                                                |  |
|             | 4th byte                            | -                                                                  | 9600 bps                                       | OK: Echo back data<br>Error: A1H $\times$ 3, A3H $\times$ 3, 62H $\times$ 3<br>(Note 1)                          |  |
|             | 5th byte<br>6th byte                | Operation command data (30H)<br>-                                  | Changed new baud rate<br>Changed new baud rate | –<br>OK: Echo back data (30H)<br>Error: A1H × 3, A3H × 3, 63H × 3<br>(Note 1)                                    |  |
|             | 7th byte<br>8th byte                | Address 15 to 08 in which to store<br>Password count (Note 4)      | Changed new baud rate<br>Changed new baud rate | <ul> <li>OK: Nothing transmitted</li> <li>Error: A1H × 3, A3H × 3 (Note 1)</li> </ul>                            |  |
|             | 9th byte<br>10th byte               | Address 07 to 00 in which to store<br>Password count (Note 4)      | Changed new baud rate<br>Changed new baud rate | <ul> <li>OK: Nothing transmitted</li> <li>Error: A1H × 3, A3H × 3 (Note 1)</li> </ul>                            |  |
|             | 11th byte<br>12th byte              | Address 15 to 08 in which to start<br>Password comparison (Note 4) | Changed new baud rate<br>Changed new baud rate | <ul> <li>OK: Nothing transmitted</li> <li>Error: A1H × 3, A3H × 3 (Note 1)</li> </ul>                            |  |
|             | 13th byte<br>14th byte              | Address 07 to 00 in which to start<br>Password comparison (Note 4) | Changed new baud rate<br>Changed new baud rate | $^-$ OK: Nothing transmitted Error: A1H × 3, A3H × 3 (Note 1)                                                    |  |
|             | 15th byte<br>:                      | Password string (Note 5)                                           | Changed new baud rate                          | _                                                                                                                |  |
|             | m'th byte                           | -                                                                  | Changed new baud rate                          | OK: Nothing transmitted<br>Error: A1H $\times$ 3, A3H $\times$ 3 (Note 1)                                        |  |
|             | m'th + 1 byte<br>:<br>n'th – 2 byte | Intel Hex format (binary)<br>(Note 2)                              | Changed new baud rate                          | _                                                                                                                |  |
|             | n'th – 1 byte                       | _                                                                  | Changed new baud rate                          | OK: SUM (High) (Note 3)<br>Error: Nothing transmitted                                                            |  |
|             | n'th byte                           | _                                                                  | Changed new baud rate                          | OK: SUM (Low) (Note 3)<br>Error: Nothing transmitted                                                             |  |
|             | n'th + 1 byte                       | (Wait for the next operation)<br>(command data)                    | Changed new baud rate                          | _                                                                                                                |  |

Table 2.19.6 FLASH Writing Mode Process

Note 1: " $xxH \times 3$ " denotes that operation stops after sending 3 bytes of xxH. For details, refer to "2.19.8 Error Code".

- Note 2: Refer to "2.19.10 Intel Hex Format (Binary)".
- Note 3: Refer to "2.19.9 Checksum (SUM)".
- Note 4: Refer to "2.19.11 Passwords".
- Note 5: If all data of addresses from FFE0H to FFFFH are "00H" or "FFH", the passwords comparison is not executed because the device is considered as blank product. However, it is necessary to specify the password count storage addresses and the password comparison start address even though it is a blank product. If a password error occurs, the UART function of TMP86FM48 stops without returning error code to the controller. Therefore, when a password error occurs, the TMP86FM48 should be reset by RESET pin input.

Description of FLASH memory writing mode

- 1. The receive data in the 1st byte is the matching data. When the boot program starts in serial PROM mode, TMP86FM48 (Mentioned as "device" hereafter) waits for the matching data (5AH) to receive. Upon receiving the matching data, it automatically adjusts the UART's initial baud rate to 9,600bps.
- 2. When the device has received the matching data, the device transmits the data "5AH" as an echo back to the controller. If the device can not receive the matching data, the device does not transmit the echo back data and waits for the matching data again with changing baud rate. Therefore, the controller should send the matching data continuously until the device transmits the echo back data. An external controller should transmit a matching data repeatedly till the device transmit an echo back data. The transmission number of times of matching data varies by the frequency of device. For details, refer to Table 2.19.4.
- 3. The receive data in the 3rd byte is the baud rate modification data. The seven kinds of baud rate modification data shown in Table 2.19.3 are available. Even if baud rate changing is no need, be sure to send the initial baud rate data (28H: 9,600 bps).
- 4. When the 3rd byte data is one of the baud rate modification data corresponding to the device's operating frequency, the device sends the echo back data which is the same as received baud rate modification data. Then the baud rate is changed. If the 3rd byte data does not correspond to the baud rate modification data, the device stops UART function after sending 3 bytes of baud rate modification error code: (62H). The changing of baud rate is executed after transmitting the echo back data.
- 5. The receive data in the 5th byte is the command data (30H) to write the FLASH memory.
- 6. When the 5th byte is one of the operation command data shown in Table 2.19.5, the device sends the echo back data which is the same as received operation command data (in this case, 30H). If the 5th byte data does not correspond to the operation command data, the device stops UART function after sending 3 bytes of operation command error code: (63H).
- 7. The 7th byte is used as an upper bit (Bit15 to bit8) of the password count storage address. When the receiving is executed correctly (No error), the device does not send any data. If the receiving error occurs, the device stops UART function after sending 3 bytes of receiving error code: (A1H or A3H).
- 8. The 9th byte is used as a lower bit (Bit7 to bit0) of the password count storage address. When the receiving is executed correctly (No error), the device does not send any data. If the receiving error occurs, the device stops UART function after sending 3 bytes of receiving error code: (A1H or A3H).
- 9. The 11th byte is used as an upper bit (Bit15 to bit8) of the password comparison start address. When the receiving is executed correctly (No error), the device does not send any data. If the receiving error occurs, the device stops UART function after sending 3 bytes of receiving error code: (A1H or A3H).
- 10. The 13th byte is used as a lower bit (Bit7 to bit0) of the password comparison start address. When the receiving is executed correctly (No error), the device does not send any data. If the receiving error occurs, the device stops UART function after sending 3 bytes of receiving error code: (A1H or A3H).

- 11. The 15th through the m'th bytes are the password data. The number of passwords is the data (N) indicated by the password count storage address. The password data are compared for N entries beginning with the password comparison start address. The controller should send N bytes of password data to the device. If the passwords do not match, the device stops UART function without returning error code to the controller. If the data of addresses from FFEOH to FFFFH are all "FFH", the comparison of passwords is not executed because the device is considered as a blank product.
- 12. The receive data in the m'th + 1 through n'th 2 byte are received as binary data in Intel Hex format. No received data are echoed back to the controller. The data which is not the start mark (3AH for ":") in Intel Hex format is ignored and does not send an error code to the controller until the device receives the start mark. After receiving the start mark, the device receives the data record, that consists of length of data, address, record type, writing data and checksum. After receiving the checksum of data record, the device waits the start mark data (3AH) again. The data of data record is temporarily stored to RAM and then, is written to specified FLASH memory by page (64 bytes) writing. For details of an organization of FLASH, refer to "2.19.7 Serial PROM Mode". Since after receiving an end record, the device starts to calculate the SUM, the controller should wait the SUM after sending the end record. If receive error or Intel Hex format error occurs, the device stops UART function without returning error code to the controller.
- 13. The n'th 1 and the n'th bytes are the SUM value that is sent to the controller in order of the upper byte and the lower byte. For details on how to calculate the SUM, refer to "2.19.9 Checksum (SUM)". The SUM calculation is performed after detecting the end record, but the calculation is not executed when receive error or Intel Hex format error has occurred. The time required to calculate the SUM of the 32 Kbytes of FLASH memory area is approximately 100 ms at fc = 16 MHz. After the SUM calculation, the device sends the SUM data to the controller. After sending the end record, the controller can judge that the transmission has been terminated correctly by receiving the checksum.
- 14. After sending the SUM, the device waits for the next operation command data.

#### 2.19.6.2 RAM Loader Mode (Operation Command: 60H)

Table 2.19.7 shows RAM loader mode process.

|             | Number of Bytes<br>Transferred      | Transfer Data from External<br>Controller to TMP86FM48 | Baud Rate                     | Transfer Data from TMP86FM48 to<br>External Controller                                        |
|-------------|-------------------------------------|--------------------------------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------|
| BOOT<br>ROM | 1st byte<br>2nd byte                | Matching data (5AH)<br>-                               | 9600 bps<br>9600 bps          | – (Baud rate auto set)<br>OK: Echo back data (5AH)                                            |
|             |                                     |                                                        |                               | Error: Nothing transmitted                                                                    |
|             | 3rd byte                            | Baud rate modification data<br>(See Table 2.19.3)      | 9600 bps                      | _                                                                                             |
|             | 4th byte                            | -                                                      | 9600 bps                      | OK: Echo back data<br>Error: A1H $\times$ 3, A3H $\times$ 3, 62H $\times$ 3<br>(Note 1)       |
|             | 5th byte                            | Operation command data (60H)                           | Changed new baud rate         | _                                                                                             |
|             | 6th byte                            | -                                                      | Changed new baud rate         | OK: Echo back data (60H)<br>Error: A1H $\times$ 3, A3H $\times$ 3, 63H $\times$ 3<br>(Note 1) |
|             | 7th byte                            | Address 15 to 08 in which to store                     | Changed new baud rate         | -                                                                                             |
|             | 8th byte                            | Password count (Note 4)                                | Changed new baud rate         | OK: Nothing transmitted<br>Error: A1H $\times$ 3, A3H $\times$ 3 (Note 1)                     |
|             | 9th byte                            | Address 07 to 00 in which to store                     | Changed new baud rate         | _                                                                                             |
|             | 10th byte                           | Password count (Note 4)                                | Changed new baud rate         | OK: Nothing transmitted<br>Error: A1H $\times$ 3, A3H $\times$ 3 (Note 1)                     |
|             | 11th byte                           | Address 15 to 08 in which to start                     | Changed new baud rate         | -                                                                                             |
|             | 12th byte                           | Password comparison (Note 4)                           | Changed new baud rate         | OK: Nothing transmitted<br>Error: A1H $\times$ 3, A3H $\times$ 3 (Note 1)                     |
|             | 13th byte                           | Address 07 to 00 in which to start                     | Changed new baud rate         | _                                                                                             |
|             | 14th byte                           | Password comparison (Note 4)                           | Changed new baud rate         | OK: Nothing transmitted<br>Error: A1H $\times$ 3, A3H $\times$ 3 (Note 1)                     |
|             | 15th byte<br>:                      | Password string (Note 5)                               | Changed new baud rate         | _                                                                                             |
|             | m'th byte                           | -                                                      | Changed new baud rate         | OK: Nothing transmitted<br>Error: A1H $\times$ 3, A3H $\times$ 3 (Note 1)                     |
|             | m'th + 1 byte<br>:<br>n'th – 2 byte | Intel Hex format (Binary)<br>(Note 2)                  | Changed new baud rate         |                                                                                               |
|             | n'th – 1 byte                       | -                                                      | Changed new baud rate         | OK: SUM (High) (Note 3)<br>Error: Nothing transmitted                                         |
|             | n'th byte                           | -                                                      | Changed new baud rate         | OK: SUM (Low) (Note 3)<br>Error: Nothing transmitted                                          |
| RAM         | _                                   | The program jumps to the start ad                      | dress of RAM in which the fin | rst transferred data has been written.                                                        |

| Table 2.19.7 RAM Loader Mode Process |  |
|--------------------------------------|--|
|--------------------------------------|--|

Note 1: " $xxH \times 3$ " denotes that operation stops after sending 3 bytes of xxH. For details, refer to 2.19.8 "Error Code".

- Note 2: Refer to 2.19.10 "Intel Hex Format (Binary)".
- Note 3: Refer to 2.19.9 "Checksum (SUM)".
- Note 4: Refer to 2.19.11 "Passwords".
- Note 5: If all data of addresses from FFE0H to FFFFH are "00H" or "FFH", the passwords comparison is not executed because the device is considered as blank product. However, it is necessary to specify the password count storage addresses and the password comparison start address even though it is a blank product. If a password error occurs, the UART function of TMP86FM48 stops without returning error code to the controller. Therefore, when a password error

occurs, the TMP86FM48 should be reset by RESET pin input.

- Note 6: Do not send only end record after transferring of password string. If the TMP86FM48 receives the end record only after reception of password string, it does not operate correctly.
- Note 7: When the FLASH power supply is turned off in user's program by setting EEPCR<MNPWDW>, be sure to disable the watchdog timer (WDT) or to clear the binary counter of WDT immediately before.

Description of RAM loader mode

- 1. The process of the 1st byte through the 4th byte are the same as FLASH memory writing mode.
- 2. The receive data in the 5th byte is the RAM loader command data (60H) to write the user's program to RAM.
- 3. When the 5th byte is one of the operation command data shown in Table 2.19.5, the device sends the echo back data which is the same as received operation command data (in this case, 60H). If the 5th byte data does not correspond to the operation command data, the device stops UART function after sending 3 bytes of operation command error code: (63H).
- 4. The process of the 7th byte through the m'th byte are the same as FLASH memory writing mode.
- 5. The receive data in the m'th + 1 through n'th 2byte are received as binary data in Intel Hex format. No received data are echoed back to the controller. The data which is not the start mark (3AH for ":") in Intel Hex format is ignored and does not send an error code to the controller until the device receives the start mark. After receiving the start mark, the device receives the data record, that consists of length of data, address, record type, writing data and checksum. After receiving the checksum of data record, the device waits the start mark data (3AH) again. The data of data record is written to specified RAM by the receiving data. Since after receiving an end record, the device starts to calculate the SUM, the controller should wait the SUM after sending the end record. If receive error or Intel Hex format error occurs, the UART function of TMP86FM48 stops without returning error code to the controller.
- 6. The n'th 1 and the n'th bytes are the SUM value that is sent to the controller in order of the upper byte and the lower byte. For details on how to calculate the SUM, refer to 2.19.9 "Checksum (SUM)". The SUM calculation is performed after detecting the end record, but the calculation is not executed when receive error or Intel Hex format error has occurred.

The SUM is calculated by the data written to RAM, but the length of data, address, record type and checksum in Intel Hex format are not included in SUM.

7. The boot program jumps to the first address that is received as data in Intel Hex format after sending the SUM to the controller.

#### 2.19.6.3 FLASH Memory SUM Output Mode (Operation Command: 90H)

Table 2.19.8 shows FLASH memory SUM output mode process.

|             |                                |                                                        | , ,                   |                                                                              |
|-------------|--------------------------------|--------------------------------------------------------|-----------------------|------------------------------------------------------------------------------|
|             | Number of Bytes<br>Transferred | Transfer Data from External<br>Controller to TMP86FM48 | Baud Rate             | Transfer Data from TMP86FM48 to<br>External Controller                       |
| BOOT<br>ROM | 1st byte<br>2nd byte           | Matching data (5AH)<br>–                               | 9600 bps<br>9600 bps  | <ul> <li>– (Baud rate auto set)</li> <li>OK: Echo back data (5AH)</li> </ul> |
|             | ,                              |                                                        |                       | Error: Nothing transmitted                                                   |
|             | 3rd byte                       | Baud rate modification data<br>(See Table 2.19.3)      | 9600 bps              | _                                                                            |
|             | 4th byte                       | -                                                      | 9600 bps              | OK: Echo back data                                                           |
|             |                                |                                                        |                       | Error: A1H $\times$ 3, A3H $\times$ 3, 62H $\times$ 3 (Note 1)               |
|             | 5th byte                       | Operation command data                                 | Changed new baud rate | _                                                                            |
|             | 6th byte                       | (90H)                                                  | Changed new baud rate | OK: Echo back data (90H)                                                     |
|             |                                | -                                                      |                       | Error: A1H $\times$ 3, A3H $\times$ 3, 63H $\times$ 3<br>(Note 1)            |
|             | 7th byte                       | _                                                      | Changed new baud rate | OK: SUM (High) (Note 2)<br>Error: Nothing transmitted                        |
|             | 8th byte                       | -                                                      | Changed new baud rate | OK: SUM (Low) (Note 2)                                                       |
|             |                                |                                                        |                       | Error: Nothing transmitted                                                   |
|             | 9th byte                       | (Wait for the next operation)<br>(Command data)        | Changed new baud rate | _                                                                            |

Table 2.19.8 FLASH Memory SUM Output Process

Note 1: " $xxH \times 3$ " denotes that operation stops after sending 3 bytes of xxH. For details, refer to "2.19.8 Error Code".

Note 2: Refer to "2.19.9 Checksum (SUM)"

Description of FLASH memory SUM output mode

- 1. The process of the 1st byte through the 4th byte are the same as FLASH memory writing mode.
- 2. The receive data in the 5th byte is the FLASH memory SUM command data (90H) to calculate the entire FLASH memory.
- 3. When the 5th byte is one of the operation command data shown in Table 2.19.5, the device sends the echo back data which is the same as received operation command data (in this case, 90H). If the 5th byte data does not correspond to the operation command data, the device stops UART function after sending 3 bytes of operation command error code: (63H).
- 4. The 7th and the 8th bytes are the SUM value that is sent to the controller in order of the upper byte and the lower byte. For details on how to calculate the SUM, refer to "2.19.9 Checksum (SUM)".
- 5. After sending the SUM, the device waits for the next operation command data.

#### 2.19.6.4 Product Discrimination Code Output Mode (Operation Command: C0H)

Table 2.19.9 shows product discrimination code output mode process.

|      | Number of Bytes<br>Transferred | Transfer Data from External<br>Controller to TMP86FM48 | Baud Rate             | Transfer Data from TMP86FM48 to<br>External Controller                                  |
|------|--------------------------------|--------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------|
| BOOT | 1st byte                       | Matching data (5AH)                                    | 9600 bps              | – (Baud rate auto set)                                                                  |
| ROM  | 2nd byte                       | -                                                      | 9600 bps              | OK: Echo back data (5AH)<br>Error: Nothing transmitted                                  |
|      | 3rd byte                       | Baud rate modification data<br>(See Table 2.19.3)      | 9600 bps              | -                                                                                       |
|      | 4th byte                       | -                                                      | 9600 bps              | OK: Echo back data<br>Error: A1H $\times$ 3, A3H $\times$ 3, 62H $\times$ 3<br>(Note 1) |
|      | 5th byte                       | Operation command data                                 | Changed new baud rate |                                                                                         |
|      | 6th byte                       | (COH)                                                  | Changed new baud rate | OK: Echo back data (C0H)                                                                |
|      |                                | -                                                      |                       | Error: A1H $\times$ 3, A3H $\times$ 3, 63H $\times$ 3 (Note 1)                          |
|      | 7th byte                       |                                                        | Changed new baud rate | 3AH Start mark                                                                          |
|      | 8th byte                       |                                                        | Changed new baud rate | OAH The number of transfer data<br>(from 9th to 18th byte)                              |
|      | 9th byte                       |                                                        | Changed new baud rate | 02H Length of address (2 bytes)                                                         |
|      | 10th byte                      |                                                        | Changed new baud rate | 00H Reserved data                                                                       |
|      | 11th byte                      |                                                        | Changed new baud rate | 00H Reserved data                                                                       |
|      | 12th byte                      |                                                        | Changed new baud rate | 00H Reserved data                                                                       |
|      | 13th byte                      |                                                        | Changed new baud rate | 00H Reserved data                                                                       |
|      | 14th byte                      |                                                        | Changed new baud rate | 01H The number of ROM block<br>(1 block)                                                |
|      | 15th byte                      |                                                        | Changed new baud rate | 80H First address of ROM                                                                |
|      | 16th byte                      |                                                        | Changed new baud rate | 00H                                                                                     |
|      | 17th byte                      |                                                        | Changed new baud rate | FFH End address of ROM                                                                  |
|      | 18th byte                      |                                                        | Changed new baud rate | FFH                                                                                     |
|      | 19th byte                      |                                                        | Changed new baud rate | 7FH Checksum of transferred<br>data (from 9th to 18th byte)                             |
|      | 20th byte                      | (Wait for the next operation)<br>(Command data)        | Changed new baud rate | -                                                                                       |

| Table 2.19.9 | Product Discrimination Code | Output Process        |
|--------------|-----------------------------|-----------------------|
|              | r reader Bieenmaaren eeue   | 0 4 9 4 1 1 0 0 0 0 0 |

Note: " $xxH \times 3$ " denotes that operation stops after sending 3 bytes of xxH. For details, refer to "2.19.8 Error Code".

Description of product discrimination code output mode

- 1. The process of the 1st byte through the 4th byte are the same as FLASH memory writing mode.
- 2. The receive data in the 5th byte is the product discrimination code output command data (C0H).
- 3. When the 5th byte is one of the operation command data shown in Table 2.19.5, the device sends the echo back data which is the same as received operation command data (in this case, COH). If the 5th byte data does not correspond to the operation command data, the device stops UART function after sending 3 bytes of operation command error code: (63H).
- 4. The 7th and the 19th bytes are the product discrimination code. For details, refer to 2.19.12 "Product Discrimination Code".
- 5. After sending the SUM, the device waits for the next operation command data.

#### 2.19.7 FLASH memory Writing Data Format

FLASH area of TMP86FM48 consists of 512 pages and one page size is 64 bytes.

Writing to FLASH is executed by page writing. Therefore, it is necessary to send 64 bytes data (for one page) even though only a few bytes data are written. Figure 2.19.4 shows an organization of FLASH area. When the controller sends the writing data to the device, be sure to keep the format described below.

- 1. The address of data after receiving the FLASH writing command should be the first address of page. For example, in case of page 2, the first address should be 8080H.
- 2. If the last data's address of data record is not end address of page, the address of the next data record should be the address + 1. For example, if the last data's address is 802FH (Page 0), the address of the next data record should be 8030H (Page 0).

Ex)

:10802000202122232425262728292A2B2C2D2E2FD8 '8020H to 802FH data :108030000303132333435363738393A3B3C3D3E3FC8 '8030H to 803FH data

3. The last data's address of data record immediately before sending the end record should be the last address of page. For example, in case of page 1, the last data's address of data record should be 807FH.

Ex)

:10807000303132333435363738393A3B3C3D3E3F88 '8070H to 807FH data :00000001FF 'End record

Note: Do not write only the addresses from FFE0H to FFFFH when all data of FLASH memory are the same data. If these area are only written, the next operation can not be executed because of password error.

| Address | 0     | 1      | 2       | 3          | 4        | 5       | 6      | 7        | 8     | 9        | А      | В       | С       | D  | Е | F |
|---------|-------|--------|---------|------------|----------|---------|--------|----------|-------|----------|--------|---------|---------|----|---|---|
| 8000H   | F     |        |         |            |          |         |        |          |       |          |        |         |         |    |   |   |
| 8010H   |       |        |         |            |          |         |        | Pag      |       |          |        |         |         |    |   |   |
| 8020H   |       |        |         |            |          |         |        | гау      |       |          |        |         |         |    |   |   |
| 8030H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   | E |
| 8040H   | F     | !      |         |            |          |         |        |          |       | l        |        |         |         | L  |   |   |
| 8050H   |       |        |         |            |          |         |        | Pag      | e 1   |          |        |         |         |    |   |   |
| 8060H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   |   |
| 8070H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   | Е |
| 8080H   | F     |        |         |            |          |         |        |          |       |          |        |         |         |    |   |   |
| 8090H   |       |        |         |            | L]       |         |        | Pag      | e 2   | L        |        | LJ      |         | L  |   |   |
| 80A0H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   |   |
| 80B0H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   | Е |
| 80C0H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   |   |
| :       |       |        |         |            | L        |         |        |          |       |          |        |         |         |    |   |   |
| :       |       |        |         |            |          |         |        |          |       | L        |        |         |         |    |   |   |
| FF70H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   | E |
| FF80H   | F     |        |         |            |          |         |        | <u>.</u> |       |          |        |         |         |    |   |   |
| FF90H   |       |        |         |            |          |         |        | Page     | 510   |          |        |         |         |    |   |   |
| FFA0H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   |   |
| FFB0H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   | E |
| FFC0H   | . F.  |        |         |            |          |         |        |          |       |          |        |         |         |    |   |   |
| FFD0H   |       |        |         |            |          |         |        | Page     | 511   |          |        |         |         |    |   |   |
| FFE0H   |       |        |         |            |          |         |        | ·        |       |          |        |         |         |    |   |   |
| FFF0H   |       |        |         |            |          |         |        |          |       |          |        |         |         |    |   | E |
|         | Note: | "F" sh | ows the | e first ad | ddress o | of each | page a | nd "E" : | shows | the last | addres | s of ea | ch page | Э. |   |   |

Figure 2.19.4 Organization of FLASH Area

## 2.19.8 Error Code

When the device detects an error, the error codes are sent to the controller.

| Transmit Data | Meaning of Transmit Data                 |  |
|---------------|------------------------------------------|--|
| 62H, 62H, 62H | Baud rate modification error occurred.   |  |
| 63H, 63H, 63H | Operating command error occurred.        |  |
| A1H, A1H, A1H | Framing error in received data occurred. |  |
| АЗН, АЗН, АЗН | Overrun error in received data occurred. |  |

Table 2.19.10 Error Code

Note1: If password error occurs, the TMP86FM48 doesn't send error codes.

#### 2.19.9 Checksum (SUM)

(1) Calculation method

SUM consists of byte + byte... + byte, the checksum of which is returned in word as the result.

Namely, data is read out in byte and checksum of which is calculated, with the result returned in word.

| Exa | ample: |                                                                                               |
|-----|--------|-----------------------------------------------------------------------------------------------|
|     | A1H    | If the data to be calculated consists of the four bytes shown to the left, SUM of the data is |
|     | B2H    | A1H + B2H + C3H + D4H = 02EAH                                                                 |
|     | СЗН    | SUM (HIGH) = 02H<br>SUM (LOW) = EAH                                                           |
|     | D4H    |                                                                                               |
|     |        |                                                                                               |

The SUM returned when executing the FLASH memory write command, RAM loader command, or FLASH memory SUM command is calculated in the manner shown above.

(2) Calculation data

The data from which SUM is calculated are listed in Table 2.19.11 below.

| Operating Mode                             | Calculation Data                                     | Remarks                                                                                                |  |  |
|--------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|--|
| FLASH memory writing mode                  | Data in the entire area (32 Kbytes) of FLASH memory  | Even when written to part of the FLASH area, data in the entire memory area (32 Kbytes) is calculated. |  |  |
| FLASH memory SUM output mode               |                                                      | The length of data, address, record type and checksum in Intel Hex format are not included in SUM.     |  |  |
| RAM loader mode                            | Data written to RAM                                  | The length of data, address, record type and checksum in Intel Hex format are not included in SUM.     |  |  |
| Product Discrimination Code<br>Output mode | Checksum of transferred data (from 9th to 18th byte) | For details, refer to 2.19.12 Product Discrimination Code.                                             |  |  |

Table 2.19.11 Checksum Calculation Data

#### 2.19.10 Intel Hex Format (Binary)

- 1. After receiving the checksum of a record, the device waits for the start mark data (3AH for ":") of the next record. Therefore, the device ignores the data, which does not match the start mark data after receiving the checksum of a record.
- 2. Make sure that once the controller program has finished sending the checksum of the end record, it does not send anything and waits for two bytes of data to be received (Upper and lower bytes of checksum). This is because after receiving the checksum of the end record, the boot program calculates the checksum and returns the calculated checksum in two bytes to the controller.
- 3. If a receive error or Intel Hex format error occurs, the UART function of TMP86FM48 stops without returning error code to the controller. In the following cases, an Intel Hex format error occurs:
  - When the record type is not 00H, 01H, or 02H
  - When a SUM error occurred
  - When the data length of an extended record (Type = 02H) is not 02H
  - When the address of an extended record (Type = 02H) is larger than 1000H and after that, receives the data record
  - When the data length of the end record (Type = 01H) is not 00H

### 2.19.11 Passwords

The eight or more bytes consecutive data in flash memory area can be used as password. In password check, TMP86FM48 compares these data with data which are transmitted from the external controller. The area in which passwords can be specified is located at addresses 8000H to FF9FH. The area from FFA0H to FFFFH can not be specified as passwords area. The device compares the stored passwords with the passwords, which are received from the controller. If all data of addresses from FFE0H to FFFFH are "00H" or "FFH", the passwords comparison is not executed because the device is considered as blank product. It is necessary to specify the password count storage addresses and the password comparison start address even though it is a blank product. Table 2.19.12 shows the password setting in the blank product and non blank product.

| Decoverd Plank Product (Nate 1) Non Plank Product |                                          |                               |  |  |  |  |  |  |  |
|---------------------------------------------------|------------------------------------------|-------------------------------|--|--|--|--|--|--|--|
| Password                                          | Blank Product (Note 1)                   | Non Blank Product             |  |  |  |  |  |  |  |
| PNSA<br>(Password count storage addresses)        | $8000H \le PNSA \le FF9FH$               | $8000H \le PNSA \le FF9FH$    |  |  |  |  |  |  |  |
| PCSA<br>(Password comparison start address)       | $8000H \le \text{PCSA} \le \text{FF9FH}$ | $8000H \le PCSA \le FFA0 - N$ |  |  |  |  |  |  |  |
| N<br>(Password count)                             | *                                        | $8 \leq N$                    |  |  |  |  |  |  |  |
| Setting of password                               | No need                                  | Need (Note 2)                 |  |  |  |  |  |  |  |

 Table 2.19.12
 Password Setting in the Blank Product and Non Blank Product

Note 1: When all data of addresses from FFE0H to FFFFH area are "00H" or "FFH", the device is judged as blank product.

Note 2: The same three or more bytes consecutive data can not be used as password. When the password includes the same consecutive data (three or more bytes), the password error occurs. If the password error occurred, the UART function of device stops without returning error code.

Note 3: \*: Don't care.

- Note 4: When the password doesn't match the above condition, the password error occurs. If the password error occurred, the UART function of device stops without returning error code.
- 2.19.11.1 Confirmation Method of the Blank Product and Non Blank Product

The external controller can confirm whether the device is the blank product or not, by transmission of data described below.

- (1) Executes FLASH memory writing mode or RAM loader mode.
- (2) Transmits the PNSA and PCSA.
- (3) Transmits the end record.
- (4) In case of the blank product, the device sends checksum of flash memory. In case of the non blank product, the device doesn't send checksum of flash memory but the UART function stops without sending any data.

The external controller can confirm the blank product and non blank product by receiving checksum.

Note: When the UART function stops in non blank product, the TMP86FM48 should be reset by pin reset input for restarting the Serial PROM Mode.

#### 2.19.11.2 Password String

A string of passwords in the received data are compared with the data in the FLASH memory. In the following cases, a password error occurs:

• When the received data does not match the data in the FLASH memory



#### 2.19.11.3 Handling of Password Error

If a password error occurs, the UART function of TMP86FM48 stops without returning error code to the controller. Therefore, when a password error occurs, the TMP86FM48 should be reset by RESET pin input.

### 2.19.12 Product Discrimination Code

The product discrimination code is a 13-byte data, that includes the start address and the end address of ROM. Table 2.19.13 shows the product discrimination code format.

| Data | The Meaning of Data                                  | In Case of TMP86FM48 |
|------|------------------------------------------------------|----------------------|
| 1st  | Start Mark (3AH)                                     | ЗАН                  |
| 2nd  | The number of transfer data (from 3rd to 12th byte)  | 0AH                  |
| 3rd  | Length of address                                    | 02H                  |
| 4th  | Reserved data                                        | 00H                  |
| 5th  | Reserved data                                        | 00H                  |
| 6th  | Reserved data                                        | 00H                  |
| 7th  | Reserved data                                        | 00H                  |
| 8th  | The number of ROM block                              | 01H                  |
| 9th  | The upper byte of the first address of ROM           | 80H                  |
| 10th | The lower byte of the first address of ROM           | 00H                  |
| 11th | The upper byte of the end address of ROM             | FFH                  |
| 12th | The lower byte of the end address of ROM             | FFH                  |
| 13th | Checksum of transferred data (from 3rd to 12th byte) | 7FH                  |

Table 2.19.13 Product Discrimination Code Format

2.19.13 Flowchart



### 2.19.14 UART Timing

| Parameter                                                                                    | Symbol | The Number of   | Required Minimum Time |                |  |  |  |  |  |
|----------------------------------------------------------------------------------------------|--------|-----------------|-----------------------|----------------|--|--|--|--|--|
| i ulumotor                                                                                   | Cymbol | Clock (fc)      | At fc = 2 MHz         | At fc = 16 MHz |  |  |  |  |  |
| Time from the reception of a matching data until the output of an echo back                  | CMeb1  | Approx. 600     | 300 μs                | 37.5 μs        |  |  |  |  |  |
| Time from the reception of a baud rate modification data<br>until the output of an echo back | CMeb2  | Approx. 700     | 350 μs                | 43.7 μs        |  |  |  |  |  |
| Time from the reception of an operation command until the output of an echo back             | CMeb3  | Approx. 600     | 300 μs                | 37.5 μs        |  |  |  |  |  |
| Calculation time of checksum                                                                 | CKsm   | Approx. 1573000 | 786.5 ms              | 98.3 ms        |  |  |  |  |  |

#### Table 2.19.14 UART Timing-1 (VDD = 2.7 V to 3.6 V, fc = 2 MHz to 16 MHz, Ta = 25°C)

#### Table 2.19.15 UART Timing-2 (VDD = 2.7 V to 3.6 V, fc = 2 MHz to 16 MHz, Ta = $25^{\circ}$ C)

| Parameter                                                                                                       | Symbol | The Number    | <b>Required Minimum Time</b> |                |  |
|-----------------------------------------------------------------------------------------------------------------|--------|---------------|------------------------------|----------------|--|
| l aramotor                                                                                                      | Cymbol | of Clock (fc) | At fc = 2 MHz                | At fc = 16 MHz |  |
| Time from reset release until acceptance of start bit of RXD pin                                                | RXsup  | 110000        | 55 ms                        | 6.9 ms         |  |
| Time between a matching data and the next matching data                                                         | CMtr1  | 28500         | 14.3 ms                      | 1.8 ms         |  |
| Time from the echo back of matching data until the acceptance of baud rate modification data                    | CMtr2  | 600           | 300 μs                       | 37.5 μs        |  |
| Time from the output of echo back of baud rate modification data until the acceptance of an operation command   | CMtr3  | 750           | 375 μs                       | 46.9 μs        |  |
| Time from the output of echo back of operation command until the acceptance of Password count storage addresses | CMtr4  | 950           | 475 μs                       | 59.4 μs        |  |



# Input/Output Circuitry

(1) Control pins

The input/output circuitries of the  $\rm TMP86FM48$  control pins are shown below.

| Control Pin   | I/O             | Input/Output Circuitry                                                                                                                                    | Remarks                                                                                                                  |
|---------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| XIN<br>XOUT   | Input<br>Output | Osc. enable                                                                                                                                               | Resonator connecting pins<br>(High frequency)<br>$R_f = 3 M\Omega$ (typ.)<br>$R_O = 0.5 k\Omega$ (typ.)                  |
| XTIN<br>XTOUT | Input<br>Output | NORMAL1<br>mode     NORMAL2 mode       Refer to<br>port P2     Osc.<br>enable     XTEN<br>Refer to<br>VDD 0<br>R<br>XIN     VDD 0<br>R<br>K     XTEN<br>R | C Resonator connecting pins<br>(Low frequency)<br>$R_f = 20 M\Omega$ (typ.)<br>$R_O = 220 k\Omega$ (typ.)                |
| RESET         | Input           | Address-trap-reset                                                                                                                                        | Hysteresis input<br>Pull-up resistor<br>$R_{IN} = 220 \text{ k}\Omega \text{ (typ.)}$<br>$R = 100 \Omega \text{ (typ.)}$ |
| TEST          | Input           | Rin \$ m                                                                                                                                                  | Pull-down resistor<br>R <sub>IN</sub> = 70 kΩ (typ.)<br>R = 100 Ω (typ.)                                                 |
| BOOT          | Input           |                                                                                                                                                           | Pull-down resistor<br>R <sub>IN</sub> = 70 kΩ (typ.)<br>R = 100 Ω (typ.)                                                 |

# (2) Input/output ports

| Port       | I/O | Input/Output Circuitry                                                                                                                    | Remarks                                                                                                                                            |
|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| P0<br>P1   | I/O | Initial "High-Z"<br>Pch control<br>(Control output))<br>Data output )<br>Input from output latch<br>Disable<br>Pin input (Control input)) | Sink open drain output or<br>CMOS output<br>Hysteresis input<br>$R = 100 \Omega$ (typ.)                                                            |
| P20        | I/O | Initial "High-Z"<br>Pch control )<br>Data output )<br>Input from output latch<br>Disable )<br>Pin input (Control input)                   | Sink open drain output or<br>CMOS output<br>Hysteresis input<br>$R = 100 \Omega$ (typ.)                                                            |
| P21<br>P22 | 1/0 | Initial "High-Z"<br>Resistor control )<br>Data output )<br>Input from output latch<br>Disable )<br>Pin input )                            | Sink open drain output or<br>CMOS output<br>Hysteresis input<br>Programmable pull-up<br>resistor<br>$R_{IN3} = 220 \text{ k}\Omega \text{ (typ.)}$ |
| P3         | 1/0 | Initial "High-Z"<br>Pch control )<br>Data output )<br>Input from output latch<br>Disable )<br>Pin input )                                 | Sink open drain or<br>CMOS output<br>Hysteresis input<br>High current output (Nch)<br>$R = 100 \Omega$ (typ.)                                      |
| Ρ5         | I/O | Initial "High-Z"<br>Pch control )<br>(Control output)<br>Data output )<br>Input from output latch<br>Disable<br>Pin input                 | Sink open drain output or<br>CMOS output<br>Hysteresis input<br>High current output (Nch)<br>$R = 100 \Omega$ (typ.)                               |

| Port     | I/O | Input/Output Circuitry                                                                                                | Remarks                                               |
|----------|-----|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| P6<br>P7 | 1/0 | Initial "High-Z"<br>Data output)<br>Input from output latch<br>I/O control)<br>Pin input<br>Disable)<br>Analog input) | Tri-state I/O<br>Hysteresis input<br>R = 100 Ω (typ.) |
| P8       | 1/0 | Initial "High-Z"<br>Data output)<br>Input from output latch<br>I/O control<br>Pin input                               | Tri-state I/O<br>Hysteresis input<br>R = 100 Ω (typ.) |

# **Electrical Characteristics**

| Absolute Maximum Ratings | $(V_{SS} = 0 V)$ |
|--------------------------|------------------|
|--------------------------|------------------|

| Parameter                       | Symbol            | Pins                                  | Rating                        | Unit |
|---------------------------------|-------------------|---------------------------------------|-------------------------------|------|
| Supply voltage                  | V <sub>DD</sub>   |                                       | -0.3 to 4.0                   |      |
| Input voltage                   | V <sub>IN</sub>   |                                       | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Output voltage                  | V <sub>OUT1</sub> |                                       | -0.3 to V <sub>DD</sub> + 0.3 |      |
| Output current (Per 1 pin)      | I <sub>OUT1</sub> | P0, P1, P20, P3, P5, P6, P7, P8 ports | -2                            |      |
|                                 | IOUT2             | P0, P1, P2, P4, P6, P7, P8 ports      | 2                             |      |
|                                 | IOUT3             | P3, P5 ports                          | 10                            |      |
|                                 | $\Sigma I_{OUT1}$ | P0, P1, P20, P3, P5, P6, P7, P8 ports | -30                           | mA   |
| Output current (Total)          | $\Sigma I_{OUT2}$ | P0, P1, P2, P4, P6, P7, P8 ports      | 80                            |      |
|                                 | ΣΙΟυτ3            | P3, P5 ports                          | 30                            |      |
| Power dissipation [Topr = 85°C] | PD                |                                       | 350                           | mW   |
| Soldering temperature (Time)    | Tsld              |                                       | 260 (10 s)                    |      |
| Storage temperature             | Tstg              |                                       | -55 to 125                    | °C   |
| Operating temperature           | Topr              |                                       | -40 to 85                     |      |

Note: The absolute maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded.

| Parameter              | Symbol           | Pins                    | Condition                                                        |                                     | Min                  | Max                         | Unit   |  |
|------------------------|------------------|-------------------------|------------------------------------------------------------------|-------------------------------------|----------------------|-----------------------------|--------|--|
|                        |                  |                         | fc = 16 MHz                                                      | NORMAL1, 2 mode<br>IDLE0, 1, 2 mode | 2.7                  |                             |        |  |
|                        |                  |                         | fc = 8 MHz<br>(In case of connecting                             | NORMAL1, 2 mode                     |                      |                             |        |  |
|                        |                  |                         | the resonator)                                                   | IDLE0, 1, 2 mode                    | 1.8                  |                             |        |  |
| Supply voltage         | V <sub>DD</sub>  |                         | fc = 4.2 MHz<br>(In case of external                             | NORMAL1, 2 mode                     | 1.0                  | 3.6                         |        |  |
|                        |                  |                         | clock input)                                                     | IDLE0, 1, 2 mode                    |                      |                             |        |  |
|                        |                  |                         | fs =                                                             | SLOW1, 2 mode                       | 1.8                  |                             |        |  |
|                        |                  |                         | 32.768 kHz SLEEP0, 1, 2                                          | SLEEP0, 1, 2 mode                   |                      |                             | V      |  |
|                        |                  |                         |                                                                  | STOP mode                           |                      |                             |        |  |
|                        | V <sub>IH1</sub> | Except Hysteresis input | Vע ≥ 2.7 V                                                       |                                     | $V_{DD} \times 0.70$ |                             |        |  |
| Input high level       | V <sub>IH2</sub> | Hysteresis input        | VDD 2 2.7 V                                                      |                                     | $V_{DD} \times 0.75$ | V <sub>DD</sub>             |        |  |
|                        | V <sub>IH3</sub> |                         | $V_{DD}$ < 2.7 V                                                 |                                     | $V_{DD} 	imes 0.90$  |                             |        |  |
|                        | V <sub>IL1</sub> | Except Hysteresis input | $V_{DD} \ge 2.7 \text{ V}$                                       |                                     |                      | $V_{\text{DD}} \times 0.30$ |        |  |
| Input low level        | V <sub>IL2</sub> | Hysteresis input        |                                                                  |                                     | 0                    | $V_{DD} \times 0.25$        |        |  |
|                        | V <sub>IL3</sub> |                         | $V_{DD}$ < 2.7 V                                                 |                                     |                      | $V_{\text{DD}} \times 0.10$ |        |  |
| Clock frequency        | fc               | XIN, XOUT               | V <sub>DD</sub> = 1.8 to 3.6 V                                   |                                     | 1.0                  | 8.0                         | N 41 I |  |
| (In case of connecting | IC               |                         | $V_{DD} = 2.7 \text{ to } 3.6 \text{ V}$                         |                                     | 1.0                  | 16.0                        | MHz    |  |
| the resonator)         | fs               | XTIN, XTOUT             | V <sub>DD</sub> = 1.8 to 3.6 V                                   |                                     | 30.0                 | 34.0                        | kHz    |  |
| Clock frequency        | fo               |                         | V <sub>DD</sub> = 1.8 to 3.6 V<br>V <sub>DD</sub> = 2.7 to 3.6 V |                                     | 1.0                  | 4.2                         | NAL /- |  |
| (In case of external   | fc               | XIN, XOUT               |                                                                  |                                     | 1.0                  | 16.0                        | MHz    |  |
| clock input)           | fs               | XTIN, XTOUT             | V <sub>D</sub> = 1.8 to 3.6 V                                    |                                     | 30.0                 | 34.0                        | kHz    |  |

Recommended Operating Condition-1 (MCU mode)  $(V_{SS} = 0 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$ 

Note: The recommended operating conditions for a device are operating conditions under which it can be guaranteed that the device will operate as specified. If the device is used under operating conditions other than the recommended operating conditions (Supply voltage, operating temperature range, specified AC/DC values etc.), malfunction may occur. Thus, when designing products which include this device, ensure that the recommended operating conditions for the device are always adhered to.

| Parameter       | Symbol | Pins      | Condition          | Min | Max  | Unit |
|-----------------|--------|-----------|--------------------|-----|------|------|
| Supply voltage  | VDD    |           | 2 MHz ≤ fc ≤16 MHz | 2.7 | 3.6  | V    |
| Clock frequency | fc     | XIN, XOUT | VDD = 2.7 to 3.6 V | 2.0 | 16.0 | MHz  |

Note: The operating temperature area of serial PROM mode is  $25^{\circ}C \pm 5^{\circ}C$  and the operating area of high frequency of serial PROM mode is different from MCU mode.

| Parameter                           | Symbol           |                            | Pir                        | าร                                                       | Cond                                                      | Condition     |     | Тур. | Max     | Unit |
|-------------------------------------|------------------|----------------------------|----------------------------|----------------------------------------------------------|-----------------------------------------------------------|---------------|-----|------|---------|------|
| Hysteresis voltage                  | V <sub>HS</sub>  | Hyster                     | esis in                    | out                                                      | V <sub>DD</sub> = 3.3 V                                   |               | -   | 0.4  | -       | V    |
|                                     | I <sub>IN1</sub> | TEST                       |                            |                                                          | $V_{DD} = 3.6 \text{ V}, \text{ V}_{IN}$                  | = 0 V         | -   | -    | -5      |      |
| Input current                       | I <sub>IN2</sub> | Sink o                     | Sink open drain, Tri-state |                                                          | $V_{DD} = 3.6 \text{ V}, \text{ V}_{IN}$                  | = 3.6 V/0 V   | -   | -    | ±5      | μA   |
|                                     | I <sub>IN3</sub> | RESE                       | Г                          |                                                          | V <sub>DD</sub> = 3.6 V, V <sub>IN</sub>                  | = 3.6 V       | _   | -    | +5      |      |
|                                     | R <sub>IN1</sub> | TEST                       | pull do                    | wn                                                       | $V_{DD} = 3.6 \text{ V}, \text{ V}_{IN}$                  | = 3.6 V       | _   | 70   | -       |      |
| land the state set                  | R <sub>IN2</sub> | BOOT                       | pull do                    | wn                                                       | $V_{DD} = 3.6 V, V_{IN}$                                  | = 3.6 V       | _   | 70   | -       | kΩ   |
| Input resistance                    | R <sub>IN3</sub> |                            | ¯ pull u<br>22 por         |                                                          | $V_{DD} = 3.6 \text{ V}, \text{ V}_{IN}$                  | = 0 V         | 100 | 220  | 450     | K22  |
| High frequency<br>feedback resistor | R <sub>FB</sub>  | XOUT                       |                            |                                                          | V <sub>DD</sub> = 3.6 V                                   |               | -   | 3    | -       | MΩ   |
| Low frequency<br>feedback resistor  | R <sub>FBT</sub> | хтоит                      |                            | V <sub>DD</sub> = 3.6 V                                  |                                                           | -             | 20  | -    | 11/12/2 |      |
| Output leakage<br>current           | ILO              | Sink open drain, Tri-state |                            | V <sub>DD</sub> = 3.6 V<br>V <sub>OUT</sub> = 3.4V/0.2 V |                                                           | -             | _   | ±10  | μΑ      |      |
| Output high voltage                 | V <sub>OH</sub>  | CMOS, Tri-state            |                            | $V_{DD} = 3.6 \text{ V}, I_{OH} = -0.6 \text{ mA}$       |                                                           | 3.2           | -   | -    |         |      |
| Output low voltage                  | V <sub>OL</sub>  | Excep<br>ports             | t XOUT                     | , P3 and P5                                              | $V_{DD} = 3.6 \text{ V}, \text{ I}_{OL} = 0.9 \text{ mA}$ |               | -   | -    | 0.4     | V    |
| Output low current                  | I <sub>OL</sub>  | P3, P5                     | 5 ports                    | -                                                        | $V_{DD} = 3.6 \text{ V}, V_{OL} = 1.0 \text{ V}$          |               | -   | 6    | _       | mA   |
| Supply current in                   |                  |                            | Fetch                      | Flash area                                               | V <sub>DD</sub> = 3.6 V                                   | MNP = "1"     | -   | 5.0  | 6.0     |      |
| NORMAL 1, 2 mode                    |                  |                            | area                       | RAM area                                                 | $V_{IN} = 3.4 \text{ V}/0.2 \text{ V}$                    | MNP = "0"     | _   | 3.5  | 4.8     | mA   |
| Supply current in                   |                  |                            |                            |                                                          | fc = 16 MHz                                               | MNP•ATP = "1" | -   | 3.5  | 4.5     |      |
| IDLE 0, 1, 2 mode                   |                  | г                          |                            |                                                          | fs = 32.768 kHz                                           | MNP•ATP = "0" | -   | 2.5  | 3.7     |      |
| Supply current in                   |                  |                            | Fetch                      | Flash area                                               | -                                                         | MNP = "1"     | -   | 800  | 1400    |      |
| SLOW 1 mode                         | I <sub>DD</sub>  |                            | area                       | RAM area                                                 | V <sub>DD</sub> = 3.0 V                                   | MNP = "0"     | _   | 6    | 20      |      |
| Supply current in                   | .00              |                            |                            |                                                          | $V_{IN} = 2.8 V/0.2 V$                                    | MNP•ATP = "1" | -   | 800  | 1400    |      |
| SLEEP 1 mode                        | -                |                            |                            |                                                          | fs = 32.768 kHz                                           | MNP•ATP = "0" | _   | 5    | 18      | μA   |
| Supply current in                   |                  |                            |                            |                                                          |                                                           | MNP•ATP = "1" | -   | 800  | 1400    |      |
| SLEEP 0 mode                        | -                |                            |                            |                                                          |                                                           | MNP•ATP = "0" | -   | 5    | 18      |      |
| Supply current in<br>STOP mode      |                  |                            |                            |                                                          | V <sub>DD</sub> = 3.6 V<br>V <sub>IN</sub> = 3.4 V/0.2 V  |               | _   | 0.5  | 10      |      |

DC Characteristics  $| (V_{SS} = 0 \text{ V}, \text{Topr} = -40 \text{ to } 85^{\circ}\text{C}) |$ 

Note 1: Typical values show those at Topr =  $25^{\circ}$ C.

Note 2: Input current (I<sub>IN1</sub>, I<sub>IN2</sub>): 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: The supply currents of SLOW2 and SLEEP2 modes are equivalent to IDLE0, IDLE1, IDLE2.
- Note 5: MNP (MNPWDW) shows bit0 in EEPCR register and ATP (ATPWDW) shows bit1 in EEPCR register.
- Note 6: "Fetch" means reading operation of FLASH data as an instruction by CPU.

#### AD Conversion Characteristics

 $(V_{SS} = 0.0 \text{ V}, 2.7 \text{ V} \le V_{DD} \le 3.6 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$ 

| Parameter                                         | Symbol            | Condition                                                 | Min                    | Тур.            | Max              | Unit |
|---------------------------------------------------|-------------------|-----------------------------------------------------------|------------------------|-----------------|------------------|------|
| Analog reference voltage                          | VAREF             |                                                           | A <sub>VDD</sub> - 1.0 | _               | A <sub>VDD</sub> |      |
| Power supply voltage of analog<br>control circuit | A <sub>VDD</sub>  |                                                           |                        | V <sub>DD</sub> |                  | V    |
| Analog reference voltage range<br>(Note 4)        | $\Delta V_{AREF}$ |                                                           | 2.5                    | _               | -                | v    |
| Analog input voltage                              | VAIN              |                                                           | V <sub>SS</sub>        | -               | VAREF            |      |
| Power supply current of analog reference voltage  | I <sub>REF</sub>  | $V_{DD} = A_{VDD} = V_{AREF} = 3.6 V$<br>$V_{SS} = 0.0 V$ | -                      | 0.35            | 0.61             | mA   |
| Non linearity error                               |                   | VD = AVD = 2.7 V                                          | -                      | -               | ±2               |      |
| Zero point error                                  |                   |                                                           | -                      | _               | ±2               | LSB  |
| Full scale error                                  |                   | $V_{SS} = 0.0 V$                                          | -                      | _               | ±2               | LOD  |
| Total error                                       |                   | V <sub>AREF</sub> = 2.7 V                                 | _                      | =               | ±2               |      |

 $(V_{SS} = 0.0 \text{ V}, 2.0 \text{ V} \le V_{DD} < 2.7 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$ 

| Parameter                                        | Symbol            | Condition                                             | Min                    | Тур.            | Max              | Unit |
|--------------------------------------------------|-------------------|-------------------------------------------------------|------------------------|-----------------|------------------|------|
| Analog reference voltage                         | VAREF             |                                                       | A <sub>VDD</sub> - 0.6 | -               | A <sub>VDD</sub> |      |
| Power supply voltage of analog control circuit   | A <sub>VDD</sub>  |                                                       |                        | V <sub>DD</sub> |                  | V    |
| Analog reference voltage range<br>(Note 4)       | $\Delta V_{AREF}$ |                                                       | 2.0                    | _               | -                | V    |
| Analog input voltage                             | V <sub>AIN</sub>  |                                                       | V <sub>SS</sub>        | _               | VAREF            |      |
| Power supply current of analog reference voltage | I <sub>REF</sub>  | $V_{DD} = A_{VDD} = V_{AREF} = 2.0V$ $V_{SS} = 0.0 V$ | -                      | 0.20            | 0.34             | mA   |
| Non linearity error                              |                   | VD = AVD = 2.0 V                                      | _                      | -               | ±4               |      |
| Zero point error                                 |                   | 55 155                                                | -                      | -               | ±4               | LSB  |
| Full scale error                                 |                   | $V_{SS} = 0.0 V$                                      | -                      | _               | ±4               | LOD  |
| Total error                                      |                   | V <sub>AREF</sub> = 2.0 V                             | -                      | -               | ±4               |      |

#### $(V_{SS} = 0.0 \text{ V}, 1.8 \text{ V} \le V_{DD} < 2.0 \text{ V}, \text{ Topr} = -10 \text{ to } 85^{\circ}\text{C}) \text{ (Note 5)}$

| Parameter                                         | Symbol            | Condition                                                 | Min                    | Тур. | Max              | Unit |
|---------------------------------------------------|-------------------|-----------------------------------------------------------|------------------------|------|------------------|------|
| Analog reference voltage                          | VAREF             |                                                           | A <sub>VDD</sub> - 0.1 | _    | A <sub>VDD</sub> |      |
| Power supply voltage of analog<br>control circuit | A <sub>VDD</sub>  |                                                           | V <sub>DD</sub>        |      |                  | v    |
| Analog reference voltage<br>range (Note 4)        | $\Delta V_{AREF}$ |                                                           | 1.8                    | -    | -                | v    |
| Analog input voltage                              | VAIN              |                                                           | V <sub>SS</sub>        | -    | VAREF            |      |
| Power supply current of analog reference voltage  | I <sub>REF</sub>  | $V_{DD} = A_{VDD} = V_{AREF} = 1.8 V$<br>$V_{SS} = 0.0 V$ | -                      | 0.18 | 0.31             | mA   |
| Non linearity error                               |                   | V = Aעס = 1.8 V                                           | -                      | _    | ±4               |      |
| Zero point error                                  |                   | $V_{SS} = 0.0 V$                                          | _                      | -    | ±4               |      |
| Full scale error                                  |                   |                                                           | -                      | -    | ±4               | LSB  |
| Total error                                       |                   | V <sub>AREF</sub> = 1.8 V                                 | -                      | _    | ±4               |      |

Note 1: The total error includes all errors except a quantization error, and is defined as a maximum deviation from the ideal conversion line.

Note 2: Conversion time is different in recommended value by power supply voltage. About conversion time, please refer to "2.15.2 Register configration".

Note 3: Please use input voltage to AIN input Pin in limit of VAREF – VSS. When voltage of range outside is input, conversion value becomes unsettled and gives affect to other channel conversion value.

Note 4: Analog Reference Voltage Range:  $\Delta VAREF = VAREF - VSS$ 

Note 5: When AD is used with VDD < 2.0 V, the guaranteed temperature range varies with the operating voltage.

Note 6: When AD converter is not used, fix the AVDD pin and VAREFpin on the V<sub>DD</sub> level.

#### AC Characteristics $(V_{SS} = 0 V, V_{DD} = 2.7 \text{ to } 3.6 V, \text{Topr} = -40 \text{ to } 85^{\circ}\text{C})$

| Parameter                                                   | Symbol       | Condition                                                  | Min   | Тур.  | Max   | Unit |
|-------------------------------------------------------------|--------------|------------------------------------------------------------|-------|-------|-------|------|
| Machine cycle time                                          | tcy          | NORMAL1, 2 mode<br>IDLE1, 2 mode                           | 0.25  | -     | 4     |      |
|                                                             |              | SLOW1, 2 mode<br>SLEEP1, 2 mode                            | 117.6 | _     | 133.3 | μs   |
| High Level clock pulse width<br>Low level clock pulse width | twcH<br>twcL | For external clock operation (XIN input), fc = 16 MHz      | _     | 31.25 | _     | ns   |
| High level clock pulse width<br>Low level clock pulse width | twcH<br>twcL | For external clock operation (XTIN input), fs = 32.768 kHz | -     | 15.26 | -     | μS   |

#### $(V_{SS} = 0 \text{ V}, V_{DD} = 1.8 \text{ to } 3.6 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$

| Parameter                                                   | Symbol       | Condition                                                  | Min   | Тур.   | Max   | Unit |
|-------------------------------------------------------------|--------------|------------------------------------------------------------|-------|--------|-------|------|
| Machine cycle time                                          | tcy          | NORMAL1, 2 mode<br>IDLE1, 2 mode                           | 0.5   | -      | 4     |      |
|                                                             |              | SLOW1, 2 mode<br>SLEEP1, 2 mode                            | 117.6 | _      | 133.3 | μs   |
| High level clock pulse width<br>Low level clock pulse width | twcH<br>twcL | For external clock operation (XIN input), fc = 4.2 MHz     | _     | 119.04 | _     | ns   |
| High level clock pulse width<br>Low level clock pulse width | twcH<br>twcL | For external clock operation (XTIN input), fs = 32.768 kHz | -     | 15.26  | _     | μS   |

Flash Characteristics  $(V_{SS} = 0 V)$ 

| Parameter                                                                            | Condition                                                                                                        | Min | Тур. | Max             | Unit  |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----|------|-----------------|-------|
| Number of guaranteed writes (page<br>writing) to Flash memory in serial PROM<br>mode | $V_{DD} = 2.7 \text{ to } 3.6 \text{ V}, 2 \text{ MHz} \le \text{fc} \le 16 \text{ MHz}$ (Topr = 25°C $\pm$ 5°C) | -   | -    | 10 <sup>5</sup> | Times |
| Number of guaranteed writes (page writing) to Flash data memory in MCU mode          | $V_{DD} = 1.8$ to 3.6 V at fc = 8 MHz<br>$V_{DD} = 2.7$ to 3.6 V at fc = 16 MHz<br>(Topr = -40 to 85°C)          | _   | _    | 10 <sup>5</sup> | Times |
| Writing time to Flash data memory for one page (64 bytes) in MCU mode                |                                                                                                                  | _   | 4    | 6               | ms    |

Recommended Oscillating Conditions

- Note 1: An electrical shield by metal shield plate on the surface of IC package is recommended in order to protect the device from the high electric field stress applied from CRT (Cathodic Ray Tube) for continuous reliable operation.
- Note 2: The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following http://www.murata.com/

## Handling Precaution

- The solderability test conditions for lead-free products (indicated by the suffix G in product name) are shown below.
- When using the Sn-37Pb solder bath Solder bath temperature = 230°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°C Dipping time = 5 seconds Number of times = once R-type flux used

Note : The pass criteron of the above test is as follows: Solderability rate until forming  $\geq 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.

# Package Dimensions

LQFP64-P-1010-0.50E

Unit: mm



QFP64-P-1414-0.80C

Unit: mm



This is a technical document that describes the operating functions and electrical specifications of the 8-bit microcontroller series TLCS-870/C (LSI).

Toshiba provides a variety of development tools and basic software to enable efficient software development.

These development tools have specifications that support advances in microcomputer hardware (LSI) and can be used extensively. Both the hardware and software are supported continuously with version updates.

The recent advances in CMOS LSI production technology have been phenomenal and microcomputer systems for LSI design are constantly being improved. The products described in this document may also be revised in the future. Be sure to check the latest specifications before using.

Toshiba is developing highly integrated, high-performance microcomputers using advanced MOS production technology and especially well proven CMOS technology.

We are prepared to meet the requests for custom packaging for a variety of application areas. We are confident that our products can satisfy your application needs now and in the future.