# TOSHIBA

TOSHIBA Original CMOS 16-Bit Microcontroller

# TLCS-900/L1 Series

# TMP91C824

# **TOSHIBA CORPORATION**

Semiconductor Company

# Preface

Thank you very much for making use of Toshiba microcomputer LSIs. Before use this LSI, refer the section, "Points of Note and Restrictions". Especially, take care below cautions.

#### \*\*CAUTION\*\* How to release the HALT mode

Usually, interrupts can release all halts status. However, the interrupts =  $(\overline{NMI}, INT0 \text{ to INT3}, INTRTC, INTALM0 \text{ to INTALM4})$ , which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 5 clocks of f<sub>FPH</sub>) with IDLE1 or STOP mode (IDLE2 is not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficultly. The priority of this interrupt is compare with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

## CMOS 16-Bit Microcontrollers TMP91C824F/JTMP91C824-S

## 1. Outline and Features

TMP91C824 is a high-speed 16-bit microcontroller designed for the control of various mid- to large-scale equipment.

TMP91C824F comes in a 100-pin flat package. JTMP91C824-S is a chip form product.

Listed below are the features.

- (1) High-speed 16-bit CPU (900/L1 CPU)
  - Instruction mnemonics are upward-compatible with TLCS-90
  - 16 Mbytes of linear address space
  - General-purpose registers and register banks
  - 16-bit multiplication and division instructions; bit transfer and arithmetic instructions
  - Micro DMA: 4 channels (485 ns/2 bytes at 33 MHz)
- (2) Minimum instruction execution time: 121 ns (at 33 MHz)
- (3) Built-in RAM: 8 Kbytes Built-in ROM: None

#### RESTRICTIONS ON PRODUCT USE

030619EBP

- The information contained herein is subject to change without notice.
- 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 patent or patent rights of TOSHIBA or others.
- 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..

- 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 malfunctionor 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.
- The products described in this document are subject to the foreign exchange and foreign trade laws.
- TOSHIBA products should not be embedded to the downstream products which are prohibited to be produced and sold, under any law and regulations.
- 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.

- (4) External memory expansion
  - Expandable up to 106 Mbytes (shared program/data area)
  - Can simultaneously support 8-/16-bit width external data bus Dynamic data bus sizing
  - Separate bus system
- (5) 8-bit timers: 4 channels
- (6) General-purpose serial interface: 2 channels
  - UART/Synchronous mode: 2 channels
  - IrDA Ver.1.0 (115.2 kbps) mode selectable: 1 channel
- (7) Serial bus interface: 1 channel
  - $\bullet \quad I^2C \ \text{bus mode/clock synchronous mode selectable}$
- (8) Timer for real-time clock (RTC)
  - Based on TC8521A
- (9) 10-bit AD converter: 8 channels
- (10) Watchdog timer
- (11) Melody/alarm generator
  - Melody: Output of clock 4 to 5461 Hz
  - Alarm: Output of the 8 kinds of alarm pattern
  - Output of the 5 kinds of interval interrupt

(12) Chip select/wait controller: 4 channels

(13) Memory management unit

• Expandable up to 106 Mbytes (4 local areas/8-bank method)

(14) Interrupts: 37 interrupts

- 9 CPU interrupts: Software interrupt instruction and illegal instruction
- 23 internal interrupts: 7 priority levels are selectable
- 5 external interrupts: 7 priority levels are selectable (among 4 interrupts are selectable edge mode)

(15) Input/output ports: 35 pins (at external 16-bit data bus memory)

(16) Standby function

Three HALT modes: IDLE2 (Programmable), IDLE1 and STOP

(17) Triple-clock controller

- Clock doubler (DFM) circuit is inside
- Clock gear function: Select a high-frequency clock fc/1 to fc/16
- Slow mode (fs = 32.768 kHz)

(18) Operating voltage

- V<sub>CC</sub> = 2.7 V to 3.6 V (fc max = 33 MHz)
- $V_{CC} = 1.8 \text{ V to } 3.6 \text{ V (fc max} = 10 \text{ MHz})$

(19) Package

- 100-pin QFP: P-LQFP100-1414-0.50F
- Chip form supply also available. For details, contact your local Toshiba sales representative.



Figure 1.1 TMP91C824 Block Diagram

# 2. Pin Assignment and Functions

The assignment of input/output pins for the TMP91C824, their names and functions are as follows:

#### 2.1 Pin Assignment Diagram

Figure 2.1 shows the pin assignment of the TMP91C824F.



Figure 2.1 Pin Assignment Diagram (100-pin QFP)

Unit: µm

## 2.2 Pad Layout

(Chip size 4.37 mm  $\times$  4.37 mm)

| Pin<br>No. | Name  | X Point | Y Point | Pin<br>No. | Name | X Point | Y Point | Pin<br>No. | Name  | X Point | Y Point |
|------------|-------|---------|---------|------------|------|---------|---------|------------|-------|---------|---------|
| 1          | VREFL | -2050   | 1721    | 35         | PC0  | -140    | -2050   | 69         | P21   | 2045    | 939     |
| 2          | AVSS  | -2050   | 1596    | 36         | PC1  | -14     | -2050   | 70         | P20   | 2045    | 1075    |
| 3          | AVCC  | -2050   | 1470    | 37         | PC2  | 112     | -2050   | 71         | A15   | 2045    | 1207    |
| 4          | P80   | -2050   | 1337    | 38         | PC3  | 238     | -2050   | 72         | A14   | 2045    | 1337    |
| 5          | P81   | -2050   | 1209    | 39         | PC4  | 365     | -2050   | 73         | A13   | 2045    | 1464    |
| 6          | P82   | -2050   | 1076    | 40         | PC5  | 491     | -2050   | 74         | A12   | 2045    | 1592    |
| 7          | P83   | -2050   | 943     | 41         | PD5  | 618     | -2050   | 75         | A11   | 2045    | 1721    |
| 8          | P84   | -2050   | 810     | 42         | PD6  | 744     | -2050   | 76         | A10   | 1720    | 2045    |
| 9          | P85   | -2050   | 677     | 43         | PD7  | 871     | -2050   | 77         | A9    | 1591    | 2045    |
| 10         | P86   | -2050   | 544     | 44         | D0   | 998     | -2050   | 78         | A8    | 1464    | 2045    |
| 11         | P87   | -2050   | 416     | 45         | D1   | 1124    | -2050   | 79         | A7    | 1337    | 2045    |
| 12         | P70   | -2050   | 148     | 46         | D2   | 1251    | -2050   | 80         | A6    | 1197    | 2045    |
| 13         | P71   | -2050   | 15      | 47         | D3   | 1377    | -2050   | 81         | A5    | 1058    | 2045    |
| 14         | P72   | -2050   | -118    | 48         | D4   | 1504    | -2050   | 82         | A4    | 918     | 2045    |
| 15         | PB0   | -2050   | -251    | 49         | D5   | 1630    | -2050   | 83         | A3    | 778     | 2045    |
| 16         | PB1   | -2050   | -384    | 50         | D6   | 1757    | -2050   | 84         | A2    | 639     | 2045    |
| 17         | PB2   | -2050   | -517    | 51         | D7   | 2045    | -1750   | 85         | A1    | 499     | 2045    |
| 18         | PB3   | -2050   | -650    | 52         | P10  | 2045    | -1614   | 86         | A0    | 359     | 2045    |
| 19         | PB4   | -2050   | -783    | 53         | P11  | 2045    | -1478   | 87         | RD    | 219     | 2045    |
| 20         | PB5   | -2050   | -916    | 54         | P12  | 2045    | -1341   | 88         | WR    | 80      | 2045    |
| 21         | PB6   | -2050   | -1049   | 55         | P13  | 2045    | -1205   | 89         | PZ2   | -59     | 2045    |
| 22         | P54   | -2050   | -1182   | 56         | P14  | 2045    | -1069   | 90         | PZ3   | -199    | 2045    |
| 23         | P55   | -2050   | -1315   | 57         | P15  | 2045    | -933    | 91         | P56   | -338    | 2045    |
| 24         | AM0   | -2050   | -1448   | 58         | P16  | 2045    | -796    | 92         | P60   | -478    | 2045    |
| 25         | VCC   | -2050   | -1581   | 59         | P17  | 2045    | -660    | 93         | P61   | -618    | 2045    |
| 26         | X2    | -1551   | -2050   | 60         | P27  | 2045    | -524    | 94         | P62   | -757    | 2045    |
| 27         | VSS   | -1330   | -2050   | 61         | P26  | 2045    | -388    | 95         | P63   | -897    | 2045    |
| 28         | X1    | -1205   | -2050   | 62         | VSS  | 2045    | -234    | 96         | P64   | -1037   | 2045    |
| 29         | AM1   | -1075   | -2050   | 63         | NMI  | 2045    | -80     | 97         | P65   | -1176   | 2045    |
| 30         | RESET | -948    | -2050   | 64         | VCC  | 2045    | 240     | 98         | P66   | -1316   | 2045    |
| 31         | XT1   | -822    | -2050   | 65         | P25  | 2045    | 394     | 99         | P67   | -1456   | 2045    |
| 32         | XT2   | -520    | -2050   | 66         | P24  | 2045    | 530     | 100        | VREFH | -1725   | 2045    |
| 33         | EMU0  | -394    | -2050   | 67         | P23  | 2045    | 666     |            |       |         |         |
| 34         | EMU1  | -267    | -2050   | 68         | P22  | 2045    | 803     |            |       |         |         |

#### 2.3 Pin Names and Functions

The names of the input/output pins and their functions are described below.

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

| Pin Name         | Number<br>of Pins | I/O    | Functions                                                                 |
|------------------|-------------------|--------|---------------------------------------------------------------------------|
| D0 to D7         | 8                 | I/O    | Data (Lower): Bits 0 to 7 of data bus                                     |
| P10 to P17       | 8                 | I/O    | Port 1: I/O port that allows I/O to be selected at the bit level          |
|                  |                   |        | (when used to the external 8-bit bus)                                     |
| D8 to D15        |                   | I/O    | Data (Upper): bits 8 to15 of data bus                                     |
| P20 to P27       | 8                 | Output | Port 2: Output port                                                       |
| A16 to A23       |                   | Output | Address: Bits 16 to 23 of address bus                                     |
| A8 to A15        | 8                 | Output | Address: Bits 8 to 15 of address bus                                      |
| A0 to A7         | 8                 | Output | Address: Bits 0 to 7 of address bus                                       |
| RD               | 1                 | Output | Read: Strobe signal for reading external memory                           |
|                  |                   |        | RD is outputted by setting PZ <rde> to "0" even when read internal</rde>  |
|                  |                   |        | memory.                                                                   |
| WR               | 1                 | Output | Write: Strobe signal for writing data to pins D0 to D7                    |
| PZ2              | 1                 | I/O    | Port Z2: I/O port (with pull-up resistor)                                 |
| HWR              |                   | Output | High write: Strobe signal for writing data to pins D8 to D15              |
| PZ3              | 1                 | I/O    | Port Z3: I/O port (with pull-up resistor)                                 |
| $R/\overline{W}$ |                   | Output | Read/write: 1 represents read or dummy cycle; 0 represents write cycle.   |
| P54              | 1                 | I/O    | Port 54: I/O port (with pull-up resistor)                                 |
| BUSRQ            |                   | Output | Bus request: High-impedance used to request bus release                   |
| P55              | 1                 | I/O    | Port 55: I/O port (with pull-up resistor)                                 |
| BUSAK            |                   | Output | Bus acknowledge: Signal used to acknowledge bus release                   |
| P56              | 1                 | I/O    | Port 56: I/O port (with pull-up resistor)                                 |
| WAIT             |                   | Input  | Wait: Pin used to request CPU bus wait ((1 + N) wait states)              |
| P60              | 1                 | Output | Port 60: Output port                                                      |
| CSO              |                   | Output | Chip select 0: Outputs 0 when address is within specified address area.   |
| P61              | 1                 | Output | Port 61: Output port                                                      |
| CS1              |                   | Output | Chip select 1: Outputs 0 when address is within specified address area    |
| P62              | 1                 | Output | Port 62: Output port                                                      |
| CS2              |                   | Output | Chip select 2: Outputs 0 when address is within specified address area    |
| <del>CS2A</del>  |                   | Output | Expand chip select 2A: Outputs 0 when address is within specified address |
|                  |                   |        | area                                                                      |
| P63              | 1                 | Output | Port 63: Output port                                                      |
| CS3              |                   | Output | Chip select 3: Outputs 0 when address is within specified address area    |
| P64              | 1                 | Output | Port 64: Output port                                                      |
| EA24             |                   | Output | Address 24: Expand address                                                |
| CS2B             |                   | Output | Expand chip select 2B: Outputs 0 when address is within specified address |
|                  |                   |        | area                                                                      |
| P65              | 1                 | Output | Port 65: Output port                                                      |
| EA25             |                   | Output | Address 25: Expand address                                                |
| CS2C             |                   | Output | Expand chip select 2C: Outputs 0 when address is within specified address |
|                  |                   |        | area                                                                      |
| P66              | 1                 | Output | Port 66: Output port                                                      |
| CS2D             |                   | Output | Expand chip select 2D: Outputs 0 when address is within specified address |
|                  |                   |        | area                                                                      |
| P67              | 1                 | Output | Port 67: Outpt port                                                       |
| CS2E             |                   | Output | Expand chip select 2E: Outputs 0 when address is within specified address |
|                  |                   |        | area                                                                      |

| Table 2.3.2 | Pin Names and Functions (     | 2/3)  |  |
|-------------|-------------------------------|-------|--|
| Table Lioit | in in italie and i anotorio ( | _, _, |  |

| Pin Name     | Number<br>of Pins | I/O    | Functions                                                                   |
|--------------|-------------------|--------|-----------------------------------------------------------------------------|
| P70          | 1                 | I/O    | Port 70: I/O port                                                           |
| SCK          |                   | I/O    | Serial bus interface clock I/O data at SIO mode                             |
| OPTRX0       |                   | Input  | Serial 0 receive data                                                       |
| P71          | 1                 | I/O    | Port 71: I/O port                                                           |
| SO           |                   | Output | Serial bus interface send data at SIO mode                                  |
| SDA          |                   | I/O    | Serial bus interface send/receive data at I <sup>2</sup> C bus mode         |
|              |                   |        | Open-drain output mode by programmable (with pull up)                       |
| OPTTX0       |                   | Output | Serial 0 send data                                                          |
| P72          | 1                 | I/O    | Port 72: I/O port                                                           |
| SI           |                   | Input  | Serial bus interface recive data at SIO mode                                |
| SCL          |                   | I/O    | Serial bus interface clock I/O data at I <sup>2</sup> C bus mode            |
|              |                   |        | Open-drain output mode by programmable (with pull up)                       |
| P80 to P87   | 8                 | Input  | Port 80 to 87 port: Pin used to input ports                                 |
| AN0 to AN7   |                   | Input  | Analog input 0 to 7: Pin used to input to AD conveter                       |
| ADTRG        |                   | Input  | AD trigger: Signal used to request AD start (with used to P83)              |
| PB0          | 1                 | I/O    | Port B0: I/O port                                                           |
| TAOIN        |                   | Input  | 8-bit timer 0 input: Timer 0 input                                          |
| PB1          | 1                 | I/O    | Port B1: I/O port                                                           |
| TA1OUT       |                   | Output | 8-bit timer 1 output: Timer 0 output or timer 1 output                      |
| PB2          | 1                 | I/O    | Port B2: I/O port                                                           |
| TA3OUT       |                   | Output | 8-bit timer 3 output: Timer 2 output or timer 3 output                      |
| PB3          | 1                 | I/O    | Port B0: I/O port                                                           |
| INTO         |                   | Input  | Interrupt request pin0: Interrupt request pin with programmable rising      |
|              |                   |        | /falling edge                                                               |
| PB4 to PB6   | 3                 | I/O    | Port B4 to B6: I/O port                                                     |
| INT1 to INT3 |                   | Input  | Interrupt request pin1 to 3: Interrupt request pin with programmable rising |
|              |                   |        | /falling edge                                                               |
| PC0          | 1                 | I/O    | Port C0: I/O port                                                           |
| TXD0         |                   | Output | Serial 0 send data: Open-drain output pin by programmable                   |
| PC1          | 1                 | I/O    | Port C1: I/O port                                                           |
| RXD0         |                   | Input  | Serial 0 receive data                                                       |

| Table 2.3.3 | Pin Names and Functions ( | (3/3) | ) |
|-------------|---------------------------|-------|---|
|             |                           |       |   |

| Pin Name   | Number<br>of Pins | I/O    | Functions                                                                  |
|------------|-------------------|--------|----------------------------------------------------------------------------|
| PC2        | 1                 | I/O    | Port C2: I/O port                                                          |
| SCLK0      |                   | I/O    | Serial 0 clock                                                             |
| CTS0       |                   | Input  | Serial data send enable 0 (Clear to send)                                  |
| PC3        | 1                 | I/O    | Port C3: I/O port                                                          |
| TXD1       |                   | Output | Serial 1 send data                                                         |
|            |                   |        | Open-drain output pin by programmable                                      |
| PC4        | 1                 | I/O    | Port C4: I/O port                                                          |
| RXD1       |                   | Input  | Serial 1 receive data                                                      |
| PC5        | 1                 | I/O    | Port C5: I/O port                                                          |
| SCLK1      |                   | I/O    | Serial clock I/O 1                                                         |
| CTS1       |                   | Input  | Serial 1 data send enable (Clear to send)                                  |
| XT1        | 1                 | Input  | Low-frequency oscillator connecting pin                                    |
| XT2        | 1                 | Output | Low-frequency oscillator connecting pin                                    |
| PD5        | 1                 | Output | Port D5: Output port                                                       |
| SCOUT      |                   | Output | System clock output: fSYS or fs output                                     |
| PD6        | 1                 | Output | Port D6: Output port                                                       |
| ALARM      |                   | Output | RTC alarm output pin                                                       |
| MLDALM     |                   | Output |                                                                            |
| PD7        | 1                 | Output | Port D7: Output port                                                       |
| MLDALM     |                   | Output | Melody/alarm output pin                                                    |
| NMI        | 1                 | Input  | Non-maskable interrupt request pin: Interrupt request pin with             |
|            |                   | -      | programmable falling edge level or with both edge levels programmable      |
| AM0 to AM1 | 2                 | Input  | Operation mode:                                                            |
|            |                   | -      | Fixed to AM1 = 0, AM0 = 1 16-bit external bus or 8-/16-bit dynamic sizing. |
|            |                   |        | Fixed to AM1 = 0, AM0 = 0 8-bit external bus fixed.                        |
| EMU0       | 1                 | Output | Open pin                                                                   |
| EMU1       | 1                 | Output | Open pin                                                                   |
| RESET      | 1                 | Input  | Reset: Initializes TMP91C824 (with pull-up resistor).                      |
| VREFH      | 1                 | Input  | Pin for reference voltage input to AD converter (H)                        |
| VREFL      | 1                 | Input  | Pin for reference voltage input to AD converter (L)                        |
| AVCC       | 1                 |        | Power supply pin for AD converter                                          |
| AVSS       | 1                 |        | GND pin for AD converter (0 V)                                             |
| X1/X2      | 2                 |        | High-frequency oscillator connection pins                                  |
| DVCC       | 2                 |        | Power supply pins (All VCC pins should be connecyed with the power         |
|            |                   |        | Supply pin.)                                                               |
| DVSS       | 2                 |        | GND pins (0 V) (All pins shuold be connected with GND (0 V).)              |

## 3. Operation

This following describes block by block the functions and operation of the TMP91C824. Notes and restrictions for eatch book are outlined in 6 "Precautions and Restrictions" at the end of this manual.

#### 3.1 CPU

The TMP91C824 incorporates a high-performance 16-bit CPU (the 900/L1 CPU). For CPU operation, see the TLCS-900/L1 CPU.

The following describe the unique function of the CPU used in the TMP91C824; these functions are not covered in the TLCS-900/L1 CPU section.

#### 3.1.1 Reset

When resetting the TMP91C824 microcontroller, ensure that the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then set the  $\overline{\text{RESET}}$  input to low level at least for 10 system clocks (10 µs at 33 MHz). Thus, when turn on the switch, be set to the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then hold the  $\overline{\text{RESET}}$  input to low level at least for 10 system clocks.

Clock gear is initialized 1/16 mode by reset operation. It means that the system clock mode fsys is set to fc/32 (= fc/16  $\times$  1/2).

When the reset is accept, the CPU:

• Sets as follows the program counter (PC) in accordance with the reset vector stored at address FFFF00H to FFFF02H:

| PC<0:7>   | $\leftarrow$ | Value at FFFF00H address |
|-----------|--------------|--------------------------|
| PC<15:8>  | ←            | Value at FFFF01H address |
| PC<23:16> | ←            | Value at FFFF02H address |

- Sets the stack pointer (XSP) to 100H.
- Sets bits <IFF2:0> of the status register (SR) to 111. (Sets the interrupt level mask register to level 7.)
- Sets the <MAX> bit of the status register (SR) to 1 (MAX mode).
   (Note: As this product does not support MIN mode, do not write a 0 to the <MAX>)
- Clears bits <RFP2:0> of the status register (SR) to 000. (Sets the register bank to 0.)

When reset is released, the CPU starts executing instructions in accordance with the program counter settings. CPU internal registers not mentioned above do not change when the reset is released.

When the reset is accepted, the CPU sets internal I/O, ports, and other pins as follows.

- Initializes the internal I/O registers.
- Sets the port pins, including the pins that also act as internal I/O, to generalpurpose input or output port mode.
- Note: The CPU internal register (except to PC, SR, XSP) and internal RAM data do not change by resetting.

Figure 3.1.1 is a reset timing chart of the TMP91C824.



Figure 3.1.1 TMP91C824 Reset Timing Chart

#### 3.2 Memory Map

Figure 3.2.1 is a memory map of the TMP91C824.



Figure 3.2.1 Memory Map

Note: Address 000FE0H to 00FFFH is assigned for the TOSHIBA reserve area, user can't use.

#### 3.3 Triple Clock Function and Standby Function

TMP91C824 contains (1) clock gear, (2) clock doubler (DFM), (3) standby controller and (4) noise-reduction circuit. It is used for low-power and low-noise systems.

This chapter is organized as follows:

- 3.3.1 Block Diagram of System Clock
- 3.3.2 SFR
- 3.3.3 System Clock Controller
- 3.3.4 Prescaler Clock Controller
- 3.3.5 Clock Doubler (DFM)
- 3.3.6 Noise Reduction Circuits
- 3.3.7 Standby Controller

The clock operating modes are as follows: (a) Single clock mode (X1, X2 pins only), (b) Dual clock mode (X1, X2, XT1 and XT2 pins) and (c) Triple clock mode (The X1, X2, XT1 and XT2 pins and DFM).

Figure 3.3.1 shows a transition figure.



- Note 1: It's prohibited to control DFM in SLOW mode when shifting from SLOW mode to NORMAL mode with use of DFM. (DFM start up/stop/change write to DFMCR0<ACT1:0> register)
- Note 2: If you shift from NORMAL mode with use of DFM to NORMAL mode, the instructions should be separated into two procedures as below. Change CPU clock → Stop DFM circuit.
- Note 3: It's prohibited to shift from NORMAL mode with use of DFM to STOP mode directly. You should set NORMAL mode once, and then shift to STOP mode. (You should stop high-frequency oscillator after you stop DFM.)



Note: The clock frequency input from the X1 and X2 pins is called  $f_{OSCH}$  and the clock frequency input from the XT1 and XT2 pins is called fs. The clock frequency selected by SYSCR1<SYSCK> is called the system clock  $f_{FPH}$ . The system clock  $f_{SYS}$  is defined as the divided clock of  $f_{FPH}$ , and one cycle of  $f_{SYS}$  is called one state.

#### 3.3.1 Block Diagram of System Clock



Figure 3.3.2 Block Diagram of System Clock

#### 3.3.2 SFR

|         | $\sim$      | 7               | 6                   | 5                          | 4               | 3             | 2                                        | 1                          | 0          |
|---------|-------------|-----------------|---------------------|----------------------------|-----------------|---------------|------------------------------------------|----------------------------|------------|
| SYSCR0  | Bit symbol  | ,<br>XEN        | XTEN                | RXEN                       | RXTEN           | RSYSCK        | WUEF                                     | PRCK1                      | PRCK0      |
| (00E0H) | Read/Write  | ALIN            | ATEN                | NALN                       |                 | W             | WOLF                                     | FROM                       | FICINU     |
|         | After reset | 1               | 1                   | 1                          | 0               | 0             | 0                                        | 0                          | 0          |
|         | Function    | High-           | Low-                | High-                      | Low-            | Selects clock | Warm-up timer                            | Select prescal             |            |
|         |             | frequency       | frequency           | frequency                  | frequency       | after release | 0: Write                                 | 00: f <sub>FPH</sub> (Note |            |
|         |             | oscillator (fc) | oscillator (fs)     | oscillator (fc)            | oscillator (fs) | of STOP       | Don't care                               | 01: Reserved               | ,          |
|         |             | 0: Stop         | 0: Stop             | after release              | after release   | mode          | 1: Write                                 | 10: fc/16                  |            |
|         |             | 1: Oscillation  | 1: Oscillation      | of STOP                    | of STOP         | 0: fc         | start timer                              | 11: Reserved               |            |
|         |             |                 | (Note 1)            | mode                       | mode            | 1: fs         | 0: Read                                  |                            |            |
|         |             |                 | . ,                 | 0: Stop                    | 0: Stop         |               | end warm up<br>1: Read                   |                            |            |
|         |             |                 |                     | 1: Oscillation             | 1: Oscillation  |               | do not end                               |                            |            |
|         |             |                 |                     |                            |                 |               | warm up                                  |                            |            |
|         | /           | 7               | 6                   | 5                          | 4               | 3             | 2                                        | 1                          | 0          |
| SYSCR1  | Bit symbol  | /               |                     |                            |                 | SYSCK         | GEAR2                                    | GEAR1                      | GEAR0      |
| (00E1H) | Read/Write  | /               | /                   | /                          |                 |               | R/                                       | W                          |            |
|         | After reset | /               |                     |                            |                 | 0             | 1                                        | 0                          | 0          |
|         | Function    | Function        |                     |                            |                 | Select        | Select gear value of high frequency (fc) |                            |            |
|         |             |                 |                     |                            |                 | system        | 000: fc                                  |                            |            |
|         |             |                 |                     |                            |                 | clock         | 001: fc/2                                |                            |            |
|         |             |                 |                     |                            |                 | 0: fc         | 010: fc/4                                |                            |            |
|         |             |                 |                     |                            |                 | 1: fs         | 011: fc/8                                |                            |            |
|         |             |                 |                     |                            |                 |               | 100: fc/16                               |                            |            |
|         |             |                 |                     |                            |                 |               | 101: (Reserv                             | ed)                        |            |
|         |             |                 |                     |                            |                 |               | 110: (Reserv                             | ed)                        |            |
|         |             |                 |                     |                            |                 |               | 111: (Reserv                             | ed)                        |            |
|         |             | 7               | 6                   | 5                          | 4               | 3             | 2                                        | 1                          | 0          |
| SYSCR2  | Bit symbol  |                 | SCOSEL              | WUPTM1                     | WUPTM0          | HALTM1        | HALTM0                                   | SELDRV                     | DRVE       |
| (00E2H) | Read/Write  |                 | R/W                 | R/W                        | R/W             | R/W           | R/W                                      | R/W                        | R/W        |
|         | After reset |                 | 0                   | 1                          | 0               | 1             | 1                                        | 0                          | 0          |
|         | Function    |                 | 0: fs               | Warm-up tim                | er              | HALT mode     |                                          | <drve></drve>              | Pin state  |
|         |             |                 | 1: f <sub>SYS</sub> | 00: Reserved               |                 | 00: Reserved  | b                                        | mode                       | control in |
|         |             |                 |                     | 01: 2 <sup>8</sup> inputte | ed frequency    | 01: STOP m    | ode                                      | select                     | STOP/IDLE1 |
|         |             |                 |                     | 10: 2 <sup>14</sup>        |                 | 10: IDLE1 m   |                                          | 0: STOP                    | mode       |
|         |             |                 |                     | 11: 2 <sup>16</sup>        |                 | 11: IDLE2 m   | ode                                      | 1: IDLE1                   | 0: I/O off |
|         |             |                 |                     |                            |                 |               |                                          |                            | 1: Remains |
|         |             |                 |                     |                            |                 |               |                                          |                            | the state  |
|         |             |                 |                     |                            |                 |               |                                          |                            | before     |
|         |             |                 |                     |                            |                 |               |                                          |                            | halt       |

Note 1: By reset, low-frequency oscillator is enable.

Note 2: In case of using built-in SBI circuit, it must set SYSCR0<PRCK1:0> to 00.

Figure 3.3.3 SFR for System Clock

|         |             |              | 7        | 6           | 5           | 4                               | 3   | 2   | 1   | 0   |
|---------|-------------|--------------|----------|-------------|-------------|---------------------------------|-----|-----|-----|-----|
| DFMCR0  | Bit symbol  |              | ACT1     | ACT0        | DLUPFG      | DLUPTM                          |     |     | /   |     |
| (00E8H) | Read/Write  |              | R/W      | R/W         | R           | R/W                             |     |     | /   |     |
|         | After reset |              | 0        | 0           | 0           | 0                               |     |     | /   |     |
|         | Function    |              | DFM LUP  | select fFPH | Lockup      | Lockup time                     |     |     |     |     |
|         |             | 00           | STOP STO | P fosch     | status flag | 0: 2 <sup>12</sup> /fosch       |     |     |     |     |
|         |             | 01           | RUN RUN  | fosch       | 0: LUP end  | 1: 2 <sup>10</sup> /fOSCH       |     |     |     |     |
|         |             | 10           | RUN STO  | P fDFM      | 1: LUP not  |                                 |     |     |     |     |
|         |             | 11           | RUN STO  | P fosch     | end         |                                 |     |     |     |     |
| DFMCR1  | Bit symbol  |              | D7       | D6          | D5          | D4                              | D3  | D2  | D1  | D0  |
| (00E9H) | Read/Write  |              | R/W      | R/W         | R/W         | R/W                             | R/W | R/W | R/W | R/W |
|         | After reset |              | 0        | 0           | 0           | 1                               | 0   | 0   | 1   | 1   |
|         | Function    | DFM revision |          |             |             |                                 |     |     |     |     |
|         |             |              |          |             |             | 4 to 8.25 MHz<br>y 2 to 2.5 MHz | •   | ,   |     |     |



Limitation point on the use of DFM

1. It's prohibited to execute DFM enable/disable control in the SLOW mode (fs). (Write to DFMCR0<ACT1:0> = "10").

You should control DFM in the NORMAL mode.

2. If you stop DFM operation during using DFM (DFMCR0<ACT1:0> = "10"), you shouldn't execute that change the clock fDFM to fOSCH and stop the DFM at the same time. Therefore the above execution should be separated into two procedures as showing below.

| LD | (DFMCR0), C0H | ; | Change the clock f <sub>DFM</sub> to f <sub>OSCH</sub> |
|----|---------------|---|--------------------------------------------------------|
| LD | (DFMCR0), 00H | ; | DFM stop                                               |

3. If you stop high-frequency oscillator during using DFM (DFMCR0<ACT1:0> = "10"), you should stop DFM before you stop high-frequency oscillator.

Please refer to 3.3.5 "Clock Doubler (DFM)" for the details.

|         |             | 7            | 6              | 5               | 4               | 3                                  | 2                            | 1              | 0              |
|---------|-------------|--------------|----------------|-----------------|-----------------|------------------------------------|------------------------------|----------------|----------------|
| EMCCR0  | Bit symbol  | PROTECT      | -              | -               | -               | -                                  | EXTIN                        | DRVOSCH        | DRVOSCL        |
| (00E3H) | Read/Write  | R            | R/W            | R/W             | R/W             | R/W                                | R/W                          | R/W            | R/W            |
|         | After reset | 0            | 0              | 1               | 0               | 0                                  | 0                            | 1              | 1              |
|         | Function    | Protect flag | Always         | Always          | Always          | Always                             | 1: External                  | fc oscillator  | fs oscillator  |
|         |             | 0: OFF       | write 0        | write 1         | write 0         | write 0                            | clock                        | driver ability | driver ability |
|         |             | 1: ON        |                |                 |                 |                                    |                              | 1: Normal      | 1: Normal      |
|         |             |              |                |                 |                 |                                    |                              | 0: Weak        | 0: Weak        |
| EMCCR1  | Bit symbol  |              |                |                 |                 |                                    |                              |                |                |
| (00E4H) | Read/Write  |              |                |                 |                 |                                    |                              |                |                |
|         | After reset |              | Cwitch         | ing the protoco |                 | urita ta fallowin                  |                              |                |                |
|         | Function    |              |                | 0 1             | ,               | write to followii<br>CCR2 = A5H ir | 0                            |                |                |
| EMCCR2  | Bit symbol  |              |                |                 | ,               | CR2 = A5H ii<br>CCR2 = 5AH ii      |                              |                |                |
| (00E5H) | Read/Write  |              | 2110-          |                 | τ - Αστι, Εινικ | 50NZ - 5ATTI                       | 1 SUCCESSION N               | VIILE          |                |
|         | After reset |              |                |                 |                 |                                    |                              |                |                |
|         | Function    |              |                |                 |                 |                                    |                              |                |                |
| EMCCR3  | Bit symbol  | /            | ENFROM         | ENDROM          | ENPROM          |                                    | FFLAG                        | DFLAG          | PFLAG          |
| (00E6H) | Read/Write  | /            | R/W            | R/W             | R/W             |                                    | R/W                          | R/W            | R/W            |
|         | After reset | /            | 0              | 0               | 0               |                                    | 0                            | 0              | 0              |
|         | Function    |              | CS1A area      | CS2B-2G         | CS2A area       |                                    | CS1A write                   | CS2B-2G write  | CS2A write     |
|         |             |              | detect control | area detect     | detect control  |                                    | operation flag               | operation flag | operation flag |
|         |             |              | 0: Disable     | control         | 0: Disable      |                                    | When reading                 |                |                |
|         |             |              | 1: Enable      | 0: Disable      | 1: Enable       |                                    | 0: Not written<br>1: Written |                |                |
|         |             |              |                | 1: Enable       |                 |                                    | When writing                 |                |                |
|         |             |              |                |                 |                 |                                    | 0: Clear flag                |                |                |

Note1: In case restarting the oscillator in the stop oscillation state (e.g. Restart the oscillator in STOP mode), set EMCCR0<DRVOSCH>, <DRVOSCL>="1".

Note2: In case of Vcc = 2 V  $\pm$  10% use, fixed to EMCCR0<DRVOSCH> = 1.

Figure 3.3.5 SFR for Noise Reduction

#### 3.3.3 System Clock Controller

The system clock controller generates the system clock signal (f<sub>SYS</sub>) for the CPU core and internal I/O. It contains two oscillation circuits and a clock gear circuit for highfrequency (fc) operation. The register SYSCR1<SYSCK> changes the system clock to either fc or fs, SYSCR0<XEN> and SYSCR0<XTEN> control enabling and disabling of each oscillator, and SYSCR1<GEAR0:2> sets the high-frequency clock gear to either 1, 2, 4, 8 or 16 (fc, fc/2, fc/4, fc/8 or fc/16). These functions can reduce the power consumption of the equipment in which the device is installed.

The combination of settings  $\langle XEN \rangle = 1$ ,  $\langle XTEN \rangle = 0$ ,  $\langle SYSCK \rangle = 0$  and  $\langle GEAR0:2 \rangle = 100$  will cause the system clock (f<sub>SYS</sub>) to be set to fc/32 (fc/16 × 1/2) after a reset.

For example, f<sub>SYS</sub> is set to 1.03 MHz when the 33-MHz oscillator is connected to the X1 and X2 pins.

(1) Switching from NORMAL mode to SLOW mode

When the resonator is connected to the X1 and X2 pins, or to the XT1 and XT2 pins, the warm-up timer can be used to change the operation frequency after stable oscillation has been attained.

The warm-up time can be selected using SYSCR2<WUPTM0:1>.

This warm-up timer can be programmed to start and stop as shown in the following examples 1 and 2.

Table 3.3.1 shows the warm-up time.

- Note 1: When using an oscillator (other than a resonator) with stable oscillation, a warmup timer is not needed.
- Note 2: The warm-up timer is operated by an oscillation clock. Hence, there may be some variation in warm-up time.

| Warm-up Time<br>SYSCR2<br><wuptm1:0></wuptm1:0> | Change to<br>NORMAL Mode | Change to<br>SLOW Mode |                                |
|-------------------------------------------------|--------------------------|------------------------|--------------------------------|
| 01 (2 <sup>8</sup> /frequency)                  | 8 (μs)                   | 7.8 (ms)               | at f <sub>OSCH</sub> = 33 MHz, |
| 10 (2 <sup>14</sup> /frequency)                 | 0.496 (ms)               | 500 (ms)               | fs = 32.768 kHz                |
| 11 (2 <sup>16</sup> /frequency)                 | 1.986 (ms)               | 2000 (ms)              |                                |

Table 3.3.1 Warm-up Times





Changing from low frequency (fs) to high frequency (fc).



(2) Clock gear controller

When the high-frequency clock fc is selected by setting SYSCR1<SYSCK> = 0, fFPH is set according to the contents of the clock gear select register SYSCR1<GEAR0:2> to either fc, fc/2, fc/4, fc/8 or fc/16. Using the clock gear to select a lower value of fFPH reduces power consumption.

Example 3:

Changing to a high-frequency gear

| SYSCR1       | EQU | 00E1H              |                                     |
|--------------|-----|--------------------|-------------------------------------|
|              | LD  | (SYSCR1),XXXX0000B | ; Changes f <sub>SYS</sub> to fc/2. |
| X: Don't car | е   |                    |                                     |

(High-speed clock gear changing)

To change the clock gear, write the register value to the SYSCR1<GEAR2:0> register. It is necessary the warm-up time until changing after writing the register value.

There is the possibility that the instruction next to the clock gear changing instruction is executed by the clock gear before changing. To execute the instruction next to the clock gear switching instruction by the clock gear after changing, input the dummy instruction as follows (Instruction to execute the write cycle).

Example:

| Example. |            |                               |     |                                   |
|----------|------------|-------------------------------|-----|-----------------------------------|
| SYSCR1   | EQU        | 00E1H                         |     |                                   |
|          | LD         | (SYSCR1),XXXX0001B            | ;   | Changes f <sub>SYS</sub> to fc/4. |
|          | LD         | (DUMMY), 00H                  | ;   | Dummy instruction                 |
|          | Instructio | on to be executed after clock | gea | r has changed                     |

(3) Internal clock terminal out function

It can out internal clock (f<sub>SYS</sub> or fs) from PD5/SCOUT.

PD5 pin function is set to SCOUT output by the following bit setting.

: PDFC < PD5F > = 1

Output clock select

: Refer to SYSCR2<SCOSEL> bit setting

| HALT Mode             | NORMAL                     |       | HALT Mode |         |
|-----------------------|----------------------------|-------|-----------|---------|
| SCOUT Select          | SLOW                       | IDLE2 | IDLE1     | STOP    |
| <scosel> = 0</scosel> | fs clock out               |       |           |         |
| <scosel> = 1</scosel> | f <sub>SYS</sub> clock out |       | 0 or 1    | fix out |

#### 3.3.4 Prescaler Clock Controller

For the internal I/O (TMRA01 to TMRA23, SIO0 to SIO1) there is a prescaler which can divide the clock.

The  $\phi$ T0 clock input to the prescaler is either the clock fFPH divided by 4 or the clock fc/16 divided by 4. The setting of the SYSCR0<PRCK0:1> register determines which clock signal is input.

#### 3.3.5 Clock Doubler (DFM)

DFM outputs the  $f_{DFM}$  clock signal, which is four times as fast as  $f_{OSCH}$ . It can use the low-frequency oscillator, even though the internal clock is high frequency.

A reset initializes DFM to stop status, setting to DFMCR0 register is needed before use.

Like an oscillator, this circuit requires time to stabilize. This is called the lockup time.

The following example shows how DFM is used.



Note: Input frequency limitation and correction for DFM

Recommend to use input frequency (High-speed oscillation) for DFM in the following condition.

 $f_{OSCH} = 4$  to 8.25 MHz (Vcc = 2.7 V to 3.6 V): Write 0BH to DFMCR1

 $f_{OSCH}$  = 2 to 2.5 MHz (Vcc = 2.0 V  $\pm$  10%): Write 1BH to DFMCR1

Limitation point on the use of DFM

- 1. it's prohibited to execute DFM enable/disable control in the SLOW mode (fs). You should control DFM in the NORMAL mode.
- 2. If you stop DFM operation during using DFM (DFMCR0<ACT1:0> = "10"), you shouldn't execute the commands that change the clock fDFM to fOSCH and stop the DFM at the same time. Therefore the above execution should be separated into two procedures as showing below.
  - LD (DFMCR0), C0H ; Change the clock f<sub>DFM</sub> to f<sub>OSCH</sub>
  - LD (DFMCR0), 00H
- 3. If you stop high-frequency oscillator during using DFM (DFMCR0<ACT1:0> = "10"), you should stop DFM before you stop high-frequency oscillator.

DFM stop

4. More than 1 ms of interval time is required from stop of DFM to the next start up of DFM.

Examples of settings are below.

(1) Start up control

#### (OK) Low-frequency oscillator operation mode (fs) (High-frequency oscillator STOP)

 $\rightarrow$  High-frequency oscillator start up  $\rightarrow$  High-frequency oscillator operation mode (f<sub>OSCH</sub>)  $\rightarrow$  DFM start up  $\rightarrow$  DFM use mode (f<sub>DFM</sub>)

|      | LD  | (SYSCR0), 111B  | ; High-frequency oscillator start up/warm-up start |
|------|-----|-----------------|----------------------------------------------------|
| WUP: | BIT | 2, (SYSCR0)     | ; Check for the flag of warm-up end                |
|      | JR  | NZ, WUP         | ; Check for the hag of warm-up end                 |
|      | LD  | (SYSCR1),0B     | ; Change the system clock fs to fOSCH              |
|      | LD  | (DFMCR0), 01-0B | ; DFM start up/lockup start                        |
| LUP: | BIT | 5, (DFMCR0)     | ; Check for the flog of lookup and                 |
|      | JR  | NZ, LUP         | ; Check for the flag of lockup end                 |
|      | LD  | (DFMCR0), 10-0B | ; Change the system clock fOSCH to fDFM            |
|      |     |                 |                                                    |

(OK) Low-frequency oscillator operation mode (fs) (High-frequency oscillator operate)

 $\rightarrow$  High-frequency oscillator operation mode (fosch)  $\rightarrow$  DFM start up  $\rightarrow$  DFM use mode (form)

|      | LD  | (SYSCR1),0B     | ; Change the system clock fs to fOSCH   |
|------|-----|-----------------|-----------------------------------------|
|      | LD  | (DFMCR0), 01-0B | ; DFM start up/lockup start             |
| LUP: | BIT | 5, (DFMCR0)     | ;<br>Check for the flag of lockup end   |
|      | JR  | NZ, LUP         | ; J                                     |
|      | LD  | (DFMCR0), 10-0B | ; Change the system clock fOSCH to fDFM |
|      |     |                 |                                         |

(Error) Low-frequency oscillator operation mode (fs) (High-frequency oscillator STOP)  $\rightarrow$  High-frequency oscillator start up  $\rightarrow$  DFM start up  $\rightarrow$  DFM use mode (f<sub>DFM</sub>)

| WUP: | LD<br>BIT<br>JR<br>LD | (SYSCR0), 111B<br>2, (SYSCR0)<br>NZ, WUP<br>(DFMCR0), 01-0B | ; High-frequency oscillator start up/warm-up start<br>; Check for the flag of warm-up end<br>; DFM start up/lockup start                                                    |
|------|-----------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LUP: | BIT<br>JR<br>LD<br>LD | 5, (DFMCR0)<br>NZ, LUP<br>(DFMCR0), 10-0B<br>(SYSCR1),0B    | <ul> <li>Check for the flag of lockup end</li> <li>Change the clock f<sub>OSCH</sub> to f<sub>DFM</sub></li> <li>Change the internal clock fs to f<sub>DFM</sub></li> </ul> |

(2) Change/stop control

(OK) DFM use mode ( $f_{DFM}$ )  $\rightarrow$  High-frequency oscillator operation mode ( $f_{OSCH}$ )  $\rightarrow$  DFM stop  $\rightarrow$  Low-frequency oscillator operation mode (fs)  $\rightarrow$  High-frequency oscillator stop

| LD | (DFMCR0), 11B | ; | Change the system clock fDFM to fOSCH |
|----|---------------|---|---------------------------------------|
| LD | (DFMCR0), 00B | ; | DFM stop                              |
| LD | (SYSCR1),1B   | ; | Change the system clock fOSCH to fs   |
| LD | (SYSCR0), 0B  | ; | High-frequency oscillator stop        |

(Error) DFM use mode (f<sub>DFM</sub>)  $\rightarrow$  Low-frequency oscillator operation mode (fs)  $\rightarrow$  DFM stop  $\rightarrow$  High-frequency oscillator stop

| LD | (SYSCR1),1B   | ; | Change the system clock fDFM to fs                                   |
|----|---------------|---|----------------------------------------------------------------------|
| LD | (DFMCR0), 11B | ; | Change the internal clock (fc) $f_{\mbox{DFM}}$ to $f_{\mbox{OSCH}}$ |
| LD | (DFMCR0), 00B | ; | DFM stop                                                             |
| LD | (SYSCR0), 0B  | ; | High-frequency oscillator stop                                       |
|    | ( ),          | , | 1                                                                    |

(OK) DFM use mode ( $f_{DFM}$ )  $\rightarrow$  Set the STOP mode  $\rightarrow$  High-frequency oscillator operation mode ( $f_{OSCH}$ )  $\rightarrow$  DFM stop  $\rightarrow$  HALT (High-frequency oscillator stop)

| LD   | (SYSCR2),01B  | ; | Set the STOP mode                            |
|------|---------------|---|----------------------------------------------|
|      |               |   | (This command can execute before use of DFM) |
| LD   | (DFMCR0), 11B | ; | Change the system clock fDFM to fOSCH        |
| LD   | (DFMCR0), 00B | ; | DFM stop                                     |
| HALT |               | ; | Shift to STOP mode                           |

(Error) DFM use mode (fDFM)  $\rightarrow$  Set the STOP mode  $\rightarrow$  HALT (High-frequency oscillator stop)

| LD   | (SYSCR2),01B | ; | Set the STOP mode                            |
|------|--------------|---|----------------------------------------------|
|      |              |   | (This command can execute before use of DFM) |
| HALT |              | ; | Shift to STOP mode                           |

#### 3.3.6 Noise Reduction Circuits

Noise reduction circuits are built in, allowing implementation of the following features.

- (1) Reduced drivability for high-frequency oscillator
- (2) Reduced drivability for low-frequency oscillator
- (3) Single drive for high-frequency oscillator
- (4) SFR protection of register contents
- (5) ROM protection of register contents
- (1) Reduced drivability for high-frequency oscillator
  - (Purpose)

Reduces noise and power for oscillator when a resonator is used.

(Block diagram)



(Setting method)

The drivability of the oscillator is reduced by writing 0 to EMCCR0<DRVOSCH> register. By reset, <DRVOSCH> is initialized to 1 and the oscillator starts oscillation by normal-drivability when the power supply is on.

Don't set  $\langle DRVOSCH \rangle$  to 0 at Vcc = 2 V  $\pm$  10%.

(2) Reduced drivability for low-frequency oscillator

#### (Purpose)

Reduces noise and power for oscillator when a resonator is used.

(Block diagram)



(Setting method)

The drivability of the oscillator is reduced by writing 0 to the EMCCR0 <DRVOSCL> register. By reset, <DRVOSCL> is initialized to 1.

(3) Single drive for high-frequency oscillator

#### (Purpose)

Not need twin-drive and protect mistake operation by inputted noise to X2 pin when the external-oscillator is used.



(Setting method)

The oscillator is disabled and starts operation as buffer by writing 1 to EMCCR0<EXTIN> register. X2 pin is always outputted 1.

By reset, <EXTIN> is initialized to 0.

Note: Do not write EMCCR0<EXTIN> = "1" when using external resonator.

(4) Runaway provision with SFR protection register

(Purpose)

Provision in runaway of program by noise mixing.

Write operation to specified SFR is prohibited so that provision program in runaway prevents that it is it in the state which is fetch impossibility by stopping of clock, memory control register (CS/WAIT controller, MMU) is changed.

And error handling in runaway becomes easy by INTP0 interruption.

Specified SFR list

| 1. | CS/WAIT controller                                 |
|----|----------------------------------------------------|
|    | B0CS, B1CS, B2CS, B3CS, BEXCS,                     |
|    | MSAR0, MSAR1, MSAR2, MSAR3,                        |
|    | MAMR0, MAMR1, MAMR2, MAMR3                         |
| 2. | MMU                                                |
|    | LOCAL0/1/2/3                                       |
| 3. | Clock gear (only EMCCR1, EMCCR2 can be written to) |
|    | SYSCR0, SYSCR1, SYSCR2, EMCCR0, EMCCR3             |
| 4. | DFM                                                |
|    | DFMCR0, DFMCR1                                     |

#### (Operation explanation)

Execute and release of protection (write operation to specified SFR) become possible by setting up a double key to EMCCR1 and EMCCR2 register.

(Double key)

1st-KEY: Succession writes in 5AH at EMCCR1 and A5H at EMCCR2 2nd-KEY: Succession writes in A5H at EMCCR1 and 5AH at EMCCR2

A state of protection can be confirmed by reading EMCCR0<PROTECT>.

By reset, protection becomes OFF.

And INTPO interruption occurs when write operation to specified SFR was executed with protection ON state.

(5) Runaway provision with ROM protection register

(Purpose)

Provision in runaway of program by noise mixing.

(Operation explanation)

When write operation was executed for external three kinds of ROM by runaway of program, INTP1 is occurred and detects runaway function.

Three kinds of ROM is fixed as for flash ROM (Option program ROM), data ROM, program ROM are as follows on the logical address memory map.

- 1. Flash ROM: Address 400000H to 7FFFFFH
- 2. Data ROM: Address 800000H to BFFFFFH
- 3. Program ROM: Address C00000H to FFFFFFH

For these address, admission/prohibition of detection of write operation sets it up with EMCCR3<ENFROM, ENDROM, ENPROM>. And INTP1 interruption occurred within which ROM can confirm each with EMCCR3<FFLAG, DFLAG, PFLAG>. This flag is cleared when write in 0.

#### 3.3.7 Standby Controller

(1) HALT modes

When the HALT instruction is executed, the operating mode switches to IDLE2, IDLE1 or STOP mode, depending on the contents of the SYSCR2<HALTM1:0> register.

The subsequent actions performed in each mode are as follows:

a. IDLE2: Only the CPU halts.

The internal I/O is available to select operation during IDLE2 mode. By setting the following register.

Table 3.3.2 shows the registers of setting operation during IDLE2 mode.

| • 1          | <b>.</b>                  |
|--------------|---------------------------|
| Internal I/O | SFR                       |
| TMRA01       | TA01RUN <i2ta01></i2ta01> |
| TMRA23       | TA23RUN <i2ta23></i2ta23> |
| SIO0         | SC0MOD1 <i2s0></i2s0>     |
| SIO1         | SC1MOD1 <i2s1></i2s1>     |
| AD converter | ADMOD1 <i2ad></i2ad>      |
| WDT          | WDMOD <i2wdt></i2wdt>     |
| SBI          | SBI0BR0 <i2sbi0></i2sbi0> |

Table 3.3.2 SFR Seting Operation during IDLE2 Mode

- b. IDLE1: Only the oscillator and the RTC (Real time clock) and MLD continue to operate.
- c. STOP: All internal circuits stop operating.

The operation of each of the different HALT modes is described in Table 3.3.3.

| HALT Mode                    |              | IDLE2                                                     | IDLE1               | STOP        |  |
|------------------------------|--------------|-----------------------------------------------------------|---------------------|-------------|--|
| SYSCR2 <haltm1:0></haltm1:0> |              | 11                                                        | 10                  | 01          |  |
| CPU                          |              | Stop                                                      |                     |             |  |
|                              | I/O ports    | Keep the state when the HALT<br>instruction was executed. | See Table 3.3.6,    | Table 3.3.7 |  |
| Diask                        | TMRA         |                                                           | Stop                |             |  |
| Block                        | SIO, SBI     | Available to estart                                       |                     |             |  |
|                              | AD converter | Available to select<br>operation block                    |                     |             |  |
|                              | WDT          | operation block                                           |                     |             |  |
|                              | RTC, MLD     |                                                           | Possible to operate |             |  |

Table 3.3.3 I/O Operation during HALT Modes

(2) How to release the HALT mode

These halt states can be released by resetting or requesting an interrupt. The HALT release sources are determined by the combination between the states of interrupt mask register <IFF2:0> and the HALT modes. The details for releasing the halt status are shown in Table 3.3.4.

• Released by requesting an interrupt

The operating released from the HALT mode depends on the interrupt enabled status. When the interrupt request level set before executing the HALT instruction exceeds the value of interrupt mask register, the interrupt due to the source is processed after releasing the HALT mode, and CPU status executing an instruction that follows the HALT instruction. When the interrupt request level set before executing the HALT instruction is less than the value of the interrupt mask register, releasing the HALT mode is not executed. (In non-maskable interrupts, interrupt processing is processed after releasing the HALT mode regardless of the value of the mask register.) However only for INT0 to INT3 and INTRTC and INTALM interrupts, even if the interrupt request level set before executing the HALT mode is executed. In this case, interrupt processing, and CPU starts executing the instruction next to the HALT instruction, but the interrupt request flag is held at 1.

Note: Usually, interrupts can release all halts status. However, the interrupts ( $\overline{\text{NMI}}$ , INT0 to INT3, INTRTC, INTALM0 to INTALM4) which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 5 clocks of f<sub>FPH</sub>) with IDLE1 or STOP mode (IDLE2 is not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficulty. The priority of this interrupt is compared with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

• Releasing by resetting

Releasing all halt status is executed by resetting.

When the STOP mode is released by reset, it is necessry enough resetting time (See Table 3.3.5) to set the operation of the oscillator to be stable.

When releasing the HALT mode by resetting, the internal RAM data keeps the state before the HALT instruction is executed. However the other settings contents are initialized. (Releasing due to interrupts keeps the state before the HALT instruction is executed.)

| Status of Received Interrupt      |           | atus of Received Interrupt   | Interrupt Enabled<br>(Interrupt level) ≥ (Interrupt mask) |       | Interrupt Disabled<br>(Interrupt level) < (Interrupt mask) |       |       |      |
|-----------------------------------|-----------|------------------------------|-----------------------------------------------------------|-------|------------------------------------------------------------|-------|-------|------|
| HALT Mode                         |           | HALT Mode                    | IDLE2                                                     | IDLE1 | STOP                                                       | IDLE2 | IDLE1 | STOP |
| e                                 |           | NMI                          | •                                                         | •     | *1                                                         | _     | -     | -    |
| Clearance                         |           | INTWDT                       | •                                                         | ×     | ×                                                          | -     | -     | -    |
| lea                               |           | INT0 to INT3 (Note 1)        | •                                                         | •     | *1                                                         | 0     | 0     | °1   |
| e C                               | ht        | INTALM0 to INTALM4           | •                                                         | •     | ×                                                          | 0     | 0     | ×    |
| State                             | Interrupt | INTTA0 to INTTA3             | •                                                         | ×     | ×                                                          | ×     | ×     | ×    |
| Halt \$                           | lnt       | INTRX0 to INTRX1, TX0 to TX1 | •                                                         | ×     | ×                                                          | ×     | ×     | ×    |
| of H                              |           | INTAD                        | •                                                         | ×     | ×                                                          | ×     | ×     | ×    |
|                                   |           | INTRTC                       | •                                                         | •     | ×                                                          | 0     | 0     | ×    |
| Source                            |           | INTSBI                       | •                                                         | ×     | ×                                                          | ×     | ×     | ×    |
| й RESET Reset initializes the LSI |           |                              |                                                           |       |                                                            |       |       |      |

Table 3.3.4 Source of Halt State Clearance and Halt Clearance Operation

- •: After clearing the HALT mode, CPU starts interrupt processing.
- •: After clearing the HALT mode, CPU resumes executing starting from instruction following the HALT instruction.
- ×: It can not be used to release the HALT mode.
- -: The priority level (Interrupt request level) of non-maskable interrupts is fixed to 7, the highest priority level. There is not this combination type.
- \*1: Releasing the HALT mode is executed after passing the warm-up time.
- Note: When the HALT mode is cleared by an INT0 interrupt of the level mode in the interrupt enabled status, hold level "H" until starting interrupt processing. If level "L" is set before holding level "L", interrupt processing is correctly started.

(Example: Clearing IDLE1 mode)

An INTO interrupt clears the halt state when the device is in IDLE1 mode.



(3) Operation

a. IDLE2 mode

In IDLE2 mode only specific internal I/O operations, as designated by the IDLE2 setting register, can take place. Instruction execution by the CPU stops.

Figure 3.3.6 illustrates an example of the timing for clearance of the IDLE2 mode halt state by an interrupt.



Figure 3.3.6 Timing Chart for IDLE2 Mode Halt State Cleared by Interrupt

#### b. IDLE1 mode

In IDLE1 mode, only the internal oscillator and the RTC, MLD continue to operate. The system clock in the MCU stops. The pin status in the IDLE1 mode is depended on setting the register SYSCR2<SELDRV, DRVE>. Table 3.3.6, Table 3.3.7 summarizes the state of these pins in the IDLE mode1.

In the halt state, the interrupt request is sampled asynchronously with the system clock; however, clearance of the halt state (e.g., restart of operation) is synchronous with it.

Figure 3.3.7 illustrates the timing for clearance of the IDLE1 mode halt state by an interrupt.



Figure 3.3.7 Timing Chart for IDLE1 Mode Halt State Cleared by Interrupt

#### c. STOP mode

When STOP mode is selected, all internal circuits stop, including the internal oscillator pin status in STOP mode depends on the settings in the SYSCR2<DRVE> register. Table 3.3.6, Table 3.3.7 summarizes the state of these pins in STOP mode.

After STOP mode has been cleared system clock output starts when the warm-up time has elapsed, in order to allow oscillation to stabilize. After STOP mode has been cleared, either NORMAL mode or SLOW mode can be selected using the SYSCR0<RSYSCK> register. Therefore, <RSYSCK>, <RXEN> and <RXTEN> must be set See the sample warm-up times in Table 3.3.5.

Figure 3.3.8 illustrates the timing for clearance of the STOP mode halt state by an interrupt.



Figure 3.3.8 Timing Chart for STOP Mode Halt State Cleared by Interrupt

|                   |                              | at f <sub>OS</sub>    | <sub>SCH</sub> = 33 MHz, fs = 32.768 kHz |  |  |
|-------------------|------------------------------|-----------------------|------------------------------------------|--|--|
| SYSCR0            | SYSCR2 <wuptm1:0></wuptm1:0> |                       |                                          |  |  |
| <rsysck></rsysck> | 01 (2 <sup>8</sup> )         | 10 (2 <sup>14</sup> ) | 11 (2 <sup>16</sup> )                    |  |  |
| 0 (fc)            | 8 μs                         | 0.496 ms              | 1.986 ms                                 |  |  |
| 1 (fs)            | 7.8 ms                       | 500 ms                | 2000 ms                                  |  |  |

| Table 3.3.5 | Sample Warm-up | Times after | Clearance of STOP Mode |
|-------------|----------------|-------------|------------------------|
|-------------|----------------|-------------|------------------------|

#### Example:

The STOP mode is entered when the low-frequency operates, and high-frequency operates after releasing due to NMI.



Note: When different modes are used before and after STOP mode as the above mentioned, there is possible to release the HALT mode without changing the operation mode by acceptance of the halt release interrupt request during execution of HALT instruction (during 6 states). In the system which accepts the interrupts during execution HALT instruction, set the same operation mode before and after the STOP mode.

|              |                  |                 |                                 |                               | Inpu                               | Input Buffer State            |                                    |                               |                                 |                               |  |    |  |
|--------------|------------------|-----------------|---------------------------------|-------------------------------|------------------------------------|-------------------------------|------------------------------------|-------------------------------|---------------------------------|-------------------------------|--|----|--|
|              |                  | -               | When the                        | e CPU is                      |                                    |                               |                                    | n HALT mod                    | le(IDLE1/STC                    | P)                            |  |    |  |
| Dort         | Input            |                 | opera                           | ating                         | In HALT mo                         | ode(IDLE2)                    |                                    | n A (Note)                    | Condition B (Note)              |                               |  |    |  |
| Port<br>Name | Function<br>Name | During<br>Reset | When Used<br>as function<br>Pin | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin | When<br>Used as<br>Input Port | When Used<br>as function<br>Pin | When<br>Used as<br>Input Port |  |    |  |
| D0-D7        | -                | 055             | ON upon                         | _                             | 055                                | _                             |                                    | _                             | 055                             | -                             |  |    |  |
| P10-P17      | D8-D15           | OFF             | external read                   |                               | OFF                                | OFF                           | OFF                                |                               | OFF                             | OFF                           |  |    |  |
| P54(*1)      | BUSRQ            | ON              | ON                              | ON                            | ON                                 | ON                            |                                    | OFF                           | ON                              | ON                            |  |    |  |
| P55(*1)      | _                | OFF             | -                               |                               | -                                  | OFF                           | -                                  |                               | -                               | OFF                           |  |    |  |
| P56(*1)      | WAIT             |                 |                                 |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| D70          | SCK              |                 |                                 |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| P70          | OPTRX0           | ON              | ON                              | ON                            | ON                                 | ON                            | OFF                                | OFF                           | ON                              | ON                            |  |    |  |
| P71(*1)      | SDA              | ON              | ON                              | ON                            | ON                                 | ON                            |                                    |                               | ON                              | ON                            |  |    |  |
| P72(*1)      | SI<br>SCL        |                 |                                 |                               |                                    | ON                            | ON                                 |                               |                                 |                               |  |    |  |
| P80-P82(*2)  | _                | OFF             | -                               |                               | -                                  |                               | -                                  | _                             | -                               |                               |  |    |  |
| P83(*2)      | ADTRG            |                 | ON                              | ON upon                       | ON                                 | OFF                           | ON                                 |                               | ON                              | OFF                           |  |    |  |
| P84-P87(*2)  | _                |                 | -                               | port read                     | -                                  |                               | -                                  | 055                           | -                               |                               |  |    |  |
| PB0          | TAOIN            |                 | ON                              |                               | ON                                 |                               | OFF                                | OFF                           | ON                              |                               |  |    |  |
| PB1          | _                |                 | _                               |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| PB2          | _                | ON              | _                               |                               | -                                  | ON                            | -                                  |                               | -                               | ON                            |  |    |  |
| PB3          | INT0             |                 |                                 |                               |                                    |                               | ON                                 | ON                            | -                               |                               |  |    |  |
| PB4          | INT1             | OFF             | OFF                             |                               |                                    |                               |                                    | ON                            |                                 |                               |  | ON |  |
| PB5          | INT2             |                 |                                 | ON                            |                                    | ON                            | OFF                                | ON                            | ON                              | OFF                           |  |    |  |
| PB6          | INT3             |                 |                                 |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| PC0          | -                |                 | -                               |                               | -                                  |                               | -                                  |                               | -                               |                               |  |    |  |
| PC1          | RXD0             |                 |                                 | ON                            |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| PC2          | SCLK0            |                 | ON                              |                               | ON                                 |                               | OFF                                |                               | ON                              |                               |  |    |  |
| 1.02         | CTS0             | ON              |                                 |                               |                                    | ON                            |                                    | OFF                           |                                 | ON                            |  |    |  |
| PC3          | -                |                 | -                               |                               | -                                  |                               | -                                  |                               | -                               |                               |  |    |  |
| PC4          | RXD1             |                 |                                 |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| PC5          | SCLK1            |                 | ON                              |                               | ON                                 |                               | OFF                                |                               | ON                              |                               |  |    |  |
|              | CTS1             |                 |                                 |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| PZ2(*1)      | -                | OFF             | -                               |                               | -                                  | OFF                           | -                                  |                               | -                               | OFF                           |  |    |  |
| PZ3(*1)      | -                |                 |                                 |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| NMI          | -                |                 |                                 |                               |                                    |                               |                                    |                               |                                 |                               |  |    |  |
| RESET        | -                | ON              | ON ON                           | _                             | ON                                 | -                             | ON                                 | _                             | ON                              | -                             |  |    |  |
| AM0,AM1      | -                |                 |                                 |                               |                                    |                               | <u> </u>                           |                               |                                 |                               |  |    |  |
| X1,XT1       | -                |                 |                                 |                               |                                    |                               |                                    | IDLE1 : ON                    | I, STOP : OFF                   |                               |  |    |  |

Table 3.3.6 Input Buffer State Table

ON: The buffer is always turned on. A current flows the \*1: Port having a pull-up/pull-down resistor.

 $\ensuremath{^{\ast}2^{\circ}}$  AIN input does not cause a current to flow through the buffer.

input buffer if the input pin is not driven. OFF: The buffer is always turned off.

-: No applicable

Note: Condition A/B are as follows.

| SYSCR2 re     | egister setting   | HALT mode   |             |  |  |  |
|---------------|-------------------|-------------|-------------|--|--|--|
| <drve></drve> | <seldrv></seldrv> | IDLE1       | STOP        |  |  |  |
| 0             | 0                 | Condition B | Condition A |  |  |  |
| 0             | 1                 | Condition A | Condition A |  |  |  |
| 1             | 0                 | Canditian D | Condition D |  |  |  |
| 1             | 1                 | Condition B | Condition B |  |  |  |

|         |                 |        |          |          | Outr       | out Buffer S | State                     |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
|---------|-----------------|--------|----------|----------|------------|--------------|---------------------------|--------------|----------------|------------|----|--|--|--|--|--|--|--|--|--|--|
|         |                 |        | When the | e CPU is |            |              | In HALT mode (IDLE1/STOP) |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| Port    | Output          |        | Oper     |          | In HALI mo | ode(IDLE2)   | Conditior                 |              |                | n B (Note) |    |  |  |  |  |  |  |  |  |  |  |
| Name    | Function        | During | When     | When     | When       | When         | When                      | When         | When           | When       |    |  |  |  |  |  |  |  |  |  |  |
| Itanio  | Name            | Reset  | Used as  | Used as  | Used as    | Used as      | Used as                   | Used as      | Used as        | Used as    |    |  |  |  |  |  |  |  |  |  |  |
|         |                 |        | function | Output   | function   | Output       | function                  | Output       | function       | Output     |    |  |  |  |  |  |  |  |  |  |  |
|         |                 |        | Pin      | Port     | Pin        | Port         | Pin                       | Port         | Pin            | Port       |    |  |  |  |  |  |  |  |  |  |  |
| D0-D7   | -               |        | ON upon  | -        |            | -            |                           | -            |                | -          |    |  |  |  |  |  |  |  |  |  |  |
| P10-P17 | D8-15           | OFF    | OFF      | external |            | OFF          |                           |              |                | OFF        |    |  |  |  |  |  |  |  |  |  |  |
|         |                 |        | write    | ON       |            | ON           |                           | OFF          |                | ON         |    |  |  |  |  |  |  |  |  |  |  |
| P20-P27 | A16-23          |        |          |          |            |              | OFF                       |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| A0-A15  | -               | ON     | ON       |          | ON         |              |                           |              | ON             |            |    |  |  |  |  |  |  |  |  |  |  |
| RD      | -               |        |          | -        |            | -            |                           | -            |                | -          |    |  |  |  |  |  |  |  |  |  |  |
| WR      | -               |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P54(*1) | -               |        | -        |          | -          |              | -                         |              | -              |            |    |  |  |  |  |  |  |  |  |  |  |
| P55(*1) | BUSAK           | OFF    | ON       |          | ON         |              | OFF                       |              | ON             |            |    |  |  |  |  |  |  |  |  |  |  |
| P56(*1) | -               |        | -        |          | -          |              | -                         |              | -              |            |    |  |  |  |  |  |  |  |  |  |  |
| P60     | CS0             |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P61     | CS1             |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P62     | CS2, CS2A       |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P63     | CS3             |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P64     | EA24<br>CS2B    | ON     |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P65     | EA25            |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
|         | CS2C            |        | ON       |          | ON         |              | OFF                       |              | ON             |            |    |  |  |  |  |  |  |  |  |  |  |
| P66     | CS2D            |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P67     | CS2E            |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P70     | SCK             |        |          |          |            | l            |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| D74/*4) | SDA<br>SO       |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P71(*1) | OPTTX0          |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| P72(*1) | SCL             |        |          |          | ON         |              | ON                        | OFF          | OFF            |            | ON |  |  |  |  |  |  |  |  |  |  |
| PB0     | _               |        | _        |          | _          |              | _                         |              | _              |            |    |  |  |  |  |  |  |  |  |  |  |
| PB1     | TA1OUT          |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| PB2     | TA3OUT          | OFF    | ON       |          | ON         |              | OFF                       |              | ON             |            |    |  |  |  |  |  |  |  |  |  |  |
| PB3-PB6 | _               |        | _        |          | -          | 1            | _                         |              | -              | 1          |    |  |  |  |  |  |  |  |  |  |  |
| PC0     | TXD0            |        | ON       |          | ON         | ]            | OFF                       |              | ON             | ]          |    |  |  |  |  |  |  |  |  |  |  |
| PC1     | -               |        | -        |          | -          |              | -                         |              | -              |            |    |  |  |  |  |  |  |  |  |  |  |
| PC2     | SCLK0           |        | ON       |          | ON         |              | OFF                       |              | ON             |            |    |  |  |  |  |  |  |  |  |  |  |
| PC3     | TXD1            |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| PC4     | -               |        | -        |          | -          |              | -                         |              | -              |            |    |  |  |  |  |  |  |  |  |  |  |
| PC5     | SCLK1           |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| PD5     | SCOUT           |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| PD6     | ALARM<br>MLDALM | ON     | ON       |          |            |              | OFF                       |              | ON             |            |    |  |  |  |  |  |  |  |  |  |  |
| PD7     | MLDALM          |        | ON       |          | ON         |              | UFF                       |              | UN             |            |    |  |  |  |  |  |  |  |  |  |  |
| PZ2(*1) | HWR             |        |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| PZ3(*1) | R/W             | OFF    |          |          |            |              |                           |              |                |            |    |  |  |  |  |  |  |  |  |  |  |
| X2      | _               |        | 1        |          | 1          |              | IDLE                      | 1 : ON . STO | P : output "H" | level      |    |  |  |  |  |  |  |  |  |  |  |
| ~~~     |                 | ON     | 1        |          | 1          | -            |                           | IDLE1 : ON , |                |            |    |  |  |  |  |  |  |  |  |  |  |

Table 3.3.7 Output buffer State Table

ON: The buffer is always turned on. When the bus is \*1: Port having a pull-up/pull-down resistor. released, however, output buffers for some pins are

turned off.

OFF: The buffer is always turned off. -: No applicable

Note: Condition A/B are as follows.

| Note. Condition A/D are as follows. |                   |             |             |  |  |  |
|-------------------------------------|-------------------|-------------|-------------|--|--|--|
| SYSCR2 re                           | egister setting   | HALT        | mode        |  |  |  |
| <drve></drve>                       | <seldrv></seldrv> | IDLE1       | STOP        |  |  |  |
| 0                                   | 0                 | Condition B | Condition A |  |  |  |
| 0                                   | 1                 | Condition A | Condition A |  |  |  |
| 1                                   | 0                 |             |             |  |  |  |
| 1                                   | 1                 | Condition B | Condition B |  |  |  |

## 3.4 Interrupts

Interrupts are controlled by the CPU interrupt mask register SR<IFF2:0> and by the built-in interrupt controller.

The TMP91C824 has a total of 37 interrupts divided into the following five types:

| • | Interrupts generated by CPU: 9 sources               |
|---|------------------------------------------------------|
|   | (Software interrupts, illegal instruction interrupt) |

- Internal interrupts: 23 sources
- Interrupts on external pins ( NMI and INT0 to INT3): 5 sources

A (Fixed) individual interrupt vector number is assigned to each interrupt.

One of six (Variable) priority level can be assigned to each maskable interrupt.

The priority level of non-maskable interrupts are fixed at 7 as the highest level.

When an interrupt is generated, the interrupt controller sends the piority of that interrupt to the CPU. If multiple interrupts are generated simultaneously, the interrupt controller sends the interrupt with the highest priority to the CPU. (The highest priority is level 7 using for non-maskable interrupts.)

The CPU compares the priority level of the interrupt with the value of the CPU interrupt mask register <IFF2:0>. If the priority level of the interrupt is higher than the value of the interrupt mask register, the CPU accepts the interrupt.

The interrupt mask register <IFF2:0> value can be updated using the value of the EI instruction (EI num sets <IFF2:0> data to num).

For example, specifying EI 3 enables the maskable interrupts which priority level set in the interrupt controller is 3 or higher, and also non-maskable interrupts.

Operationally, the DI instruction ( $\langle IFF2:0 \rangle = 7$ ) is identical to the EI7 instruction. DI instruction is used to disable maskable interrupts because of the priority level of maskable interrupts is 1 to 6. The EI instruction is valid immediately after execution.

In addition to the above general-purpose interrupt processing mode, TLCS-900/L1 has a micro DMA interrupt processing mode as well. The CPU can transfer the data (1/2/4 bytes) automatically in micro DMA mode, therefore this mode is used for speed-up interrupt processing, such as transferring data to the internal or external peripheral I/O. Moreover, TMP91C824 has software start function for micro DMA processing request by the software not by the hardware interrupt.

Figure 3.4.1 shows the overall interrupt processing flow.



Figure 3.4.1 Overall Interrupt Processing Flow

### 3.4.1 General-purpose Interrupt Processing

When the CPU accepts an interrupt, it usually performs the following sequence of operations. That is also the same as TLCS-900/L and TLCS-900/H.

(1) The CPU reads the interrupt vector from the interrupt controller.

If the same level interrupts occur simultaneously, the interrupt controller generates an interrupt vector in accordance with the default priority and clears the interrupt request.

(The default priority is already fixed for each interrupt: The smaller vector value has the higher priority level.)

- (2) The CPU pushes the value of program counter (PC) and status register (SR) onto the stack area (Indicated by XSP).
- (3) The CPU sets the value which is the priority level of the accepted interrupt plus 1 (+1) to the interrupt mask register <IFF2:0>. However, if the priority level of the accepted interrupt is 7, the register's value is set to 7.
- (4) The CPU increases the interrupt nesting counter INTNEST by 1 (+1).
- (5) The CPU jumps to the address indicated by the data at address FFFF00H + interrupt vector and starts the interrupt processing routine.
- (6) The above processing time is 18-states (1.09  $\mu$ s at 33 MHz) as the best case (16 bits data bus width and 0 waits).

When the CPU compled the interrupt processing, use the RETI instruction to return to the main routine. RETI restores the contents of program counter (PC) and status register (SR) from the stack and decreases the interrupt nesting counter INTNEST by 1(-1).

Non-maskable interrupts cannot be disabled by a user program. Maskable interrupts, however, can be enabled or disabled by a user program. A program can set the priority level for each interrupt source. (A priority level setting of 0 or 7 will disable an interrupt request.)

If an interrupt request which has a priority level equal to or greater than the value of the CPU interrupt mask register <IFF2:0> comes out, the CPU accepts its interrupt. Then, the CPU interrupt mask register <IFF2:0> is set to the value of the priority level for the accepted interrupt plus 1 (+1).

Therefore, if an interrupt is generated with a higher level than the current interrupt during its processing, the CPU accepts the later interrupt and goes to the nesting status of interrupt processing.

Moreover, if the CPU receives another interrupt request while performing the said (1) to (5) processing steps of the current interrupt, the latest interrupt request is sampled immediately after execution of the first instruction of the current interrupt processing routine. Specifying DI as the start instruction disables maskable interrupt nesting.

A reset initializes the interrupt mask register <IFF2:0> to 111, disabling all maskable interrupts.

Table 3.4.1 shows the TMP91C824 interrupt vectors and micro DMA start vectors. The address FFFF00H to FFFFFFH (256 bytes) is assigned for the interrupt vector area.

| Default<br>Priority | Туре         | Interrupt Source and Source of Micro DMA<br>Request  | Vector<br>Value (V) | Vector<br>Reference<br>Address | Micro DMA<br>Start Vector |
|---------------------|--------------|------------------------------------------------------|---------------------|--------------------------------|---------------------------|
| 1                   |              | Reset or "SWI 0" instruction                         | 0000H               | FFFF00H                        | _                         |
| 2                   |              | "SWI 1" instruction                                  | 0004H               | FFFF04H                        | _                         |
| 3                   |              | INTUNDEF: Illegal instruction or "SWI 2" instruction | 0008H               | FFFF08H                        | _                         |
| 4                   |              | "SWI 3" instruction                                  | 000CH               | FFFF0CH                        | _                         |
| 5                   | Non mookohlo | "SWI 4" instruction                                  | 0010H               | FFFF10H                        | _                         |
| 6                   | Non maskable | "SWI 5" instruction                                  | 0014H               | FFFF14H                        | _                         |
| 7                   |              | "SWI 6" instruction                                  | 0018H               | FFFF18H                        | _                         |
| 8                   |              | "SWI 7" instruction                                  | 001CH               | FFFF1CH                        | _                         |
| 9                   |              | NMI pin                                              | 0020H               | FFFF20H                        | _                         |
| 10                  |              | INTWD: Watchdog timer                                | 0024H               | FFFF24H                        | _                         |
| _                   |              | Micro DMA (MDMA)                                     | _                   | _                              | -                         |
| 11                  |              | INTO pin                                             | 0028H               | FFFF28H                        | 0AH                       |
| 12                  |              | INT1 pin                                             | 002CH               | FFFF2CH                        | 0BH                       |
| 13                  |              | INT2 pin                                             | 0030H               | FFFF30H                        | 0CH                       |
| 14                  |              | INT3 pin                                             | 0034H               | FFFF34H                        | 0DH                       |
| 15                  |              | INTALMO: ALMO (8 kHz)                                | 0038H               | FFFF38H                        | 0EH                       |
| 16                  |              | INTALM1: ALM1 (512 Hz)                               | 003CH               | FFFF3CH                        | 0FH                       |
| 17                  |              | INTALM2: ALM2 (64 Hz)                                | 0040H               | FFFF40H                        | 10H                       |
| 18                  |              | INTALM3: ALM3 (2 Hz)                                 | 0044H               | FFFF44H                        | 11H                       |
| 19                  |              | INTALM4: ALM4 (1 Hz)                                 | 0048H               | FFFF48H                        | 12H                       |
| 20                  |              | INTTA0: 8-bit timer 0                                | 004CH               | FFFF4CH                        | 13H                       |
| 21                  |              | INTTA1: 8-bit timer 1                                | 0050H               | FFFF50H                        | 14H                       |
| 22                  |              | INTTA2: 8-bit timer 2                                | 0054H               | FFFF54H                        | 15H                       |
| 23                  |              | INTTA3: 8-bit timer 3                                | 0058H               | FFFF58H                        | 16H                       |
| 24                  | Maalaakia    | INTRX0: Serial reception (Channel 0)                 | 005CH               | FFFF5CH                        | 17H                       |
| 25                  | Maskable     | INTTX0: Serial transmission (Channel 0)              | 0060H               | FFFF60H                        | 18H                       |
| 26                  |              | INTRX1: Serial reception (Channel 1)                 | 0064H               | FFFF64H                        | 19H                       |
| 27                  |              | INTTX1: Serial transmission (Channel 1)              | 0068H               | FFFF68H                        | 1AH                       |
| 28                  |              | INTAD: AD conversion end                             | 006CH               | FFFF6CH                        | 1BH                       |
| 29                  |              | INTRTC: RTC (Alarm interrupt)                        | 0074H               | FFFF74H                        | 1DH                       |
| 30                  |              | INTSBI: SBI interrupt                                | 0078H               | FFFF78H                        | 1EH                       |
| 31                  |              | INTP0: Protect 0 (WR to special SFR)                 | 0080H               | FFFF80H                        | 20H                       |
| 32                  |              | INTP1: Protect 1 (WR to ROM)                         | 0084H               | FFFF84H                        | 21H                       |
| 33                  |              | INTTC0: Micro DMA end (Channel 0)                    | 0088H               | FFFF88H                        | _                         |
| 34                  |              | INTTC1: Micro DMA end (Channel 1)                    | 008CH               | FFFF8CH                        | _                         |
| 35                  |              | INTTC2: Micro DMA end (Channel 2)                    | 0090H               | FFFF90H                        | -                         |
| 36                  |              | INTTC3: Micro DMA end (Channel 3)                    | 0094H               | FFFF94H                        | _                         |
|                     |              | (Reserved)                                           | 0098H               | FFFF98H                        | -                         |
|                     |              | :                                                    | :                   | :                              | :                         |
|                     |              | (Reserved)                                           | 00FCH               | FFFFFCH                        | _                         |

| Table 3.4.1 | TMP91C824 Int | errupt Vectors Table |
|-------------|---------------|----------------------|
| 10010 0.4.1 |               | chupt veotors lubic  |

#### 3.4.2 Micro DMA Processing

In addition to general-purpose interrupt processing, the TMP91C824 supprots a micro DMA function. Interrupt requests set by micro DMA perform micro DMA processing at the highest priority level (Level 6) among maskable interrupts, regardless of the priority level of the particular interrupt source. Micro. The micro DMA has 4 channels and is possible continuous transmission by specifing the say later burst mode.

Because the micro DMA function has been implemented with the cooperative operation of CPU, when CPU goes to a standby mode by HALT instruction, the requirement of micro DMA will be ignored (Pending).

#### (1) Micro DMA operation

When an interrupt request specified by the micro DMA start vector register is generated, the micro DMA triggers a micro DMA request to the CPU at interrupt priority level 6 and starts processing the request in spite of any interrupt source's level. The micro DMA is ignored on  $\langle IFF2:0 \rangle = 7$ .

The 4 micro DMA channels allow micro DMA processing to be set for up to 4 types of interrupts at any one time. When micro DMA is accepted, the interrupt request flip-flop assigned to that channel is cleared.

The data are automatically transferred once (1/2/4 bytes) from the transfer source address to the transfer destination address set in the control register, and the transfer counter is decreased by 1 (-1).

If the decreased result is 0, the micro DMA transfer end interrupt (INTTC0 to INTTC3) passes from the CPU to the interrupt controller. In addition, the micro DMA start vector register DMAnV is cleared to 0, the next micro DMA is disabled and micro DMA processing completes. If the decreased result is other than 0, the micro DMA processing completes if it isn't specified the say later burst mode. In this case, the micro DMA transfer end interrupt (INTTC0 to INTTC3) aren't generated.

If an interrupt request is triggered for the interrupt source in use during the interval between the clearing of the micro DMA start vector and the next setting, general-purpose interrupt processing executes at the interrupt level set. Therefore, if only using the interrupt for starting the micro DMA (Not using the interrupts as a general-purpose interrupt: Level 1 to 6), first set the interrupt level to 0 (Interrupt requests disabled).

If using micro DMA and general-purpose interrupts together, first set the level of the interrupt used to start micro DMA processing lower than all the other interrupt levels. In this case, the cause of general interrupt is limited to the edge interrupt. (Note)

The priority of the micro DMA transfer end interrupt (INTTC0 to INTTC3) is defined by the interrupt level and the default priority as the same as the other maskable interrupt.

Note: If the priority level of micro DMA is set higher than that of other interrupts, CPU operates as follows. In case INTxxx interrupt is generated first and then INTyyy interrupt is generated between checking "Interrupt specified by micro DMA start vector" (in the Figure 3.4.1) and reading interrupt vector with setting below. The vector shifts to that of INTyyy at the time.

This is because the priority level of INTyyy is higher than that of INTxxx.

- In the interrupt routine, CPU reads the vector of INTyyy because cheking of micro DMA has finished.
- And INTyyy is generated regardless of transfer counter of micro DMA.
- INTxxx: level 1 without micro DMA

INTyyy: level 6 with micro DMA

If a micro DMA request is set for more than one channel at the same time, the priority is not based on the interrupt priority level but on the channel number. The smaller channel number has the higher priority (Channel 0 (High) > Channel 3 (Low)).

While the register for setting the transfer source/transfer destination addresses is a 32-bit control register, this register can only effectively output 24-bit addresses. Accordingly, micro DMA can access 16 Mbytes (The upper 8 bits of the 32 bits are not valid).

Three micro DMA transfer modes are supported: 1-byte transfer, 2-byte (One word) transfer, and 4-byte transfer. After a transfer in any mode, the transfer source/destination addresses are increased, decreased, or remain unchanged.

This simplifies the transfer of data from I/O to memory, from memory to I/O, and from I/O to I/O. For details of the transfer modes, see 3.4.2 (4) "Detailed description of the transfer mode register". As the transfer counter is a 16-bit counter, micro DMA processing can be set for up to 65536 times per interrupt source. (The micro DMA processing count is maximized when the transfer counter initial value is set to 0000H.)

Micro DMA processing can be started by the 24 interrupts shown in the micro DMA start vectors of Table 3.4.1 and by the micro DMA soft start, making a total of 25 interrupts.

Figure 3.4.2 shows the word transfer micro DMA cycle in transfer destination address INC mode (except for counter mode, the same as for other modes).

(The conditions for this cycle are based on an external 16-bit bus, 0 waits, transfer source/transfer destination addresses both even-numberd values.)



Figure 3.4.2 Timing for Micro DMA Cycle

- States 1 to 3: Instruction fetch cycle (gets next address code). If 3 bytes and more instruction codes are inserted in the instruction queue buffer, this cycle becomes a dummy cycle.
- States 4 to 5: Micro DMA read cycle
- State 6: Dummy cycle (The address bus remains unchanged from state 5)
- States 7 to 8: Micro DMA write cycle

Note 1: If the source address area is an 8-bit bus, it is increased by two states.

If the source address area is a 16-bit bus and the address starts from an odd number, it is increased by two states.

Note 2: If the destination address area is an 8-bit bus, it is increased by two states. If the destination address area is a 16-bit bus and the address starts from an odd number, it is increased by two states. (2) Soft start function

In addition to starting the micro DMA function by interrupts, TMP91C824 includes a micro DMA software start function that starts micro DMA on the generation of the write cycle to the DMAR register.

Writing "1" to each bit of DMAR register causes micro DMA once (If write "0" to each bit, micro DMA doesn't operate). At the end of transfer, the corresponding bit of the DMAR register which support the end channel are automatically cleared to "0".

Only one-channel can be set for DMA request at once. (Do not write "1" to plural bits.)

When writing again "1" to the DMAR register, check whether the bit is "0" before writing "1". If read "1", micro DMA transfer isn't started yet.

When a burst is specified by DMAB register, data is continuously transferred until the value in the micro DMA transfer counter is "0" after start up of the micro DMA. If execute soft start during micro DMA transfer by interrupt source, micro DMA transfer counter doesn't change. Don't use Read-modify-write instruction to avoid writing to other bits by mistake.

| Symbol | Name     | Address           | 7 | 6 | 5 | 4 | 3     | 2     | 1      | 0     |
|--------|----------|-------------------|---|---|---|---|-------|-------|--------|-------|
|        | 5144     |                   |   |   | / | / | DMAR3 | DMAR2 | DMAR1  | DMAR0 |
| DMAD   | DMA      | 89H               |   |   |   |   |       | R/    | W      |       |
| DMAR   | request  | (Prohibit<br>RMW) |   |   |   |   | 0     | 0     | 0      | 0     |
|        | register | rivivy)           |   |   |   |   |       | DMA r | equest |       |

## (3) Transfer control registers

The transfer source address and the transfer destination address are set in the following registers in CPU. Data setting for these registers is done by an LDC cr, r instruction.



(4) Detailed description of the transfer mode register

| DMAM0 1<br>DMAM3      | to 0                 | 0 0 | 8 bits Mode                    | Note: When setting a value in this                                                                       | register, write 0 to th       | e upper 3 bits.                             |
|-----------------------|----------------------|-----|--------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------|---------------------------------------------|
|                       |                      |     | Number of<br>Transfer Bytes    | Mode Description                                                                                         | Number of<br>Execution States | Minimum<br>Execution Time<br>at fc = 33 MHz |
| 000 000 00<br>(Fixed) |                      | 00  | Byte transfer                  | Transfer destination address INC mode<br>I/O to memory                                                   | 8 states                      | 485 ns                                      |
|                       |                      | 01  | Word transfer                  | $(DMADn+) \leftarrow (DMASn)$<br>DMACn $\leftarrow$ DMACn - 1<br>If DMACn = 0, then INTTCn is generated. | 12 states                     | 727 ns                                      |
|                       |                      | 10  | 4-byte transfer                |                                                                                                          |                               |                                             |
|                       | 001                  | 00  | Byte transfer                  | Transfer destination address DEC mode<br>I/O to memory                                                   | 8 states                      | 485 ns                                      |
| 01 Word transfer      |                      |     | Word transfer                  | (DMADn–) ← (DMASn)<br>DMACn ← DMACn – 1                                                                  | 12 states                     | 727 ns                                      |
|                       |                      | 10  | 4-byte transfer                | If DMACn = 0, then INTTCn is generated.                                                                  |                               |                                             |
|                       | 010 00 Byte transfer |     | Byte transfer                  | Transfer source address INC mode<br>Memory to I/O                                                        | 8 states                      | 485 ns                                      |
|                       |                      | 01  | Word transfer                  | (DMADn) ← (DMASn+)<br>DMACn ← DMACn − 1                                                                  | 12 states                     | 727 ns                                      |
|                       |                      | 10  | 4-byte transfer                | If DMACn = 0, then INTTCn is generated.                                                                  |                               |                                             |
|                       | 011                  | 00  | Byte transfer                  | Transfer source address DEC mode<br>Memory to I/O                                                        | 8 states                      | 485 ns                                      |
|                       |                      | 01  | Word transfer                  | (DMADn) ← (DMASn–)<br>DMACn ← DMACn − 1                                                                  | 12 states                     | 727 ns                                      |
|                       |                      | 10  | 4-byte transfer                | If DMACn = 0, then INTTCn is generated.                                                                  |                               |                                             |
|                       | 100                  | 00  | Byte transfer                  | Fixed address mode<br>I/O to I/O                                                                         | 8 states                      | 485 ns                                      |
|                       |                      | 01  | Word transfer                  | (DMADn) ← (DMASn–)<br>DMACn ← DMACn – 1                                                                  | 12 states                     | 727 ns                                      |
|                       |                      | 10  | 4-byte transfer                | If DMACn = 0, then INTTCn is generated.                                                                  |                               |                                             |
|                       | 101                  | 00  | Counter mode                   | unting number of times interrupt is generated                                                            |                               |                                             |
|                       |                      |     | DMASn ← DMASn<br>DMACn ← DMACn | – 1                                                                                                      | 5 states                      | 303 ns                                      |
|                       |                      |     | If DMACn = 0, then             | INTTCn is generated.                                                                                     |                               |                                             |

Note 1: "n" is the corresponding micro DMA channels 0 to 3

DMADn+/DMASn+: Post-increment (Increment register value after transfer) DMADn-/DMASn-: Post-decrement (Decrement register value after transfer) The I/Os in the table mean fixed address and the memory means increment (INC) or decrement (DEC) addresses.

Note 2: Execution time is under the condition of:

16-bit bus width (Both translation and destination address area)/0 waits/fc = 33 MHz/selected high-frequency mode (fc  $\times$  1)

Note 3: Do not use an undefined code for the transfer mode register except for the defined codes listed in the above table.

## 3.4.3 Interrupt Controller Operation

The block diagram in Figure 3.4.3 shows the interrupt circuits. The left-hand side of the diagram shows the interrupt controller circuit. The right-hand side shows the CPU interrupt request signal circuit and the halt release circuit.

For each of the 36 interrupt channels there is an interrupt request flag (Consisting of a flip-flop), an interrupt priority setting register and a micro DMA start vector register. The interrupt request flag latches interrupt requests from the peripherals. The flag is cleared to 0 in the following cases:

- when reset occurs
- when the CPU reads the channel vector after accepted its interrupt
- when executing an instruction that clears the interrupt (Write DMA start vector to INTCLR register)
- when the CPU receives a micro DMA request (when micro DMA is set)
- when the micro DMA burst transfer is terminated

An interrupt priority can be set independently for each interrupt source by writing the priority to the interrupt priority setting register (e.g., INTEOAD or INTE12). 6 interrupt priorities levels (1 to 6) are provided. Setting an interrupt source's priority level to 0 (or 7) disables interrupt requests from that source. The priority of non-maskable interrupts (NMI pin interrupts and watchdog timer interrupts) is fixed at 7. If interrupt request with the same level are generated at the same time, the default priority (The interrupt with the lowest priority or, in other words, the interrupt with the lowest vector value) is used to determine which interrupt request is accepted first.

The 3rd and 7th bits of the interrupt priority setting register indicate the state of the interrupt request flag and thus whether an interrupt request for a given channel has occurred.

The interrupt controller sends the interrupt request with the highest priority among the simulateous interrupts and its vector address to the CPU. The CPU compares the priority value <IFF2:0> in the status register by the interrupt request signal with the priority value set; if the latter is higher, the interrupt is accepted. Then the CPU sets a value higher than the priority value by 1 (+1) in the CPU SR<IFF2:0>. Interrupt request where the priority value equals or is higher than the set value are accepted simultaneously during the previous interrupt routine.

When interrupt processing is completed (after execution of the RETI instruction), the CPU restores the priority value saved in the stack before the interrupt was generated to the CPU SR<IFF2:0>.

The interrupt controller also has registers (4 channels) used to store the micro DMA start vector. Writing the start vector of the interrupt source for the micro DMA processing (See Table 3.4.1), enables the corresponding interrupt to be processed by micro DMA processing. The values must be set in the micro DMA parameter register (e.g., DMAS and DMAD) prior to the micro DMA processing.



Figure 3.4.3 Block Diagram of Interrupt Controller

| Symbol   | Name                           | Address   | 7        | 6      | 5       | 4      | 3     | 2      | 1       | 0      |
|----------|--------------------------------|-----------|----------|--------|---------|--------|-------|--------|---------|--------|
|          |                                |           |          | INT    | AD      | -      |       | IN     | Т0      |        |
| INTE0AD  | INT0 &<br>INTAD                | 90H       | IADC     | IADM2  | IADM1   | IADM0  | I0C   | 10M2   | I0M1    | I0M0   |
| INTEUAD  | enable                         | 901       | R        |        | R/W     |        | R     |        | R/W     |        |
|          | Chabic                         |           | 0        | 0      | 0       | 0      | 0     | 0      | 0       | 0      |
|          |                                |           |          | IN     | T2      |        |       | IN     | T1      |        |
| INTE12   | INT1 &<br>12 INT2              | 91H       | I2C      | I2M2   | I2M1    | I2M0   | I1C   | I1M2   | I1M1    | I1M0   |
| INTETZ   | enable                         | 910       | R        |        | R/W     |        | R     |        | R/W     |        |
|          | enable                         |           | 0        | 0      | 0       | 0      | 0     | 0      | 0       | 0      |
|          |                                |           |          | INTA   | LM4     |        |       | IN     | T3      |        |
|          | INT3 &                         | 0011      | IA4C     | IA4M2  | IA4M1   | IA4M0  | I3C   | 13M2   | I3M1    | I3M0   |
| NTE3ALM4 | INTALM4<br>enable              | 92H       | R        |        | R/W     |        | R     |        | R/W     |        |
|          | enable                         |           | 0        | 0      | 0       | 0      | 0     | 0      | 0       | 0      |
|          |                                |           |          | INTA   | LM1     |        |       | INTA   | LM0     |        |
|          | INTALM0 &                      | 0011      | IA1C     | IA1M2  | IA1M1   | IA1M0  | IA0C  | IA0M2  | IA0M1   | IA0M0  |
| NTEALM01 |                                |           | R        |        | R/W     |        | R     |        | R/W     |        |
| enable   | enable                         |           | 0        | 0      | 0       | 0      | 0     | 0      | 0       | 0      |
|          |                                | FALM3 94H |          | INTA   | LM3     |        |       | INTA   | LM2     |        |
|          | INTALM2 &<br>INTALM3<br>enable |           | IA3C     | IA3M2  | IA3M1   | IA3M0  | IA2C  | IA2M2  | IA2M1   | IA2M0  |
| NTEALM23 |                                |           | R        |        | R/W     |        | R     |        | R/W     |        |
|          | enable                         |           | 0        | 0      | 0       | 0      | 0     | 0      | 0       | 0      |
|          |                                |           |          | INTTA1 | (TMRA1) |        |       | INTTA0 | (TMRA0) |        |
|          | INTTA0 &                       | 0511      | ITA1C    | ITA1M2 | ITA1M1  | ITA1M0 | ITA0C | ITA0M2 | ITA0M1  | ITA0M0 |
| INTETA01 | INTTA1<br>enable               |           | R        |        | R/W     |        | R     |        | R/W     |        |
|          | enable                         |           | 0        | 0      | 0       | 0      | 0     | 0      | 0       | 0      |
|          |                                |           |          | INTTA3 | (TMRA3) |        |       | INTTA2 | (TMRA2) |        |
|          | INTTA2 &                       | 0.011     | ITA3C    | ITA3M2 | ITA3M1  | ITA3M0 | ITA2C | ITA2M2 | ITA2M1  | ITA2M0 |
| INTETA23 | INTTA3<br>enable               | 96H       | R        |        | R/W     |        | R     |        | R/W     |        |
|          | enable                         |           | 0        | 0      | 0       | 0      | 0     | 0      | 0       | 0      |
|          |                                |           | /        |        | /       | /      |       | INT    | RTC     |        |
|          | INTRTC                         | 0711      | /        |        |         |        | IRC   | IRM2   | IRM1    | IRM0   |
| INTERTC  | enable                         | 97H       | /        |        | /       | /      | R     |        | R/W     |        |
|          |                                |           | /        | /      | /       |        | 0     | 0      | 0       | 0      |
|          |                                |           |          |        |         |        |       |        |         |        |
| Interru  | upt request fl                 | ag 🔶 🚽    | <b>\</b> |        |         |        |       |        |         |        |

| (1) | Interrupt leve | el setting | registers |
|-----|----------------|------------|-----------|
|-----|----------------|------------|-----------|

| lxxM2 | lxxM1 | lxxM0 | Function (Write)                   |
|-------|-------|-------|------------------------------------|
| 0     | 0     | 0     | Disables interrupt requests        |
| 0     | 0     | 1     | Sets interrupt priority level to 1 |
| 0     | 1     | 0     | Sets interrupt priority level to 2 |
| 0     | 1     | 1     | Sets interrupt priority level to 3 |
| 1     | 0     | 0     | Sets interrupt priority level to 4 |
| 1     | 0     | 1     | Sets interrupt priority level to 5 |
| 1     | 1     | 0     | Sets interrupt priority level to 6 |
| 1     | 1     | 1     | Disables interrupt requests        |

| Symbol                              | Name               | Address | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |  |
|-------------------------------------|--------------------|---------|--------|--------|--------|--------|--------|--------|--------|--------|--|
|                                     |                    | 0011    |        | INT    | TX0    |        | INTRX0 |        |        |        |  |
|                                     | Interrupt          |         | ITX0C  | ITX0M2 | ITX0M1 | ITX0M0 | IRX0C  | IRX0M2 | IRX0M1 | IRX0M0 |  |
| INTES0                              | Enable<br>serial 0 | 98H     | R      |        | R/W    |        | R      |        | R/W    |        |  |
|                                     | Senar U            |         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |  |
|                                     |                    |         |        | INT    | TX1    |        |        | INT    | RX1    |        |  |
| INTRX1 &<br>INTES1 INTTX1<br>enable |                    | 99H     | ITX1C  | ITX1M2 | ITX1M1 | ITX1M0 | IRX1C  | IRX1M2 | IRX1M1 | IRX1M0 |  |
|                                     |                    | 99⊓     | R      |        | R/W    |        | R      |        | R/W    |        |  |
|                                     |                    | 0       | 0      | 0      | 0      | 0      | 0      | 0      | 0      |        |  |
| INTES2                              |                    |         | /      | /      | /      | /      |        | INTSBI |        |        |  |
|                                     | INTESBI            | 9AH     |        |        |        |        | ISBIC  | ISBIM2 | ISBIM1 | ISBIM0 |  |
| INTESZ                              | enable             | 5711    |        |        |        |        | R      |        | R/W    |        |  |
|                                     |                    |         |        |        |        |        | 0      | 0      | 0      | 0      |  |
|                                     |                    | 9BH     | INTTC1 |        |        |        |        | INT    | TC0    |        |  |
| INTETC01                            | INTTC0 &<br>INTTC1 |         | ITC1C  | ITC1M2 | ITC1M1 | ITC1M0 | ITC0C  | ITC0M2 | ITC0M1 | ITC0M0 |  |
| INTERCOT                            | enable             | 9011    | R      |        | R/W    |        | R R/W  |        |        |        |  |
|                                     | enable             |         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |  |
|                                     |                    |         |        | INT    | ТСЗ    |        | INTTC2 |        |        |        |  |
| INTETC23                            | INTTC2 &<br>NTTC3  | 9CH     | ITC3C  | ITC3M2 | ITC3M1 | ITC3M0 | ITC2C  | ITC2M2 | ITC2M1 | ITC2M0 |  |
| INTETC23                            | enable             | 9011    | R      |        | R/W    |        | R      | R/W    |        |        |  |
|                                     | chabic             |         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |  |
|                                     |                    |         |        | INT    | P1     |        | INTP0  |        |        |        |  |
| INTEP01                             | INTP0 &<br>NTP1    | 9DH     | IP1C   | IP1M2  | IP1M1  | IP1M0  | IP0C   | IP0M2  | IP0M1  | IP0M0  |  |
| INTEP01                             | enable             | 9DH     | R      |        | R/W    |        | R      | R/W    |        |        |  |
|                                     | enable             |         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |  |

Interrupt request flag

| lxxM2 | lxxM1 | lxxM0 | Function (Write)                   |
|-------|-------|-------|------------------------------------|
| 0     | 0     | 0     | Disables interrupt requests        |
| 0     | 0     | 1     | Sets interrupt priority level to 1 |
| 0     | 1     | 0     | Sets interrupt priority level to 2 |
| 0     | 1     | 1     | Sets interrupt priority level to 3 |
| 1     | 0     | 0     | Sets interrupt priority level to 4 |
| 1     | 0     | 1     | Sets interrupt priority level to 5 |
| 1     | 1     | 0     | Sets interrupt priority level to 6 |
| 1     | 1     | 1     | Disables interrupt requests        |

| Symbol            | Name                              | Address   | 7       | 6       | 5             | 4          | 3          | 2             | 1         | 0                           |
|-------------------|-----------------------------------|-----------|---------|---------|---------------|------------|------------|---------------|-----------|-----------------------------|
|                   |                                   |           | -       | -       | <b>I3EDGE</b> | I2EDGE     | I1EDGE     | <b>I0EDGE</b> | IOLE      | NMIREE                      |
|                   |                                   |           |         |         |               | W          |            |               |           |                             |
|                   | Interrupt<br>IIMC input<br>mode ( | 8CH       | 0       | 0       | 0             | 0          | 0          | 0             | 0         | 0                           |
|                   |                                   | 0011      | Always  | Always  | INT3EDGE      | INT2EDGE   | INT1EDGE   | INT0EDGE      | INT0 mode | 1: Operates                 |
| IIMC              |                                   | (Prohibit | write 0 | write 0 | 0: Rising     | 0: Rising  | 0: Rising  | 0: Rising     | 0: Edge   | even on                     |
|                   | control                           | RMW)      |         |         | 1: Falling    | 1: Falling | 1: Falling | 1: Falling    | 1: Level  | rising/                     |
|                   | control                           | ,         |         |         |               |            |            |               |           | 0<br>1: Operates<br>even on |
|                   |                                   |           |         |         |               |            |            |               |           | edge of                     |
|                   |                                   |           |         |         |               |            |            |               |           | NMI                         |
| INTO level enable |                                   |           |         |         |               |            |            |               |           |                             |
| 0 edge detect INT |                                   |           |         |         |               |            |            |               |           |                             |
| 1 H level INT     |                                   |           |         |         |               |            |            |               |           |                             |
| NMI ris           | sina edae i                       | enable    |         |         |               |            |            |               |           |                             |

(2) External interrupt control

| IN I U IEVE | el enable                                     |   |  |
|-------------|-----------------------------------------------|---|--|
| 0           | edge detect INT                               |   |  |
| 1           | H level INT                                   | < |  |
| NMI risin   | g edge enable                                 |   |  |
| 0           | INT request generation at falling edge        |   |  |
| 1           | INT request generation at rising/falling edge | < |  |

(3) Interrupt request flag clear register

The interrupt request flag is cleared by writing the appropriate micro DMA start vector, as given in Table 3.4.1, to the register INTCLR.

For example, to clear the interrupt flag INTO, perform the following register operation after execution of the DI instruction.

| INTCLR $\leftarrow$ 0AH: | Clears interrupt request | flag INT0. |
|--------------------------|--------------------------|------------|
|--------------------------|--------------------------|------------|

| Symbol    | Name                    | Address           | 7 | 6     | 5     | 4                | 3     | 2     | 1     | 0 |  |
|-----------|-------------------------|-------------------|---|-------|-------|------------------|-------|-------|-------|---|--|
| Interrupt |                         | /                 | / | CLRV5 | CLRV4 | CLRV3            | CLRV2 | CLRV1 | CLRV0 |   |  |
|           |                         | 88H               |   |       |       | _                | V     | V     | _     |   |  |
| INTCLR    | INTCLR clear<br>control | (Prohibit<br>RMW) | / |       | 0     | 0                | 0     | 0     | 0     | 0 |  |
|           |                         | RIVIVV)           |   |       |       | Interrupt vector |       |       |       |   |  |

(4) Micro DMA start vector registers

This register assigns micro DMA processing to which interrupt source. The interrupt source with a micro DMA start vector that matches the vector set in this register is assigned as the micro DMA start source.

When the micro DMA transfer counter value reaches zero, the micro DMA transfer end interrupt corresponding to the channel is sent to the interrupt controller, the micro DMA start vector register is cleared, and the micro DMA start source for the channel is cleared. Therefore, to continue micro DMA processing, set the micro DMA start vector register again during the processing of the micro DMA transfer end interrupt.

If the same vector is set in the micro DMA start vector registers of more than one channel, the channel with the lowest number has a higher priority.

Accordingly, if the same vector is set in the micro DMA start vector registers of two channels, the interrupt generated in the channel with the lower number is executed until micro DMA transfer is complete. If the micro DMA start vector for this channel is not set again, the next micro DMA is started for the channel with the higher number (Micro DMA chaining).

| Symbol  | Name            | Address | 7 | 6 | 5      | 4                 | 3        | 2          | 1      | 0      |  |
|---------|-----------------|---------|---|---|--------|-------------------|----------|------------|--------|--------|--|
|         |                 |         |   | / | DMA0V5 | DMA0V4            | DMA0V3   | DMA0V2     | DMA0V1 | DMA0V0 |  |
| DMAON   | DMA0            | 0011    | / | / |        | R/W               |          |            |        |        |  |
| DMA0V   | start<br>vector | 80H     |   | / | 0      | 0                 | 0        | 0          | 0      | 0      |  |
|         | Vector          |         |   |   |        |                   | DMA0 sta | art vector |        |        |  |
|         | DMAA            |         |   |   | DMA1V5 | DMA1V4            | DMA1V3   | DMA1V2     | DMA1V1 | DMA1V0 |  |
| DMA1V   | DMA1            | 81H     |   |   |        |                   | R/       | W          |        |        |  |
| DIVIATV | start<br>vector | 011     |   |   | 0      | 0                 | 0        | 0          | 0      | 0      |  |
| vect    | Vector          |         |   |   |        | DMA1 start vector |          |            |        |        |  |
|         | DIALO           |         |   |   | DMA2V5 | DMA2V4            | DMA2V3   | DMA2V2     | DMA2V1 | DMA2V0 |  |
| DMA2V   | DMA2            | 82H     |   |   |        | R/W               |          |            |        |        |  |
| DIVIAZV | start<br>vector | 02Π     |   |   | 0      | 0                 | 0        | 0          | 0      | 0      |  |
|         | Vector          |         |   |   |        | DMA2 start vector |          |            |        |        |  |
|         | DIALO           |         |   |   | DMA3V5 | DMA3V4            | DMA3V3   | DMA3V2     | DMA3V1 | DMA3V0 |  |
| DMA3V   | DMA3            | 0211    |   |   |        |                   | R/       | W          |        |        |  |
| DIVIASV | start           | 83H     |   |   | 0      | 0                 | 0        | 0          | 0      | 0      |  |
|         | vector          | ſ       |   |   |        |                   | DMA3 sta | art vector |        |        |  |

(5) Micro DMA burst specification

Specifying the micro DMA burst continues the micro DMA transfer until the transfer counter register reaches zero after micro DMA start. Setting a bit which corresponds to the micro DMA channel of the DMAB registers mentioned below to 1 specifies a burst.

| Symbol | Name              | Address           | 7 | 6 | 5 | 4 | 3                       | 2         | 1           | 0     |
|--------|-------------------|-------------------|---|---|---|---|-------------------------|-----------|-------------|-------|
| DMAR   | DMA               |                   |   |   |   |   | DMAR3                   | DMAR2     | DMAR1       | DMAR0 |
|        | software          | 89H<br>(Drahihit  |   |   |   |   | R/W                     | R/W       | R/W         | R/W   |
|        | request           | (Prohibit<br>RMW) |   |   |   |   | 0                       | 0         | 0           | 0     |
|        | register          |                   |   |   |   |   | 1: DMA software request |           |             |       |
|        | DMA               |                   | / | / | / |   | DMAB3                   | DMAB2     | DMAB1       | DMAB0 |
| DMAB   | DMA               | 8AH               | / | / | / | / |                         | R/        | W           |       |
| DIVIAB | burst<br>register | олп               | / | / | / |   | 0                       | 0         | 0           | 0     |
|        | register          |                   |   |   |   |   |                         | 1: DMA bu | rst request |       |

(6) Attention point

The instruction execution unit and the bus interface unit of this CPU operate independently. Therefore, immediately before an interrupt is generated, if the CPU fetches an instruction that clears the corresponding interrupt request flag, the CPU may execute the instruction that clears the interrupt request flag (Note) between accepting and reading the interrupt vector. In this case, the CPU reads the default vector 0008H and reads the interrupt vector address FFFF08H.

To avoid the avobe plogram, place instructions that clear interrupt request flags after a DI instruction. And in the case of setting an interrupt enable again by EI instruction after the execution of clearing instruction, execute EI instruction after clearing and more than 1-instructions (e.g., "NOP"  $\times$  1 times).

In the case of changing the value of the interrupt mask register <IFF2:0> by execution of POP SR instruction, disable an interrupt by DI instruction before execution of POP SR instruction.

In addition, take care as the following 2 circuits are exceptional and demand special attention.

| INT0 Level Mode | In level mode INT0 is not an edge-triggered interrupt. Hence, in level                                                                  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
|                 | mode the interrupt request flip-flop for INT0 does not function. The                                                                    |
|                 | peripheral interrupt request passes through the S input of the flip-flop                                                                |
|                 | and becomes the Q output. If the interrupt input mode is changed                                                                        |
|                 | from edge mode to level mode, the interrupt request flag is cleared                                                                     |
|                 | automatically.                                                                                                                          |
|                 | If the CPU enters the interrupt response sequence as a result of INTO going from 0 to 1, INTO must then be held at 1 until the          |
|                 | interrupt response sequence has been completed. If INT0 is set to level mode so as to release a halt state, INT0 must be held at 1 from |
|                 | the time INTO changes from 0 to 1 until the halt state is released.                                                                     |
|                 | (Hence, it is necessary to ensure that input noise is not interpreted                                                                   |
|                 | as a 0, causing INT0 to revert to 0 before the halt state has been                                                                      |
|                 | released.)                                                                                                                              |
|                 | When the mode changes from level mode to edge mode, interrupt                                                                           |
|                 | request flags which were set in level mode will not be cleared.                                                                         |
|                 | Interrupt request flags must be cleared using the following                                                                             |
|                 | sequence.                                                                                                                               |
|                 | DI                                                                                                                                      |
|                 | LD (IIMC), 00H; Switches interrupt input mode from level mode to edge mode.                                                             |
|                 | LD (INTCLR), 0AH; Clears interrupt request flag.                                                                                        |
|                 | NOP ; Wait El instruction                                                                                                               |
|                 | El                                                                                                                                      |
| INTRX           | The interrupt request flip-flop can only be cleared by a reset or by                                                                    |
|                 | reading the serial channel receive buffer. It cannot be cleared by                                                                      |
|                 | writing INTCLR register.                                                                                                                |

Note: The following instructions or pin input state changes are equivalent to instructions that clear the interrupt request flag.

INTO: Instructions which switch to level mode after an interrupt request has been generated in edge mode.

The pin input change from high to low after interrupt request has been generated in level mode. (H  $\rightarrow$  L)

INTRX: Instruction which read the receive buffer

# 3.5 Port Functions

The TMP91C824 features 56-bit settings which relate to the various I/O ports.

As well as general-purpose I/O port functionality, the port pins also have I/O functions which relate to the built-in CPU and internal I/Os. Table 3.5.1 lists the functions of each port pin. Table 3.5.2 lists I/O registers and their specifications.

|           |            |                   | (R: P      | U = with | programmable pull         | -up resistor/U = with pull-up resistor)            |
|-----------|------------|-------------------|------------|----------|---------------------------|----------------------------------------------------|
| Port Name | Pin Name   | Number<br>of Pins | Direction  | R        | Direction<br>Setting Unit | Pin Name for Built-in<br>Function                  |
| Port 1    | P10 to P17 | 8                 | I/O        | _        | Bit                       | D8 to D15                                          |
| Port 2    | P20 to P27 | 8                 | Output     | _        | (Fixed)                   | A16 to A23                                         |
| Port 5    | P54        | 1                 | I/O        | PU       | Bit                       | BUSRQ                                              |
|           | P55        | 1                 | I/O        | PU       | Bit                       | BUSAK                                              |
|           | P56        | 1                 | I/O        | PU       | Bit                       | WAIT                                               |
| Port 6    | P60        | 1                 | Output     | -        | (Fixed)                   | CSO                                                |
|           | P61        | 1                 | Output     | _        | (Fixed)                   | CS1                                                |
|           | P62        | 1                 | Output     | —        | (Fixed)                   | $\overline{\text{CS2}}$ , $\overline{\text{CS2A}}$ |
|           | P63        | 1                 | Output     | -        | (Fixed)                   | CS3                                                |
|           | P64        | 1                 | Output     | -        | (Fixed)                   | EA24, CS2B                                         |
|           | P65        | 1                 | Output     | -        | (Fixed)                   | EA25, CS2C                                         |
|           | P66        | 1                 | Output     | _        | (Fixed)                   | CS2D                                               |
|           | P67        | 1                 | Output     | -        | (Fixed)                   | CS2E                                               |
| Port 7    | P70        | 1                 | I/O        | -        | Bit                       | SCK,OPTRX0                                         |
|           | P71        | 1                 | I/O        | PU       | Bit                       | SO/SDA,OPTTX0                                      |
|           | P72        | 1                 | I/O        | PU       | Bit                       | SI/SCL                                             |
| Port 8    | P80 to P87 | 8                 | Input      | _        | (Fixed)                   | AN0 to AN7, ADTRG (P83)                            |
| Port B    | PB0        | 1                 | I/O        | _        | Bit                       | TAOIN                                              |
|           | PB1        | 1                 | I/O        | -        | Bit                       | TA1OUT                                             |
|           | PB2        | 1                 | I/O        | -        | Bit                       | TA3OUT                                             |
|           | PB3        | 1                 | I/O        | -        | Bit                       | INTO                                               |
|           | PB4        | 1                 | I/O        | -        | Bit                       | INT1                                               |
|           | PB5        | 1                 | I/O        | -        | Bit                       | INT2                                               |
| De et O   | PB6        | 1                 | I/O        | -        | Bit                       | INT3                                               |
| Port C    | PC0<br>PC1 | 1<br>1            | I/O<br>I/O | _        | Bit<br>Bit                | TXD0<br>RXD0                                       |
|           | PC1<br>PC2 | 1                 | 1/O<br>1/O | _        | Bit                       | SCLK0/ CTS0                                        |
|           | PC3        | 1                 | 1/O        | _        | Bit                       | TXD1                                               |
|           | PC4        | 1                 | I/O        | _        | Bit                       | RXD1                                               |
|           | PC5        | 1                 | I/O        | -        | Bit                       | SCLK1/CTS1                                         |
| Port D    | PD5        | 1                 | Output     | -        | (Fixed)                   | SCOUT                                              |
|           | PD6        | 1                 | Output     | _        | (Fixed)                   | ALARM , MLDALM                                     |
|           | PD7        | 1                 | Output     | _        | (Fixed)                   | MLDALM                                             |
| Port Z    | PZ2        | 1                 | I/O        | PU       | Bit                       | HWR                                                |
|           | PZ3        | 1                 | I/O        | PU       | Bit                       | $R/\overline{W}$                                   |

Table 3.5.1 Port Functions

| Port     | Pin Name   | Specification            |    | I/O Reg | gister |       |
|----------|------------|--------------------------|----|---------|--------|-------|
| Foll     | Fill Name  | Specification            | Pn | PnCR    | PnFC   | PnFC2 |
| Port 1   | P10 to P17 | Input port               | Х  | 0       |        |       |
| (Note 1) |            | Output port              | Х  | 1       | None   |       |
|          |            | D8 to D15 bus            | Х  | Х       |        |       |
| Port 2   | P20 to P27 | Output port              | Х  | None    | 0      |       |
|          |            | A16 to A23 output        | Х  | None    | 1      |       |
| Port 5   | P54 to P56 | Input port (without PU)  | 0  | 0       | 0      |       |
|          |            | Input port (with PU)     | 1  | 0       | 0      | None  |
|          |            | Output port              | Х  | 1       | 0      |       |
|          | P54        | BUSRQ input (without PU) | 0  | 0       | 1      |       |
|          |            | BUSRQ input (with PU)    | 1  | 0       | 1      |       |
|          | P55        | BUSAK output             | Х  | 1       | 1      |       |
|          | P56        | WAIT input (without PU)  | 0  | 0       | None   |       |
|          |            | WAIT input (with PU)     | 1  | 0       | None   |       |
| Port 6   | P60 to P64 | Output port              | Х  |         | 0      | 0     |
|          | P60        | CS0 output               | Х  |         | 1      | Nama  |
|          | P61        | CS1 output               | Х  |         | 1      | None  |
|          | P62        | CS2 output               | Х  |         | 1      | 0     |
|          |            | CS2A output              | Х  |         | Х      | 1     |
|          | P63        | CS3 output               | Х  | None    | 1      | None  |
|          | P64        | EA24 output              | Х  | None    | 1      | 0     |
|          |            | CS2B output              | Х  |         | Х      | 1     |
|          | P65        | EA25 output              | Х  | ]       | 1      | 0     |
|          |            | CS2C output              | Х  |         | Х      | 1     |
|          | P66        | CS2D output              | Х  |         | 0      | 1     |
|          | P67        | CS2E output              | Х  |         | 0      | 1     |
| Port 7   | P70 to P72 | Input port (without PU)  | 0  | 0       | 0      | 0     |
|          |            | Input port (with PU)     | 1  | 0       | 0      | 0     |
|          |            | Output port              | Х  | 1       | 0      | 0     |
|          | P70        | SCK input                | Х  | 0       | 0      | 0     |
|          |            | SCK output               | Х  | 1       | 1      | 0     |
|          |            | OPTRX0 input (Note 2)    | 1  | 0       | Х      | 1     |
|          | P71        | SDA input                | Х  | 0       | 0      | 0     |
|          |            | SDA output (Note 3)      | Х  | 1       | 1      | 0     |
|          |            | SO output                | Х  | 1       | 1      | 0     |
|          |            | OPTTX0 output (Note 2)   | 1  | 1       | Х      | 1     |
|          | P72        | SI input                 | Х  | 0       | 0      | 0     |
|          |            | SCL input                | Х  | 0       | 0      | 0     |
|          |            | SCL output (Note 3)      | Х  | 1       | 1      | 0     |

| Table 352   | I/O Registers and Specifications (1/2 | 2) |
|-------------|---------------------------------------|----|
| Table 3.3.2 | I/O Registers and Specifications (1/2 | 2) |

X: Don't care

| Port   | Pin Name   | Specific                | I/O Register      |    |      |      |       |  |
|--------|------------|-------------------------|-------------------|----|------|------|-------|--|
| Port   | Pin Name   | Specific                | ation             | Pn | PnCR | PnFC | PnFC2 |  |
| Port 8 | P80 to P87 | Input port              |                   | Х  |      |      |       |  |
|        |            | AN0 to 7 input          | (Note 4)          | Х  | Nor  | ne   |       |  |
|        | P83        | ADTRG input             | (Note 5)          | Х  |      |      |       |  |
| Port B | PB0 to PB6 | Input port              |                   | Х  | 0    | 0    |       |  |
|        |            | Output port             |                   | Х  | 1    | 0    |       |  |
|        | PB0        | TA0IN input             |                   | Х  | 0    | None |       |  |
|        | PB1        | TA1OUT output           |                   | Х  | 1    | 1    |       |  |
|        | PB2        | TA3OUT output           |                   | Х  | 1    | 1    |       |  |
|        | PB3        | INT0 input              |                   | Х  | 0    | 1    |       |  |
|        | PB4        | INT1 input              |                   | Х  | 0    | 1    |       |  |
|        | PB5        | INT2 input              |                   | Х  | 0    | 1    |       |  |
|        | PB6        | INT3 input              |                   | Х  | 0    | 1    |       |  |
| Port C | PC0 to PC5 | Input port              |                   | Х  | 0    | 0    |       |  |
|        |            | Output port             |                   | Х  | 1    | 0    |       |  |
|        | PC0        | TXD0 output             | (Note 2)          | 1  | 1    | 1    |       |  |
|        | PC1        | RXD0 input              | (Note 2) (Note 6) | 1  | 0    | None |       |  |
|        | PC2        | SCLK0 input             | (Note 2)          | 1  | 0    | 0    | None  |  |
|        |            | SCLK0 output            | (Note 2)          | 1  | 1    | 1    | none  |  |
|        |            | CTS0 input              | (Note 2)          | 1  | 0    | 0    |       |  |
|        | PC3        | TXD1 output             | (Note 2)          | 1  | 1    | 1    |       |  |
|        | PC4        | RXD1 input              | (Note 2)          | 1  | 0    | None |       |  |
|        | PC5        | SCLK1 input             | (Note 2)          | 1  | 0    | 0    |       |  |
|        |            | SCLK1 output            | (Note 2)          | 1  | 1    | 1    |       |  |
|        |            | CTS1 input              | (Note 2)          | 1  | 0    | 0    |       |  |
| Port D | PD5 to PD7 | Output port             |                   | Х  |      | 0    |       |  |
|        | PD5        | SCOUT output            |                   | Х  |      | 1    |       |  |
|        | PD6        | ALARM output            |                   | 1  | None | 1    |       |  |
|        |            | MLDALM output           |                   | 0  |      | 1    |       |  |
|        | PD7        | MLDALM output           |                   | Х  |      | 1    |       |  |
| Port Z | PZ2 to PZ3 | Input port (without PU) | )                 | 0  | 0    | 0    |       |  |
|        |            | Input port (with PU)    |                   | 1  | 0    | 0    |       |  |
|        |            | Output port             |                   | Х  | 1    | 0    |       |  |
|        | PZ2        | HWR output              |                   | Х  | 1    | 1    |       |  |
|        | PZ3        | R/W output              |                   | Х  | 1    | 1    | ]     |  |

X: Don't care

Note 1: Port 1 is only use for Port or DATA bus (D8 to D15) by setting AM1 and AM0 pins.

- Note 2: As for input ports of SIO0 and SIO1 (OPTRX0, OPTTX0, TXD0, RXD0, SCLK0, CTS0, TXD1, RXD1, SCLK1, CTS1), logical selection for output data or input data is determined by the output latch register Pn of each port.
- Note 3: In case using P71 and P72 for SDA and SCL as open-drain ports, set to P7ODE <ODEP71:72>.
- Note 4: In case using P80 to P87 for analog input ports of AD converter, set to ADMOD1 < ADCH2:0>.

Note 5: In case using P83 for ADTRG input port, set to ADMOD1<ADTRGE>.

Note 6: In case using PC1 for RXD0 port, set 0 to P7FC2<P70F2>.

Note about bus release and programmable pull-up I/O port pins

When the bus is released (e.g., when  $\overline{\text{BUSAK}} = 0$ ), the output buffers for D0 to D15, A0 to A23, and the control signals ( $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ,  $\overline{\text{HWR}}$ ,  $\overline{\text{R}}/\overline{\text{W}}$  and  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ , EA24, EA25,  $\overline{\text{CS2A}}$  to  $\overline{\text{2E}}$ ) are off and are set to high impedance.

However, the output of built-in programmable pull-up resistors are kept before the bus is released. These programmable pull-up resistors can be selected ON/OFF by programmable when they are used as the input ports.

When they are used as output ports, they cannot be turned ON/OFF in software.

Table 3.5.4 shows the pin states after the bus has been released.

| Pin Name                                                         | The Pin State (when the bus is released)                                    |                                                                                                                                                |  |  |  |  |  |  |  |
|------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| T in Name                                                        | Port Mode                                                                   | Function Mode                                                                                                                                  |  |  |  |  |  |  |  |
| D0 to D7                                                         |                                                                             | Become high impedance (High-Z).                                                                                                                |  |  |  |  |  |  |  |
| D8 to D15 (P10 to P17)                                           | The state is not changed.<br>(Do not become to high impedance<br>(High-Z).) | <u>↑</u>                                                                                                                                       |  |  |  |  |  |  |  |
| A0 to A15                                                        |                                                                             | First sets all bits to high, then sets them to high impedance (High-Z).                                                                        |  |  |  |  |  |  |  |
| A16 to 23 (P20 to P27)                                           | The state is not changed.<br>(Do not become to high impedance<br>(High-Z).) | <u>↑</u>                                                                                                                                       |  |  |  |  |  |  |  |
| RD<br>WR                                                         |                                                                             | $\uparrow$                                                                                                                                     |  |  |  |  |  |  |  |
| PZ2 ( <del>IWR</del> ),<br>PZ3 (R/ ₩ ),                          | The state is not changed.<br>(Do not become to high impedance<br>(High-Z).) | First sets all bits to high, then the output<br>buffer is OFF. The programmable pull-up<br>resistor is ON irrespective of the output<br>latch. |  |  |  |  |  |  |  |
| P60 ( CS0 ), P61 ( CS1 ),<br>P62 ( CS2 , CS2A ),<br>P63 ( CS3 ), |                                                                             | First sets all bits to high, then sets them to high impedance (High-Z).                                                                        |  |  |  |  |  |  |  |

Table 3.5.4 Pin States (after bus release)

# 3.5.1 Port 1 (P10 to P17)

Port 1 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P1CR. Resetting the control register P1CR to 0 and sets port 1 to input mode.

In addition to functioning as a general-purpose I/O port, port 1 can also function as an address data bus (D8 to D15).

When AM1 = 0 and AM0 = 1, port 10 to 17 always operate data bus function even if it changes P1CR setting.



Figure 3.5.1 Port 1

# 3.5.2 Port 2 (P20 to P27)

Port 2 is an 8-bit output port. In addition to functioning as a output port, port 2 can also function as an address bus (A16 to A23).

Each bit can be set individually for address bus using the function register P2FC. Resetting sets all bits of the function register P2FC to 1 and sets port 2 to address bus.



Figure 3.5.2 Port 2

|         | Port 1 Register         |      |                                                                  |           |            |               |        |                 |      |  |  |  |  |
|---------|-------------------------|------|------------------------------------------------------------------|-----------|------------|---------------|--------|-----------------|------|--|--|--|--|
|         |                         | 7    | 6                                                                | 5         | 4          | 3             | 2      | 1               | 0    |  |  |  |  |
| P1      | Bit symbol              | P17  | P16                                                              | P15       | P14        | P13           | P12    | P11             | P10  |  |  |  |  |
| (0001H) | Read/Write              | R/W  |                                                                  |           |            |               |        |                 |      |  |  |  |  |
|         | After reset             |      | Data from external port (Output latch register is cleared to 0.) |           |            |               |        |                 |      |  |  |  |  |
|         | Port 1 Control Register |      |                                                                  |           |            |               |        |                 |      |  |  |  |  |
|         |                         | 7    | 6                                                                | 5         | 4          | 3             | 2      | 1               | 0    |  |  |  |  |
| P1CR    | Bit symbol              | P17C | P16C                                                             | P15C      | P14C       | P13C          | P12C   | P11C            | P10C |  |  |  |  |
| (0004H) | Read/Write              | Ŵ    |                                                                  |           |            |               |        |                 |      |  |  |  |  |
|         | After reset             | 0    | 0                                                                | 0         | 0          | 0             | 0      | 0               | 0    |  |  |  |  |
|         | Function                |      |                                                                  |           | 0: Input   | 1: Output     |        |                 |      |  |  |  |  |
|         |                         |      |                                                                  | Port      | 2 Registe  | ۶r            | 0      | Input<br>Output |      |  |  |  |  |
|         |                         | 7    | 6                                                                | 5         | 4          | 3             | 2      | 1               | 0    |  |  |  |  |
| P2      | Bit symbol              | P27  | P26                                                              | P25       | P24        | P23           | P22    | P21             | P20  |  |  |  |  |
| (0006H) | Read/Write              |      |                                                                  | •         | R/         | W             | •      | •               | •    |  |  |  |  |
|         | After reset             | 1    | 1                                                                | 1         | 1          | 1             | 1      | 1               | 1    |  |  |  |  |
|         |                         |      |                                                                  | Port 2 Fu | unction Re | gister        |        |                 |      |  |  |  |  |
|         |                         | 7    | 6                                                                | 5         | 4          | 3             | 2      | 1               | 0    |  |  |  |  |
| P2FC    | Bit symbol              | P27F | P26F                                                             | P25F      | P24F       | P23F          | P22F   | P21F            | P20F |  |  |  |  |
| (0009H) | Read/Write              |      |                                                                  |           | V          | V             |        |                 |      |  |  |  |  |
|         | After reset             | 1    | 1                                                                | 1         | 1          | 1             | 1      | 1               | 1    |  |  |  |  |
|         | Function                |      |                                                                  | 0: Port   | 1: Addres  | ss bus (A23 t | o A16) |                 |      |  |  |  |  |

Port 1 Register

Figure 3.5.3 Registers for Ports 1 and 2

Note: Read-modify-write is prohibited for P1CR and P2FC.

# 3.5.3 Port 5 (P54 to P56)

Port 5 is an 3-bit general-purpose I/O port. I/O is set using control register P5CR and P5FC. Resetting resets all bits of the output latch P5 to 1, the control register P5CR and the function register P5FC to 0 and sets P54 to P56 to input mode with pull-up resistor.

In addition to functioning as a general-purpose I/O port, port 5 also functions as I/O for the CPU's control/status signal.



Figure 3.5.4 Port 5 (P55)



Figure 3.5.5 Port 5 (P56, P54)

1 Output

|         | Port 5 Register |   |                                                              |                                |            |        |   |                         |   |  |  |
|---------|-----------------|---|--------------------------------------------------------------|--------------------------------|------------|--------|---|-------------------------|---|--|--|
|         |                 | 7 | 6                                                            | 5                              | 4          | 3      | 2 | 1                       | 0 |  |  |
| P5      | Bit symbol      |   | P56                                                          | P55                            | P54        |        |   |                         |   |  |  |
| (000DH) | Read/Write      |   |                                                              | R/W                            |            |        |   |                         |   |  |  |
|         | After reset     |   |                                                              | from externa<br>ch register is |            |        |   |                         |   |  |  |
|         | Function        |   | 0(Output lat<br>: Pull-up re<br>1(Output lat<br>: Pull-up re | esistor OFF<br>ch register)    |            |        |   |                         |   |  |  |
|         |                 |   |                                                              | Port 5 C                       | ontrol Reg | gister |   |                         |   |  |  |
|         |                 | 7 | 6                                                            | 5                              | 4          | 3      | 2 | 1                       | 0 |  |  |
| P5CR    | Bit symbol      |   | P56C                                                         | P55C                           | P54C       |        |   |                         |   |  |  |
| (000AH) | Read/Write      |   |                                                              | W                              |            |        |   |                         |   |  |  |
|         | After reset     |   | 0                                                            | 0                              | 0          |        |   |                         |   |  |  |
|         | Function        |   | 0: I                                                         | nput 1: Out                    | put        |        |   |                         |   |  |  |
|         |                 |   |                                                              | •                              |            |        |   | → I/O settir<br>0 Input |   |  |  |

| Port  | 5 F | unction | Reo   | lister |
|-------|-----|---------|-------|--------|
| i oit | 01  | unction | T C C | i Stor |

|         |             | 7 | 6 | 5        | 4        | 3 | 2 | 1 | 0 |
|---------|-------------|---|---|----------|----------|---|---|---|---|
| P5FC    | Bit symbol  |   |   | P55F     | P54F     |   |   |   |   |
| (000BH) | Read/Write  | / | / | V        | V        |   | / | / | / |
|         | After reset | / | / | 0        | 0        |   | / | / | / |
|         | Function    |   |   | 0: Port  | 0: Port  |   |   |   |   |
|         |             |   |   | 1: BUSAK | 1: BUSRQ |   |   |   |   |
|         |             |   |   |          |          |   |   |   |   |

Note 1: Read-modify-write is prohibited for register P5CR, P5FC.

- Note 2: When port 5 is used in the input mode, P5 register controls the built-in pull-up resistor. Readmodify-write is prohibited in the input mode or the I/O mode. Setting the built-in pull-up resistor may be depended on the states of the input pin.
- Note 3: When P56 pin is used as a WAIT pin, set P5CR<P56C> to 0 and chip select/WAIT control register BnCS<BnW2:0> to 010.

Figure 3.5.6 Register for Port 5

### 3.5.4 Port 6 (P60 to P67)

Port 60 to 67 are 8-bit output ports. Resetting sets output latch of P62 to 0 and output latches of P60 to P61, P63 to P67 to 1.

Port 6 also function as chip-select output ( $\overline{CS0}$  to  $\overline{CS3}$ ), extend address output (EA24).

Writing 1 in the corresponding bit of P6FC, P6FC2 enables the respective functions.

Resetting resets the P6FC, P6FC2 to 0, and sets all bits to output ports.

If set port 6, be careful of a setting because of chip select function.

Starting memory connects to CS2 pin, but this signal function as P62 after reset. Therefore initialized value of output data of P62 is set to "0". If manage chip select by connection many memory to outside, after program started, must to change port function to chip select function in this program. If outputted "1" remain port function, program is not run. Therefore data setting (P6) must to execute after function changing (P6FC).



Figure 3.5.7 Port 6

| -                        | Port 6 Register |                  |                  |                  |                  |         |                  |         |           |  |  |
|--------------------------|-----------------|------------------|------------------|------------------|------------------|---------|------------------|---------|-----------|--|--|
|                          |                 | 7                | 6                | 5                | 4                | 3       | 2                | 1       | 0         |  |  |
| P6                       | Bit symbol      | P67              | P66              | P65              | P64              | P63     | P62              | P61     | P60       |  |  |
| (0012H)                  | Read/Write      |                  |                  |                  | R/               | Ŵ       |                  |         |           |  |  |
|                          | After reset     | 1                | 1                | 1                | 1                | 1       | 0                | 1       | 1         |  |  |
| Port 6 Function Register |                 |                  |                  |                  |                  |         |                  |         |           |  |  |
|                          |                 | 7                | 6                | 5                | 4                | 3       | 2                | 1       | 0         |  |  |
| P6FC                     | Bit symbol      | _                | -                | P65F             | P64F             | P63F    | P62F             | P61F    | P60F      |  |  |
| (0015H)                  | Read/Write      |                  |                  |                  | ١                | W       |                  |         |           |  |  |
|                          | After reset     | 0                | 0                | 0                | 0                | 0       | 0                | 0       | 0         |  |  |
|                          | Function        | Always write 0   |                  | 0:Port           | 0: Port          | 0: Port | 0: Port          | 0: Port | 0: Port   |  |  |
|                          |                 |                  |                  | 1:EA25           | 1: EA24          | 1: CS3  | 1: CS2           | 1: CS1  | 1: CS0    |  |  |
|                          |                 |                  |                  | Port 6 Fu        | unction Regis    | ster 2  |                  |         |           |  |  |
|                          |                 | 7                | 6                | 5                | 4                | 3       | 2                | 1       | 0         |  |  |
| P6FC2                    | Bit symbol      | P67F2            | P66F2            | P65F2            | P64F2            | -       | P62F2            | _       | -         |  |  |
| (001BH)                  | Read/Write      |                  | V                | V                |                  | W       | W                | W       | W         |  |  |
|                          | After reset     | 0                | 0                | 0                | 0                | 0       | 0                | 0       | 0         |  |  |
|                          | Function        | 0: <p67f></p67f> | 0: <p66f></p66f> | 0: <p65f></p65f> | 0: <p64f></p64f> | Always  | 0: <p62f></p62f> | Always  | s write 0 |  |  |
|                          |                 | 1: CS2E          | 1: CS2D          | 1: CS2C          | 1: CS2B          | write 0 | 1: CS2A          |         |           |  |  |

Note: Read-modify-write is prohibited for P6FC and P6FC2.

Figure 3.5.8 Register for Port 6

#### 3.5.5 Port 7 (P70 to P72)

Port 7 is a 3-bit general-purpose I/O port. I/O can be set on bit basis using the control register. Resetting sets port 7 to input port and all bits of output latch to 1.

In addition to functioning as a general-purpose I/O port, port 7 also functions as follows.

- 1. Input/output function for serial bus interface (SCK, SO/SDA.SI/SCL)
- 2. Input/output function for IrDA (OPTRX0, OPTTX0)

Writing 1 in the corresponding bit of P7FC, P7FC2 enables the respective functions. Resetting resets the P7FC, P7FC2, and P7CR to 0, and sets all bits to input ports.

(1) Port 70 (SCK, OPTRX0)

Port 70 is a general-purpose I/O port. It is also used as SCK (Clock signal for SIO mode) and OPTRX0 (Receive input for IrDA mode of SIO0).

Used as OPTRX0, it is possible to logical invert by P7 < P70 > = 0.

For port C1, RXD0 or OPTRX0 is used P7FC2<P70F2>.



Figure 3.5.9 Port 70

(2) Port 71 (SO/SDA/OPTTX0)

Port 71 is a general-purpose I/O port. It is also used as SDA (Data input for  $I^2C$  mode), SO (Data output for SIO mode) for serial bus interface and OPTTX0 (Transmit output for IrDA mode of SIO0).

Used as OPTTX0, it is possible to logical invert by P7 < P71 > = 0.



Figure 3.5.10 Port 71

(3) Port 72 (SI/SCL)

Port 72 is a general-purpose I/O port. It is also used as SI (Data input for SIO mode), SCL (Clock input/output for  $I^2C$  mode) for serial bus interface and input for release hard protect.



Figure 3.5.11 Port 72

|         | Port 7 Register |          |               |            |              |         |             |                              |                |  |
|---------|-----------------|----------|---------------|------------|--------------|---------|-------------|------------------------------|----------------|--|
|         |                 | 7        | 6             | 5          | 4            | 3       | 2           | 1                            | 0              |  |
| P7      | Bit symbol      |          |               |            |              |         | P72         | P71                          | P70            |  |
| (0013H) | Read/Write      |          |               |            |              |         |             | R/W                          |                |  |
|         | After reset     |          | $\overline{}$ |            |              |         |             | from externa                 |                |  |
|         |                 |          |               |            |              |         |             | tch register is              | s set to "1".) |  |
|         | Function        |          |               |            |              |         |             | tch register)                |                |  |
|         |                 |          |               |            |              |         |             | esistor ON                   | -              |  |
|         |                 |          |               |            |              |         | · ·         | tch register)<br>esistor OFF |                |  |
|         |                 |          |               |            |              |         | : Pull-up r | esistor OFF                  |                |  |
|         |                 |          |               | Port 7 Co  | ontrol Reg   | jister  |             |                              |                |  |
|         |                 | 7        | 6             | 5          | 4            | 3       | 2           | 1                            | 0              |  |
| P7CR    | Bit symbol      |          |               | /          | /            | /       | P72C        | P71C                         | P70C           |  |
| (0016H) | Read/Write      | $\frown$ | $\frown$      | $\sim$     | $\mathbb{Z}$ | $\sim$  |             | W                            |                |  |
|         | After reset     |          | $\frown$      |            |              |         | 0           | 0                            | 0              |  |
|         | Function        |          |               |            |              |         | 0:          | Input 1: Ou                  | itput          |  |
|         |                 |          |               |            | notion Do    |         |             |                              |                |  |
|         |                 | _        |               |            | nction Re    | -       |             | · ·                          |                |  |
|         |                 | 7        | 6             | 5          | 4            | 3       | 2           | 1                            | 0              |  |
| P7FC    | Bit symbol      |          |               |            |              |         | P72F        | P71F                         | P70F           |  |
| (0017H) | Read/Write      |          |               | >          |              |         |             | W                            |                |  |
|         | After reset     |          |               |            |              |         | 0           | 0                            | 0              |  |
|         | Function        |          |               |            |              |         | 0: Port     | 0: Port                      | 0: Port        |  |
|         |                 |          |               |            |              |         | 1: SCL      | 1: SDA/SO                    | 1: SCK         |  |
|         |                 |          |               |            |              |         | output      | output                       | output         |  |
|         |                 |          |               | Port 7 Fun | ction Reg    | ister 2 |             |                              |                |  |
|         |                 | 7        | 6             | 5          | 4            | 3       | 2           | 1                            | 0              |  |
| P7FC2   | Bit symbol      |          |               |            | /            |         | -           | P71F2                        | P70F2          |  |
| (001CH) | Read/Write      |          |               | /          |              | /       |             | W                            |                |  |
|         | After reset     |          |               |            | /            | /       | 0           | 0                            | 0              |  |
|         | Function        |          |               |            |              |         | Always      | 0: <p71f></p71f>             | SIO0 RXD       |  |
|         |                 |          |               |            |              |         | write 0     | 1: OPTTX0                    | pin select     |  |
|         |                 |          |               |            |              |         |             | output                       | 0: RXD0 (PC1)  |  |
|         |                 |          |               |            |              |         |             |                              | 1: OPTRX0      |  |
|         |                 |          |               |            |              |         |             |                              | (P70)          |  |
|         |                 |          |               | Port 7 (   | DDE Regi     | ster    |             |                              |                |  |
|         |                 | 7        | 6             | 5          | 4            | 3       | 2           | 1                            | 0              |  |
| P70DE   | Bit symbol      |          |               |            |              |         | ODEP72      | ODEP71                       |                |  |
| (001FH) | Read/Write      | $\frown$ | $\sim$        |            | $\sim$       |         |             | W                            |                |  |
|         | After reset     |          | $\sim$        |            | $\sim$       |         | 0           | 0                            |                |  |
|         | Function        |          |               |            |              |         | 0: 3 states |                              |                |  |
|         |                 |          |               |            |              |         | 1: Open dra | ain                          |                |  |
|         |                 |          |               |            |              |         |             |                              |                |  |

Port 7 Register

Note: Read-modify-write is prohibited for P7CR, P7FC, P7FC2 and P7ODE.

Figure 3.5.12 Register for Port 7

# 3.5.6 Port 8 (P80 to P87)

Port 8 is an 8-bit input port and can also be used as the analog input pins for the internal AD converter. P83 can also be used as ADTRG pin for the AD converter.



#### Figure 3.5.13 Port 8

| Port 8 Register |             |     |     |     |             |              |     |     |     |  |  |
|-----------------|-------------|-----|-----|-----|-------------|--------------|-----|-----|-----|--|--|
| P8<br>(0018H)   | /           | 7   | 6   | 5   | 4           | 3            | 2   | 1   | 0   |  |  |
|                 | Bit symbol  | P87 | P86 | P85 | P84         | P83          | P82 | P81 | P80 |  |  |
|                 | Read/Write  |     | R   |     |             |              |     |     |     |  |  |
|                 | After reset |     |     |     | Data from e | xternal port |     |     |     |  |  |

Note: The input channel selection of AD converter and the permission of ADTRG input are set by AD converter mode register ADMOD1.

Figure 3.5.14 Register for Port 8

## 3.5.7 Port B (PB0 to PB6)

Port B0 to PB6 is a 7-bit general-purpose I/O port. Each bit can be set individually for input or output. Resetting sets port B to be an input port.

In addition to functioning as a general-purpose I/O port, port B0 has clock input terminal TA0IN of 8-bit timer 0, and port B1, B2 each has facility of 8-bit timer listing TA10UT, TA30UT terminal. And, port B3 to B6 has each external interruption input facility of INT0 to INT3. Edge selection of external interruption is establishes by IIMC register in the interrupt controller.

Timer output function and external interrupt function can be enabled by writing 1 to the corresponding bits in the port B function register (PBFC). Resetting resets all bits of the registers PBCR and PBFC to 0, and sets all bits to be input ports.



(1) PB0 to PB2

Figure 3.5.15 Port B0 to B2







Figure 3.5.17 Port B4 to B6

|         | 5                        |   |                    |           |              |                |               |              |      |  |  |  |  |
|---------|--------------------------|---|--------------------|-----------|--------------|----------------|---------------|--------------|------|--|--|--|--|
|         | /                        | 7 | 6                  | 5         | 4            | 3              | 2             | 1            | 0    |  |  |  |  |
| PB      | Bit symbol               | / | PB6                | PB5       | PB4          | PB3            | PB2           | PB1          | PB0  |  |  |  |  |
| (0022H) | Read/Write               |   |                    |           |              | R/W            |               |              |      |  |  |  |  |
|         | After reset              |   |                    | Data from | external por | t (Output late | h register is | set to "1".) |      |  |  |  |  |
|         | Port B Control Register  |   |                    |           |              |                |               |              |      |  |  |  |  |
|         | /                        | 7 | 6                  | 5         | 4            | 3              | 2             | 1            | 0    |  |  |  |  |
| PBCR    | Bit symbol               |   | PB6C               | PB5C      | PB4C         | PB3C           | PB2C          | PB1C         | PB0C |  |  |  |  |
| (0024H) | Read/Write               |   |                    | W         |              |                |               |              |      |  |  |  |  |
|         | After reset              | / | 0                  | 0         | 0            | 0              | 0             | 0            | 0    |  |  |  |  |
|         | Function                 |   | 0: Input 1: Output |           |              |                |               |              |      |  |  |  |  |
|         | Port B Function Register |   |                    |           |              |                |               |              |      |  |  |  |  |
|         |                          | 7 | 6                  | 5         | 4            | 3              | 2             | 1            | 0    |  |  |  |  |
| PBFC    | Bit symbol               |   | PB6F               | PB5F      | PB4F         | PB3F           | PB2F          | PB1F         |      |  |  |  |  |
| (0025H) | Read/Write               | / |                    |           | V            | V              |               |              |      |  |  |  |  |
| . ,     | After reset              | / | 0                  | 0         | 0            | 0              | 0             | 0            |      |  |  |  |  |
|         | Function                 |   | 0: Port            | 0: Port   | 0: Port      | 0: Port        | 0: Port       | 0: Port      |      |  |  |  |  |
|         |                          |   | 1: INT3            | 1: INT2   | 1: INT1      | 1: INT0        | 1: TA3OUT     | 1: TA1OUT    |      |  |  |  |  |

#### Port B Register

Note 1: Read-Modify-Write is prohibited for the registers PBCR and PBFC.

Note 2: PB0/TA0IN pin does not have a register changing PORT/FUNCTION.

For example, when it is used as an input port, the input signal is inputted to 8-bit timer.

Figure 3.5.18 Register for Port B

### 3.5.8 Port C (PC0 to PC5)

Port C0 to C5 are 6-bit general-purpose I/O ports. Each bit can be set individually for input or output. Resetting sets PC0 to PC5 to be an input ports. It also sets all bits of the output latch register to 1.

In addition to functioning as general-purpose I/O port pins, PC0 to PC5 can also function as the I/O for serial channels 0 and 1. A pin can be enabled for I/O by writing 1 to the corresponding bit of the port C function register (PCFC).

Resetting resets all bits of the registers  $\ensuremath{\text{PCFC}}$  and  $\ensuremath{\text{PCFC}}$  to 0 and sets all pins to be input ports .

#### (1) Port C0, C3 (TXD0/TXD1)

As well as functioning as I/O port pins, port C0 and C3 can also function as serial channel TXD output pins. In case of use TXD0/TXD1, it is possible to logical invert by setting the register PC<PC0, 3>.

And port C0 to C3 have a programmable open-drain function which can be controlled by the register PCODE<ODEPC0, 3>.



Figure 3.5.19 Port C0 and C3

(2) Port C1, C4 (RXD0, RXD1)

Port C1 and C4 are I/O port pins and can also is used as RXD input for the serial channels. In case of use RXD0/RXD1, it is possible to logical invert by setting the register PC<PC1, 4>.

And input data of SIO0 can be select from RXD0/PC1 pin or OPTRX0/P70 by setting the register PCFC2<P70F2>.



Figure 3.5.20 Port C1 and C4

(3) Port C2 ( $\overline{\text{CTS0}}$ , SCLK0), C5 ( $\overline{\text{CTS1}}$ , SCLK1)

Port C2 and C4 are I/O port pins and can also is used as  $\overline{\text{CTS}}$  input or SCLK input/output for the serial channels. In case of use  $\overline{\text{CTS}}$ , SCLK, it is possible to logical invert by setting the register PC<PC2, 5>.



Figure 3.5.21 Port C2 and C5

|        |             |   |              | Port     | C Regist    | er             |                |                |         |
|--------|-------------|---|--------------|----------|-------------|----------------|----------------|----------------|---------|
|        |             | 7 | 6            | 5        | 4           | 3              | 2              | 1              | 0       |
| с      | Bit symbol  |   |              | PC5      | PC4         | PC3            | PC2            | PC1            | PC0     |
| 0023H) | Read/Write  |   |              |          | •           | R              | Ŵ              |                |         |
|        | After reset |   |              | Dat      | a from exte | rnal port (Out | put latch regi | ster is set to | o "1".) |
|        |             |   |              | Port C C | Control Re  | egister        |                |                |         |
|        |             | 7 | 6            | 5        | 4           | 3              | 2              | 1              | 0       |
|        | Bit symbol  | / | $\backslash$ | PC5C     | PC4C        | PC3C           | PC2C           | PC1C           | PC0C    |
| CCR    | Read/Write  |   |              |          | •           | · ·            | V              |                |         |
| 0026H) | After reset |   | /            | 0        | 0           | 0              | 0              | 0              | 0       |
|        | Function    |   |              |          | •           | 0: Input       | 1: Output      |                |         |
|        |             |   |              | Port C F | uncton R    | egister        |                |                |         |
|        |             | 7 | 6            | 5        | 4           | 3              | 2              | 1              | 0       |
| PCFC   | Bit symbol  | / | $\bigcirc$   | PC5F     |             | PC3F           | PC2F           | /              | PC0F    |
| 0027H) | Read/Write  |   | /            | W        |             | W              | W              |                | W       |
|        | After reset | / |              | 0        |             | 0              | 0              |                | 0       |
|        | Function    |   |              | 0: Port  |             | 0: Port        | 0: Port        |                | 0: Port |
|        |             |   |              | 1: SCLK1 |             | 1: TXD1        | 1: SCLK0       |                | 1: TXD0 |
|        |             |   |              | output   |             |                | output         |                |         |
|        |             |   |              | Port C   | ODE Reg     | gister         |                |                |         |
|        |             | 7 | 6            | 5        | 4           | 3              | 2              | 1              | 0       |
|        | Bit symbol  |   |              |          |             | ODEPC3         |                |                | ODEPC   |
| CODE   | Read/Write  |   |              |          |             | W              |                |                | W       |
| 0028H) | After reset |   |              |          |             | 0              |                | /              | 0       |
|        | Function    |   |              |          |             | TXD1           |                |                | TXD0    |
|        |             |   |              |          |             | 0: CMOS        |                |                | 0: CMOS |
|        |             |   |              |          |             | 1: Open        |                |                | 1: Open |
|        |             |   |              |          |             | drain          |                |                | drain   |

Note 1: Read-modify-write is prohibited for the registers PCCR, PCFC and PCODE.

Note 2: PC1/RXD0, PC4/RXD1 pins do not have a register changing PORT/FUNCTION. For example, when it is used as an input port, the input signal is inputted to SIO as the cereal receive data.

Figure 3.5.22 Register for Port C

### 3.5.9 Port D (PD0 to PD7)

Port D is an 8-bit output port. Resetting sets the output latch PD to 1, and PD5 to PD7 pin output 1.

In addition to functioning as output port, port D also function as output pin for output pin for internal clock (SCOUT), output pin for RTC alarm ( $\overline{\text{ALARM}}$ ) and output pin for melody/alarm generator (MLDALM,  $\overline{\text{MLDALM}}$ ). Above setting is used the function register PDFC.

Only PD6 has two output functions which  $\overline{\text{ALARM}}$  and  $\overline{\text{MLDALM}}$ . This selection is used PD<PD6>. Resetting resets the function register PDFC to 0, and sets all ports to output ports.



Figure 3.5.23 Port D



Figure 3.5.24 Port D



Figure 3.5.25 Port D

|                          | Port D Register |           |                  |          |   |   |   |   |   |  |  |  |
|--------------------------|-----------------|-----------|------------------|----------|---|---|---|---|---|--|--|--|
|                          |                 | 7         | 6                | 5        | 4 | 3 | 2 | 1 | 0 |  |  |  |
| PD                       | Bit symbol      | PD7       | PD6              | PD5      | / | / |   |   |   |  |  |  |
| (0029H)                  | Read/Write      |           | R/W              |          | / | / |   |   |   |  |  |  |
|                          | After reset     | 1         | 1                | 1        |   |   |   |   |   |  |  |  |
| Port D Function Register |                 |           |                  |          |   |   |   |   |   |  |  |  |
|                          | /               | 7         | 6                | 5        | 4 | 3 | 2 | 1 | 0 |  |  |  |
| PDFC                     | Bit symbol      | PD7F      | PD6F             | PD5F     |   |   | / |   |   |  |  |  |
| (002AH)                  | Read/Write      |           | W                |          | / | / | / | / | / |  |  |  |
|                          | After reset     | 0         | 0                | 0        |   |   |   |   |   |  |  |  |
|                          | Function        | 0: Port   | 0: Port          | 0: Port  |   |   |   |   |   |  |  |  |
|                          |                 | 1: MLDALM | 1: ALARM         | 1: SCOUT |   |   |   |   |   |  |  |  |
|                          |                 |           | at <pd6>=1</pd6> |          |   |   |   |   |   |  |  |  |
|                          |                 |           | 1: MLDALM        |          |   |   |   |   |   |  |  |  |
|                          |                 |           | at <pd6>=0</pd6> |          |   |   |   |   |   |  |  |  |

Note: Read-modify-write is prohibited for the registers PDFC.

Figure 3.5.26 Register for Port D

#### 3.5.10 Port Z (PZ2 to PZ3)

Port Z is the 2-bit general-purpose I/O port. I/O is set using control register PZCR and PZFC. Resetting resets all bits of the output latch PZ to 1.

In addition to functioning as a general-purpose I/O port, port Z also functions as output for the CPU's control/status signal.

Resetting initializes  $\ensuremath{\text{PZ2}}$  and  $\ensuremath{\text{PZ3}}$  pins to input mode with pull-up resistor.

When the PZ<RDE> register clearing to 0,outputs the  $\overline{\text{RD}}$  strobe (used for the peused static RAM) of the  $\overline{\text{RD}}$  pin even when the internal addressed.

If the  $\langle RDE \rangle$  remains 1, the  $\overline{RD}$  strobe signal is output only when the external address are is accessed.



Figure 3.5.27 Port Z (PZ2, PZ3)

|         | Port Z Register                              |                   |    |           |            |                    |                                                                      |              |     |  |  |
|---------|----------------------------------------------|-------------------|----|-----------|------------|--------------------|----------------------------------------------------------------------|--------------|-----|--|--|
|         |                                              | 7                 | 6  | 5         | 4          | 3                  | 2                                                                    | 1            | 0   |  |  |
| Z       | Bit symbol                                   |                   |    |           |            | PZ3                | PZ2                                                                  |              | RDE |  |  |
| 007DH)  | Read/Write                                   | /                 |    |           | /          | R                  | /W                                                                   | /            | R/W |  |  |
|         | After reset                                  |                   |    |           |            | (Output la         | Data from external port<br>(Output latch register<br>is set to "1".) |              | 1   |  |  |
|         | Function                                     |                   |    |           |            | : Pull-up re       | tch register)<br>esistor OFF<br>tch register)<br>esistor ON          |              |     |  |  |
|         |                                              |                   |    | Port Z C  | ontrol Reg | gister             |                                                                      |              |     |  |  |
|         |                                              | 7                 | 6  | 5         | 4          | 3                  | 2                                                                    | 1            | 0   |  |  |
| ZCR     | Bit symbol                                   |                   |    |           |            | PZ3C               | PZ2C                                                                 |              |     |  |  |
| (007EH) | Read/Write                                   | /                 | /  |           | /          | W                  |                                                                      | /            |     |  |  |
|         | After reset                                  |                   |    |           |            | 0                  | 0                                                                    |              |     |  |  |
|         | Function                                     |                   |    |           |            | 0: Input           | 1: Output                                                            |              |     |  |  |
|         |                                              |                   |    | Port Z Fu | unction Re | gister             |                                                                      |              |     |  |  |
|         |                                              | 7                 | 6  | 5         | 4          | 3                  | 2                                                                    | 1            | 0   |  |  |
| ZFC     | Bit symbol                                   | -                 | // | /         | /          | PZ3F               | PZ2F                                                                 |              | /   |  |  |
| 007FH)  | Read/Write                                   | W                 | // |           |            | ١                  | N                                                                    |              |     |  |  |
|         | After reset                                  | 0                 | /  |           | /          | 0                  | 0                                                                    |              |     |  |  |
|         | Function                                     | Always<br>write 0 |    |           |            | 0: Port<br>1: R/ W | 0: Port<br>1: HWR                                                    |              |     |  |  |
|         |                                              | 1                 | 1  |           |            |                    |                                                                      | → HWR settir |     |  |  |
|         | PZFC <pz2f> 1<br/>PZCR<pz2c> 1</pz2c></pz2f> |                   |    |           |            |                    |                                                                      |              |     |  |  |

Port Z Register

Note 1: Read-modify-write is prohibited for registers PZCR and PZFC.

Note 2: When port Z is used in input mode, the PZ register controls the built-in pull-up resistor. Readmodify-write is prohibited in input mode or I/O mode. Setting the built-in pull-up resistor may be depended on the states of the input pin.

Figure 3.5.28 Port Register for Port Z

### 3.6 Chip Select/Wait Controller

On the TM91C824, four user-specifiable address areas (CS0 to CS3) can be set. The data bus width and the number of waits can be set independently for each address area (CS0 to CS3 and others).

The pins  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  (which can also function as port pins P60 to P63) are the respective output pins for the areas CS0 to CS3. When the CPU specifies an address in one of these areas, the corresponding  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  pin outputs the chip select signal for the specified address area (in ROM or SRAM). However, in order for the chip select signal to be output, the port 6 function register P6FC must be set.

 $\overline{\text{CS2A}}$  To  $\overline{\text{CS2E}}$  (CS pin except  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ ) are made by MMU.

These pins are  $\overline{CS}$  pin that area and BANK value is fixed without concern in setting of CS/WAIT controller.

The areas CS0 to CS3 are defined by the values in the memory start address registers MSAR0 to MSAR3 and the memory address mask registers MAMR0 to MAMR3.

The chip select/wait control registers B0CS to B3CS and BEXCS should be used to specify the master enable/disable status the data bus width and the number of waits for each address area.

The input pin controlling these states is the bus wait request pin  $(\overline{WAIT})$ .

#### 3.6.1 Specifying an Address Area

The CS0 to CS3 address areas are specified using the start address registers (MSAR0 to MSAR3) and memory address mask registers (MAMR0 to MAMR3).

At each bus cycle, a compare operation is performed to determine if the address on the specified a location in the CS0 to CS3 area. If the result of the comparison is a match, this indicates an access to the corresponding CS area. In this case, the  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  pin outputs the chip select signal and the bus cycle operates in accordance with the settings in chip select/wait control register B0CS to B3CS. (See 3.6.2 "Chip Select/Wait Control Registers".)

(1) Memory start address registers

Figure 3.6.1 shows the memory start address registers. The memory start address registers MSAR0 to MSAR3 set the start addresses for the CS0 to CS3 areas. Set the upper 8 bits (A23 to A16) of the start address in <S23:16>. The lower 16 bits of the start address (A15 to A0) are permanently set to 0. Accordingly, the start address can only be set in 64-Kbyte increments, starting from 000000H. Figure 3.6.2 shows the relationship between the start address and the start address register value.

|                  |            | 7   | 6                                       | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |  |
|------------------|------------|-----|-----------------------------------------|-----|-----|-----|-----|-----|-----|--|--|--|--|
| MSAR0 /MSAR1     | Bit symbol | S23 | S22                                     | S21 | S20 | S19 | S18 | S17 | S16 |  |  |  |  |
| (00C8H)/ (00CAH) | Read/Write |     | R/W                                     |     |     |     |     |     |     |  |  |  |  |
| MSAR2 /MSAR3     | 7          | 1   | 1                                       | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |  |
| (00CCH)/ (00CEH) | Function   |     | Determines A23 to A16 of start address. |     |     |     |     |     |     |  |  |  |  |
|                  |            |     |                                         |     | •   |     |     |     |     |  |  |  |  |

#### Memory Start Address Registers (for areas CS0 to CS3)

 $\longrightarrow$  Sets start addresses for areas CS0 to CS3.



| Address<br>000000H <sub>f</sub> | •           | Start address                                    | Value in start | address register (MSAR0 to MSAR3) |
|---------------------------------|-------------|--------------------------------------------------|----------------|-----------------------------------|
| -                               | ↓ 64 Kbytes | ←000000H                                         |                | 00H                               |
| -                               |             | ←010000H                                         |                | 01H                               |
| -                               |             | ←020000H                                         |                | 02H                               |
| -                               |             | ←───030000H                                      |                | 03H                               |
| -                               |             | ←040000H                                         |                | 04H                               |
| -                               |             | ←───050000H                                      |                | 05H                               |
|                                 |             | ←060000H                                         |                | 06H                               |
| -                               |             | to                                               |                | to                                |
| FFFFFFH                         |             | <ff0000h< td=""><td></td><td>FFH</td></ff0000h<> |                | FFH                               |

#### Figure 3.6.2 Relationship between Start Address and Start Address Register Value

(2) Memory address mask registers

Figure 3.6.3 shows the memory address mask registers. Memory address mask registers MAMR0 to MAMR3 are used to set the size of the CS0 to CS3 areas by specifying a mask for each bit of the start address set in memory start address registers MAMR0 to MAMR3. The compare operation used to determine if an address is in the CS0 to CS3 areas is only performed for bus address bits corresponding to bits set to 0 in these registers. Also, the address bits that can be masked by MAMR0 to MAMR3 differ between CS0 to CS3 areas. Accordingly, the size that can be each area is different.

|         |                                                            | 7   | 6   | 5   | 4   | 3   | 2   | 1         | 0  |  |  |  |
|---------|------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----------|----|--|--|--|
| MAMR0   | Bit symbol                                                 | V20 | V19 | V18 | V17 | V16 | V15 | V14 to V9 | V8 |  |  |  |
| (00C9H) | Read/Write                                                 | R/W |     |     |     |     |     |           |    |  |  |  |
|         | After reset                                                | 1   | 1   | 1   | 1   | 1   | 1   | 1         | 1  |  |  |  |
|         | Function Sets size of CS0 area 0: Used for address compare |     |     |     |     |     |     |           |    |  |  |  |

Memory Address Mask Register (for CS0 area)

Range of possible settings for CS0 area size: 256 bytes to 2 Mbytes

#### Memory Address Mask Register (CS1)

|         |                                                            | 7   | 6                                | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
|---------|------------------------------------------------------------|-----|----------------------------------|---|---|---|---|---|---|--|--|--|--|
| MAMR1   | Bit symbol                                                 | V21 | V21 V20 V19 V18 V17 V16 V15 to V |   |   |   |   |   |   |  |  |  |  |
| (00CBH) | Read/Write                                                 |     | R/W                              |   |   |   |   |   |   |  |  |  |  |
|         | After reset                                                | 1   | 1                                | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |
|         | Function Sets size of CS1 area 0: Used for address compare |     |                                  |   |   |   |   |   |   |  |  |  |  |

Range of possible settings for CS1 area size: 256 bytes to 4 Mbytes.

| Memory Address | Mask Registe | r (CS2, CS3) |
|----------------|--------------|--------------|
|----------------|--------------|--------------|

|                  |                                                                   | 7   | 6                           | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|------------------|-------------------------------------------------------------------|-----|-----------------------------|---|---|---|---|---|---|--|--|--|
| MAMR2 / MAMR3    | DILSVIIDUI                                                        | V22 | V22 V21 V20 V19 V18 V17 V16 |   |   |   |   |   |   |  |  |  |
| (00CDH)/ (00CFH) | Read/Write                                                        | R/W |                             |   |   |   |   |   |   |  |  |  |
|                  | After reset                                                       | 1   | 1                           | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |
|                  | Function Sets size of CS2 or CS3 area 0: Used for address compare |     |                             |   |   |   |   |   |   |  |  |  |

Range of possible settings for CS2 and CS3 area sizes: 32 Kbytes to 8 Mbytes.

Figure 3.6.3 Memory Address Mask Registers

(3) Setting memory start addresses and address areas

Figure 3.6.4 show an example of specifying a 64-Kbyte address area starting from 010000H using the CS0 areas.

Set 01H in memory start address register MSAR0<S23:16> (Corresponding to the upper 8 bits of the start address). Next, calculate the difference between the start address and the anticipated end address (01FFFFH). Bits 20 to 8 of the result correspond to the mask value to be set for the CS0 area. Setting this value in memory address mask register MAMR0<V20:8> sets the area size This example sets 07H in MAMR0 to specify a 64-Kbyte area.



Figure 3.6.4 Example Showing How to Set the CS0 Area

After a reset, MSAR0 to MSAR3 and MAMR0 to MAMR3 are set to FFH. B0CS<B0E>, B1CS<B1E> and B3CS<B3E> are reset to 0. This disabling the CS0, CS1 and CS3 areas. However, as B2CS<B2M> to 0 and B2CS<B2E> to 1, CS2 is enabled from 000FE0H to 000FFFH to 003000H to FFFFFFH in TMP91C824. Also, the bus width and number of waits specified in BEXCS are used for accessing addresses outside the specified CS0 to CS3 area. (See 3.6.2 "Chip Select/Wait Control Registers".)

(4) Address area size specification

Table 3.6.1 shows the relationship between CS area and area size. " $\Delta$ " indicates areas that cannot be set by memory start address register and address mask register combinations. When setting an area size using a combination indicated by " $\Delta$ ", set the start address mask register in the desired steps starting from 000000H.

If the CS2 area is set to 16-Mbytes or if two or more areas overlap, the smaller CS area number has the higher priority.

Example: To set the area size for CS0 to 128 Kbytes:

a. Valid start addresses



| Size (Bytes)<br>CS Area | 256 | 512 | 32 K | 64 K | 128 K | 256 K | 512 K | 1 M | 2 M | 4 M | 8 M |
|-------------------------|-----|-----|------|------|-------|-------|-------|-----|-----|-----|-----|
| CS0                     | 0   | 0   | 0    | 0    | Δ     | Δ     | Δ     | Δ   | Δ   |     |     |
| CS1                     | 0   | 0   |      | 0    | Δ     | Δ     | Δ     | Δ   | Δ   | Δ   |     |
| CS2                     |     |     | 0    | 0    | Δ     | Δ     | Δ     | Δ   | Δ   | Δ   | Δ   |
| CS3                     |     |     | 0    | 0    | Δ     | Δ     | Δ     | Δ   | Δ   | Δ   | Δ   |

Table 3.6.1 Valid Area Sizes for Each CS Area

Note: " $\Delta$ " indicates areas that cannot be set by memory start address register and address mask register combinations.

### 3.6.2 Chip Select/Wait Control Registers

Figure 3.6.5 lists the chip select/wait control registers.

The master enable/disable, chip select output waveform, data bus width and number of wait states for each address area (CS0 to CS3 and others) are set in their respective chip select/wait control registers, BOCS to B3CS and BEXCS.

|                       |                          | 7                      | 6            | 5             | 4         | 3                              | 2                          | 1             | 0                  |  |
|-----------------------|--------------------------|------------------------|--------------|---------------|-----------|--------------------------------|----------------------------|---------------|--------------------|--|
| B0CS                  | Bit symbol               | B0E                    | $\backslash$ | B0OM1         | B0OM0     | B0BUS                          | B0W2                       | B0W1          | B0W0               |  |
| (00C0H)               | Read/Write               | W                      | $\backslash$ | Doomi         | Doomo     |                                | V                          | Donn          | 20110              |  |
|                       | After reset              | 0                      | $\backslash$ | 0             | 0         | 0                              | 0                          | 0             | 0                  |  |
| Read-                 | Function                 | 0: Disable             |              | Chip select   | -         | Data bus                       | Number of                  |               |                    |  |
| modify-<br>write      | 1 dilotion               | 1: Enable              |              | waveform s    |           | width                          | 000: 2 wait                |               | Reserved           |  |
| instructions          |                          |                        |              | 00: For RO    |           | 0: 16 bits                     | 001: 1 wait                |               | 3 waits            |  |
| are prohibited.       |                          |                        |              | 01: ר         |           | 1: 8 bits                      |                            | ) waits 110:  |                    |  |
| promotion             |                          |                        |              |               | on't care |                                | 011: 0 wait                |               | 8 waits            |  |
|                       |                          |                        |              | 11: J         |           |                                |                            |               |                    |  |
| B1CS                  | Bit symbol               | B1E                    | /            | B1OM1         | B1OM0     | B1BUS                          | B1W2                       | B1W1          | B1W0               |  |
| (00C1H)               | Read/Write               | W                      |              |               | •         | V                              | V                          |               |                    |  |
|                       | After reset              | 0                      | /            | 0             | 0         | 0                              | 0                          | 0             | 0                  |  |
| Read-                 | Function                 | 0: Disable             |              | Chip select   |           | Data bus                       | Number of                  |               |                    |  |
| modify-<br>write      |                          | 1: Enable              |              | waveform s    | •         | width                          | 000: 2 wait                |               | Reserved           |  |
| instructions          |                          |                        |              | 00: For RO    | M/SRAM    | 0: 16 bits                     | 001: 1 wait                | 101:          | 3 waits            |  |
| are prohibited.       |                          |                        |              | ר :01         |           | 1: 8 bits                      | 010: (1 + N                | ) waits 110:  | 4 waits            |  |
|                       |                          |                        |              | 10: - Do      | on't care |                                | 011: 0 wait                | s 111:        | 8 waits            |  |
|                       |                          |                        |              | 11: J         |           |                                |                            |               |                    |  |
| B2CS                  | Bit symbol               | B2E                    | B2M          | B2OM1         | B2OM0     | B2BUS                          | B2W2                       | B2W1          | B2W0               |  |
| (00C2H)               | Read/Write               |                        |              |               | V         | V                              |                            |               |                    |  |
|                       | After reset              | 1                      | 0            | 0             | 0         | 0                              | 0                          | 0             | 0                  |  |
| Read-                 | Functions                | 0: Disable             | CS2 area     | Chip select   | t output  | Data bus                       | Number of                  | waits         |                    |  |
| modify-<br>write      | modify-<br>write         |                        | selection    | waveform s    | selection | width                          | 000: 2 wait                | s 100:        | Reserved           |  |
| instructions          |                          |                        | 0: 16-Mbyte  | 00: For RO    | M/SRAM    | 0: 16 bits                     | 001: 1 wait                | 101:          | 3 waits            |  |
| are<br>prohibited.    |                          |                        | area         | 01: ך         |           | 1: 8 bits                      | 010: (1 + N                | ) waits 110:  | 4 waits            |  |
|                       |                          |                        | 1: CS area   | 10:           | on't care |                                | 011: 0 wait                | s 111:        | 8 waits            |  |
|                       |                          |                        |              | 11: J         | r         |                                |                            |               |                    |  |
| B3CS                  | Bit symbol               | B3E                    |              | B3OM1         | B3OM0     | B3BUS                          | B3W2                       | B3W1          | B3W0               |  |
| (00C3H)               | Read/Write               | W                      |              |               | i         | V                              | V                          |               |                    |  |
|                       | After reset              | 0                      |              | 0             | 0         | 0                              | 0                          | 0             | 0                  |  |
| Read-<br>modify-      | Functions                | 0: Disable             |              | Chip select   | t output  | Data bus                       | Number of                  | waits         |                    |  |
| write                 |                          | 1: Enable              |              | waveform s    |           | width                          | 000: 2 wait                | s 100:        | Reserved           |  |
| instructions are      |                          |                        |              | 00: For RO    | M/SRAM    | 0: 16 bits                     | 001: 1 wait                | -             | 3 waits            |  |
| prohibited.           |                          |                        |              | 01: ך         |           | 1: 8 bits                      |                            | ) waits 110:  |                    |  |
|                       |                          |                        |              |               | on't care |                                | 011: 0 wait                | s 111:        | 8 waits            |  |
| BEXCS                 |                          |                        |              | 11: J         |           |                                |                            |               |                    |  |
| (00C7H)               | Bit symbol               |                        |              |               |           | BEXBUS                         | BEXW2                      | BEXW1         | BEXW0              |  |
| ( )                   | Read/Write               |                        |              |               |           |                                | V                          |               |                    |  |
| Read-                 | After reset              |                        |              |               |           | 0                              | 0                          | 0             | 0                  |  |
| modify-               | Functions                |                        |              |               |           | Data bus                       | Number of                  |               |                    |  |
| write<br>instructions |                          |                        |              |               |           | width                          | 000: 2 wait                |               | Reserved           |  |
| are                   |                          |                        |              |               |           | 0: 16 bits                     | 001: 1 wait                | ) waits 110:  | 3 waits            |  |
| prohibited.           |                          |                        |              |               |           | 1:8 bits                       | 010: (1 + N<br>011: 0 wait | ,             | 4 waits<br>8 waits |  |
|                       |                          |                        |              |               |           |                                | 011. 0 Wall                | <u>s III.</u> |                    |  |
|                       | Master enable            | bit                    |              | Chip select o | utput     |                                |                            | $\overline{}$ |                    |  |
| Г                     |                          | UIL ¥                  |              | vaveform sel  |           | Number of address area wa      |                            |               | ea waits           |  |
| F                     | 0 Enable                 |                        | ——   「       | 00 For RO     | M/SRAM    | (See 3.6.2, (3) Wait control.) |                            |               |                    |  |
| L                     | 1 Disable                |                        | [            | 01            |           |                                | <b>D</b> · · ·             |               | (*                 |  |
|                       | CS2 area sel             | ection <del>&lt;</del> |              | 10 Don't ca   | are       |                                | $\rightarrow$ Data bus     | s width selec | tion               |  |
| Г                     | 0 16-Mbyte               |                        |              | 11            |           | 0 16-bit data bus              |                            |               |                    |  |
| -                     |                          |                        | 3            |               |           |                                | 1 8-bit                    | data bus      |                    |  |
| L                     | 1 Specified address area |                        |              |               |           |                                |                            |               |                    |  |

| Figure 3.6.5 | Chip Select/Wait Control Registers |
|--------------|------------------------------------|
|--------------|------------------------------------|

(1) Master enable bits

Bit 7 (<B0E>, <B1E>, <B2E> or <B3E>) of a chip select/wait control register is the master bit which is used to enable or disable settings for the corresponding address area. Writing 1 to this bit enables the settings. Reset disables (Sets to 0) <B0E>, <B1E> and <B3E>, and enabled (Sets to 1) <B2E>. This enables area CS2 only.

(2) Data bus width selection

Bit 3 (<B0BUS>, <B1BUS>, <B2BUS>, <B3BUS> or <BEXBUS>) of a chip select/wait control register specifies the width of the data bus. This bit should be set to 0 when memory is to be accessed using a 16-bit data bus and to 1 when an 8-bit data bus is to be used.

This process of changing the data bus width according to the address being accessed is known as dynamic bus sizing. For details of this bus operation see Table 3.6.2.

| Operand Data | Operand Start | Memory Data | CPU Address  | CPU Data   |            |  |
|--------------|---------------|-------------|--------------|------------|------------|--|
| Bus Width    | Address       | Bus Width   | CF 0 Address | D15 to D8  | D7 to D0   |  |
| 8 bits       | 2n + 0        | 8 bits      | 2n + 0       | XXXXX      | b7 to b0   |  |
|              | (Even number) | 16 bits     | 2n + 0       | xxxxx      | b7 to b0   |  |
|              | 2n + 1        | 8 bits      | 2n + 1       | XXXXX      | b7 to b0   |  |
|              | (Odd number)  | 16 bits     | 2n + 1       | b7 to b0   | xxxxx      |  |
| 16 bits      | 2n + 0        | 8 bits      | 2n + 0       | xxxxx      | b7 to b0   |  |
|              | (Even number) |             | 2n + 1       | xxxxx      | b15 to b8  |  |
|              |               | 16 bits     | 2n + 0       | b15 to b8  | b7 to b0   |  |
|              | 2n + 1        | 8 bits      | 2n + 1       | XXXXX      | b7 to b0   |  |
|              | (Odd number)  |             | 2n + 2       | xxxxx      | b15 to b8  |  |
|              |               | 16 bits     | 2n + 1       | b7 to b0   | xxxxx      |  |
|              |               |             | 2n + 2       | xxxxx      | b15 to b8  |  |
| 32 bits      | 2n + 0        | 8 bits      | 2n + 0       | xxxxx      | b7 to b0   |  |
|              | (Even number) |             | 2n + 1       | xxxxx      | b15 to b8  |  |
|              |               |             | 2n + 2       | XXXXX      | b23 to b16 |  |
|              |               |             | 2n + 3       | xxxxx      | b31 to b24 |  |
|              |               | 16 bits     | 2n + 0       | b15 to b8  | b7 to b0   |  |
|              |               |             | 2n + 2       | b31 to b24 | b23 to b16 |  |
|              | 2n + 1        | 8 bits      | 2n + 1       | xxxxx      | b7 to b0   |  |
|              | (Odd number)  |             | 2n + 2       | XXXXX      | b15 to b8  |  |
|              |               |             | 2n + 3       | XXXXX      | b23 to b16 |  |
|              |               |             | 2n + 4       | xxxxx      | b31 to b24 |  |
|              |               | 16 bits     | 2n + 1       | b7 to b0   | XXXXX      |  |
|              |               |             | 2n + 2       | b23 to b16 | b15 to b8  |  |
|              |               |             | 2n + 4       | XXXXX      | b31 to b24 |  |

Table 3.6.2 Dynamic Bus Sizing

Note: xxxxx indicates that the input data from these bits are ignored during a read. During a write, indicates that the bus for these bits goes too high impedance; also, that the write strobe signal for the bus remains inactive.

(3) Wait control

Bits 0 to 2 (<B0W0:2>, <B1W0:2>, <B2W0:2>, <B3W0:2>, <BEXW0:2>) of a chip select/wait control register specify the number of waits that are to be inserted when the corresponding memory area is accessed.

The following types of wait operation can be specified using these bits. Bit settings other than those listed in the table should not be made.

| <bxw2:0></bxw2:0> | Number of Waits | Wait Operation                                                                                                                                                          |
|-------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000               | 2               | Inserts a wait of 2 states, irrespective of the $\overline{WAIT}$ pin state.                                                                                            |
| 001               | 1               | Inserts a wait of 1 state, irrespective of the WAIT pin state.                                                                                                          |
| 010               | (1 + N)         | Samples the state of the $\overline{WAIT}$ pin after inserting a wait of 1 state. If the $\overline{WAIT}$ pin is low, the waits continue and the bus cycle is extended |
|                   |                 | until the pin goes high.                                                                                                                                                |
| 011               | 0               | Ends the bus cycle without a wait, regardless of the $\overline{\text{WAIT}}$ pin state.                                                                                |
| 100               | Reserved        | Invalid setting                                                                                                                                                         |
| 101               | 3               | Inserts a wait of 3 states, irrespective of the $\overline{WAIT}$ pin state.                                                                                            |
| 110               | 4               | Inserts a wait of 4 states, irrespective of the $\overline{WAIT}$ pin state.                                                                                            |
| 111               | 8               | Inserts a wait of 8 states, irrespective of the WAIT pin state.                                                                                                         |

Table 3.6.3 Wait Operation Settings

A reset sets these bits to 000 (2 waits).

(4) Bus width and wait control for an area other than CS0 to CS3

The chip select/wait control register BEXCS controls the bus width and number of waits when memory locations which are not in one of the four user-specified address areas (CS0 to CS3) are accessed. The BEXCS register settings are always enabled for areas other than CS0 to CS3.

(5) Selecting 16-Mbyte area/specified address area

Setting B2CS<B2M> (Bit 6 of the chip select/wait control register for CS2) to 0 designates the 16-Mbyte area 000FE0H to 000FFFH, 003000H to FFFFFFH as the CS2 area. Setting B2CS<B2M> to 1 designates the address area specified by the start address register MSAR2 and the address mask register MAMR2 as CS2 (e.g., if B2CS<B2M> = 1, CS2 is specified in the same manner as CS0, CS1 and CS3 are).

A reset clears this bit to 0, specifying CS2 as a 16-Mbyte address area.

(6) Procedure for setting chip select/wait control

When using the chip select/wait control function, set the registers in the following order:

- 1. Set the memory start address registers MSAR0 to MSAR3. Set the start addresses for CS0 to CS3.
- 2. Set the memory address mask registers MAMR0 to MAMR3. Set the sizes of CS0 to CS3.
- 3. Set the chip select/wait control registers B0CS to B3CS.

Set the chip select output waveform, data bus width, number of waits and master enable/disable status for  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ .

The CS0 to CS3 pins can also function as pins P60 to P63. To output a chip select signal using one of these pins, set the corresponding bit in the port 6 function register P6FC to 1.

If a CS0 to CS3 address is specified which is actually an internal I/O and RAM area address, the CPU accesses the internal address area and no chip select signal is output on any of the  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  pins.

Setting example:

In this example CS0 is set to be the 64-Kbyte area 010000H to 01FFFFH. The bus width is set to 16 bits and the number of waits is set to 0.

| MSAR0 = 01H | Start address: 010000H                                         |
|-------------|----------------------------------------------------------------|
| MAMR0 = 07H | Address area: 64 Kbytes                                        |
| B0CS = 83H  | ROM/SRAM, 16-bit data bus, 0 waits, CS0 area settings enabled. |

### 3.6.3 Connecting External Memory

Figure 3.6.6 shows an example of how to connect external memory to the TMP91C824.

In this example the ROM is connected using a 16-bit bus. The RAM and I/O are connected using an 8-bit bus.



Figure 3.6.6 Example of External Memory Connection (ROM uses 16-bit bus; RAM and I/O use 8-bit bus.)

A reset clears all bits of the port 6 control register P6CR and the port 6 function register P6FC to 0 and disables output of the CS signal. To output the CS signal, the appropriate bit must be set to 1.



Figure 3.6.7 Example of External Memory Connection (RAM and I/O use 16-bit bus)

# 3.7 8-Bit Timers (TMRA)

The TMP91C824 features 4 channel (TMRA0 to TMRA3) built-in 8-bit timers.

These timers are paired into 2 modules: TMRA01 and TMRA23. Each module consists of 2 channels and can operate in any of the following 4 operating modes.

- 8-bit interval timer mode
- 16-bit interval timer mode
- 8-bit programmable square wave pulse generation output mode (PPG: Variable duty cycle with variable period)
- 8-bit pulse width modulation output mode (PWM: Variable duty cycle with constant period)

Figure 3.7.1 to Figure 3.7.2 show block diagrams for TMRA01 and TMRA23.

Each channel consists of an 8-bit up counter, an 8-bit comparator and an 8-bit timer register. In addition, a timer flip-flop and a prescaler are provided for each pair of channels.

The operation mode and timer flip-flop condition are controlled by 5-byte registers.

We call control registers SFRs: Special function registers.

Each of the two modules (TMRA01 and TMRA23) can be operated independently. All modules operate in the same manner; hence only the operation of TMRA01 is explained here.

The contents of this chapter are as follows.

- 3.7.1 Block Diagrams
- 3.7.2 Operation of Each Circuit
- 3.7.3 SFRs

3.7.4 Operation in Each Mode

- (1) 8-bit timer mode
- (2) 16-bit timer mode
- (3) 8-bit PPG (Programmable pulse generation) output mode
- (4) 8-bit PWM (Pulse width modulation) output mode
- (5) Settings for each mode

|              | Module                           | TMRA01                           | TMRA23                           |  |  |  |  |  |
|--------------|----------------------------------|----------------------------------|----------------------------------|--|--|--|--|--|
| External pin | Input pin for external clock     | TA0IN<br>(shared with PB0)       | None                             |  |  |  |  |  |
|              | Output pin for timer flip-flop   | TA1OUT<br>(shared with PB1)      | TA3OUT<br>(shared with PB2)      |  |  |  |  |  |
|              | Timer run register               | TA01RUN (0100H)                  | TA23RUN (0108H)                  |  |  |  |  |  |
| SFR          | Timer register                   | TA0REG (0102H)<br>TA1REG (0103H) | TA2REG (010AH)<br>TA3REG (010BH) |  |  |  |  |  |
| (Address)    | Timer mode register              | TA01MOD (0104H)                  | TA23MOD (010CH)                  |  |  |  |  |  |
|              | Timer flip-flop control register | TA1FFCR (0105H)                  | TA3FFCR (010DH)                  |  |  |  |  |  |

#### Table 3.7.1 Registers and Pins for Each Module



Figure 3.7.1 TMRA01 Block Diagram



Figure 3.7.2 TMRA23 Block Diagram

# 3.7.2 Operation of Each Circuit

### (1) Prescalers

A 9-bit prescaler generates the input clock to TMRA01.

The  $\phi$ TO as the input clock to prescaler is a clock divided by 4 which selected using the prescaler clock selection register SYSCR0<PRCK1:0>.

The prescaler's operation can be controlled using TA01RUN<TA01PRUN> in the timer control register. Setting <TA01PRUN> to 1 starts the count; setting <TA01PRUN> to 0 clears the prescaler to zero and stops operation. Table 3.7.2 shows the various prescaler output clock resolutions.

|                     |                                            |                               |                                   |                              | at fc = $33$ MHz,             | fs = 32.768 kHz               |  |  |
|---------------------|--------------------------------------------|-------------------------------|-----------------------------------|------------------------------|-------------------------------|-------------------------------|--|--|
| Selection<br>SYSCR1 | Prescaler Clock                            | Gear Value                    | Prescaler Output Clock Resolution |                              |                               |                               |  |  |
|                     | Selection<br>SYSCR0<br><prck1:0></prck1:0> | SYSCR1<br><gear2:0></gear2:0> | φT1                               | φT4                          | φT16                          | φT256                         |  |  |
| 1 (fs)              |                                            | XXX                           | 2 <sup>3</sup> /fs (244 μs)       | 2 <sup>5</sup> /fs (977 μs)  | 2 <sup>7</sup> /fs (3.9 ms)   | 2 <sup>11</sup> /fs (62.5 ms) |  |  |
|                     |                                            | 000 (fc)                      | 2 <sup>3</sup> /fc (0.2 μs)       | 2 <sup>5</sup> /fc (1.0 μs)  | 2 <sup>7</sup> /fc (3.9µs)    | 2 <sup>11</sup> /fc (62.1 μs) |  |  |
|                     | 00<br>(ffph)                               | 001 (fc/2)                    | 2 <sup>4</sup> /fc (0.5 μs)       | 2 <sup>6</sup> /fc (1.9 μs)  | 2 <sup>8</sup> /fc (7.8 μs)   | 2 <sup>12</sup> /fc (248.2 μs |  |  |
|                     |                                            | 010 (fc/4)                    | 2 <sup>5</sup> /fc (1.0 μs)       | 2 <sup>7</sup> /fc (3.9 μs)  | 2 <sup>9</sup> /fc (15.5 μs)  | 2 <sup>13</sup> /fc (496.5 μs |  |  |
| 0 (fc)              |                                            | 011 (fc/8)                    | 2 <sup>6</sup> /fc (1.9 μs)       | 2 <sup>8</sup> /fc (7.8 μs)  | 2 <sup>10</sup> /fc (31.0 µs) | 2 <sup>14</sup> /fc (1024 µs) |  |  |
| -                   |                                            | 100 (fc/16)                   | 2 <sup>7</sup> /fc (3.9 μs)       | 2 <sup>9</sup> /fc (15.5 μs) | 2 <sup>11</sup> /fc (62.1 μs) | 2 <sup>15</sup> /fc (993 μs)  |  |  |
|                     | 10<br>(fc/16 clock)                        | xxx                           | 2 <sup>7</sup> /fc (3.9 μs)       | 2 <sup>9</sup> /fc (15.5 μs) | 2 <sup>11</sup> /fc (62.1 μs) | 2 <sup>15</sup> /fc (993 μs)  |  |  |

Table 3.7.2 Prescaler Output Clock Resolution

xxx: Don't care

(2) Up counters (UC0 and UC1)

These are 8-bit binary counters which count up the input clock pulses for the clock specified by TA01MOD.

The input clock for UC0 is selectable and can be either the external clock input via the TA0IN pin or one of the three internal clocks  $\phi$ T1,  $\phi$ T4 or  $\phi$ T16. The clock setting is specified by the value set in TA01MOD<TA0CLK1:0>.

The input clock for UC1 depends on the operation mode. In 16-bit timer mode, the overflow output from UC0 is used as the input clock. In any mode other than 16-bit timer mode, the input clock is selectable and can either be one of the internal clocks  $\phi$ T1,  $\phi$ T16 or  $\phi$ T256, or the comparator output (The match detection signal) from TMRA0.

For each interval timer the timer operation control register bits TA01RUN<TA0RUN> and TA01RUN<TA1RUN> can be used to stop and clear the up counters and to control their count. A reset clears both up counters, stopping the timers.

(3) Timer registers (TA0REG and TA1REG)

These are 8-bit registers which can be used to set a time interval. When the value set in the timer register TAOREG or TA1REG matches the value in the corresponding up counter, the comparator match detect signal goes active. If the value set in the timer register is 00H, the signal goes active when the up counter overflows.

The TAOREG are double buffer structure, each of which makes a pair with register buffer.

The setting of the bit TA01RUN<TA0RDE> determines whether TA0REG's double buffer structure is enabled or disabled. It is disabled if  $\langle TA0RDE \rangle = 0$  and enabled if  $\langle TA0RDE \rangle = 1$ .

When the double buffer is enabled, data is transferred from the register buffer to the timer register when a  $2^n$  overflow occurs in PWM mode, or at the start of the PPG cycle in PPG mode. Hence the double buffer cannot be used in timer mode.

A reset initializes <TA0RDE> to 0, disabling the double buffer. To use the double buffer, write data to the timer register, set <TA0RDE> to 1, and write the following data to the register buffer. Figure 3.7.3 show the configuration of TA0REG.



Figure 3.7.3 Configuration of TA0REG

Note: The same memory address is allocated to the timer register and the register buffer. When <TA0RDE> = 0, the same value is written to the register buffer and the timer register; when <TA0RDE> = 1, only the register buffer is written to.

The address of each timer register is as follows.

| TA0REG: 000102H | TA1REG: 000103H |
|-----------------|-----------------|
| TA2REG: 00010AH | TA3REG: 00010BH |

All these registers are write only and cannot be read.

(4) Comparator (CP0)

The comparator compares the value in an up counter with the value set in a timer register. If they match, the up counter is cleared to zero and an interrupt signal (INTTA0 or INTTA1) is generated. If timer flip-flop inversion is enabled, the timer flip-flop is inverted at the same time.

(5) Timer flip-flop (TA1FF)

The timer flip-flop (TA1FF) is a flip-flop inverted by the match detects signal (8-bit comparator output) of each interval timer.

Whether inversion is enabled or disabled is determined by the setting of the bit TA1FFCR<TA1FFIE> in the timer flip-flop control register.

A reset clears the value of TA1FF1 to 0.

Writing 01 or 10 to TA1FFCR<TA1FFC1:0> sets TA1FF to 0 or 1. Writing 00 to these bits inverts the value of TA1FF. (This is known as software inversion.)

The TA1FF signal is output via the TA1OUT pin (Concurrent with PB1). When this pin is used as the timer output, the timer flip-flop should be set beforehand using the port B function register PBCR, PBFC.

Note: When the double buffer is enabled for an 8-bit timer in PWM or PPG mode, caution is required as explained below.

If new data is written to the register buffer immediately before an overflow occurs by a match between the timer register value and the up-counter value, the timer flip-flop may output an unexpected value.

For this reason, make sure that in PWM mode new data is written to the register buffer by six cycles ( $f_{SYS} \times 6$ ) before the next overflow occurs by using an overflow interrupt. In the case of using PPG mode, make sure that new data is written to the register buffer by six cycles before the next cycle compare match occurs by using a cycle compare match interrupt.

#### Example when using PWM mode



# 3.7.3 SFRs

|         | TMRA01 Run Register |               |                 |        |   |            |               |                   |               |  |
|---------|---------------------|---------------|-----------------|--------|---|------------|---------------|-------------------|---------------|--|
|         |                     | 7             | 6               | 5      | 4 | 3          | 2             | 1                 | 0             |  |
| TA01RUN | Bit symbol          | <b>TA0RDE</b> |                 |        |   | I2TA01     | TA01PRUN      | TA1RUN            | <b>TAORUN</b> |  |
| (0100H) | Read/Write          | R/W           |                 |        |   |            | R/            | W                 |               |  |
|         | After reset         | 0             |                 |        |   | 0          | 0             | 0                 | 0             |  |
|         | Function            | Double        |                 |        |   | IDLE2      | 8-bit timer r | un/stop cont      | rol           |  |
|         |                     | buffer        |                 |        |   | 0: Stop    | 0: Stop and   | 0: Stop and clear |               |  |
|         |                     | 0: Disable    | •               |        |   | 1: Operate | 1: Run (Co    | unt up)           |               |  |
|         |                     | 1: Enable     |                 |        |   |            |               |                   |               |  |
|         | r                   | TAOREG d      | ouble buffer co | ontrol |   |            |               | → Timer run       | /stop control |  |
|         |                     | 0 Dis         | sable           |        |   |            |               | 0 S               | top and clear |  |
|         |                     | 1 En          | able            |        |   |            |               | 1 R               | un (Count up) |  |
|         |                     |               |                 |        |   |            |               |                   |               |  |

I2TA01:Operation in IDLE2 modeTA01PRUN:Run prescalerTA1RUN:Run TMRA1TA0RUN:Run TMRA0

Note: The values of bits 4, 5, 6 of TA01RUN are undefined when read.

TMRA23 Run Register

7 6 5 4 3 2 1 0 TA23RUN TA2RDE I2TA23 TA23PRUN TA3RUN TA2RUN Bit symbol (0108H) Read/Write R/W R/W After reset 0 0 0 0 0 IDLE2 Function Double 8-bit timer run/stop control buffer 0: Stop 0: Stop and clear 1: Operate 1: Run (Count up) 0: Disable 1: Enable Timer run/stop control TA2REG double buffer control 0 Stop and clear Disable 0 1 Run (Count up) Enable 1

I2TA23:Operation in IDLE2 modeTA23PRUN:Run prescalerTA3RUN:Run TMRA3TA2RUN:Run TMRA2

Note: The values of bits 4, 5, 6 of TA23RUN are undefined when read.

Figure 3.7.4 TMRA Registers

|        |                                                                                                   |                                                                               |                                 |                                                                                            | mode ne | giotoi                                                       |                                                       |                                                   |                                                                     |
|--------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------|---------|--------------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------|---------------------------------------------------------------------|
|        |                                                                                                   | 7                                                                             | 6                               | 5                                                                                          | 4       | 3                                                            | 2                                                     | 1                                                 | 0                                                                   |
| A01MOD | Bit symbol                                                                                        | TA01M1                                                                        | TA01M0                          | PWM01                                                                                      | PWM00   | TA1CLK1                                                      | TA1CLK0                                               | TA0CLK1                                           | TA0CLK0                                                             |
| 0104H) | Read/Write                                                                                        |                                                                               |                                 |                                                                                            | R/      | W                                                            |                                                       |                                                   |                                                                     |
|        | After reset                                                                                       | 0                                                                             | 0                               | 0                                                                                          | 0       | 0                                                            | 0                                                     | 0                                                 | 0                                                                   |
|        | Function                                                                                          | Operation r<br>00: 8-bit tim<br>01: 16-bit ti<br>10: 8-bit PF<br>11: 8-bit PV | ner mode<br>mer mode<br>PG mode | PWM cycle<br>00: Reserve<br>01: 2 <sup>6</sup><br>10: 2 <sup>7</sup><br>11: 2 <sup>8</sup> |         | Source cloc<br>00: TA0TR<br>01: φT1<br>10: φT16<br>11: φT256 | k for TMRA1<br>RG                                     | Source clock for TMRA0<br>00: TAOIN pin<br>01:    |                                                                     |
|        | <ta01m1:0> ≠ 01         <ta< td="">           00         Comparator         Over</ta<></ta01m1:0> |                                                                               |                                 |                                                                                            |         |                                                              |                                                       | ection<br>TA0<br>01 <ta<br>Ove<br/>00 TMF</ta<br> | 1MOD<br>01M1:0> = 01<br>rflow output from<br>RAO<br>bit timer mode) |
|        |                                                                                                   |                                                                               |                                 | Ĺ                                                                                          |         | 01 2 <sup>6</sup>                                            | selection<br>served<br>× source cloc<br>× source cloc |                                                   |                                                                     |
|        |                                                                                                   |                                                                               |                                 |                                                                                            |         | 11 2 <sup>8</sup><br>TMRA01 op                               | × source cloc<br>eration mode<br>o 8-bit timers       | k                                                 |                                                                     |
|        |                                                                                                   |                                                                               |                                 |                                                                                            |         | 01 16-                                                       | bit timer                                             |                                                   |                                                                     |
|        |                                                                                                   |                                                                               |                                 |                                                                                            |         |                                                              |                                                       |                                                   |                                                                     |

TMRA01 Mode Register

8-bit PPG

8-bit PWM (TMRA0) + 8-bit timer (TMRA1)

10 11

|         |             |               |          | -                  |       | 9                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                             |                                             |
|---------|-------------|---------------|----------|--------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------|
|         |             | 7             | 6        | 5                  | 4     | 3                                                                                                                                          | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1                                                                                           | 0                                           |
| TA23MOD | Bit symbol  | TA23M1        | TA23M0   | PWM21              | PWM20 | TA3CLK <sup>2</sup>                                                                                                                        | 1 TA3CLK0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | TA2CLK                                                                                      | 1 TA2CLK0                                   |
| (010CH) | Read/Write  |               |          |                    | R     | /W                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                             |                                             |
|         | After reset | 0             | 0        | 0                  | 0     | 0                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0                                                                                           | 0                                           |
|         | Function    | Operation r   | node     | PWM cycle          |       | TMRA3 clo                                                                                                                                  | ock for TMRA3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TMRA2 cl                                                                                    | ock for TMRA2                               |
|         |             | 00: 8-bit tim | ner mode | 00: Reserve        | ed    | 00: TA2T                                                                                                                                   | RG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 00: Rese                                                                                    | rved                                        |
|         |             | 01: 16-bit ti | mer mode | 01: 2 <sup>6</sup> |       | 01:                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 01:                                                                                         |                                             |
|         |             | 10: 8-bit PF  | PG mode  | 10: 2 <sup>7</sup> |       | 10:                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 10:                                                                                         |                                             |
|         |             | 11: 8-bit PV  | VM mode  | 11: 2 <sup>8</sup> |       | 11: φT25                                                                                                                                   | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 11: φT16                                                                                    |                                             |
|         |             |               |          |                    |       | 00         D           01         φ1           10         φ1           11         φ1           TMRA3 so         T/           <1         <1 | urce clock sele<br>o not set<br>(Prescaler)<br>(4 (Prescaler))<br>(16 (Prescaler))<br>urce clock sele<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>(23MOD)<br>( | ection<br>TA<br>11 <t< th=""><th>23MOD<br/>A23M1:0&gt; = 01<br/>erflow output fro</th></t<> | 23MOD<br>A23M1:0> = 01<br>erflow output fro |
|         |             |               |          |                    |       |                                                                                                                                            | om TMRA2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                             | IRA2                                        |
|         |             |               |          |                    |       |                                                                                                                                            | 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                             |                                             |
|         |             |               |          |                    |       |                                                                                                                                            | 256                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (16                                                                                         | S-bit timer mode                            |
|         |             |               |          | l                  |       | PWM cycle                                                                                                                                  | e selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                             |                                             |
|         |             |               |          |                    |       | 00 R                                                                                                                                       | eserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                             |                                             |
|         |             |               |          |                    |       | 01 2 <sup>6</sup>                                                                                                                          | × source cloc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | k                                                                                           |                                             |
|         |             |               |          |                    |       | 10 27                                                                                                                                      | × source cloc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | k                                                                                           |                                             |
|         |             |               |          |                    |       | 11 2 <sup>8</sup>                                                                                                                          | × source cloc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | k                                                                                           |                                             |
|         |             |               |          |                    |       | TMRA23 c                                                                                                                                   | peration mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | selection                                                                                   |                                             |
|         |             |               |          |                    |       | 00 T\                                                                                                                                      | wo 8-bit timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                             |                                             |
|         |             |               |          |                    |       | 01 16                                                                                                                                      | S-bit timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                             |                                             |
|         |             |               |          |                    |       | 10 8-                                                                                                                                      | bit PPG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                             |                                             |
|         |             |               |          |                    |       | 11 8-                                                                                                                                      | bit PWM (TMR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | A2) + 8-bi                                                                                  | t timer (TMRA3)                             |

TMRA23 Mode Register

Figure 3.7.6 TMRA Registers

|                                                                                                                                                                                    |             |   |   | · · · · · · · · · · · · · · · · · · · |   | or regiotor  |               |               |           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---|---|---------------------------------------|---|--------------|---------------|---------------|-----------|
|                                                                                                                                                                                    |             | 7 | 6 | 5                                     | 4 | 3            | 2             | 1             | 0         |
| TA1FFCR                                                                                                                                                                            | Bit symbol  |   |   |                                       |   | TA1FFC1      | TA1FFC0       | TA1FFIE       | TA1FFIS   |
| (0105H)                                                                                                                                                                            | Read/Write  | / |   |                                       |   | R            | /W            | R             | /W        |
| Read-                                                                                                                                                                              | After reset |   |   |                                       |   | 1            | 1             | 0             | 0         |
| modify-write                                                                                                                                                                       | Function    |   |   |                                       |   | 00: Invert T | A1FF          | TA1FF         | TA1FF     |
| instructions                                                                                                                                                                       |             |   |   |                                       |   | 01: Set TA   | 1FF           | control for   | inversion |
| are                                                                                                                                                                                |             |   |   |                                       |   | 10: Clear T  |               | inversion     | select    |
| prohibited.                                                                                                                                                                        |             |   |   |                                       |   | 11: Don't c  | are           | 0: Disable    | 0: TMRA0  |
|                                                                                                                                                                                    |             |   |   |                                       |   |              |               | 1: Enable     | 1: TMRA1  |
| Inverse signal for timer flip-flop 1 (TA<br>(Don't care except in 8-bit timer mod<br>0 Inversion by TMRA0<br>1 Inversion by TMRA1<br>Inversion of TA1FF<br>0 Disabled<br>1 Enabled |             |   |   |                                       |   |              | imer mode)    |               |           |
|                                                                                                                                                                                    |             |   |   |                                       |   |              | ontrol of TA1 | FF            |           |
|                                                                                                                                                                                    |             |   |   |                                       |   |              |               | s the value o | f TA1FF   |
|                                                                                                                                                                                    |             |   |   |                                       |   |              |               | A1FF to 1     |           |
|                                                                                                                                                                                    |             |   |   |                                       |   | -            |               | s TA1FF to 0  |           |
|                                                                                                                                                                                    |             |   |   |                                       |   |              | 11 Don't      | care          |           |

TMRA1 Flip-Flop Control Register

Figure 3.7.7 TMRA Registers

|                     |             | 7 | 6 | 5 | 4 | 3            | 2                                                                                                                                                                                                                                                                                                                  | 1                                                                       | 0              |
|---------------------|-------------|---|---|---|---|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------|
| <b>TA3FFCR</b>      | Bit symbol  |   |   |   |   | TA3FFC1      | TA3FFC0                                                                                                                                                                                                                                                                                                            | <b>TA3FFIE</b>                                                          | <b>TA3FFIS</b> |
| (010DH)             | Read/Write  |   |   |   |   | R/           | Ŵ                                                                                                                                                                                                                                                                                                                  | R                                                                       | /W             |
| Read-               | After reset |   |   |   |   | 1            | 1                                                                                                                                                                                                                                                                                                                  | 0                                                                       | 0              |
| modify-write        | Function    |   |   |   |   | 00: Invert T | A3FF                                                                                                                                                                                                                                                                                                               | TA3FF                                                                   | TA3FF          |
| instructions<br>are |             |   |   |   |   | 01: Set TA3  |                                                                                                                                                                                                                                                                                                                    | control for                                                             | inversion      |
| prohibited.         |             |   |   |   |   | 10: Clear T  | -                                                                                                                                                                                                                                                                                                                  | inversion                                                               | select         |
|                     |             |   |   |   |   | 11: Don't ca | are                                                                                                                                                                                                                                                                                                                | 0: Disable                                                              | 0: TMRA2       |
|                     |             |   |   |   |   |              |                                                                                                                                                                                                                                                                                                                    | 1: Enable                                                               | 1: TMRA3       |
|                     |             |   |   |   |   |              | 0     Invers       0     Invers       1     Invers       1     Invers       0     Disa       1     Ena       0     Otra       0     Invers       0     Disa       1     Ena       0     Invers       0     Invers       0     Invers       0     Invers       00     Invers       01     Sets       10     Cleater | ept in 8-bit ti<br>ion by TMRA<br>ion by TMRA<br>TA3FF<br>abled<br>bled | v2<br>v3       |



# TMRA3 Flip-Flop Control Register

|               |                     |           |   | TM | RA registe | r |   |   |   |  |  |  |
|---------------|---------------------|-----------|---|----|------------|---|---|---|---|--|--|--|
|               |                     | 7         | 6 | 5  | 4          | 3 | 2 | 1 | 0 |  |  |  |
| <b>TA0REG</b> | bit Symbol          | _         |   |    |            |   |   |   |   |  |  |  |
| (0102H)       | Read/Write          | W         |   |    |            |   |   |   |   |  |  |  |
|               | After reset         | Undefined |   |    |            |   |   |   |   |  |  |  |
| TA1REG        | TA1REG bit Symbol – |           |   |    |            |   |   |   |   |  |  |  |
| (0103H)       | Read/Write          | W         |   |    |            |   |   |   |   |  |  |  |
|               | After reset         | Undefined |   |    |            |   |   |   |   |  |  |  |
| TA2REG        | bit Symbol          | -         |   |    |            |   |   |   |   |  |  |  |
| (010AH)       | Read/Write          | W         |   |    |            |   |   |   |   |  |  |  |
|               | After reset         | Undefined |   |    |            |   |   |   |   |  |  |  |
| TA3REG        | bit Symbol –        |           |   |    |            |   |   |   |   |  |  |  |
| (010BH)       | Read/Write          | W         |   |    |            |   |   |   |   |  |  |  |
|               | After reset         | Undefined |   |    |            |   |   |   |   |  |  |  |

Note: The above registers are prohibited read-modify-write instruction.

Figure 3.7.9 TMRA Registers

### 3.7.4 Operation in Each Mode

(1) 8-bit timer mode

Both TMRA0 and TMRA1 can be used independently as 8-bit interval timers.

Setting its function or counter data for TMRA0 and TMRA1 after stop these registers.

a. Generating interrupts at a fixed interval (using TMRA1)

To generate interrupts at constant intervals using TMRA1 (INTTA1), first stop TMRA1 then set the operation mode, input clock and a cycle to TA01MOD and TA1REG register, respectively. Then, enable the interrupt INTTA1 and start TMRA1 counting.

Example: To generate an INTTA1 interrupt every 10 µseconds at fc = 33 MHz, set each register as follows:

|             | *              | Cloc | ck sta | ate |   |   |   |    | System clock: High frequency (fc)<br>Prescaler clock: f <sub>FPH</sub>         |
|-------------|----------------|------|--------|-----|---|---|---|----|--------------------------------------------------------------------------------|
|             | MSB            |      |        |     |   |   | L | SB |                                                                                |
| _           | 7              | 6    | 5      | 4   | 3 | 2 | 1 | 0  |                                                                                |
| TA01RUN     | $\leftarrow$ - | Х    | Х      | Х   | _ | - | 0 | -  | Stop TMRA1 and clear it to 0.                                                  |
| TA01MOD     | 0 ~ 0          | 0    | Х      | Х   | 1 | 0 | Х | Х  | Select 8-bit timer mode and select $\phi T1$                                   |
|             |                |      |        |     |   |   |   |    | $((2^{3}/fc)s at fc = 33 MHz) as the input clock.$                             |
| TA1REG      | ← 0            | 0    | 1      | 0   | 1 | 0 | 0 | 0  | Set TA1REG to 10 $\mu$ s ÷ $\phi$ T1 (2 <sup>3</sup> /fc)s $\approx$ 40 = 28H. |
| INTETA01    | $\leftarrow$ - | 1    | 0      | 1   | - | - | - | -  | Enable INTTA1 and set it to level 5.                                           |
| _TA01RUN    | $\leftarrow$ - | Х    | Х      | Х   | - | 1 | 1 | -  | Start TMRA1 counting.                                                          |
| X: Don't ca | are, –: No c   | hang | ge     |     |   |   |   |    |                                                                                |

Select the input clock using in Table 3.7.2.

Note: The input clocks for TMRA0 and TMRA1 are different from as follows. TMRA0: TA0IN input,  $\phi$ T1,  $\phi$ T4 or  $\phi$ T16 TMRA1: Match output of TMRA0,  $\phi$ T1,  $\phi$ T16,  $\phi$ T256 b. Generating a 50% duty ratio square wave pulse

The state of the timer flip-flop (TA1FF) is inverted at constant intervals and its status output via the timer output pin (TA1OUT).

Example: To output a 1.5 µs square wave pulse from the TA1OUT pin at fc = 33 MHz, use the following procedure to make the appropriate register settings. This example uses TMRA1; however, either TMRA0 or TMRA1 may be used.

|                                                                                                                                                                                                         | * Clock state System clock: High frequency (fc)<br>Clock gear: 1 (fc)<br>Prescaler clock: f <sub>FPH</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TA01RUN<br>TA01MOD<br>TA1REG<br>TA1FFCR<br>PBCR<br>PBFC<br>TA01RUN<br>X: Don't care                                                                                                                     | 7       6       5       4       3       2       1       0 $\leftarrow$ -       X       X       -       -       0       -       Stop TMRA1 and clear it to 0. $\leftarrow$ 0       0       X       X       0       1       -       -       Stop TMRA1 and clear it to 0. $\leftarrow$ 0       0       X       X       0       1       -       -       Select 8-bit timer mode and select $\phi$ T1         ((2³/fc)s at fc = 33 MHz) as the input clock.       .       .       Set the timer register to 1.5 µs ÷ $\phi$ T1(2³/fc)s ÷ 2 ≈ 3. $\leftarrow$ X       X       X       1       0       1       1 $\leftarrow$ X       X       X       1       0       1       1 $\leftarrow$ X       X       X       1       0       1       1       . $\leftarrow$ X       X       X       1       0       1       1       . $\leftarrow$ X       X       X       1       1       1       .       . $\leftarrow$ X       X       X       -       1       1       .       . $\leftarrow$ |
| φT1<br>TA01RUN<br><ta1run><br/>Up<br/>counter<br/>Bit7 to 2<br/>Bit1<br/>Bit0<br/>Comparator<br/>timing<br/>Comparator output<br/>(Match detect)<br/>INTTA1<br/>UC1 clear<br/>TA1FF<br/>TA1OUT</ta1run> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Figure 3.7.10 Square Wave Output Timing Chart (50% duty)

c. Making TMRA1 count up on the match signal from the TMRA0 comparator Select 8-bit timer mode and set the comparator output from TMRA0 to be the input clock to TMRA1.



Figure 3.7.11 TMRA1 Count up on Signal from TMRA0

#### (2) 16-bit timer mode

A 16-bit interval timer is configured by pairing the two 8-bit timers TMRA0 and TMRA1.

To make a 16-bit interval timer in which TMRA0 and TMRA1 are cascaded together, set TA01MOD<TA01M1:0> to 01.

In 16-bit timer mode, the overflow output from TMRA0 is used as the input clock for TMRA1, regardless of the value set in TA01MOD<TA01CLK1:0>. Table 3.7.2 shows the relationship between the timer (Interrupt) cycle and the input clock selection.

LSB 8 bits set to TA0REG and MSB 8 bits set to TA1REG. Please keep setting TA0REG first because setting data for TA0REG inhibit its compare function and setting data for TA1REG permit it.

Example: To generate an INTTA1 interrupt every 0.24 [s] at fc = 33 MHz, set the timer registers TA0REG and TA1REG as follows:

\* Clock state

System clock:High frequency (fc)Clock gear:1 (fc)Prescaler clock:fFPH

If  $\phi$ T16 ((2<sup>7</sup>/fc)s at 33 MHz) is used as the input clock for counting, set the following value in the registers: 0.24 s ÷ (2<sup>7</sup>/fc)s ≈ 62500 = F424H

(e.g., set TA1REG to F4H and TA0REG to 24H).

As a result, INTTA1 interrupt can be generated every 0.24 [s].

The comparator match signal is output from TMRA0 each time the up counter UC0 matches TA0REG, though the up counter UC0 is not be cleared and also INTTA0 is not generated.

In the case of the TMRA1 comparator, the match detect signal is output on each comparator pulse on which the values in the up counter UC1 and TA1REG match. When the match detect signal is output simultaneously from both the comparators TMRA0 and TMRA1, the up counters UC0 and UC1 are cleared to 0 and the interrupt INTTA1 is generated. Also, if inversion is enabled, the value of the timer flip-flop TA1FF is inverted.

Example: When TA1REG = 04H and TA0REG = 80H





(3) 8-bit PPG (Programmable pulse generation) output mode

Square wave pulses can be generated at any frequency and duty ratio by TMRA0. The output pulses may be active-Low or active-High. In this mode TMRA1 cannot be used.

TMRA0 outputs pulses on the TA1OUT pin.



Figure 3.7.13 8-Bit PPG Output Waveforms

In this mode, a programmable square wave is generated by inverting the timer output each time the 8-bit up counter (UC0) matches the value in one of the timer registers TA0REG or TA1REG.

The value set in TA0REG must be smaller than the value set in TA1REG.

Although the up counter for TMRA1 (UC1) is not used in this mode, TA01RUN<TA1RUN> should be set to 1, so that UC1 is set for counting.

Figure 3.7.14 shows a block diagram representing this mode.



Figure 3.7.14 Block Diagram of 8-Bit PPG Output Mode

If the TAOREG double buffer is enabled in this mode, the value of the register buffer will be shifted into TAOREG each time TA1REG matches UCO.

Use of the double buffer facilitates the handling of low-duty waves (when duty is varied).



Figure 3.7.15 Operation of Register Buffer

Example: To generate 1/4-duty 50-kHz pulses (at fc = 33 MHz)



Calculate the value which should be set in the timer register.

To obtain a frequency of 50 kHz, the pulse cycle t should be:  $t = 1/50 \text{ kHz} = 20 \text{ }\mu\text{s} \phi\text{T1} = (2^3/\text{fc})\text{s}$  (at 33 MHz);

 $\begin{array}{l} 20 \ \mu s \div (2^3/fc) s \approx 83 \\ \\ Therefore \ set \ TA1REG = 83 = 53H \\ The \ duty \ is \ to \ be \ set \ to \ 1/4 \ t \ \times \ 1/4 = 20 \ \mu s \ \times \ 1/4 = 5 \ \mu s \\ \\ 5 \ \mu s \ \div \ (2^3/fc) s \approx 10 \\ \\ Therefore, \ set \ TA0REG = 21 = 15H. \end{array}$ 

|              | 7   | 6 | 5  | 4 | 3 | 2 | 1 | 0   |                                                              |
|--------------|-----|---|----|---|---|---|---|-----|--------------------------------------------------------------|
| TA01RUN      | ← - | Х | Х  | Х | - | 0 | 0 | 0   | Stop TMRA0 and TMRA01 and clear it to 0.                     |
| TA01MOD      | ← 1 | 0 | Х  | Х | Х | Х | 0 | 1   | Set the 8-bit PPG mode, and select $\phi$ T1 as input clock. |
| TAOREG       | ← 0 | 0 | 0  | 1 | 0 | 1 | 0 | 1   | Write 15H                                                    |
| TA1REG       | ← 0 | 1 | 0  | 1 | 0 | 0 | 1 | 1   | Write 53H                                                    |
| TA1FFCR      | ← X | Х | Х  | Х | 0 | 1 | 1 | Х   | Set TA1FF, enabling both inversion and the double buffer.    |
|              |     |   |    |   |   |   |   |     | Writing 10 provides negative logic pulse.                    |
| PBCR         | ← X |   | -  | - | - | - | 1 | - J | Set PB1 as the TA1OUT pin.                                   |
| PBFC         | ← X | - | -  | - | - | - | 1 | х ј | Set PBT as the TATOUT pin.                                   |
| _TA01RUN     | ← 1 | Х | Х  | Х | - | 1 | 1 | 1   | Start TMRA0 and TMRA01 counting.                             |
| V. Don't cor |     |   | ~~ |   |   |   |   |     |                                                              |

X: Don't care, -: No change

91C824-108

(4) 8-bit PWM (Pulse width modulation) output mode

This mode is only valid for TMRA0. In this mode, a PWM pulse with the maximum resolution of 8 bits can be output.

When TMRA0 is used the PWM pulse is output on the TA1OUT pin. TMRA1 can also be used as an 8-bit timer.

The timer output is inverted when the up counter (UC0) matches the value set in the timer register TA0REG or when  $2^n$  counter overflow occurs (n = 6, 7 or 8 as specified by TA01MOD<PWM01:00>). The up counter UC0 is cleared when  $2^n$  counter overflow occurs.

The following conditions must be satisfied before this PWM mode can be used.

Value set in TAOREG < Value set for  $2^n$  counter overflow Value set in TAOREG  $\neq 0$ 



Figure 3.7.16 8-Bit PWM Waveforms

Figure 3.7.17 shows a block diagram representing this mode.



Figure 3.7.17 Block Diagram of 8-Bit PWM Mode

In this mode, the value of the register buffer will be shifted into TA0REG if  $2^n$  overflow is detected when the TA0REG double buffer is enabled.

Use of the double buffer facilitates the handling of low duty ratio waves.





Example: To output the following PWM waves on the TA1OUT pin at fc = 33MHz:



To achieve a 31.0  $\mu s$  PWM cycle by setting  $\phi T1$  = (2³/fc)s (at fc = 33 MHz): 31.0  $\mu s$  ÷ (2³/fc)s  $\approx 128$  = 2<sup>n</sup>

Therefore n should be set to 7.

Since the low-level period is 37.0  $\mu$ s when  $\phi$ T1 = (2<sup>3</sup>/fc)s,

set the following value for TA0REG:

 $17.9 \ \mu s \div (2^3/\text{fc})s \approx 74 = 4AH$ 

|               | MS           | В    |     |    |   |   |   | L | SB  |                                                                   |
|---------------|--------------|------|-----|----|---|---|---|---|-----|-------------------------------------------------------------------|
| _             |              | 7    | 6   | 5  | 4 | 3 | 2 | 1 | 0   |                                                                   |
| TA01RUN       | ←            | _    | Х   | Х  | Х | - | _ | - | 0   | Stop TMRA0 and clear it to 0.                                     |
| TA01MOD       | ←            | 1    | 1   | 1  | 0 | - | - | 0 | 1   | Select 8-bit PWM mode (Cycle: $2^7$ ) and select $\phi$ T1 as the |
|               |              |      |     |    |   |   |   |   |     | input clock.                                                      |
| TAOREG        | $\leftarrow$ | 0    | 1   | 0  | 0 | 1 | 0 | 1 | 0   | Write 4AH.                                                        |
| TA1FFCR       | $\leftarrow$ | Х    | Х   | Х  | Х | 1 | 0 | 1 | х   | Clear TA1FF to 0, enable the inversion and double buffer.         |
|               |              |      |     |    |   |   |   |   |     |                                                                   |
| PBCR<br>PBFC  | $\leftarrow$ | Х    | -   | -  | - | - | - | 1 | - l | Set PB1 and the TA1OUT pin.                                       |
| PBFC          | $\leftarrow$ | Х    | -   | -  | - | - | - | 1 | х∫  | Set PB1 and the TATOOT pin.                                       |
| _TA01RUN      | ←            | 1    | Х   | Х  | Х | - | 1 | - | 1   | Start TMRA0 counting.                                             |
| X: Don't care | e, –: N      | lo c | han | ge |   |   |   |   |     |                                                                   |

|                          |                                                    |                     |              |                |          |          |                | at f     | c = 33 MH | lz, fs = 32    | .768 kHz |  |
|--------------------------|----------------------------------------------------|---------------------|--------------|----------------|----------|----------|----------------|----------|-----------|----------------|----------|--|
| Select                   | Select Select                                      |                     | PWM Cycle    |                |          |          |                |          |           |                |          |  |
| System                   | Prescaler                                          | Gear Value          |              | 2 <sup>6</sup> |          |          | 2 <sup>7</sup> |          |           | 2 <sup>8</sup> |          |  |
| Clock<br><sysck></sysck> | Clock Clock<br><sysck> <prck1:0></prck1:0></sysck> | <gear2:0></gear2:0> | φ <b>T</b> 1 | φ <b>T</b> 4   | φT16     | φT1      | φT4            | φT16     | φT1       | φT4            | φT16     |  |
| 1 (fs)                   |                                                    | XXX                 | 15.6 ms      | 62.5 ms        | 250 ms   | 31.3 ms  | 125 ms         | 500 ms   | 62.5 ms   | 250 ms         | 1000 ms  |  |
|                          |                                                    | 000 (fc)            | 15.5 μs      | 62.1 μs        | 248.2 μs | 31.0 μs  | 124.1 μs       | 496.5 μs | 62.1 μs   | 248.2 μs       | 993.0 μs |  |
|                          | 00                                                 | 001 (fc/2)          | 31.0 μs      | 124.1 μs       | 496.5 μs | 62.1 μs  | 248.2 μs       | 993.0 µs | 124.1 μs  | 496.5 μs       | 1986 μs  |  |
|                          | (f <sub>FPH</sub> )                                | 010 (fc/4)          | 32.1 μs      | 248.2 μs       | 993.0 μs | 124.1 μs | 496.5 μs       | 1986 μs  | 248.2 μs  | 993.0 μs       | 3972 μs  |  |
| 0 (fc)                   |                                                    | 011 (fc/8)          | 124.1 μs     | 496.5 μs       | 1986 μs  | 248.2 μs | 993.0 μs       | 3972 μs  | 496.5 μs  | 1986 μs        | 7944 μs  |  |
|                          |                                                    | 100 (fc/16)         | 248.2 μs     | 993.0 μs       | 3972 μs  | 496.5 μs | 1986 μs        | 7944 μs  | 993 μs    | 3972 μs        | 15888 μs |  |
|                          | 10<br>(fc/16 clock)                                | xxx                 | 248.2 μs     | 993.0 μs       | 3972 μs  | 496.5 μs | 1986 μs        | 7944 μs  | 993 µs    | 3972 μs        | 15888 μs |  |

# Table 3.7.3 PWM Cycle

XXX: Don't care

(5) Settings for each mode

Table 3.7.4 shows the SFR settings for each mode.

|                          |                       |                                                                  | 0 0                                                       |                                                      | TA1FFCR                                        |  |  |
|--------------------------|-----------------------|------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------|------------------------------------------------|--|--|
| Register Name            |                       | TA01MOD                                                          |                                                           |                                                      |                                                |  |  |
| <bit symbol=""></bit>    | <ta01m1:0></ta01m1:0> | <pwm01:00></pwm01:00>                                            | <ta1clk1:0></ta1clk1:0>                                   | <ta0clk1:0></ta0clk1:0>                              | TA1FFIS                                        |  |  |
| Function                 | Timer Mode            | PWM Cycle                                                        | Upper Timer Input<br>Clock                                | Lower Timer<br>Input Clock                           | Timer F/F Invert Signal<br>Select              |  |  |
| 8-bit timer × 2 channels | 00                    | _                                                                | Lower timer match<br>φT1, φT16, φT256<br>(00, 01, 10, 11) | External clock<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | 0: Lower timer output<br>1: Upper timer output |  |  |
| 16-bit timer mode        | 01                    | _                                                                | _                                                         | External clock<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | _                                              |  |  |
| 8-bit PPG × 1 channel    | 10                    | _                                                                | _                                                         | External clock<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | _                                              |  |  |
| 8-bit PWM × 1 channel    | 11                    | 2 <sup>6</sup> , 2 <sup>7</sup> , 2 <sup>8</sup><br>(01, 10, 11) | _                                                         | External clock<br>φT1, φT4, φT16<br>(00, 01, 10, 11) | _                                              |  |  |
| 8-bit Timer × 1 channel  | 11                    | _                                                                | φT1, φT16, φT256<br>(01, 10, 11)                          | _                                                    | Output disabled                                |  |  |

| Table 3.7.4 | Timer Mode | e Setting Registers |
|-------------|------------|---------------------|
|             |            |                     |

-: Don't care

# 3.8 External Memory Extension Function (MMU)

This is MMU function which can expand program/data area to 106 Mbytes by having 4 local areas.

Address pins to external memory are 2 extended address bus pins (EA24, EA25) and 8 extended chip select pins ( $\overline{CS2A}$  to  $\overline{CS2E}$ ) in addition to 24 address bus pins (A0 to A23) which are common specification of TLCS-900 family and 4 chip select pins ( $\overline{CS0}$  to  $\overline{CS3}$ ) output from CS/WAIT controller.

The feature and the recommendation setting method of two types are shown below. In addition, AH in the table is the value which number address 23 to 16 displayed as hex.

| Purpose            | ltem                         | (A): For Standard<br>Extended Memory     | (B): For Many Pieces<br>Extended Memory                                                                   |  |  |
|--------------------|------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------|--|--|
|                    | Maximum memory size          | 2 Mbytes: COMMON2 + 14 Mbyt              | es: bank (16 Mbytes × 1 pcs)                                                                              |  |  |
| Program ROM        | Used local area, BANK number | LOCAL2 (AH = C0 – DF: 2 Mbyte            | es × 7 BANK)                                                                                              |  |  |
|                    | Setting CS/WAIT              | Setup AH = C0 – FF to CS2                | Setup AH = 80 – FF to CS2                                                                                 |  |  |
|                    | Used CS pin                  | CS2                                      | CS2A                                                                                                      |  |  |
|                    | Maximum memory size          | 64 Mbytes (64 Mbytes × 1 pcs)            | 64 Mbytes (16 Mbytes × 4 pcs)                                                                             |  |  |
|                    | Used local area, BANK number | LOCAL3 (AH = 80 - BF:                    | LOCAL3 (AH = 80 - BF:                                                                                     |  |  |
| Data ROM           |                              | 4 Mbytes × 16 BANK)                      | 4 Mbytes × 16 BANK)                                                                                       |  |  |
|                    | Setting CS/WAIT              | Setup AH = 80 – BF to CS3                | Setup AH = 80 – FF to CS2                                                                                 |  |  |
|                    | Used CS pins                 | CS3 , EA24, EA25                         | $\overline{\text{CS2B}}$ , $\overline{\text{CS2C}}$ , $\overline{\text{CS2D}}$ , $\overline{\text{CS2E}}$ |  |  |
|                    | Maximum memory size          | 2 Mbytes: COMMON1 + 14 Mbyt              | es : bank (16 Mbytes × 1 pcs)                                                                             |  |  |
| Option program ROM | Used local area, BANK number | LOCAL1 (AH = 40 – 5F: 2 Mbytes × 7 BANK) |                                                                                                           |  |  |
| Option program ROM | Setting CS/WAIT              | Setup AH = 40 – 7F to CS1                |                                                                                                           |  |  |
|                    | Used CS pin                  | CSI                                      |                                                                                                           |  |  |
|                    | Maximum memory size          | 1 Mbyte : COMMON0 + 7 Mbytes             | s: bank (8 Mbytes × 1 pcs)                                                                                |  |  |
| Data RAM           | Used local area, BANK number | LOCAL0 (AH = 10 - 1F: 1 Mbyte × 7 BANK)  |                                                                                                           |  |  |
| Data RAM           | Setting CS/WAIT              | Setup AH = 00 – 3F to CS0                | Setup AH = 00 – 1F to CS3                                                                                 |  |  |
|                    | Used CS pin                  | CS0                                      | CS3                                                                                                       |  |  |
|                    | Maximum memory size          | COMMON0a                                 | 2 Mbytes (2 Mbytes × 1 pcs)                                                                               |  |  |
| Extended memory 1  | Used local area, BANK number | Overlapped data RAM                      | None                                                                                                      |  |  |
| Extended memory 1  | Setting CS/WAIT              | Setup AH = 00 – 3F to CS0                | Setup AH = 20 – 3F to CS0                                                                                 |  |  |
|                    | Used CS pin                  | CSO                                      | CSO                                                                                                       |  |  |
| Total me           | mory size                    | 16M + 64M + 16M + 8M = 104<br>Mbytes     | 16M + (16M + 16M + 16M +<br>16M) + 16M + 8M + 2M = 106<br>Mbytes                                          |  |  |

# 3.8.1 Recommendable Memory Map

The recommendation logic address memory map at the time of varieties extension memory correspondence is shown in Figure 3.8.1. And, a physical-address map is shown in Figure 3.8.2.

However, when memory area is less than 16 Mbytes and is not expanded, please refer to section of CS/WAIT controller. Setting of register in MMU is not necessary.

Since it is being fixed, the address of a local area cannot be changed.



Figure 3.8.1 Logical Address Map



Figure 3.8.2 Physical Address Map

# 3.8.2 Control Registers

Setup bank value and bank use in bank setting register of each local area of LOCAL register in common area. Moreover, in that case, a combination pin is set up and mapping is simultaneously setup by the CS/WAIT controller. When CPU outputs logical address of the local area, MMU outputs physical address to the outside address bus pin according to value of bank setting register. Access of external memory becomes possible therefore.

|                   | $\sim$                                                            |                                                                                          |        |     |                                       |                                                               |                                                                                         |                                                                                          |                                                                             |
|-------------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------|--------|-----|---------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
|                   |                                                                   | 7                                                                                        | 6      | 5   | 4                                     | 3                                                             | 2                                                                                       | 1                                                                                        | 0                                                                           |
| LOCAL0            | Bit symbol                                                        | L0E                                                                                      |        | /   |                                       |                                                               | L0EA22                                                                                  | L0EA21                                                                                   | L0EA20                                                                      |
| (0350H)           | Read/Write                                                        | R/W                                                                                      | $\sim$ | //  |                                       |                                                               |                                                                                         | R/W                                                                                      |                                                                             |
|                   | After reset                                                       | 0                                                                                        | $\sim$ |     |                                       |                                                               | 0                                                                                       | 0                                                                                        | 0                                                                           |
|                   | Function                                                          | BANK for<br>LOCAL0                                                                       |        |     |                                       |                                                               | Setting BAN                                                                             | NK number fo                                                                             | or LOCAL                                                                    |
|                   |                                                                   | 0: Disable<br>1: Enable                                                                  |        |     |                                       |                                                               |                                                                                         | ng is prohibite                                                                          |                                                                             |
|                   |                                                                   |                                                                                          |        | LOC | AL1 Regist                            | ter                                                           |                                                                                         |                                                                                          |                                                                             |
|                   |                                                                   | 7                                                                                        | 6      | 5   | 4                                     | 3                                                             | 2                                                                                       | 1                                                                                        | 0                                                                           |
| _OCAL1            | Bit symbol                                                        | L1E                                                                                      |        |     |                                       |                                                               | L1EA23                                                                                  | L1EA22                                                                                   | L1EA21                                                                      |
| (0351H)           | Read/Write                                                        | R/W                                                                                      |        |     | $\square$                             |                                                               |                                                                                         | R/W                                                                                      |                                                                             |
|                   | After reset                                                       | 0                                                                                        |        |     |                                       |                                                               | 0                                                                                       | 0                                                                                        | 0                                                                           |
|                   | Function                                                          | BANK for<br>LOCAL1                                                                       |        |     |                                       |                                                               | Setting BAN                                                                             | NK number fo                                                                             | or LOCAL1                                                                   |
|                   |                                                                   | 0: Disable<br>1: Enable                                                                  |        |     |                                       |                                                               |                                                                                         | ng is prohibite                                                                          |                                                                             |
|                   |                                                                   |                                                                                          |        |     |                                       |                                                               |                                                                                         |                                                                                          |                                                                             |
|                   |                                                                   |                                                                                          |        | LOC | AL2 Regist                            | ter                                                           | 1                                                                                       |                                                                                          |                                                                             |
|                   |                                                                   | 7                                                                                        | 6      | LOC | AL2 Regist                            | ter<br>3                                                      | 2                                                                                       | 1                                                                                        | 0                                                                           |
| LOCAL2            | Bit symbol                                                        | 7                                                                                        | 6      |     | -                                     | 1                                                             | 2                                                                                       | 1                                                                                        | 0                                                                           |
|                   | Bit symbol<br>Read/Write                                          |                                                                                          | 6      |     | -                                     | 1                                                             |                                                                                         | 1<br>L2EA22                                                                              |                                                                             |
|                   | Read/Write                                                        | 7<br>L2E                                                                                 | 6      |     | -                                     | 1                                                             | 2                                                                                       | 1                                                                                        | 0                                                                           |
| LOCAL2<br>(0352H) |                                                                   | 7<br>L2E<br>R/W                                                                          | 6      |     | -                                     | 1                                                             | 2<br>L2EA23<br>0                                                                        | 1<br>L2EA22<br>R/W                                                                       | 0<br>L2EA21<br>0                                                            |
|                   | Read/Write<br>After reset                                         | 7<br>L2E<br>R/W<br>0<br>BANK for                                                         | 6      |     | -                                     | 1                                                             | 2<br>L2EA23<br>0<br>Setting BAI<br>"111" settin                                         | 1<br>L2EA22<br>R/W<br>0                                                                  | 0<br>L2EA21<br>0<br>or LOCAL2                                               |
|                   | Read/Write<br>After reset                                         | 7<br>L2E<br>R/W<br>0<br>BANK for<br>LOCAL2<br>0: Disable                                 | 6      | 5   | -                                     | 3                                                             | 2<br>L2EA23<br>0<br>Setting BAI<br>"111" settin                                         | 1<br>L2EA22<br>R/W<br>0<br>NK number fr                                                  | 0<br>L2EA21<br>0<br>or LOCAL2<br>ed because                                 |
|                   | Read/Write<br>After reset                                         | 7<br>L2E<br>R/W<br>0<br>BANK for<br>LOCAL2<br>0: Disable                                 | 6      | 5   | 4                                     | 3                                                             | 2<br>L2EA23<br>0<br>Setting BAI<br>"111" settin                                         | 1<br>L2EA22<br>R/W<br>0<br>NK number fr                                                  | 0<br>L2EA21<br>0<br>or LOCAL2<br>ed because                                 |
| (0352H)<br>LOCAL3 | Read/Write<br>After reset                                         | 7<br>L2E<br>R/W<br>0<br>BANK for<br>LOCAL2<br>0: Disable<br>1: Enable                    |        | 5   | 4<br>AL3 Regist                       | 3                                                             | 2<br>L2EA23<br>0<br>Setting BAI<br>"111" settin<br>it preter                            | 1<br><u>L2EA22</u><br><u>R/W</u><br>0<br>NK number fr<br>ng is prohibite<br>nd COMMON    | 0<br>L2EA21<br>0<br>or LOCAL2<br>ed because<br>10 area                      |
| (0352H)           | Read/Write<br>After reset<br>Function                             | 7<br>L2E<br>R/W<br>0<br>BANK for<br>LOCAL2<br>0: Disable<br>1: Enable                    |        | 5   | 4<br>AL3 Regist                       | 3                                                             | 2<br>L2EA23<br>0<br>Setting BAI<br>"111" settin<br>it preter                            | 1<br>L2EA22<br>R/W<br>0<br>NK number fr<br>ng is prohibite<br>nd COMMON<br>1             | 0<br>L2EA21<br>0<br>or LOCAL2<br>ed because<br>10 area<br>0                 |
| (0352H)<br>LOCAL3 | Read/Write<br>After reset<br>Function<br>Bit symbol               | 7<br>L2E<br>R/W<br>0<br>BANK for<br>LOCAL2<br>0: Disable<br>1: Enable<br>7<br>L3E        |        | 5   | 4<br>AL3 Regist<br>4<br>L3EA26        | 3<br>ter<br>3<br>L3EA25                                       | 2<br>L2EA23<br>0<br>Setting BAI<br>"111" settin<br>it preter<br>2<br>L3EA24             | 1<br>L2EA22<br>R/W<br>0<br>NK number fr<br>ng is prohibite<br>nd COMMON<br>1<br>L3EA23   | 0<br>L2EA21<br>0<br>or LOCAL2<br>ed because<br>10 area<br>0<br>L3EA22       |
| LOCAL3            | Read/Write<br>After reset<br>Function<br>Bit symbol<br>Read/Write | 7<br>L2E<br>R/W<br>0<br>BANK for<br>LOCAL2<br>0: Disable<br>1: Enable<br>7<br>L3E<br>R/W |        | 5   | 4<br>AL3 Regist<br>4<br>L3EA26<br>R/W | 3<br>ter<br>3<br>L3EA25<br>R/W<br>0<br>011: CS2D<br>011: CS2B | 2<br>L2EA23<br>0<br>Setting BAI<br>"111" settin<br>it preter<br>2<br>L3EA24<br>R/W<br>0 | 1<br><u>L2EA22</u><br>R/W<br>0<br>NK number fr<br>nd COMMON<br>1<br><u>L3EA23</u><br>R/W | 0<br>L2EA21<br>or LOCAL3<br>d because<br>10 area<br>0<br>L3EA22<br>R/W<br>0 |

LOCAL0 Register

Note: In case of this TMP91C824, because most upper address bit of physical address is EA25, most upper address bit of BANK register is meaningless. 4 bits of upper 5-bit address means 16 BANKs.



\* In case of 16-bit bus memory

\* In case of 8-bit bus memory



\* In case of 16-bit bus memory, address connection is ... : CPU A1 = Memory A0, CPU A2 = Memory A1...

\* In case of 8-bit bus memory, address connection is ... : CPU A0 = Memory A0, CPU A1 = Memory A1...

Figure 3.8.3 H/W Setting Example

At Figure 3.8.3, it shows example of connection TMP91C824 and some memories: Program ROM: MROM, 16 Mbytes, data ROM: MROM, 64 Mbytes, data RAM: SRAM, 8 Mbytes, 8-bit bus, option ROM: Flash, 16 Mbytes.

In case of 16-bit bus memory connection, it need to shift 1-bit address bus from TMP91C824 and 8-bit bus case, direct connection address bus from TMP91C824.

In that figure, logical address and physical address are shown. And each memory allot each chip select signal, RAM:  $\overline{\text{CS0}}$ ,  $\overline{\text{FLASH}}$  ROM:  $\overline{\text{CS1}}$ , program MROM:  $\overline{\text{CS2}}$ , data MROM:  $\overline{\text{CS3}}$ . In case of this example, as data MROM is 64 Mbytes, this MROM connect to EA24 and EA25.

Initial condition after reset, because TMP91C824 access from  $\overline{CS2}$  area,  $\overline{CS2}$  area allot to program ROM. It can set free setting except program ROM.

;Initial Setting

| ;CS0  | )  |             |                                                                                   |
|-------|----|-------------|-----------------------------------------------------------------------------------|
|       | LD | (MSAR0),00H | ; Logical address area: 000000H to 1FFFFFH                                        |
|       | LD | (MAMR0),FFH | ; Logical address size: 2 Mbytes                                                  |
|       | LD | (B0CS),89H  | ; Condition: 8 bits, 1 wait (8 Mbytes, SRAM)                                      |
| ;CS1  |    |             |                                                                                   |
|       | LD | (MSAR1),40H | ; Logical address area: 400000H to 7FFFFFH                                        |
|       | LD | (MAMR1),FFH | ; Logical address size: 4 Mbytes                                                  |
|       | LD | (B1CS),80H  | ; Condition: 16 bits, 2 waits (16 Mbytes, Flash ROM)                              |
| ;CS2  | 2  |             |                                                                                   |
|       | LD | (MSAR2),C0H | ; Logical address area: C00000H to FFFFFFH                                        |
|       | LD | (MAMR2),7FH | ; Logical address size: 4 Mbytes                                                  |
|       | LD | (B2CS),C3H  | ; Condition: 16 bits, 0 waits (16 Mbytes, MROM)                                   |
| ;CS3  | 5  |             |                                                                                   |
|       | LD | (MSAR3),80H | ; Logical address area: 800000H to BFFFFFH                                        |
|       | LD | (MAMR3),7FH | ; Logical address size: 4 Mbytes                                                  |
|       | LD | (B3CS),85H  | ; Condition: 16 bits, 3 waits (64 Mbytes, MROM)                                   |
| ;CSX  | X  |             |                                                                                   |
|       | LD | (BEXCS),00H | ; Other : 16 bits, 2 waits (Don't care)                                           |
| ;Port | t  |             |                                                                                   |
|       | LD | (P6FC), 3FH | ; $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ , EA24, EA25: Port 6 setting |
|       |    |             |                                                                                   |

Figure 3.8.4 BANK Operation S/W Example 1

Secondly, it shows example of initial setting at Figure 3.8.4.

Because  $\overline{\text{CS0}}$  connect to RAM: 8-bit bus, 8 Mbytes, it need to set 8-bit bus. At this example, it set 1-wait setting. In the same way  $\overline{\text{CS1}}$  set to 16-bit bus and 2 waits,  $\overline{\text{CS2}}$  set 16-bit bus and 0 waits,  $\overline{\text{CS3}}$  set 16-bit bus and 3 waits.

By CS/WAIT controller, each chip selection signal's memory size, don't set actual connect memory size, need to set that logical address size: fitting to each local area. Actual physical address is set by each area's BANK register setting.

CSX setting of CS/WAIT controller is except above CS0 to CS3's setting. This program example isn't used CSX setting.

Finally pin condition is set. Port 60 to 65 set to  $\overline{\text{CS0}}$ ,  $\overline{\text{CS1}}$ ,  $\overline{\text{CS2}}$ ,  $\overline{\text{CS3}}$ , EA24, EA25.

| BANK Operation               |                                                                                              |
|------------------------------|----------------------------------------------------------------------------------------------|
| ;***** <u>CS2</u> *****      | i                                                                                            |
| ORG 000000H                  | ; Program ROM: Start address at BANK0 of LOCAL2                                              |
| ORG 200000H                  | ; Program ROM: Start address at BANK1 of LOCAL2                                              |
| ORG 400000H                  | ; Program ROM: Start address at BANK2 of LOCAL2                                              |
| ORG 600000H                  | ; Program ROM: Start address at BANK3 of LOCAL2                                              |
| ORG 800000H                  | ; Program ROM: Start address at BANK4 of LOCAL2                                              |
| ORG a00000H                  | ; Program ROM: Start address at BANK5 of LOCAL2                                              |
| ORG c00000H                  | ; Program ROM: Start address at BANK6 of LOCAL2                                              |
| ORG E00000H                  | ; Program ROM: Start address at BANK7 (= COMMON2) of LOCAL2                                  |
| 1                            | ; Logical address E00000H to FFFFFFH                                                         |
| I                            | ; Physical address 0E00000H to 0FFFFFFH                                                      |
| LD (LOCAL3),85H              | ; LOCAL3 BANK5 set 14xxxxH                                                                   |
| LDW HL,(800000H) -           |                                                                                              |
|                              | (140000H: Physical address) of LOCAL3 ( $\overline{\text{CS3}}$ )                            |
| LD (LOCAL3),88H              | ; LOCAL3 BANK8 set 20xxxxH                                                                   |
| LDW BC,(800000H)             | ; Load data (AAAAH) form BANK8                                                               |
|                              | (200000H: Physical address) of LOCAL3 ( $\overline{CS3}$ )                                   |
| ORG FFFFFFH                  | ; Program ROM: End address at BANK7 (= COMMON2) of LOCAL2                                    |
|                              |                                                                                              |
| ;***** <u>CS</u> 3 ****      |                                                                                              |
| ORG 0000000H                 | ; Data ROM: Start address at BANK0 of LOCAL3                                                 |
| ORG 0400000H                 | ; Data ROM: Start address at BANK1 of LOCAL3                                                 |
| ORG 0800000H                 | ; Data ROM: Start address at BANK2 of LOCAL3                                                 |
| ORG 0C00000H                 | ; Data ROM: Start address at BANK3 of LOCAL3                                                 |
| ORG 1000000H                 | ; Data ROM: Start address at BANK4 of LOCAL3                                                 |
| ORG 1400000H                 | ; Data ROM: Start address at BANK5 of LOCAL3                                                 |
| dw 5555H ←                   |                                                                                              |
|                              | Dete DOM: Charles Harris et DANIZCE (LOCAL)                                                  |
| ORG 1800000H<br>ORG 1C00000H | ; Data ROM: Start address at BANK6 of LOCAL3<br>; Data ROM: Start address at BANK7 of LOCAL3 |
| ORG 2000000H                 | ; Data ROM: Start address at BANK7 of LOCAL3                                                 |
| dw AAAAH ←                   | , Data ROM: Start address at DANKO OF LOCALS                                                 |
|                              | I                                                                                            |
| ORG 2400000H                 | ; Data ROM: Start address at BANK9 of LOCAL3                                                 |
| ORG 2800000H                 | ; Data ROM: Start address at BANK10 of LOCAL3                                                |
| ORG 2C00000H                 | ; Data ROM: Start address at BANK10 of LOCAL3                                                |
| ORG 3000000H                 | ; Data ROM: Start address at BANK12 of LOCAL3                                                |
| ORG 3400000H                 | ; Data ROM: Start address at BANK12 of LOCAL3                                                |
| ORG 3800000H                 | ; Data ROM: Start address at BANK14 of LOCAL3                                                |
| ORG 3C00000H                 | ; Data ROM: Start address at BANK15 of LOCAL3                                                |
| ORG 3FFFFFFH                 | ; Data ROM: End address at BANK15 of LOCAL3                                                  |
| ·                            |                                                                                              |

Figure 3.8.5 BANK Operation S/W Example 2

Here shows example of data access between one BANK and other BANK. Figure 3.8.5 is one software example. A dot line square area shows one memory and each dot line square shows  $\overline{\text{CS2}}$ 's program ROM and  $\overline{\text{CS3}}$ 's data ROM. Program start from E00000H address, firstly, write to BANK register of LOCAL3 area upper 5-bit address of access point.

In case of this TMP91C824, because most upper address bit of physical address is EA25, most upper address bit of BANK register is meaningless. 4 bits of upper 5-bit address means 16 BANKs. After setting BANK5, accessing 800000H to BFFFFFH address: Logical LOCAL3 address, actually access to physical 1400000H to 1700000H address.

|                 | K Operation                                    | i                                                                                                        |
|-----------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| ,               | <ul> <li>CS2 *****</li> <li>000000H</li> </ul> | ; Program ROM: Start address at BANK0 of LOCAL2                                                          |
|                 | 200000H                                        | ; Program ROM: Start address at BANK1 of LOCAL2 <                                                        |
| I _             | NOP                                            | ; Operation at BANK1of LOCAL2                                                                            |
|                 | JP E00100H                                     | ; Jump to BANK7 (= COMMON2) of LOCAL2                                                                    |
| ORG             | 400000H                                        | ; Program ROM: Start address at BANK2 of LOCAL2                                                          |
| ORG             | 600000H<br>NOP                                 | ; Program ROM: Start address at BANK3 of LOCAL2<br>; Operation at BANK3 of LOCAL2                        |
| <b>~</b>        |                                                |                                                                                                          |
| ORG             | JP E00200H<br>800000H                          | ; Jump to BANK7 (= COMMON2) of LOCAL2<br>; Program ROM: Start address at BANK4 of LOCAL2                 |
| ORG             | a00000H                                        | ; Program ROM: Start address at BANK5 of LOCAL2                                                          |
| ORG             | c00000H                                        | ; Program ROM: Start address at BANK6 of LOCAL2                                                          |
| •<br>I !!!! Pro | ogram Start !!!!                               |                                                                                                          |
| ORG             | E00000H                                        | ; Program ROM: Start address at BANK7 (= COMMON2) of LOCAL2                                              |
| I               |                                                | ; Logical address E00000H to FFFFFFH<br>; Physical address 0E00000H to 0FFFFFFH                          |
|                 | LD (LOCAL2),81H                                | ; LOCAL2 BANK1 set 20xxxxH                                                                               |
|                 | JP C00000H                                     | ; Jump to BANK1 (200000H: Physical address) of LOCAL2                                                    |
| • ~<br>• ORG    | Е00100Н                                        |                                                                                                          |
| I               | LD (LOCAL2),83H                                | ; LOCAL2 BANK3 set 60xxxH                                                                                |
| I ~             | JP C00000H                                     | ; Jump to BANK3 (600000H: Physical address) of LOCAL2                                                    |
| ORG             | E00200H                                        |                                                                                                          |
| i               | LD (LOCAL1),84H<br>JP 400000H                  | ; LOCAL1 BANK4 set 80xxxxH<br>; Jump to BANK4 (800000H: Physical address) of LOCAL1                      |
| I ORG           | FFFFFFH                                        | ; Program ROM: End address at BANK7 (= COMMON2) of LOCAL2                                                |
|                 |                                                |                                                                                                          |
| ;****           | · CS1 ****                                     | · · · · · · · · · · · · · · · · · · ·                                                                    |
| ORG             |                                                | ; Program ROM: Start address at BANK0 of LOCAL1                                                          |
| I ORG           | 200000H<br>400000H                             | ; Program ROM: Start address at BANK1 of LOCAL1<br>; Program ROM: Start address at BANK2 of LOCAL1       |
| I ORG           | 600000H                                        | ; Program ROM: Start address at BANK3 (= COMMON1) of LOCAL1 ←                                            |
| 1               | LD (LOCAL1),87H<br>JP 400000H                  | ; LOCAL1 BANK7 set E0xxxxH                                                                               |
| ORG             | 800000H                                        | ; Jump to BANK7 (E00000H: Physical address) of LOCAL1<br>; Program ROM: Start address at BANK4 of LOCAL1 |
| 1               | NOP                                            | ; Operation at BANK4 of LOCAL1                                                                           |
| Ĩ               | JP 600000H                                     | ; Jump to BANK3 (= COMMON1) of LOCAL1                                                                    |
| I ORG           | a00000H                                        | ; Program ROM: Start address at BANK5 of LOCAL1                                                          |
| ORG             | c00000H                                        | ; Program ROM: Start address at BANK6 of LOCAL1                                                          |
| ORG             | E00000H<br>LD (LOCAL1),80H                     | ; Program ROM: Start address at BANK7 of LOCAL1 ←<br>; LOCAL1 BANK0 set 00xxxH                           |
|                 | JP 400000H                                     | ; Jump to BANK0 (000000H: Physical address) of LOCAL1                                                    |
|                 | It's prohibit t                                | o set other BANK setting in except common area<br>Program run away                                       |
| ORG             | FFFFFFH                                        | ; Program ROM: End address at BANK7 of LOCAL1                                                            |

Figure 3.8.6 BANK Operation S/W Example 3

At Figure 3.8.6, it shows example of program jump.

In the same way with before example, two dot line squares show each  $\overline{CS2}$ 's program ROM and  $\overline{CS1}$ 's option ROM. Program start from E00000H common address, firstly, write to BANK register of LOCAL2 area upper 3-bit address of jumping point.

After setting BANK1, jumping C00000H to DFFFFFH address: Logical LOCAL2 address, actually jump to physical 2000000H to 3FFFFFH address. When return to common area, it can only jump to E00000H to FFFFFFH without writing to BANK register of LOCAL2 area.

By a way of setting of BANK register, the setting that BANK address and common address conflict with is possible. When two kinds or more logical addresses to show common area exist, management of BANK is confused. We recommend not using The BANK setting, BANK address and common address conflict with.

When it jumps to one memory from other different memory, it can set same as the last time setting. It needs to write to BANK register of local1 area upper 3-bit address of jumping point. After setting BANK4, jumping 400000H to 5FFFFFH address: Logical LOCAL1 address, actually jump to physical 8000000H to 9FFFFFH address.

It is a mark paid attention to here, it needs to go by way of common area by all means when moves from a bank to a bank. <u>In other words, it must write to BANK register only</u> <u>in common area and It is prohibit writing the BANK register in BANK area</u>. If it modify the BANK register's data in BANK area, program run-away.

# 3.9 Serial Channels

TMP91C824 includes 2 serial I/O channels. For both channels either UART mode (Asynchronous transmission) or I/O interface mode (Synchronous transmission) can be selected.

I/O interface mode — Mode 0: For transmitting and receiving I/O data using the synchronizing signal SCLK for extending I/O.

|   |           | _ Mode 1:                     | 7-bit data |
|---|-----------|-------------------------------|------------|
| • | UART mode | Mode 1:<br>Mode 2:<br>Mode 3: | 8-bit data |
|   |           | L Mode 3:                     | 9-bit data |

In mode 1 and mode 2, a parity bit can be added. Mode 3 has a wakeup function for making the master controller start slave controllers via a serial link (A multi-controller system).

Figure 3.9.2, Figure 3.9.3 are block diagrams for each channel.

Serial channels 0 and 1 can be used independently.

Both channels operate in the same fashion except for the following points; hence only the operation of channel 0 is explained below.

|           | Channel 0                                     | Channel 1                                     |  |  |  |  |
|-----------|-----------------------------------------------|-----------------------------------------------|--|--|--|--|
| Pin Name  | TXD0 (PC0)<br>RXD0 (PC1)<br>CTS0 /SCLK0 (PC2) | TXD1 (PC3)<br>RXD1 (PC4)<br>CTS1 /SCLK1 (PC5) |  |  |  |  |
| IrDA Mode | Yes                                           | No                                            |  |  |  |  |

Table 3.9.1 Differences between Channels 0 to 1

This chapter contains the following sections:

- 3.9.1 Block Diagrams
- 3.9.2 Operation of Each Circuit
- 3.9.3 SFRs
- 3.9.4 Operation in Each Mode
- 3.9.5 Support for IrDA





# 3.9.1 Block Diagrams

Figure 3.9.2 is a block diagram representing serial channel 0.



Figure 3.9.2 Block Diagram of the Serial Channel 0 (SIO0)



Figure 3.9.3 Block Diagram of the Serial Channel 1 (SIO1)

# 3.9.2 Operation of Each Circuit

## (1) Prescaler

There is a 6-bit prescaler for generating a clock to SIO0. The clock selected using SYSCR<PRCK1:0> is divided by 4 and input to the prescaler as  $\phi$ TO. The prescaler can be run by selecting the baud rate generator as the serial transfer clock.

Table 3.9.2 shows prescaler clock resolution into the baud rate generator.

| Select System                      | Select Prescaler                       |                                          | Prescale           | er Output          | Clock Re            | esolution           |
|------------------------------------|----------------------------------------|------------------------------------------|--------------------|--------------------|---------------------|---------------------|
| Clock<br>SYSCR1<br><sysck></sysck> | Clock<br>SYSCR0<br><prck1:0></prck1:0> | Gear Value<br>SYSCR1 <gear2:0></gear2:0> | φΤΟ                | φT2                | φΤ8                 | φT32                |
| 1 (fs)                             |                                        | XXX                                      | 2 <sup>2</sup> /fs | 2 <sup>4</sup> /fs | 2 <sup>6</sup> /fs  | 2 <sup>8</sup> /fs  |
|                                    |                                        | 000 (fc)                                 | 2 <sup>2</sup> /fc | 2 <sup>4</sup> /fc | 2 <sup>6</sup> /fc  | 2 <sup>8</sup> /fc  |
|                                    | 00                                     | 001 (fc/2)                               | 2 <sup>3</sup> /fc | 2 <sup>5</sup> /fc | 2 <sup>7</sup> /fc  | 2 <sup>9</sup> /fc  |
|                                    | (f <sub>FPH</sub> )                    | 010 (fc/4)                               | 2 <sup>4</sup> /fc | 2 <sup>6</sup> /fc | 2 <sup>8</sup> /fc  | 2 <sup>10</sup> /fc |
| 0 (fc)                             |                                        | 011 (fc/8)                               | 2 <sup>5</sup> /fc | 2 <sup>7</sup> /fc | 2 <sup>9</sup> /fc  | 2 <sup>11</sup> /fc |
|                                    |                                        | 100 (fc/16)                              | 2 <sup>6</sup> /fc | 2 <sup>8</sup> /fc | 2 <sup>10</sup> /fc | 2 <sup>12</sup> /fc |
|                                    | 10<br>(fc/16 clock)                    | ХХХ                                      | _                  | 2 <sup>8</sup> /fc | 2 <sup>10</sup> /fc | 2 <sup>12</sup> /fc |

| Table 3.9.2 Prescaler Clock Resolution to Baud Rate Generator |
|---------------------------------------------------------------|
|---------------------------------------------------------------|

X: Don't care, -: Cannot be used

The baud rate generator selects between 4-clock inputs:  $\phi T0, \ \phi T2, \ \phi T8, \ and \ \phi T32$  among the prescaler outputs.

(2) Baud rate generator

The baud rate generator is the circuit which generates transmission and receiving clocks which determine the transfer rate of the serial channels.

The input clock to the baud rate generator,  $\phi T0$ ,  $\phi T2$ ,  $\phi T8$  or  $\phi T32$ , is generated by the 6-bit prescaler which is shared by the timers. One of these input clocks is selected using the BR0CR<BR0CK1:0> field in the baud rate generator control register.

The baud rate generator includes a frequency divider, which divides the frequency by 1 or N + (16 - K)/16 to 16 values, determining the transfer rate.

The transfer rate is determined by the settings of BROCR<BROADDE, BROS3:0> and BROADD<BROK3:0>.

- In UART mode
- (1) When BROCR < BROADDE > = 0

The settings BR0ADD<BR0K3:0> are ignored. The baud rate generator divides the selected prescaler clock by N, which is set in BR0CK<BR0S3:0>. (N = 1, 2, 3 ... 16)

(2) When BROCR < BROADDE > = 1

The N + (16 - K)/16 division function is enabled. The baud rate generator divides the selected prescaler clock by N + (16 - K)/16 using the value of N set in BR0CR<BR0S3:0> (N = 2, 3 ... 15) and the value of K set in BR0ADD<BR0K3:0> (K = 1, 2, 3 ... 15)

Note: If N = 1 or N = 16, the N + (16 - K)/16 division function is disabled. Set BR0CR<BR0ADDE> to 0.

• In I/O interface mode

The N + (16 - K)/16 division function is not available in I/O interface mode. Set BR0CR<BR0ADDE> to 0 before dividing by N.

The method for calculating the transfer rate when the baud rate generator is used is explained below.

• In UART mode

Baud rate =  $\frac{\text{Input clock of baud rate generator}}{\text{Frequency divider for baud rate generator}} \div 16$ 

• In I/O interface mode

Baud rate =  $\frac{\text{Input clock of baud rate generator}}{\text{Frequency divider for baud rate generator}} \div 2$ 

Integer divider (N divider)

For example, when the source clock frequency (fc) = 12.288 MHz, the input clock frequency =  $\phi T2$  (fc/16), the frequency divider N (BR0CR<BR0S3:0>) = 5, and BROCR<BROADDE> = 0, the baud rate in UART mode is as follows:

1 (fc)

\* Clock state System clock: High frequency (fc) Clock gear: Prescaler clock: System clock Baud rate =  $\frac{\text{fc}/16}{5} \div 16$ 

 $= 12.288 \times 10^6 \div 16 \div 5 \div 16 = 9600$  (bps)

Note: The N + (16 - K)/16 division function is disabled and setting BR0ADD<BR0K3:0> is invalid.

N + (16 - K)/16 divider (UART mode only)

Accordingly, when the source clock frequency (fc) = 4.8 MHz, the input clock frequency =  $\phi$ T0, the frequency divider N (BR0CR<BR0S3:0>) = 7, K (BR0ADD < BR0K3:0>) = 3, and BR0CR < BR0ADDE > = 1, the baud rate in UART mode is as follows:

| * Clock state                             | System clock:                  | High frequency (fc) |
|-------------------------------------------|--------------------------------|---------------------|
|                                           | Clock gear:<br>Prescaler clock | 1 (fc)              |
|                                           | Prescaler clock                | : System clock      |
| Baud rate $=\frac{fc/4}{7+(16-3)/16}$     | ÷16                            |                     |
| $= 4.8 \times 10^6 \div 4 \div (7)^{-10}$ | $7 + 13/16) \div 16$           | 6 = 9600  (bps)     |

Table 3.9.3 show examples of UART mode transfer rates.

Additionally, the external clock input is available in the serial clock (Serial channels 0, 1). The method for calculating the baud rate is explained below:

In UART mode •

Baud rate = External clock input frequency ÷ 16

It is necessary to satisfy (External clock input cycle)  $\ge 4/fc$ 

In I/O interface mode •

Baud rate = External clock input frequency

It is necessary to satisfy (External clock input cycle)  $\geq 16/fc$ 

|            | ~                                                                      |              | r       |             | Unit (kbp: |
|------------|------------------------------------------------------------------------|--------------|---------|-------------|------------|
| fc [MHz]   | Input Clock<br>Frequency Divider<br>(set to BR1CR <br1s3:0>)</br1s3:0> | φ <b>Τ</b> Ο | φT2     | <b>φ</b> Τ8 | φT32       |
| 9.830400   | 2                                                                      | 76.800       | 19.200  | 4.800       | 1.200      |
| $\uparrow$ | 4                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |
| $\uparrow$ | 8                                                                      | 19.200       | 4.800   | 1.200       | 0.300      |
| $\uparrow$ | 0                                                                      | 9.600        | 2.400   | 0.600       | 0.150      |
| 12.288000  | 5                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |
| $\uparrow$ | A                                                                      | 19.200       | 4.800   | 1.200       | 0.300      |
| 14.745600  | 2                                                                      | 115.200      | 28.800  | 7.200       | 1.800      |
| $\uparrow$ | 3                                                                      | 76.800       | 19.200  | 4.800       | 1.200      |
| $\uparrow$ | 6                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |
| $\uparrow$ | С                                                                      | 19.200       | 4.800   | 1.200       | 0.300      |
| 19.6608    | 1                                                                      | 307.200      | 76.800  | 19.200      | 4.800      |
| $\uparrow$ | 2                                                                      | 153.600      | 38.400  | 9.600       | 2.400      |
| $\uparrow$ | 4                                                                      | 76.800       | 19.200  | 4.800       | 1.200      |
| $\uparrow$ | 8                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |
| $\uparrow$ | 10                                                                     | 19.200       | 4.800   | 1.200       | 0.300      |
| 22.1184    | 3                                                                      | 115.200      | 28.800  | 7.200       | 1.800      |
| 24.576     | 1                                                                      | 384.000      | 96.000  | 24.000      | 6.000      |
| $\uparrow$ | 2                                                                      | 192.000      | 48.000  | 12.000      | 3.000      |
| $\uparrow$ | 4                                                                      | 96.000       | 24.000  | 6.000       | 1.500      |
| $\uparrow$ | 5                                                                      | 76.800       | 19.200  | 4.800       | 1.200      |
| $\uparrow$ | 8                                                                      | 48.000       | 12.000  | 3.000       | 0.750      |
| $\uparrow$ | А                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |
| $\uparrow$ | 10                                                                     | 24.000       | 6.000   | 1.500       | 0.375      |
| 27.0336    | В                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |
| 29.4912    | 1                                                                      | 460.800      | 115.200 | 28.800      | 7.200      |
| $\uparrow$ | 3                                                                      | 153.600      | 38.400  | 9.600       | 2.400      |
| $\uparrow$ | 4                                                                      | 115.200      | 28.800  | 7.200       | 1.800      |
| $\uparrow$ | 6                                                                      | 76.800       | 19.200  | 4.800       | 1.200      |
| $\uparrow$ | 9                                                                      | 51.200       | 12.800  | 3.200       | 0.800      |
| $\uparrow$ | С                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |
| $\uparrow$ | F                                                                      | 30.720       | 7.680   | 1.920       | 0.480      |
| $\uparrow$ | 10                                                                     | 28.800       | 7.200   | 1.800       | 0.450      |
| 31.9488    | D                                                                      | 38.400       | 9.600   | 2.400       | 0.600      |

#### Table 3.9.3 Transfer Rate Selection

| (when baud rate generator Is used and $BR0CR < BR0ADDE > = 0$ ) |
|-----------------------------------------------------------------|
|-----------------------------------------------------------------|

Note 1: Transfer rates in I/O interface mode are eight times faster than the values given above.

Note 2: The values in this table are calculated for when fc is selected as the system clock, the clock gear is set for fc/1 and the system clock is the prescaler clock input  $f_{FPH}$ .

Timer out clock (TA0TRG) can be used for source clock of UART mode only.

Calculation method the frequency of TA0TRG

Frequency of TA0TRG = Baud rate  $\times$  16

Note 1:The TMRA0 match detects signal cannot be used as the transfer clock in I/O interface mode.

(3) Serial clock generation circuit

This circuit generates the basic clock for transmitting and receiving data.

• In I/O interface mode

In SCLK output mode with the setting SCOCR<IOC> = 0, the basic clock is generated by dividing the output of the baud rate generator by 2, as described previously.

In SCLK input mode with the setting SCOCR < IOC > = 1, the rising edge or falling edge will be detected according to the setting of the SCOCR < SCLKS > register to generate the basic clock.

• In UART mode

The SC0MOD0<SC1:0> setting determines whether the baud rate generator clock, the internal system clock  $f_{SYS}$ , the match detect signal from timer TMRA0 or the external clock (SCLK0) is used to generate the basic clock SIOCLK.

(4) Receiving counter

The receiving counter is a 4-bit binary counter used in UART mode which counts up the pulses of the SIOCLK clock. It takes 16 SIOCLK pulses to receive 1 bit of data; each data bit is sampled three times – on the 7th, 8th and 9th clock cycles.

The value of the data bit is determined from these three samples using the majority rule.

For example, if the data bit is sampled respectively as 1, 0 and 1 on 7th, 8th and 9th clock cycles, the received data bit is taken to be 1. A data bit sampled as 0, 0 and 1 is taken to be 0.

(5) Receiving control

• In I/O interface mode

In SCLK output mode with the setting SCOCR < IOC > = 0, the RXD0 signal is sampled on the rising edge or falling edge of the shift clock which is output on the SCLK0 pin, according to the SCOCR < SCLKS > setting.

In SCLK input mode with the setting SCOCR < IOC > = 1, the RXD0 signal is sampled on the rising or falling edge of the SCLK0 input, according to the SCOCR <SCLKS> setting.

• In UART mode

The receiving control block has circuit which detects a start bit using the majority rule. Received bits are sampled three times; when two or more out of three samples are 0, the bit is recognized as the start bit and the receiving operation commences.

The values of the data bits that are received are also determined using the majority rule.

(6) The receiving buffers

To prevent overrun errors, the receiving buffers are arranged in a double-buffer structure.

Received data is stored one bit at a time in receiving buffer 1 (which is a shift register). When 7 or 8 bits of data have been stored in receiving buffer 1, the stored data is transferred to receiving buffer 2 (SC0BUF); this cause an INTRX0 interrupt to be generated. The CPU only reads receiving buffer 2 (SC0BUF). Even before the CPU reads receiving buffer 2 (SC0BUF), the received data can be stored in receiving buffer 1. However, unless receiving buffer 2 (SC0BUF) is read before all bits of the next data are received by receiving buffer 1, an overrun error occurs. If an overrun error occurs, the contents of receiving buffer 1 will be lost, although the contents of receiving buffer 2 and SC0CR<RB8> will be preserved.

SCOCR < RB8 > is used to store either the parity bit – added in 8-bit UART mode – or the most significant bit (MSB) – in 9-bit UART mode.

In 9-bit UART mode the wakeup function for the slave controller is enabled by setting SC0MOD0<WU> to 1; in this mode INTRX0 interrupts occur only when the value of SC0CR<RB8> is 1.

(7) Transmission counter

The transmission counter is a 4-bit binary counter which is used in UART mode and which, like the receiving counter, counts the SIOCLK clock pulses; a TXDCLK pulse is generated every 16 SIOCLK clock pulses.



Figure 3.9.4 Generation of the Transmission Clock

- (8) Transmission controller
  - In I/O interface mode

In SCLK output mode with the setting SCOCR < IOC > = 0, the data in the transmission buffer is output one bit at a time to the TXD0 pin on the rising edge or falling edge of the shift clock which is output on the SCLK0 pin, according to the SCOCR < SCLKS > setting.

In SCLK input mode with the setting SCOCR < IOC > = 1, the data in the transmission buffer is output one bit at a time on the TXD0 pin on the rising or falling edge of the SCLK0 input, according to the SCOCR < SCLKS > setting.

• In UART mode

When transmission data sent from the CPU is written to the transmission buffer, transmission starts on the rising edge of the next TXDCLK.

Handshake function

Use of  $\overline{\text{CTS}}$  pin allows data can be sent in units of one frame; thus, overrun errors can be avoided. The handshake functions is enabled or disabled by the SC0MOD<CTSE> setting.

When the  $\overline{\text{CTS0}}$  pin goes high on completion of the current data send, data transmission is halted until the  $\overline{\text{CTS0}}$  pin goes low again. However, the INTTX0 interrupt is generated, it requests the next data send to the CPU. The next data is written in the transmission buffer and data sending is halted.

Though there is no RTS pin, a handshake function can be easily configured by setting any port assigned to be the  $\overline{\text{RTS}}$  function. The  $\overline{\text{RTS}}$  should be output high to request send data halt after data receive is completed by software in the  $\overline{\text{RXD}}$  interrupt routine.







Note 1: If the CTS signal goes high during transmission, no more data will be sent after completion of the current transmission.

Note 2: Transmission starts on the first falling edge of the TXDCLK clock after the TTS signal has fallen.

Figure 3.9.6 CTS (Clear to send) Timing

(9) Transmission buffer

The transmission buffer (SC0BUF) shifts out and sends the transmission data written from the CPU form the least significant bit (LSB) in order. When all the bits are shifted out, the transmission buffer becomes empty and generates an INTTX0 interrupt.

(10) Parity control circuit

When SCOCR<PE> in the serial channel control register is set to 1, it is possible to transmit and receive data with parity. However, parity can be added only in 7-bit UART mode or 8-bit UART mode. The SCOCR<EVEN> field in the serial channel control register allows either even or odd parity to be selected.

In the case of transmission, parity is automatically generated when data is written to the transmission buffer SCOBUF. The data is transmitted after the parity bit has been stored in SCOBUF<TB7> in 7-bit UART mode or in SCOMODO<TB8> in 8-bit UART mode. SCOCR<PE> and SCOCR<EVEN> must be set before the transmission data is written to the transmission buffer.

In the case of receiving, data is shifted into receiving buffer 1, and the parity is added after the data has been transferred to receiving buffer 2 (SC0BUF), and then compared with SC0BUF<RB7> in 7-bit UART mode or with SC0CR<RB8> in 8-bit UART mode. If they are not equal, a parity error is generated and the SC0CR<PERR> flag is set.

(11) Error flags

Three error flags are provided to increase the reliability of data reception.

1. Overrun error <OERR>

If all the bits of the next data item have been received in receiving buffer 1 while valid data still remains stored in receiving buffer 2 (SC0BUF), an overrun error is generated.

The below is a recommended flow when the overrun error is generated.

(INTRX interrupt routine)

- 1) Read receiving buffer
- 2) Read error flag

3) If < OERR > = 1

then

- a) Set to disable receiving (Write 0 to SC0MOD0<RXE>)
- b) Wait to terminate current frame
- c) Read receiving buffer
- d) Read error flag
  - e) Set to enable receiving (Write 1 to SC0MOD0<RXE>)
- f) Request to transmit again

#### 4) Other

2. Parity error <PERR>

The parity generated for the data shifted into receiving buffer 2 (SC0BUF) is compared with the parity bit received via the RXD pin. If they are not equal, a parity error is generated.

3. Framing error <FERR>

The stop bit for the received data is sampled three times around the center. If the majority of the samples are 0, a Framing error is generated.

### (12) Timing generation

# a. In UART mode

### Receiving

| Mode                 | 9 Bits (Note)                | 8 Bits + Parity<br>(Note)          | 8 Bits, 7 Bits + Parity,<br>7 Bits |
|----------------------|------------------------------|------------------------------------|------------------------------------|
| Interrupt timing     | Center of last bit<br>(Bit8) | Center of last bit<br>(Parity bit) | Center of stop bit                 |
| Framing error timing | Center of stop bit           | Center of stop bit                 | Center of stop bit                 |
| Parity error timing  | _                            | Center of last bit<br>(Parity bit) | Center of stop bit                 |
| Overrun error timing | Center of last bit<br>(Bit8) | Center of last bit<br>(Parity bit) | Center of stop bit                 |

Note: In 9-Bit and 8-Bit+Parity mode, interrupts coincide with the ninth bit pulse. Thus, when servicing the interrupt, it is necessary to wait for a 1-bit period (to allow the stop bit to be transferred) to allow checking for a framing error.

#### Transmitting

| Mode             | 9 Bits             | 8 Bits + Parity         | 8 Bits, 7 Bits + Parity, 7 Bits     |
|------------------|--------------------|-------------------------|-------------------------------------|
| Interrupt timing | Just before stop   | Just before stop bit is | Just before stop bit is transmitted |
|                  | bit is transmitted | transmitted             |                                     |

### b. I/O interface

| Transmission | SCLK output mode | Immediately after the last bit. (See Figure 3.9.19.)               |
|--------------|------------------|--------------------------------------------------------------------|
| interrupt    | SCLK input mode  | Immediately after rise of last SCLK signal rising mode, or         |
| timing       |                  | immediately after fall in falling mode. (See Figure 3.9.20.)       |
| Receiving    | SCLK output mode | Timing used to transfer received to data receive buffer 2 (SC0BUF) |
| interrupt    |                  | (e.g., immediately after last SCLK). (See Figure 3.9.21.)          |
| timing       | SCLK input mode  | Timing used to transfer received data to receive buffer 2 (SC0BUF) |
|              |                  | (e.g., immediately after last SCLK). (See Figure 3.9.22.)          |

# 3.9.3 SFRs

| SC0MOD |
|--------|
| (0202H |

|             | 7                     | 6                                                  | 5                                                                    | 4                                             | 3                          | 2                                                                                                                                                                                                                                                      | 1                                                                                                                                  | 0                                                                        |
|-------------|-----------------------|----------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| Bit symbol  | TB8                   | CTSE                                               | RXE                                                                  | WU                                            | SM1                        | SM0                                                                                                                                                                                                                                                    | SC1                                                                                                                                | SC0                                                                      |
| Read/Write  |                       |                                                    |                                                                      | R/V                                           |                            |                                                                                                                                                                                                                                                        |                                                                                                                                    |                                                                          |
| After reset | 0                     | 0                                                  | 0                                                                    | 0                                             | 0                          | 0                                                                                                                                                                                                                                                      | 0                                                                                                                                  | 0                                                                        |
| Function    | Transfer<br>data bit8 | Handshake<br>0: CTS<br>disable<br>1: CTS<br>enable | Receive<br>function<br>0: Receive<br>disable<br>1: Receive<br>enable | Wakeup<br>function<br>0: Disable<br>1: Enable | Serial trans<br>mode       | rface mode<br>ART mode<br>ART mode                                                                                                                                                                                                                     | Serial transmi<br>(UART)<br>00: TMRA0<br>01: Baud rat<br>generato<br>10: Internal<br>11: External                                  | ssion clock<br>rigger<br>e<br>r<br>clock f <sub>SYS</sub>                |
|             |                       |                                                    |                                                                      |                                               |                            |                                                                                                                                                                                                                                                        | (SCLK0                                                                                                                             | input)                                                                   |
|             |                       |                                                    |                                                                      |                                               | 00<br>01<br>10<br>11<br>No | <ul> <li>Timer TMF</li> <li>Baud rate</li> <li>Internal clo</li> <li>External clo</li> <li>External clo</li> <li>te: The clock</li> <li>interface</li> <li>serial cor</li> <li>rial transmission</li> <li>I/O Interface</li> <li>UART model</li> </ul> | ock f <sub>SYS</sub><br>lock (SCLK0 i<br>k selection for<br>mode is contr<br>ntrol register (<br>sion mode<br>ace mode<br>7-bit mo | tect signal<br>hput)<br>the I/O<br>olled by the<br>SCOCR).<br>bde<br>bde |
|             |                       |                                                    |                                                                      |                                               | → Wa                       | keup functio<br>9-bit UART                                                                                                                                                                                                                             |                                                                                                                                    | Other mod                                                                |
|             |                       |                                                    |                                                                      |                                               | 0                          | data is rece                                                                                                                                                                                                                                           | enerated only                                                                                                                      | n<br>Don't ca                                                            |
|             |                       |                                                    |                                                                      |                                               | → Re                       | ceiving funct                                                                                                                                                                                                                                          | ion                                                                                                                                |                                                                          |
|             |                       |                                                    |                                                                      |                                               | 0                          | Receive of Receive e                                                                                                                                                                                                                                   |                                                                                                                                    |                                                                          |
|             |                       |                                                    |                                                                      |                                               | 4                          |                                                                                                                                                                                                                                                        | ction ( CTS pi                                                                                                                     | n)                                                                       |
|             |                       |                                                    |                                                                      |                                               | 0                          | Disabled                                                                                                                                                                                                                                               | (Always trans                                                                                                                      | i                                                                        |
|             |                       |                                                    |                                                                      |                                               | 1                          | Enabled                                                                                                                                                                                                                                                |                                                                                                                                    |                                                                          |

Figure 3.9.7 Serial Mode Control Register (SIO0, SC0MOD0)



Figure 3.9.8 Serial Mode Control Register (SIO1, SC1MOD0)



Note: As all error flags are cleared after reading do not test only a single bit with a bit-testing instruction.

Figure 3.9.9 Serial Control Register (SIO0, SC0CR)



Note: As all error flags are cleared after reading do not test only a single bit with a bit-testing instruction.

Figure 3.9.10 Serial Control Register (SIO1, SC1CR)

|       |                                                     | 7             | 6                                                                                                                                                                                                                                                                                                            | 5                                                                                 | 4                                  | 3                                                                                    | 2                                                       | 1                               | 0                 |
|-------|-----------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------|-------------------|
| 0CR   | Bit symbol                                          | -             | BR0ADDE                                                                                                                                                                                                                                                                                                      | BR0CK1                                                                            | BR0CK0                             | BR0S3                                                                                | BR0S2                                                   | BR0S1                           | BR0S0             |
| 203H) | Read/Write                                          |               |                                                                                                                                                                                                                                                                                                              |                                                                                   | R                                  | /W                                                                                   |                                                         |                                 |                   |
|       | After reset                                         | 0             | 0                                                                                                                                                                                                                                                                                                            | 0                                                                                 | 0                                  | 0                                                                                    | 0                                                       | 0                               | 0                 |
|       | Function                                            | Always        | + (16 – K)/16                                                                                                                                                                                                                                                                                                | 00:                                                                               |                                    | Sett                                                                                 | ing the divid                                           | ed frequency                    | ′ "N"             |
|       |                                                     | write 0       | division                                                                                                                                                                                                                                                                                                     | 01:                                                                               |                                    |                                                                                      | (0 t                                                    | o F)                            |                   |
|       |                                                     |               | 0: Disable                                                                                                                                                                                                                                                                                                   | 10: φT8                                                                           |                                    |                                                                                      |                                                         |                                 |                   |
|       |                                                     |               | 1: Enable                                                                                                                                                                                                                                                                                                    | 11: φT32                                                                          |                                    |                                                                                      |                                                         |                                 |                   |
|       |                                                     |               |                                                                                                                                                                                                                                                                                                              |                                                                                   |                                    |                                                                                      |                                                         |                                 |                   |
|       |                                                     |               |                                                                                                                                                                                                                                                                                                              |                                                                                   |                                    |                                                                                      |                                                         |                                 |                   |
|       | _                                                   |               |                                                                                                                                                                                                                                                                                                              |                                                                                   |                                    |                                                                                      |                                                         |                                 |                   |
|       | $\downarrow$                                        |               |                                                                                                                                                                                                                                                                                                              |                                                                                   | $\downarrow$                       |                                                                                      |                                                         |                                 |                   |
| -     | + (16 – K)/16 d                                     | division enal | ble                                                                                                                                                                                                                                                                                                          | Setting the                                                                       | input clock                        | of baud rate g                                                                       | enerator                                                |                                 |                   |
|       | 0 Disable                                           |               |                                                                                                                                                                                                                                                                                                              | 00 Inter                                                                          | nal clock <sub>\$</sub> T          | 0                                                                                    |                                                         |                                 |                   |
|       | 1 Enable                                            |               |                                                                                                                                                                                                                                                                                                              | 01 Inter                                                                          | nal clock φT                       | 2                                                                                    |                                                         |                                 |                   |
| L     |                                                     |               |                                                                                                                                                                                                                                                                                                              | 10 Internal clock                                                                 |                                    |                                                                                      |                                                         |                                 |                   |
| L     | ·                                                   |               |                                                                                                                                                                                                                                                                                                              |                                                                                   |                                    |                                                                                      |                                                         | L                               |                   |
| L     |                                                     |               |                                                                                                                                                                                                                                                                                                              |                                                                                   | 'nal clock ∳T<br>'nal clock ∳T     |                                                                                      |                                                         |                                 |                   |
| L     |                                                     |               |                                                                                                                                                                                                                                                                                                              |                                                                                   |                                    |                                                                                      |                                                         |                                 |                   |
| L     |                                                     | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32                                                                                   |                                                         | 1                               | 0                 |
|       |                                                     | 7             | 6                                                                                                                                                                                                                                                                                                            |                                                                                   |                                    | 32<br>3                                                                              | 2                                                       | 1                               | 0                 |
| -     | Bit symbol                                          | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32                                                                                   | BR0K2                                                   | BR0K1                           |                   |
| 204H) | Bit symbol<br>Read/Write                            | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32<br>3<br>BR0K3                                                                     | BR0K2<br>R                                              | BR0K1<br>W                      | BR0K0             |
| -     | Bit symbol<br>Read/Write<br>After reset             | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32<br>3<br>BR0K3<br>0                                                                | BR0K2<br>R                                              | BR0K1<br>W<br>0                 | BR0K0             |
| -     | Bit symbol<br>Read/Write                            | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32<br>3<br>BR0K3<br>0<br>Se                                                          | BR0K2<br>R<br>0<br>ets the freque                       | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset             | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32<br>3<br>BR0K3<br>0<br>Se                                                          | BR0K2<br>R<br>0<br>ets the freque                       | BR0K1<br>W<br>0                 | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset             | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32<br>3<br>BR0K3<br>0<br>Se                                                          | BR0K2<br>R<br>0<br>ets the freque                       | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset             | 7             | 6                                                                                                                                                                                                                                                                                                            | 11 Inter                                                                          | nal clock ∳T                       | 32<br>3<br>BR0K3<br>0<br>Se                                                          | BR0K2<br>R<br>0<br>ets the freque                       | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset             |               |                                                                                                                                                                                                                                                                                                              | 5                                                                                 | A<br>A                             | 32<br>3<br>BR0K3<br>0<br>Se                                                          | BR0K2<br>R<br>0<br>ets the freque                       | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset             |               | rate generate                                                                                                                                                                                                                                                                                                | 5                                                                                 | divisor ←                          | 32<br>3<br>BR0K3<br>0<br>56<br>(I                                                    | BR0K2<br>R<br>0<br>Dets the freque<br>Divided by N      | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset<br>Function |               | rate generate                                                                                                                                                                                                                                                                                                | 5                                                                                 | divisor ←<br>= 1 BR0               | 32<br>3<br>BR0K3<br>0<br>Se                                                          | BR0K2 $R$ $0$ ets the freque<br>Divided by N            | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset<br>Function | Sets bau      | d rate generate<br>BR0CR <e< td=""><td>5</td><td>divisor ←<br/>= 1 BR0</td><td>32<br/>BR0K3<br/>0<br/>Se<br/>(I</td><td>BR0K2 <math display="block">R</math> <math display="block">0</math> ets the freque<br/>Divided by N</td><td>BR0K1<br/>W<br/>0<br/>ency divisor</td><td>BR0K0<br/>0<br/>'K"</td></e<> | 5                                                                                 | divisor ←<br>= 1 BR0               | 32<br>BR0K3<br>0<br>Se<br>(I                                                         | BR0K2 $R$ $0$ ets the freque<br>Divided by N            | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset<br>Function | Sets baue     | a rate generate<br>BR0CR <e<br>0000 (N = 16</e<br>                                                                                                                                                                                                                                                           | 5<br>5<br>6<br>6<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | r divisor ←<br>= 1 BR0<br>= 2) 000 | 32<br>32<br>BR0K3<br>0<br>(I<br>(I<br>CR <br0add<br>I (N = 1) (UAR</br0add<br>       | BR0K2 R 0 ets the freque Divided by N $E > = 0$ T only) | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |
| -     | Bit symbol<br>Read/Write<br>After reset<br>Function | Sets baue     | a rate generate<br>BR0CR <e<br>0000 (N = 16<br/>or</e<br>                                                                                                                                                                                                                                                    | 5<br>5<br>6<br>6<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | r divisor ←<br>= 1 BR0<br>= 2) 000 | 32<br>3<br>BR0K3<br>0<br>(I<br>(I<br>CR <br0add<br>I (N = 1) (UAR<br/>to</br0add<br> | BR0K2 $R$ $0$ $Divided by N$ $E> = 0$ $T only$          | BR0K1<br>W<br>0<br>ency divisor | BR0K0<br>0<br>'K" |

Note1: Availability of +(16-K)/16 division function

0001(K = 1)

to

1111(K = 15)

| N       | UART Mode | I/O Mode |
|---------|-----------|----------|
| 2 to 15 | 0         | ×        |
| 1, 16   | ×         | ×        |

Disable

The baud rate generator can be set "1" in UART mode and disable +(16-K)/16 division function.Don't use in I/O interface mode.

Divided by N

Note2: Set BR0CR <BR0ADDE> to 1 after setting K (K = 1 to 15) to BR0ADD<BR0K3:0> when +(16-K)/16 division function is used. Writes to unused bits in the BR0ADD register do not affext operation, and undefined data is read from these unused bits.

Figure 3.9.11 Baud Rate Generator Control (SIO0, BR0CR, BR0ADD)

Divided by

N + (16 - K)/16

|        |                                             | 7                 | 6                                                    | 5                                             | 4                                                         | 3                                             | 2       | 1                              | 0     |
|--------|---------------------------------------------|-------------------|------------------------------------------------------|-----------------------------------------------|-----------------------------------------------------------|-----------------------------------------------|---------|--------------------------------|-------|
| BR1CR  | Bit symbol                                  | _                 | BR1ADDE                                              | BR1CK1                                        | BR1CK0                                                    | BR1S3                                         | BR1S2   | BR1S1                          | BR1S0 |
| 020BH) | Read/Write                                  |                   |                                                      | R/                                            |                                                           |                                               |         |                                |       |
|        | After reset                                 | 0                 | 0                                                    | 0                                             | 0                                                         | 0                                             | 0       | 0                              | 0     |
|        | Function                                    | Always<br>write 0 | + (16 – K)/16<br>division<br>0: Disable<br>1: Enable | 00: φT0<br>01: φT2<br>10: φT8<br>11: φT32     |                                                           | Setting the divided frequency "N"<br>(0 to F) |         |                                |       |
|        |                                             |                   |                                                      |                                               | soloction for                                             | haud rate ge                                  | norator |                                |       |
| -      | + (16 – K)/16 division enable<br>0 Disabled |                   |                                                      | Input clock selection for baud rate generator |                                                           |                                               |         |                                |       |
|        |                                             | Enabled           |                                                      |                                               | 00     Internal clock φT0       01     Internal clock φT2 |                                               |         |                                |       |
| L      | Enabled                                     |                   |                                                      | 10 Internal clock $\phi$ T8                   |                                                           |                                               |         |                                |       |
|        |                                             |                   |                                                      | 11 Internal clock φT32                        |                                                           |                                               |         |                                |       |
|        |                                             | 7                 | 6                                                    | 5                                             | 4                                                         | 3                                             | 2       | 1                              | 0     |
| BR1ADD | Bit symbol                                  |                   |                                                      |                                               |                                                           | BR1K3                                         | BR1K2   | BR1K1                          | BR1K0 |
| 20CH)  | Read/Write                                  |                   |                                                      |                                               |                                                           |                                               |         | W                              | r     |
|        | After reset                                 |                   |                                                      |                                               |                                                           | 0                                             | 0       | 0                              | 0     |
|        | Function                                    |                   |                                                      |                                               |                                                           |                                               |         | ency divisor '<br>+ (16 – K)/1 |       |
|        |                                             |                   |                                                      |                                               |                                                           |                                               |         |                                |       |
|        |                                             |                   |                                                      |                                               |                                                           |                                               |         |                                |       |
|        |                                             | Roud roto o       | enerator frec                                        |                                               | ←                                                         |                                               |         |                                |       |

|                     | BR1CR <br1a< th=""><th>DDE&gt; = 1</th><th colspan="3">BR1CR<br1adde> = 0</br1adde></th></br1a<> | DDE> = 1        | BR1CR <br1adde> = 0</br1adde> |  |  |
|---------------------|--------------------------------------------------------------------------------------------------|-----------------|-------------------------------|--|--|
| BROCR               | 0000 (N = 16)                                                                                    | 0010 (N = 2)    | 0001 (N = 1) (UART only)      |  |  |
| <br1s3:0></br1s3:0> | or                                                                                               | to              | to                            |  |  |
| BR1ADD              | 0001 (N = 1)                                                                                     | 1111 (N = 15)   | 1111 (N = 15)                 |  |  |
| <br1k3:0></br1k3:0> |                                                                                                  |                 | 0000 (N = 16)                 |  |  |
| 0000                | Disable                                                                                          | Disable         |                               |  |  |
| 0001 (K = 1)        | Disable                                                                                          | Disabled by     | Divided by N                  |  |  |
| to                  |                                                                                                  | N + (16 – K)/16 |                               |  |  |
| 1111 (K = 15)       |                                                                                                  |                 |                               |  |  |

Note1: Availability of +(16-K)/16 division function

| N       | UART Mode | I/O Mode |  |  |
|---------|-----------|----------|--|--|
| 2 to 15 | 0         | ×        |  |  |
| 1, 16   | ×         | ×        |  |  |

The baud rate generator can be set "1" in UART mode and disable +(16-K)/16 division function.Don't use in I/O interface mode.

Note2: Set BR1CR <BR1ADDE> to 1 after setting K (K = 1 to 15) to BR1ADD<BR1K3:0> when +(16-K)/16 division function is used. Writes to unused bits in the BR0ADD register do not affext operation, and undefined data is read from these unused bits.

Figure 3.9.12 Baud Rate Generator Control (SIO1, BR1CR, BR1ADD)



Note: Prohibit read modify write for SC0BUF.

Figure 3.9.13 Serial Transmission/Receiving Buffer Registers (SIO0, SC0BUF)

SC0MOD1 (0205H)

|             | 7       | 6       | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|---------|---------|---|---|---|---|---|---|
| Bit symbol  | I2S0    | FDPX0   |   |   |   |   |   |   |
| Read/Write  | R/W     | R/W     | / | / | / | / | / |   |
| After reset | 0       | 0       | / | / | / | / | / |   |
| Function    | IDLE2   | Duplex  |   |   |   |   |   |   |
|             | 0: Stop | 0: Half |   |   |   |   |   |   |
|             | 1: Run  | 1: Full |   |   |   |   |   |   |

Figure 3.9.14 Serial Mode Control Register 1 (SIO0, SC0MOD1)



Note: Prohibit read modify write for SC1BUF.

Figure 3.9.15 Serial Transmission/Receiving Buffer Registers (SIO1, SC1BUF)

SC1MOD1 (020DH)

|             | 7       | 6       | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|---------|---------|---|---|---|---|---|---|
| Bit symbol  | I2S1    | FDPX1   |   |   |   |   |   |   |
| Read/Write  | R/W     | R/W     | / | / | / | / | / |   |
| After reset | 0       | 0       | / | / | / | / | / |   |
| Function    | IDLE2   | Duplex  |   |   |   |   |   |   |
|             | 0: Stop | 0: Half |   |   |   |   |   |   |
|             | 1: Run  | 1: Full |   |   |   |   |   |   |

Figure 3.9.16 Serial Mode Control Register 1 (SIO1, SC1MOD1)

# 3.9.4 Operation in Each Mode

### (1) Mode 0 (I/O interface mode)

This mode allows an increase in the number of I/O pins available for transmitting data to or receiving data from an external shift register.

This mode includes the SCLK output mode to output synchronous clock SCLK and SCLK input mode to input external synchronous clock SCLK.



Figure 3.9.17 SCLK Output Mode Connection Example



Figure 3.9.18 SCLK Input Mode Connection Example

a. Transmission

In SCLK output mode 8-bit data and a synchronous clock are output on the TXD0 and SCLK0 pins respectively each time the CPU writes the data to the transmission buffer. When all data is output, INTESO<ITX0C> will be set to generate the INTTX0 interrupt.



Figure 3.9.19 Transmitting Operation in I/O Interface Mode (SCLK0 output mode)

In SCLK input mode, 8-bit data is output on the TXD0 pin when the SCLK0 input becomes active after the data has been written to the transmission buffer by the CPU.

When all data is output, INTESO<ITX0C> will be set to generate INTTX0 interrupt.



Figure 3.9.20 Transmitting Operation in I/O Interface Mode (SCLK0 input mode)

### b. Receiving

In SCLK output mode, the synchronous clock is outputted from SCLK0 pin and the data is shifted to receiving buffer 1. This starts when the receive interrupt flag INTESO<IRX0C> is cleared by reading the received data. When 8bit data are received, the data will be transferred to receiving buffer 2 (SC0BUF according to the timing shown below) and INTESO<IRX0C> will be set to generate INTRX0 interrupt.

The outputting for the first SCLK0 starts by setting SC0MOD0<RXE> to 1.



Figure 3.9.21 Receiving Operation in I/O Interface Mode (SCLK0 output mode)

In SCLK input mode, the data is shifted to receiving buffer 1 when the SCLK input becomes active after the receive interrupt flag INTESO<IRX0C> is cleared by reading the received data. When 8-bit data is received, the data will be shifted to receiving buffer 2 (SC0BUF according to the timing shown below) and INTESO<IRX0C> will be set again to be generate INTRX0 interrupt.



Figure 3.9.22 Receiving Operation in I/O Interface Mode (SCLK0 input mode)

Note: The system must be put in the receive enable state (SCMOD0<RXE> = 1) before data can be received.

# c. Transmission and receiving (Full duplex mode)

When the full duplex mode is used, set the level of Receive Interrupt to 0 and set enable the interrupt level (1 to 6) to the transfer interrupt. In the transfer interrupt program, The receiving operation should be done like the above example before setting the next transfer data.

### Example: Channel 0, SCLK output

Baud rate = 9600 bps fc = 14.7456 MHz

| * C          | lock  | stat   | e     |     |     |     |     |   | System clock: High frequency (fc)<br>Clock gear: 1 (fc)<br>Prescaler clock: f <sub>FPH</sub> |
|--------------|-------|--------|-------|-----|-----|-----|-----|---|----------------------------------------------------------------------------------------------|
| Main routine | е     |        |       |     |     |     |     |   |                                                                                              |
|              | 7     | 6      | 5     | 4   | 3   | 2   | 1   | 0 | Set the INTTX0 level to 1.                                                                   |
| INTES0       | _     | 0      | 0     | 1   | _   | 0   | 0   | 0 | Set the INTRX0 level to 0.                                                                   |
| PCCR         | -     | -      | _     | _   | -   | 1   | 0   | 1 | Set PC0, PC1 and PC2 to function as the TXD0,                                                |
|              |       |        |       |     |     |     |     |   | RXD0 and SCLK0 pins respectively.                                                            |
| PCFC         | Х     | Х      | -     | Х   | -   | 1   | Х   | 1 |                                                                                              |
| SC0MOD0      | -     | -      | -     | -   | 0   | 0   | -   | - | Select I/O interface mode.                                                                   |
| SC0MOD1      | 1     | 1      | Х     | Х   | Х   | Х   | Х   | Х | Select full duplex mode.                                                                     |
| SC0CR        | -     | -      | -     | -   | -   | -   | 0   | - | SCLK output, transmit on negative edge, receive on positive edge                             |
| BR0CR        | 0     | 0      | 1     | 1   | 0   | 0   | 1   | 1 | Baud rate = 9600 bps                                                                         |
| SCOMODO      | -     | _      | 1     | _   | _   | _   | _   | _ | Enable receiving                                                                             |
| SC0BUF       | *     | *      | *     | *   | *   | *   | *   | * | Set the transmit data and start.                                                             |
| INTTX0 inte  | erruc | ot rou | utine |     |     |     |     |   |                                                                                              |
| Acc SC0BL    |       |        |       |     |     |     |     |   | Read the receiving buffer.                                                                   |
| SC0BUF *     | × 1   | ং গ    | د ×   | : গ | < গ | k 3 | : > | ¢ | Set the next transmit data.                                                                  |
| X: Don't car | re, – | : No   | cha   | nge |     |     |     |   |                                                                                              |

(2) Mode 1 (7-bit UART mode)

7-bit UART mode is selected by setting serial channel mode register SC0MOD0<SM1:0> to 01.

In this mode, a parity bit can be added. Use of a parity bit is enabled or disabled by the setting of the serial channel control register SCOCR<PE> bit; whether even parity or odd parity will be used is determined by the SCOCR<EVEN> setting when SCOCR<PE> is set to 1 (Enabled).

Example: When transmitting data of the following format, the control registers should be set as described below. This explanation applies to channel 0.



(3) Mode 2 (8-bit UART mode)

8-bit UART mode is selected by setting SC0MOD0<SM1:0> to 10. In this mode, a parity bit can be added (use of a parity bit is enabled or disabled by the setting of SC0CR<PE>); whether even parity or odd parity will be used is determined by the SC0CR<EVEN> setting when SC0CR<PE> is set to 1 (Enabled).

Example: When receiving data of the following format, the control registers should be set as described below.



| * Clock state                                                       | System clock:High frequency (fc)Clock gear:1 (fc)Prescaler clock:System clock |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------|
| Main settings                                                       |                                                                               |
| 7 6 5 4 3 2 1 0                                                     |                                                                               |
| PCCR $\leftarrow$ X X 0 -                                           | Set PC1 to function as the RXD0 pin.                                          |
| SC0MOD0 ← 1 - 1 0 0 1                                               | Enable receiving in 8-bit UART mode.                                          |
| SC0CR ← - 0 1                                                       | Add even parity.                                                              |
| BR0CR ← 0 0 0 1 0 1 0 1                                             | Set the transfer rate to 9600 bps.                                            |
| INTES0 ← 1 0 0                                                      | Enable the INTTX0 interrupt and set it to interrupt level 4.                  |
| Interrupt processing                                                |                                                                               |
| Acc $\leftarrow$ SC0CR AND 00011100<br>if Acc $\neq$ 0 then ERROR } | Check for errors.                                                             |
| Acc ← SC0BUF                                                        | Read the received data.                                                       |
| X: Don't care, -: No change                                         |                                                                               |

#### (4) Mode 3 (9-bit UART mode)

9-bit UART mode is selected by setting SC0MOD0<SM1:0> to 11. In this mode parity bit cannot be added.

In the case of transmission the MSB (9th bit) is written to SC0MOD0<TB8>. In the case of receiving it is stored in SC0CR<RB8>. When the buffer is written and read, the MSB is read or written first, before the rest of the SC0BUF data.

#### Wakeup function

In 9-bit UART mode, the wakeup function for slave controllers is enabled by setting SCOMOD0<WU> to 1. The interrupt INTRX0 occurs only when<RB8> = 1.



Note: The TXD pin of each slave controller must be in Open-drain output mode.

Figure 3.9.23 Serial Link Using Wakeup Function

# Protocol

- (1) Select 9-bit UART mode on the master and slave controllers.
- (2) Set the SC0MOD0<WU> bit on each slave controller to 1 to enable data receiving.
- (3) The master controller transmits one-frame data including the 8-bit select code for the slave controllers. The MSB (Bit8) <TB8> is set to 1.



- (4) Each slave controller receives the above frame. Each controller checks the above select code against its own select code. The controller whose code matches clears its WU bit to 0.
- (5) The master controller transmits data to the specified slave controller whose SC0MOD<WU> bit is cleared to 0. The MSB (Bit8) <TB8> is cleared to 0.



(6) The other slave controllers (whose <WU> bits remain at 1) ignore the received data because their MSBs (Bit8 or <RB8>) are set to 0, disabling INTRX0 interrupts.

The slave controller (WU bit = 0) can transmit data to the master controller, and it is possible to indicate the end of data receiving to the master controller by this transmission.

Example: To link two slave controllers serially with the master controller using the internal clock fSYS as the transfer clock.



Since serial channels 0 and 1 operate in exactly the same way, channel 0 only is used for the purposes of this explanation.

• Setting the master controller

Main

| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                 | Set PC0 and PC1 to function as the TXD0 and RXD0 pins<br>respectively.<br>Enable the INTTX0 interrupt and set it to interrupt level 4.<br>Enable the INTRX0 interrupt and set it to interrupt level 5.<br>Set f <sub>SYS</sub> as the transmission clock for 9-bit UART mode.<br>Set the select code for slave controller 1. |
|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\begin{array}{rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr$                                                 | Set TB8 to 0.<br>Set data for transmission.                                                                                                                                                                                                                                                                                  |
| Setting the slave controller                                                                         |                                                                                                                                                                                                                                                                                                                              |
| Main                                                                                                 |                                                                                                                                                                                                                                                                                                                              |
| PCCR $\leftarrow$ X X 0 1                                                                            |                                                                                                                                                                                                                                                                                                                              |
| $\begin{array}{ccc} PCFC & \leftarrow X X - X X 1 \\ PCODE & \leftarrow X X X X - X X 1 \end{array}$ | Set PC1 to RXD0 and PC0 to TXD0 (Open-drain output).                                                                                                                                                                                                                                                                         |
| $(\text{INTESO} \leftarrow -1 \ 0 \ 1 \ -1 \ 1 \ 0)$                                                 | Enable INTRX0 and INTTX0.                                                                                                                                                                                                                                                                                                    |
| SC0MOD0 ← 1 1 1 1 1 0                                                                                | Set <wu> to 1 in 9-bit UART transmission mode using <math display="inline">f_{\mbox{SYS}}</math></wu>                                                                                                                                                                                                                        |
|                                                                                                      | as the transfer clock.                                                                                                                                                                                                                                                                                                       |
| INTRX0 interrupt                                                                                     | as the transfer clock.                                                                                                                                                                                                                                                                                                       |

# 3.9.5 Support for IrDA

SIO0 includes support for the IrDA 1.0 infrared data communication specification. Figure 3.9.24 shows the block diagram.



Figure 3.9.24 IrDA Block Diagram

(1) Modulation of the transmission data

When the transfer data is 0, the modem outputs 1 to TXD0 pin with either 3/16 or 1/16 times for width of baud rate. The pulse width is selected by the SIRCR<PLSEL>. When the transfer data is 1, the modem outputs 0.



Figure 3.9.25 Modulation Example of Transfer Data

(2) Modulation of the receive data

When the receive data has the effective high level pulse width (Software selectable), the modem outputs 0 to SIO0. Otherwise the modem outputs 1 to SIO0. The receive pulse logic is also selectable by SIRCR<RXSEL>.



Figure 3.9.26 Demodulation Example of Receive Data

(3) Data format

The data format is fixed as follows:

- Data length: 8-bit
- Parity bits: none
- Stop bits: 1

Any other settings don't guarantee the normal operation.

### (4) SFR

Figure 3.9.27 shows the control register SIRCR. Set the data SIRCR during SIO0 is inhibited (Both TXEN and RXEN of this register should be set to 0).

Any changing for this register during transmission or receiving operation don't guarantee the normal operation.

The following example describes how to set this register:

| 1) | SIO setting            | ; Set the SIO to UART Mode.                                |
|----|------------------------|------------------------------------------------------------|
|    | $\downarrow$           |                                                            |
| 2) | LD (SIRCR), 07H        | ; Set the receive data pulse width to 16×.                 |
| 3) | LD (SIRCR), 37H        | ; TXEN, RXEN Enable the Transmission and receiving of SIO. |
|    | $\downarrow$           |                                                            |
| 4) | Start transmission     | ; The modem operates as follows:                           |
|    | and receiving for SIO0 | SIO0 starts transmitting.                                  |
|    |                        | IR receiver starts receiving.                              |
|    |                        |                                                            |

#### (5) Notes

1) Baud rate generator for IrDA

To generate baud rate for IrDA, use baud rate generator in SIO0 by setting 01 to SC0MOD0<SC1:0>. To use another source (TA0TRG, fSYS and SCLK0 input) are not allowed.

2) As the IrDA 1.0 physical layer specification, the data transfer speed and infra-red pulse width is specified.

| Baud Rate  | Modulation | Rate Tolerance<br>(% of rate) | Pulse Width<br>(Minimum) | Pulse Width<br>(Typical) | Pulse Width<br>(Maximum) |
|------------|------------|-------------------------------|--------------------------|--------------------------|--------------------------|
| 2.4 kbps   | RZI        | ±0.87                         | 1.41 μs                  | 78.13 μs                 | 88.55 μs                 |
| 9.6 kbps   | RZI        | ±0.87                         | 1.41 μs                  | 19.53 μs                 | 22.13 μs                 |
| 19.2 kbps  | RZI        | ±0.87                         | 1.41 μs                  | 9.77 μs                  | 11.07 μs                 |
| 38.4 kbps  | RZI        | ±0.87                         | 1.41 μs                  | 4.88 μs                  | 5.96 μs                  |
| 57.6 kbps  | RZI        | ±0.87                         | 1.41 μs                  | 3.26 μs                  | 4.34 μs                  |
| 115.2 kbps | RZI        | ±0.87                         | 1.41 μs                  | 1.63 μs                  | 2.23 μs                  |

Table 3.9.4 Baud Rate and Pulse Width Specifications

The infra-red pulse width is specified either baud rate T  $\times$  3/16 or 1.6  $\mu s$  (1.6  $\mu s$  is equal to 3/16 pulse width when baud rate is 115.2 kbps).

The TMP91C824F has the function selects the pulse width on the transmission either 3/16 or 1/16. But 1/16 pulse width can be selected when the baud rate is equal or less than 38.4 kbps only. When 57.6 kbps and 115.2 kbps, the output pulse width should not be set to  $T \times 1/16$ .

As the same reason, + (16 - k)/16 division functions in the baud rate generator of SIO0 can not be used to generate 115.2 kbps baud rate.

Also when the 38.4 kbps and 1/16 pulse width, + (16 - k)/16 division function can not be used. Table 3.9.5 shows Baud rate and pulse width for (16 - k)/16 division function.

Table 3.9.5 Baud Rate and Pulse Width for (16 - k)/16 Division Function

| Pulse Width | Baud Rate  |           |           |           |          |          |  |  |  |  |
|-------------|------------|-----------|-----------|-----------|----------|----------|--|--|--|--|
|             | 115.2 kbps | 57.6 kbps | 38.4 kbps | 19.2 kbps | 9.6 kbps | 2.4 kbps |  |  |  |  |
| T × 3/16    | ×          | 0         | 0         | 0         | 0        | 0        |  |  |  |  |
| T × 1/16    | -          | -         | ×         | 0         | 0        | 0        |  |  |  |  |

 $\odot$ : Can be used (16 – k)/16 division function

 $\times$ : Can not be used (16 – k)/16 division function

-: Can not be set to 1/16 pulse width

|         |             | 7           | 6          | 5          | 4       |     | 3                    | 2                  | 1                       | 0              |
|---------|-------------|-------------|------------|------------|---------|-----|----------------------|--------------------|-------------------------|----------------|
| SIRCR   | Bit symbol  | PLSEL       | RXSEL      | TXEN       | RXE     | N   | SIRWD3               | SIRWD2             | SIRWD1                  | SIRWD0         |
| (0207H) | Read/Write  |             |            |            |         |     | <u>/</u> W           |                    |                         |                |
|         | After reset | 0           | 0          | 0          | 0       |     | 0                    | 0                  | 0                       | 0              |
|         | Function    | Select      | Receive    | Transmit   | Receive | е   | Select receit        | ve pulse widt      | h                       |                |
|         |             | transmit    | data       | 0: Disable | 0: Disa | ble | Set effective        | e pulse width      | for equal or            | more than      |
|         |             | pulse width | 0: H pulse | 1: Enable  | 1: Enat | ole | $2x \times (value -$ | + 1) + 100ns       |                         |                |
|         |             | 0: 3/16     | 1: L pulse |            |         |     | Can be set:          |                    |                         |                |
|         |             | 1: 1/16     |            |            |         |     | Can not be           | set: 0, 15         |                         |                |
|         |             |             | 3          |            |         |     |                      |                    |                         |                |
|         |             |             |            |            |         |     |                      |                    |                         |                |
|         |             |             |            |            |         | Ls  | elect receive        | pulse width        |                         |                |
|         |             |             |            |            |         | F   | ormula: Effec        | •                  | $dth \ge 2x \times (V)$ | /alue + 1) + 1 |
|         |             |             |            |            |         | _   |                      | 1/f <sub>FPH</sub> |                         |                |
|         |             |             |            |            |         | -   | 0000                 | Cannot be s        |                         |                |
|         |             |             |            |            |         | (   | 0001                 | Equal or mo        | re than 4x +            | 100 ns         |
|         |             |             |            |            |         |     | to                   |                    |                         |                |
|         |             |             |            |            |         |     | 1110                 |                    | re than 30x -           | + 100 ns       |
|         |             |             |            |            |         | Ľ,  | 1111                 | Can not be s       | set                     |                |
|         |             |             |            |            |         | R   | eceive opera         |                    |                         |                |
|         |             |             |            |            |         |     |                      | Disabled           |                         |                |
|         |             |             |            |            |         | L   |                      | Enabled            |                         |                |
|         |             |             |            | I          |         |     | ransmit oper         |                    |                         |                |
|         |             |             |            |            |         |     | -                    | Disabled           |                         |                |
|         |             |             |            |            |         |     |                      | Enabled            |                         |                |
|         |             |             |            |            |         | Ś   | elect transmi        | •                  |                         |                |
|         |             |             |            |            |         | _   |                      | 3/16               |                         |                |
|         |             |             |            |            |         |     | 1                    | 1/16               |                         |                |



# 3.10 Serial Bus Interface (SBI)

The TMP91C824F has a 1-channel serial bus interface which employs a clocked-synchronous 8-bit SIO mode and an  $I^2C$  bus mode.

The serial bus interface is connected to an external device through P71 (SDA) and P72 (SCL) in the  $I^2C$  bus mode; and through P70 (SCK), P71 (SO) and P72 (SI) in the clocked-synchronous 8-bit SIO mode.

Each pin is specified as follows.

|                           | P7ODE <ode72:71></ode72:71> | P7CR <p72c:70c></p72c:70c> | P7FC <p72f:70f></p72f:70f> |  |  |
|---------------------------|-----------------------------|----------------------------|----------------------------|--|--|
| I <sup>2</sup> C bus mode | 11                          | 11X                        | 11X                        |  |  |
| Clocked synchronous       | XX                          | 011                        | 111                        |  |  |
| 8-bit SIO mode            | ~~                          | 010                        | 111                        |  |  |

X: Don't care

#### 3.10.1 Configuration



Figure 3.10.1 Serial Bus Interface (SBI)

### 3.10.2 Serial Bus Interface (SBI) Control

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

- Serial bus interface control register 1 (SBI0CR1)
- Serial bus interface control register 2 (SBI0CR2)
- Serial bus interface data buffer register (SBI0DBR)
- I<sup>2</sup>C bus address register (I2C0AR)
- Serial bus interface status register (SBI0SR)
- Serial bus interface baud rate register 0 (SBI0BR0)
- Serial bus interface baud rate register 1 (SBI0BR1)

The above registers differ depending on a mode to be used.

Refer to section 3.10.4 "I<sup>2</sup>C Bus Mode Control" and 3.10.7 "Clocked Synchronous 8-Bit SIO Mode Control".

# 3.10.3 The Data Formats in the I<sup>2</sup>C Bus Mode

The data formats in the  $I^{2}C$  bus mode is shown below.

(a) Addressing format



#### (b) Addressing format (with restart)



(c) Free data format (Data transferred from master device to slave device)

- S: Start condition
- $\mathsf{R}/\,\overline{\mathsf{W}}$  : Direction bit
- ACK: Acknowledge bit
- P: Stop condition

Figure 3.10.2 Data Format in the I<sup>2</sup>C Bus Mode

# 3.10.4 I<sup>2</sup>C Bus Mode Control

The following registers are used to control and monitor the operation status when using the serial bus interface (SBI) in the I<sup>2</sup>C bus mode.



Seirial Bus Interface Conrol Register 1

Note 1: Set the <BC2:0> to 000 before switching to a clock-synchronous 8-bit SIO mode.

Note 2: For the frequency of the SCL line clock, see 3.10.5 (3) Serial clock.

- Note 3: Initial data of SCK0 is "0", SWRMON is "1".
- Note 4: This I<sup>2</sup>C bus circuit does not support fast mode, it supports standard mode only. Although the I<sup>2</sup>C bus circuit itself allows the setting of a baud rate over 100kbps, the compliance with the I<sup>2</sup>C specification is not guraranteed in that case.

Figure 3.10.3 Registers for the I<sup>2</sup>C Bus Mode

|                   |             | -            |              | -          | 1         |                                     |                    |                |             |
|-------------------|-------------|--------------|--------------|------------|-----------|-------------------------------------|--------------------|----------------|-------------|
|                   |             | 7            | 6            | 5          | 4         | 3                                   | 2                  | 1              | 0           |
| SBI0CR2           | Bit symbol  | MST          | TRX          | BB         | PIN       | SBIM                                | 1 SBIM0            | SWRST1         | SWRST0      |
| (0243H)           | Read/Write  |              | ١            | V          | 1         |                                     | V (Note 1)         |                | ote 1)      |
|                   | After reset | 0            | 0            | 0          | 1         | 0                                   | 0                  | 0              | 0           |
| Prohibit<br>read- | Function    | Master/slave | Transmitter/ | Start/stop | Cancel    | Serial bu                           | is interface       | Software rese  | et generate |
| modify-           |             | selection    | receiver     | condition  | INTSBI    |                                     | g mode selection   | write 10 and   | -           |
| write             |             |              | selection    | generation | interrupt | (Note2)                             |                    | internal reset | signal is   |
|                   |             |              |              |            | request   | 00: Port r                          |                    | generated.     |             |
|                   |             |              |              |            |           | 01: SIO r<br>10: I <sup>2</sup> C b |                    |                |             |
|                   |             |              |              |            |           | 10:1 C b                            |                    |                |             |
|                   |             |              |              |            |           |                                     |                    |                |             |
|                   |             |              |              |            |           |                                     |                    |                |             |
|                   |             |              |              |            |           |                                     | us interface oper  |                |             |
|                   |             |              |              |            |           |                                     | rt mode (Serial b  |                |             |
|                   |             |              |              |            |           | 1                                   | ocked synchrono    | us 8-bit SIO   | mode        |
|                   |             |              |              |            |           |                                     | bus mode           |                |             |
|                   |             |              |              |            |           | 11 (Re                              | eserved)           |                |             |
|                   |             |              |              |            | ;         | INTSBI i                            | interrupt request  |                |             |
|                   |             |              |              |            |           | 0 Do                                | n't care           |                |             |
|                   |             |              |              |            |           | 1 Ca                                | ncel interrupt rec | quest          |             |
|                   |             |              |              |            | ;         | Start/sto                           | p condition gene   | eration        |             |
|                   |             |              |              |            |           | 0 Ge                                | nerates the stop   | condition      |             |
|                   |             |              |              |            |           | 1 Ge                                | nerates the start  | condition      |             |
|                   |             |              |              |            |           | Transmi                             | tter/receiver sele | oction         |             |
|                   |             |              |              |            | ,         |                                     | ceiver             |                |             |
|                   |             |              |              |            |           |                                     | ansmitter          |                |             |
|                   |             |              |              |            |           |                                     |                    |                |             |
|                   |             |              |              |            | ;         |                                     | slave selection    |                |             |
|                   |             |              |              |            |           | 0 Sla                               |                    |                |             |
|                   |             |              |              |            |           | 1 Ma                                | ster               |                |             |

Serial Bus Interface Control Register 2

Note 1: Reading this register function as SBI0SR register.

Note 2: Switch a mode to port mode after confirming that the bus is free.

Switch a mode between I<sup>2</sup>C bus mode and clock-synchronous 8-bit SIO mode after confirming that input signals via port are high level.

Figure 3.10.4 Registers for the I<sup>2</sup>C Bus Mode

|                   |             | 1       | 1            |                      | enace Sta | <u> </u>    | T                            | 1              |               |
|-------------------|-------------|---------|--------------|----------------------|-----------|-------------|------------------------------|----------------|---------------|
|                   |             | 7       | 6            | 5                    | 4         | 3           | 2                            | 1              | 0             |
| SBIOSR            | Bit symbol  | MST     | TRX          | BB                   | PIN       | AL          | AAS                          | AD0            | LRB           |
| (0243H)           | Read/Write  |         |              |                      | 1         | R           | 1                            |                |               |
| Due hilbit        | After reset | 0       | 0            | 0                    | 1         | 0           | 0                            | 0              | 0             |
| Prohibit<br>read- | Function    | Master/ | Transmitter/ | I <sup>2</sup> C bus | INTSBI    | Arbitration | Slave                        | GENERAL        | Last          |
| modify-           |             | slave   | receiver     | status               | interrupt | lost        | address                      | CALL           | received bit  |
| write             |             | status  | status       | monitor              | request   | detection   | match                        | detection      | monitor       |
|                   |             | monitor | monitor      |                      | monitor   | monitor     | detection                    | monitor        | 0:0           |
|                   |             |         |              |                      |           | 0: -        | monitor                      | 0: Undetected  | 1:1           |
|                   |             |         |              |                      |           | 1: Detected | 0: Undetected<br>1: Detected | 1: Detected    |               |
|                   |             |         |              |                      |           |             | T: Delected                  |                |               |
|                   |             |         |              |                      |           |             |                              |                |               |
|                   |             |         |              |                      |           |             |                              |                |               |
|                   |             |         |              |                      |           |             | Last received                |                |               |
|                   |             |         |              |                      |           |             |                              | eived bit was  |               |
|                   |             |         |              |                      |           |             | 1 Last rec                   | eived bit was  | 1             |
|                   |             |         |              |                      |           | $   \sqcup$ | GENERAL C                    | ALL detectior  | n monitor     |
|                   |             |         |              |                      |           |             | 0 Undetee                    |                |               |
|                   |             |         |              |                      |           |             | 1 GENER                      | AL CALL dete   | ected         |
|                   |             |         |              |                      |           |             |                              |                |               |
|                   |             |         |              |                      |           |             | Slave addres                 |                | ction monitor |
|                   |             |         |              |                      |           |             |                              | ddress match   |               |
|                   |             |         |              |                      |           |             | 1 CALL d                     |                | OF GENERA     |
|                   |             |         |              |                      |           |             | Arbitration lo               | st detection m | ionitor       |
|                   |             |         |              |                      |           |             | 0 –                          |                |               |
|                   |             |         |              |                      |           |             | 1 Arbitrati                  | on lost        |               |
|                   |             |         |              |                      |           |             | INTSBI interr                | upt request m  | nonitor       |
|                   |             |         |              |                      |           |             |                              | t requested    |               |
|                   |             |         |              |                      |           |             | 1 Interrup                   | t canceled     |               |
|                   |             |         |              |                      |           |             | I <sup>2</sup> C bus statu   | s monitor      |               |
|                   |             |         |              |                      |           |             | 0 Free                       |                |               |
|                   |             |         |              |                      |           |             | 1 Busy                       |                |               |
|                   |             |         |              |                      |           |             | Transmitter/r                | eceiver status | monitor       |
|                   |             |         |              |                      |           |             | 0 Receive                    | er             |               |
|                   |             |         |              |                      |           |             | 1 Transm                     | itter          |               |
|                   |             |         |              |                      |           |             | Master/slave                 | status monito  | or            |
|                   |             |         |              |                      |           |             | 0 Slave                      |                |               |
|                   |             |         |              |                      |           |             | 1 Master                     | -              |               |

Serial Bus Interface Status Register

Note: Writing in this register functions as SBI0CR2.

Figure 3.10.5 Registers for the  $I^2C$  Bus Mode



| Sorial | Due | Interface | Doud | Doto | Dogetor | Δ |
|--------|-----|-----------|------|------|---------|---|
| Senar  | DUS | intenace  | Dauu | Rale | Regsler | υ |

Prohibit read-When writing transmitted data, start from the MSB (Bit7). Receiving data is placed from LSB (Bit0). Note 1: modifywrite

SBIDBR can't be read the written data. Therefore read-modify-write instruction (e.g., "BIT" instruction) is Note 2: prohibitted.

Undefined

Note 3: Written data in SBI0DBR is cleared by INTSBI signal.

After reset

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

|                                       |             | 7           | 6                                                                    | 5   | 4   | 3   | 2   | 1    | 0   |  |  |  |
|---------------------------------------|-------------|-------------|----------------------------------------------------------------------|-----|-----|-----|-----|------|-----|--|--|--|
| I2C0AR<br>(0242H)                     | Bit symbol  | SA6         | SA5                                                                  | SA4 | SA3 | SA2 | SA1 | SA0  | ALS |  |  |  |
|                                       | Read/Write  |             | W                                                                    |     |     |     |     |      |     |  |  |  |
|                                       | After reset | 0           | 0                                                                    | 0   | 0   | 0   | 0   | 0    | 0   |  |  |  |
| Prohibit<br>read-<br>modify-<br>write | Function    | Slave addre | Blave address selection for when device is operating as slave device |     |     |     |     |      |     |  |  |  |
|                                       |             |             |                                                                      |     |     |     |     | -10° |     |  |  |  |



Figure 3.10.6 Registers for the I<sup>2</sup>C Bus Mode

- 3.10.5 Control in I<sup>2</sup>C Bus Mode
  - (1) Acknowledge mode specification

Set the SBI0CR1<ACK> to 1 for operation in the acknowledge mode. The TMP91C824 generates an additional clock pulse for an acknowledge signal when operating in master mode. In the transmitter mode during the clock pulse cycle, the SDA pin is released in order to receive the acknowledge signal from the receiver. In the receiver mode during the clock pulse cycle, the SDA pin is set to the low in order to generate the acknowledge signal.

Clear the <ACK> to 0 for operation in the non-acknowledge mode, The TMP91C824 does not generate a clock pulse for the acknowledge signal when operating in the master mode.

(2) Number of transfer bits

The SBI0CR1<BC2:0> is used to select a number of bits for next transmitting and receiving data.

Since the <BC2:0> is cleared to 000 as a start condition, a slave address and direction bit transmission are executed in 8 bits. Other than these, the <BC2:0> retains a specified value.

- (3) Serial clock
  - a. Clock source

The SBI0CR1<SCK2:0> is used to select a maximum transfer frequency outputted on the SCL pin in 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.



Note 1: f<sub>SBI</sub> is the clock f<sub>FPH</sub>.

Note 2: It's prohibited to use fc/16 prescaler clock when using SBI block. (I<sup>2</sup>C bus and clock synchronous.)

Figure 3.10.7 Clock Source

b. Clock synchronization

In the I<sup>2</sup>C bus mode, in order to wired-AND a bus, a master device which pulls down a clock line to low level, in the first place, invalidate a clock pulse of another master device which generates a high-level clock pulse. The master device with a high-level clock pulse needs to detect the situation and implement the following procedure.

The TMP91C824 has a clock synchronization function for normal data transfer even when more than one master exists on the bus.

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



Figure 3.10.8 Clock Synchronization

As master A pulls down the internal SCL output to the low level at point a, the SCL line of the bus becomes the low level. After detecting this situation, master B resets a counter of high-level width of an own clock pulse and sets the internal SCL output to the low level.

Master A finishes counting low-level width of an own clock pulse at point b and sets the internal SCL output to the high level. Since master B holds the SCL line of the bus at the low level, master A wait for counting high-level width of an own clock pulse. After master B finishes counting low-level width of an own clock pulse at point c and master A detects the SCL line of the bus at the high level, and starts counting high level of an own clock pulse. The clock pulse on the bus is determined by the master device with the shortest high-level width and the master device with the longest low-level width from among those master devices connected to the bus.

(4) Slave address and address recognition mode specification

When the TMP91C824 is used as a slave device, set the slave address <SA6:0> and <ALS> to the I2C0AR. Clear the <ALS> to 0 for the address recognition mode.

(5) Master/slave selection

Set the SBI0CR2<MST> to 1 for operating the TMP91C824 as a master device. Clear the SBI0CR2<MST> to 0 for operation as a slave device. The <MST> is cleared to 0 by the hardware after a stop condition on the bus is detected or arbitration is lost.

(6) Transmitter/receiver selection

Set the SBI0CR2<TRX> to 1 for operating the TMP91C824 as a transmitter. Clear the <TRX> to 0 for operation as a receiver. When data with an addressing format is transferred in slave mode, when a slave address with the same value that an I2C0AR or a GENERAL CALL is received (All 8-bit data are 0 after a start condition), the <TRX> is set to 1 by the hardware if the direction bit  $(R/\overline{W})$  sent from the master device is 1, and is cleared to 0 by the 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 the hardware if is 1, and is set to 1 by the hardware if a transmitted direction bit is 1, and is set to 1 by the hardware if it is 0. When an acknowledge signal is not returned, the current condition is maintained.

The  $\langle TRX \rangle$  is cleared to 0 by the hardware after a stop condition on the I<sup>2</sup>C bus is detected or arbitration is lost.

(7) Start/stop condition generation

When the SBI0SR<BB> is 0, slave address and direction bit which are set to SBI0DBR are output on a bus after generating a start condition by writing 1 to the SBI0CR2<MST, TRX, BB, PIN>. It is necessary to set transmitted data to the data buffer register SBI0DBR and set 1 to <ACK> beforehand.

Figure 3.10.9 Start Condition Generation and Slave Address Generation

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



Figure 3.10.10 Stop Condition Generation

The state of the bus can be ascertained by reading the contents of SBI0SR<BB>. SBI0SR<BB> will be set to 1 if a start condition has been detected on the bus, and will be cleared to 0 if a stop condition has been detected.

And about generation of stop condition in master mode, there are some limitation points. Please refer to the 3.10.6 (4) "Stop condition generation".

(8) Interrupt service requests and interrupt cancellation

When a serial bus interface interrupt request (INTSBI) occurs, the SBI0CR2<PIN> is cleared to 0. During the time that the SBI0CR2<PIN> is 0, the SCL line is pulled down to the low level.

The <PIN> is cleared to 0 when a 1 word of data is transmitted or received. Either writing/reading data to/from SBI0DBR sets the <PIN> to 1.

The time from the  $\langle PIN \rangle$  being set to 1 until the SCL line is released takes  $t_{LOW}$ .

In the address recognition mode ( $\langle ALS \rangle = 0$ ),  $\langle PIN \rangle$  is cleared to 0 when the received slave address is the same as the value set at the I2C0AR or when a GENERAL CALL is received (All 8-bit data are 0 after a start condition). Although SBI0CR2<PIN> can be set to 1 by the program, the  $\langle PIN \rangle$  is not clear it to 0 when it is written 0.

(9) Serial bus interface operation mode selection

SBIOCR2 < SBIM1:0> is used to specify the serial bus interface operation mode. Set SBIOCR2 < SBIM1:0> to 10 when the device is to be used in I<sup>2</sup>C bus mode after confirming pin condition of serial bus interface to "H".

Switch a mode to port after confirming a bus is free.

(10) Arbitration lost detection monitor

Since more than one master device can exist simultaneously on the bus in  $I^2C$  bus mode, a bus arbitration procedure has been implemented in order to guarantee the integrity of transferred data.

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

The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on the bus. Master A and master B output the same data until point a. After master A outputs "L" and master B, "H", the SDA line of the bus is wire-AND and the SDA line is pulled down to the low level by master A. When the SCL line of the bus is pulled up at point b, the slave device reads the data on the SDA line, that is, data in master A. A data transmitted from master B becomes invalid. The state in master B is called arbitration lost. Master B device which loses arbitration releases the internal SDA output in order not to affect 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 3.10.11 Arbitration Lost

The TMP91C824 compares the levels on the bus's SDA line with those of the internal SDA output on the rising edge of the SCL line. If the levels do not match, arbitration is lost and SBI0SR<AL> is set to 1.

When SBI0SR<AL> is set to 1, SBI0SR<MST, TRX> are cleared to 00 and the mode is switched to slave receiver mode. Thus, clock output is stopped in data transfer after setting <AL> = "1".

SBI0SR<AL> is cleared to 0 when data is written to or read from SBI0DBR or when data is written to SBI0CR2.



Figure 3.10.12 Example of when TMP91CW12 is a Master Device B (D7A = D7B, D6A = D6B)

(11) Slave address match detection monitor

SBI0SR < AAS > is set to 1 in slave mode, in address recognition mode (e.g., when I2C0AR < ALS > = 0), when a GENERAL CALL is received, or when a slave address matches the value set in I2C0AR. When I2C0AR < ALS > = 1, SBI0SR < AAS > is set to 1 after the first word of data has been received. SBI0SR < AAS > is cleared to 0 when data is written to or read from the data buffer register SBI0DBR.

(12) GENERAL CALL detection monitor

SBI0SR<AD0> is set to 1 in slave mode, when a GENERAL CALL is received (All 8bit received data is 0, after a start condition). SBI0SR<AD0> is cleared to 0 when a start condition or stop condition is detected on the bus.

(13) Last received bit monitor

The SDA line value stored at the rising edge of the SCL line is set to the SBI0SR<LRB>. In the acknowledge mode, immediately after an INTSBI interrupt request is generated, an acknowledge signal is read by reading the contents of the SBI0SR<LRB>.

(14) Software reset function

The software reset function is used to initialize the SBI circuit, when SBI is locked by external noises, etc.

An internal reset signal pulse can be generated by setting SBI0CR2<SWRST1:0> to 10 and 01. This initializes the SBI circuit internally. All command (except SBI0CR2<SBIM1:0>) registers and status registers are initialized as well.

 $\rm SBI0CR1{<}SWRMON{>}$  is automatically set to "1" after the SBI circuit has been initialized.

(15) Serial bus interface data buffer register (SBI0DBR)

The received data can be read and transferred data can be written by reading or writing the SBI0DBR.

In the master mode, after the start condition is generated the slave address and the direction bit are set in this register.

(16) I<sup>2</sup>C bus address register (I2C0AR)

I2C0AR<SA6:0> is used to set the slave address when the TMP91C824 functions as a slave device.

The slave address output from the master device is recognized by setting the I2COAR<ALS> to 0. The data format is the addressing format. When the slave address is not recognized at the  $\langle ALS \rangle = 1$ , the data format is the free data format.

(17) Baud rate register (SBI0BR1)

Write 1 to SBI0BR1<P4EN> before operation commences.

(18) Setting register for IDLE2 mode operation (SBI0BR0)

SBI0BR0<I2SBI0> is the register setting operation/stop during IDLE2 mode. Therefore, setting <I2SBI0> is necessary before the HALT instruction is executed.

#### 3.10.6 Data Transfer in I<sup>2</sup>C Bus Mode

(1) Device initialization

Set the SBI0BR1<P4EN>, SBI0CR1<ACK, SCK2:0>, Set SBI0BR1 to 1 and clear bits 7 to 5 and 3 in the SBI0CR1 to 0.

Set a slave address  $\langle SA6:0 \rangle$  and the  $\langle ALS \rangle = 0$  when an addressing format) to the I2C0AR.

For specifying the default setting to a slave receiver mode, clear 0 to the <MST, TRX, BB> and set 1 to the <PIN>, 10 to the <SBIM1:0>.

- (2) Start condition and slave address generation
  - a. Master mode

In the master mode, the start condition and the slave address are generated as follows.

Check a bus free status (when  $\langle BB \rangle = 0$ ).

Set the SBI0CR1<ACK> to 1 (Acknowledge mode) and specify a slave address and a direction bit to be transmitted to the SBI0DBR.

When SBI0CR2<BB> = 0, the start condition are generated by writing 1111 to SBI0CR2<MST, TRX, BB, PIN>. Subsequently to the start condition, nine clocks are output from the SCL pin. While eight clocks are output, the slave address and the direction bit which are set to the SBI0DBR. At the 9th clock, the SDA line is released and the acknowledge signal is received from the slave device.

An INTSBI interrupt request occurs at the falling edge of the 9th clock. The <PIN> is cleared to 0. In the master mode, the SCL pin is pulled down to the low level while <PIN> is 0. When an interrupt request occurs, the <TRX> is changed according to the direction bit only when an acknowledge signal is returned from the slave device.

b. Slave mode

In the slave mode, the start condition and the slave address are received.

After the start condition is received from the master device, while eight clocks are output from the SCL pin, the slave address and the direction bit which are output from the master device are received.

When a GENERAL CALL or the same address as the slave address set in I2COAR is received, the SDA line is pulled down to the low level at the 9th clock, and the acknowledge signal is output.

An INTSBI interrupt request occurs on the falling edge of the 9th clock. The  $\langle PIN \rangle$  is cleared to 0. In slave mode the SCL line is pulled down to the low level while the  $\langle PIN \rangle = 0$ .





(3) 1-word data transfer

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

a. If  $\langle MST \rangle = 1$  (Master mode)

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

When the <TRX> = 1 (Transmitter mode)

Check the  $\langle LRB \rangle$ . When  $\langle LRB \rangle$  is 1, a receiver does not request data. Implement the process to generate a stop condition (Refer to 3.10.6 (4)) and terminate data transfer.

When the <LRB> is 0, the receiver is requests new data. When the next transmitted data is 8 bits, write the transmitted data to SBI0DBR. When the next transmitted data is other than 8 bits, set the BC<2:0> <ACK> and write the transmitted data to SBI0DBR. After written the data, <PIN> becomes 1, a serial clock pulse is generated for transferring a new 1 word of data from the SCL pin, and then the 1-word data is transmitted. After the data is transmitted, an INTSBI interrupt request occurs. The <PIN> becomes 0 and the SCL line is pulled down to the low level. If the data to be transferred is more than 1 word in length, repeat the procedure from the <LRB> checking above.



Figure 3.10.14 Example in which BC<2:0> = 000 and <ACK> = 1 in Transmitter Mode

### When the <TRX> is 0 (Receiver mode)

When the next transmitted data is other than 8 bits, set <BC2:0> <ACK> and read the received data from SBI0DBR to release the SCL line (data which is read immediately after a slave address is sent is undefined). After the data is read, <PIN> becomes 1. Serial clock pulse for transferring new 1 word of data is defined SCL and outputs "L" level from SDA pin with acknowledge timing.

An INTSBI interrupt request then occurs and the <PIN> becomes 0, Then the TMP91C824F pulls down the SCL pin to the low level. The TMP91C824 outputs a clock pulse for 1 word of data transfer and the acknowledge signal each time that received data is read from the SBI0DBR.



--- Output from slave

#### Figure 3.10.15 Example of when <BC2:0> = 000, <ACK> = 1 in Receiver Mode

In order to terminate the transmission of data to a transmitter, clear <ACK> to 0 before reading data which is 1 word before the last data to be received. The last data word does not generate a clock pulse as the acknowledge signal. After the data has been transmitted and an interrupt request has been generated, set BC<2:0> to 001 and read the data. The TMP91C824 generates a clock pulse for a 1-bit data transfer. Since the master device is a receiver, the SDA line on the bus remains high. The transmitter interprets the high signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete.

After the one data bit has been received and an interrupt request been generated, the TMP91C824 generates a stop condition (See Section 3.10.6 (4)) and terminates data transfer.



Figure 3.10.16 Termination of Data Transfer in Master Receiver Mode

b. If <MST> = 0 (Slave mode)

In the slave mode the TMP91C824 operates either in normal slave mode or in slave mode after losing arbitration.

In the slave mode, an INTSBI interrupt request occurs when the TMP91C824 receives a slave address or a GENERAL CALL from the master device, or when a GENERAL CALL is received and data transfer is complete, or after matching received address. In the master mode, the TMP91C824 operates in a slave mode if it losing arbitration. An INTSBI interrupt request occurs when a word data transfer terminates after losing arbitration. When an INTSBI interrupt request occurs the <PIN> is cleared to 0 and the SCL pin is pulled down to the low level. Either reading/writing from/to the SBI0DBR or setting the <PIN> to 1 will release the SCL pin after taking tLOW time.

Check the SBI0SR<AL>, <TRX>, <AAS>, and <AD0> and implements processes according to conditions listed in the next table.

| <trx></trx> | <al></al> | <aas></aas> | <ad0></ad0> | Conditions                                                                                                                                                                                         | Process                                                                                                                                                                                                                                                                                                                                   |
|-------------|-----------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | 1         | 1           | 0           | The TMP91C824 loses arbitration when<br>transmitting a slave address and<br>receives a slave address for which the<br>value of the direction bit sent from<br>another master is 1.                 | Set the number of bits a word in<br><bc2:0> and write the transmitted data<br/>to SBI0DBR</bc2:0>                                                                                                                                                                                                                                         |
|             | 0         | 1           | 0           | In salve receiver mode the TMP91C824<br>receives a slave address for which the<br>value of the direction bit sent from the<br>master is 1.                                                         |                                                                                                                                                                                                                                                                                                                                           |
|             |           | 0           | 0           | In salve transmitter mode a single word<br>of is transmitted.<br>Set BC<2:0> to the number of bits in a<br>word.                                                                                   | Check the <lrb> setting. If <lrb> is<br/>set to 1, set <pin> to 1 since the<br/>receiver win no request the data which<br/>follows. Then, cleat <trx> to 0 to<br/>release the bus. If <lrb> is cleared to 0<br/>of and write the transmitted data to<br/>SBI0DBR since the receiver requests<br/>next data.</lrb></trx></pin></lrb></lrb> |
| 0           | 1         | 1           | 1/0         | The TMP91C824 loses arbitration when<br>transmitting a slave address and<br>receives a slave address or GENERAL<br>CALL for which the value of the direction<br>bit sent from another master is 0. | Read the SBI0DBR for setting the <pin><br/>to 1 (Reading dummy data) or set the<br/><pin> to 1.</pin></pin>                                                                                                                                                                                                                               |
|             |           | 0           | 0           | The TMP91C824 loses arbitration when transmitting a slave address or data and terminates word data transfer.                                                                                       |                                                                                                                                                                                                                                                                                                                                           |
|             | 0         | 1           | 1/0         | In slave receiver mode the TMP91C824<br>receives a slave address or GENERAL<br>CALL for which the value of the direction<br>bit sent from the master is 0.                                         |                                                                                                                                                                                                                                                                                                                                           |
|             |           | 0           | 1/0         | In slave receiver mode the TMP91C824 terminates receiving word data.                                                                                                                               | Set BC<2:0> to the number of bits in a word and read the received data from SBI0DBR.                                                                                                                                                                                                                                                      |

Table 3.10.1 Operation in the Slave Mode

(4) Stop condition generation

When SBI0SR < BB > = 1, the sequence for generating a stop condition can be initiated by writing 1 to SBI0CR2 < MST, TRX, PIN > and 0 to SBI0CR2 < BB >. Do not modify the contents of SBI0CR2 < MST, TRX, PIN, BB > until a stop condition has been generated on the bus. When the bus's SCL line has been pulled low by another device, the TMP91C824 generates a stop condition when the other device has released the SCL line.

When SBI0CR2<MST, TRX, PIN> are written 1 and <BB> is written 0, <BB> changes to 0 by internal SCL changes to 1, without waiting stop condition.

To check whether SCL and SDA pin are 1 by sensing their ports is needed to detect bus free condition.



Figure 3.10.17 Stop Condition Generation (Single master)



Figure 3.10.18 Stop Condition Generation (Multi master)

#### (5) Restart

Restart is used during data transfer between a master device and a slave device to change the data transfer direction. The following description explains how to restart when the TMP91C824 is in master mode.

Clear SBI0CR2<MST, TRX, BB> to 0 and set SBI0CR2<PIN> to 1 to release the bus. The SDA line remains high and the SCL pin is released. Since a stop condition has not been generated on the bus, other devices assume the bus to be in busy state. Monitor the value of SBI0SR<BB> until it becomes 0 so as to ascertain when the TMP91C824's SCL pin is released. Check 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 the bus remains in a free state, generate a start condition using the procedure described in 3.10.6 (2).

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



Figure 3.10.19 Timing Diagram for TMP91C824F Restart

# 3.10.7 Clocked Synchronous 8-Bit SIO Mode Control

The following registers are used to control and monitor the operation status when the serial bus interface (SBI) is being operated in clocked synchronous 8-bit SIO mode.

|                                        |                         | 7    | 6                           | 5                                                                                        | 4                                                                                                                                                                                             | 3                                                                                                           | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                                                                                                                 | 0                          |
|----------------------------------------|-------------------------|------|-----------------------------|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| SBI0CR1                                | Bit symbol              | SIOS | SIOINH SIOM1                |                                                                                          | SIOM0                                                                                                                                                                                         | /                                                                                                           | SCK2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SCK1                                                                                                                              | SCK0                       |
| (0240H)                                | Read/Write              |      | W                           |                                                                                          |                                                                                                                                                                                               |                                                                                                             | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                   | W                          |
|                                        | After reset             | 0    | 0                           | 0                                                                                        | 0                                                                                                                                                                                             |                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                 | 0                          |
| Prohibit<br>read-<br>modify-<br>write  | After reset<br>Function | -    | Continue/<br>abort transfer | 0<br>Transfer mode<br>00: Transmit r<br>01: (Reserved<br>10: Transmit/r<br>11: Receive m | e select<br>node<br>)<br>eceive mode<br>node<br>Serial cl<br>000 n<br>001 n<br>001 n<br>010 n<br>011 n<br>100 n<br>101 n<br>110 n<br>111<br>→ Transfer<br>00 8-t<br>01 (R<br>10 8-t<br>11 8-t | $\begin{array}{ccc} = 5 & 1031 \\ = 6 & 515 \\ = 7 & 257 \\ = 8 & 128 \\ = 9 & 64 \\ = 10 & 32 \end{array}$ | <pre>Serial clock s Serial clock s S</pre> | election and re<br>t write<br>System cloc<br>Clock gear:<br>fc = 33 MHz<br>(Output to S<br>(Scl = $\frac{fc}{2^n}$<br>(Input from | ck: fc<br>fc/1<br>SCK pin) |
| 0 Continue transfer                    |                         |      |                             |                                                                                          |                                                                                                                                                                                               |                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                   |                            |
| 1 Abort transfer (Automati<br>aborted) |                         |      |                             | cleared afte                                                                             | er transfer                                                                                                                                                                                   |                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                   |                            |
| Transfer start/stop                    |                         |      |                             |                                                                                          |                                                                                                                                                                                               |                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                   |                            |
|                                        |                         |      |                             |                                                                                          | 0 Sto                                                                                                                                                                                         | opped                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                   |                            |
|                                        |                         |      |                             |                                                                                          | 1 Sta                                                                                                                                                                                         | arted                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                   |                            |

### Serial Bus Interface Control Register 1

Note: Set the tranfer mode and the serial clock after setting <SIOS> to 0 and <SIOINH> to 1.

| SBI0DBR<br>(0241H)<br>Prohibit<br>read-<br>modify- |             | 7                         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|----------------------------------------------------|-------------|---------------------------|-----|-----|-----|-----|-----|-----|-----|--|--|
|                                                    | Bit symbol  | DB7                       | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |  |  |
|                                                    | Read/Write  | R (Receiver)/W (Transfer) |     |     |     |     |     |     |     |  |  |
|                                                    | After reset | Undefined                 |     |     |     |     |     |     |     |  |  |
| write                                              |             |                           |     |     |     |     |     |     |     |  |  |

# Serial Bus Interface Data Buffer Register

Figure 3.10.20 Register for the SIO Mode

|                                       |             | 7 | 6 | 5 | 4 | 3                                                                                                                                       | 2     | 1        | 0        |
|---------------------------------------|-------------|---|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------|-------|----------|----------|
| SBI0CR2                               | Bit symbol  |   | / | / |   | SBIM1                                                                                                                                   | SBIM0 | -        | -        |
| (0243H)                               | Read/Write  |   |   |   |   | W                                                                                                                                       |       | W        | W        |
|                                       | After reset |   |   |   |   | 0                                                                                                                                       | 0     | 0        | 0        |
| Prohibit<br>read-<br>modify-<br>write | Function    |   |   |   |   | Serial bus interface<br>operation mode<br>selection<br>00: Port mode<br>01: SIO mode<br>10: I <sup>2</sup> C bus mode<br>11: (Reserved) |       | (Note 2) | (Note 2) |

### Serial Bus Interface Control Register 2

Serial bus interface operation mode selection

ſ

| 00 | Port mode (Serial bus interface output disabled) |
|----|--------------------------------------------------|
| 01 | Clocked synchronous 8-bit SIO mode               |
| 10 | I <sup>2</sup> C bus mode                        |
| 11 | (Reserved)                                       |

Note 1: Set the SBI0CR1<BC2:0> 000 before switching to a clocked synchronous 8-bit SIO mode.

Note 2: Please always write SBICR2<1:0> to "00".



Figure 3.10.21 Registers for the SIO Mode



Figure 3.10.22 Registers for the SIO Mode

- (1) Serial clock
  - a. Clock source

SBI0CR1<SCK2:0> is used to select the following functions:

### Internal clock

In internal clock mode one of seven frequencies can be selected. The serial clock signal is output to the outside on the SCK pin. The SCK pin goes high when data transfer starts. When the device is writing (in transmit mode) or reading (in receive mode), data cannot follow the serial clock rate, so an automatic wait function is executed which automatically stops the serial clock and holds the next shift operation until reading or writing has been completed.



Figure 3.10.23 Automatic Wait Function

External clock (<SCK2:0> = 111)

An external clock input via the SCK pin is used as the serial clock. In order to ensure the integrity of shift operations, both the high and low-level serial clock pulse widths shown below must be maintained. The maximum data transfer frequency is 2.1 MHz (when fc = 33 MHz).



Figure 3.10.24 Maximum Data Transfer Frequency when External Clock Input Used

b. Shift edge

Data is transmitted on the leading edge of the clock and received on the trailing edge.

# <u>Leading edge shift</u>

Data is shifted on the leading edge of the serial clock (on the falling edge of the SCK pin input/output).

# <u>Trailing edge shift</u>

Data is shifted on the trailing edge of the serial clock (on the rising edge of the SCK pin input/output).



Figure 3.10.25 Shift Edge

(2) Transfer modes

The SBI0CR1<SIOM1:0> is used to select a transmit, receive or transmit/receive mode.

a. 8-bit transmit mode

Set a control register to a transmit mode and write transmit data to the SBI0DBR.

After the transmit data is written, set the SBI0CR1<SIOS> to 1 to start data transfer. The transmitted data is transferred from SBI0DBR to the shift register and output to the SO pin in synchronized with the serial clock, starting from the least significant bit (LSB), When the transmission data is transferred to the shift register, the SBI0DBR becomes empty. An INTSBI (Buffer empty) interrupt request is generated to request new data.

When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated if new data is not loaded to the data buffer register after the specified 8-bit data is transmitted. When new transmit data is written, automatic-wait function is canceled.

When the external clock is used, data should be written to SBI0DBR before new data is shifted. The transfer speed is determined by the maximum delay time between the time when an interrupt request is generated and the time when data is written to SBI0DBR by the interrupt service program.

When the transmit is started, after the SBI0SR<SIOF> goes 1 output from the SO pin holds final bit of the last data until falling edge of the SCK.

Transmitting data is ended by clearing the <SIOS> to 0 by the buffer empty interrupt service program or setting the <SIOINH> to 1. When the <SIOS> is cleared, the transmitted mode ends when all data is output. In order to confirm if data is surely transmitted by the program, set the <SIOF> (Bit3 of SBI0SR) to be sensed. The SBI0SR<SIOF> is cleared to 0 when transmitting is complete. When the <SIOINH> is set to 1, transmitting data stops. SBI0SR<SIOF> turns 0.

When an external clock is used, it is also necessary to clear SBI0SR<SIOS> to 0 before new data is shifted; otherwise, dummy data is transmitted and operation ends.



Example: Program to stop data transmission (when an external clock is used)



| BIT 2, (SBI0SR)         | ; If <sef> = 1 then loop</sef>        |
|-------------------------|---------------------------------------|
| JR NZ, STEST1           |                                       |
| BIT 0, (P7)             | ; If SCK = 0 then loop                |
| JR Z, STEST2            |                                       |
| LD (SBI0CR1), 00000111B | ; $\langle SIOS \rangle \leftarrow 0$ |
|                         | BIT 0, (P7)<br>JR Z, STEST2           |

b. 8-bit receive mode



Figure 3.10.27 Transmitted Data Hold Time at End of Transmission

Set the control register to receive mode and set SBI0CR1<SIOS> to 1 for switching to receive mode. Data is received into the shift register via the SI pin and synchronized with the serial clock, starting from the least significant bit (LSB). When 8-bit data is received, the data is transferred from the shift register to SBI0DBR. An INTSBI (Buffer full) interrupt request is generated to request that the received data be read. The data is then read from SBI0DBR by the interrupt service program.

When an internal clock is used, the serial clock will stop and the automatic wait function will be in effect until the received data has been read from SBI0DBR.

When an external clock is used, since shift operation is synchronized with an external clock pulse, the received data should be read from SBI0DBR before the next serial clock pulse is input. If the received data is not read, any further data which is to be received is canceled. The maximum transfer speed when an external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when the received data is read.

Receiving of data ends when <SIOS> is cleared to 0 by the buffer full interrupt service program or when <SIOINH> is set to 1. If <SIOS> is cleared to 0, received data is transferred to SBI0DBR in complete blocks. The received mode ends when the transfer is complete. In order to confirm whether data is being received properly by the program, set SBI0SR<SIOF> to be sensed. <SIOF> is cleared to 0 when receiving has been completed. When it is confirmed that receiving has been completed, the last data is read. When <SIOINH> is set to 1, data receiving stops. <SIOF> is cleared to 0 (The received data becomes invalid, therefore no need to read it).

Note: When the transfer mode is changed, the contents of SBI0DBR will be lost. If the mode must be changed, conclude data receiving by clearing <SIOS> to 0, read the last data, then change the mode.



Figure 3.10.28 Receiver Mode (Example: Internal clock)

c. 8-bit transmit/receive mode

Set a control register to a transmit/receive mode and write data to SBI0DBR. After the data has been written, set SBI0CR<SIOS> to 1 to start transmitting/receiving. When data is transmitted, the data is output via the SO pin, starting from the least significant bit (LSB) and synchronized with the leading edge of the serial clock signal. When data is received, the data is input via the SI pin on the trailing edge of the serial clock signal. 8-bit data is transferred from the shift register to SBI0DBR and an INTSBI interrupt request is generated. The interrupt service program reads the received data from the data buffer register and writes the data which is to be transmitted. SBI0DBR is used for both transmitting and receiving. Transmitted data should always be written after received data has been read.

When an internal clock is used, the automatic wait function will be in effect until the received data has been read and the next data has been written.

When an external clock is used, since the shift operation is synchronized with the external clock, received data is read and transmitted data is written before a new shift operation is executed. The maximum transfer speed when an external clock is used is determined by the delay time between the time when an interrupt request is generated and the time at which received data is read and transmitted data is written.

When the transmit is started, after the SBI0SR<SIOF> goes 1 output from the SO pin holds final bit of the last data until falling edge of the SCK.

Transmitting/receiving data ends when <SIOS> is cleared to 0 by the INTS2 interrupt service program or when SBI0CR1<SIOINH> is set to 1. When <SIOS> is cleared to 0, received data is transferred to SBI0DBR in complete blocks. The transmit/receive mode ends when the transfer is complete. In order to confirm whether data is being transmitted/received properly by the program, set SBI0SR to be sensed. <SIOF> is set to 0 when transmitting/receiving has been completed. When <SIOINH> is set to 1, data transmitting/receiving stops. <SIOF> is then cleared to 0.

Note: When the transfer mode is changed, the contents of SBI0DBR will be lost. If the mode must be changed, conclude data transmitting/receiving by clearing <SIOS> to 0, read the last data, then change the transfer mode.



Figure 3.10.29 Transmit/Received Mode (Example using internal clock)



Figure 3.10.30 Transmitted Data Hold Time at End of Transmit/Receive

# 3.11 Analog/Digital Converter

The TMP91C824 incorporates a 10-bit successive approximation-type analog/digital converter (AD converter) with 8-channel analog input.

Figure 3.11.1 is a block diagram of the AD converter. The 8-channel analog input pins (AN0 to AN7) are shared with the input only port 8 and can thus be used as an input port.

Note: When IDLE2, IDLE1 or STOP mode is selected, so as to reduce the power, with some timings the system may enter a standby mode even though the internal comparator is still enabled. Therefore be sure to check that AD converter operations are halted before a HALT instruction is executed.



Figure 3.11.1 Block Diagram of AD Converter

## 3.11.1 Analog/Digital Converter Registers

The AD converter is controlled by the two AD mode control registers: ADMOD0 and ADMOD1. The AD conversion results are stored in 8 kinds of AD conversion data upper and lower registers: ADREG04H/L, ADREG15H/L, ADREG26H/L and ADREG37H/L.

Figure 3.11.2 shows the registers related to the AD converter.

| in prog                                                                                      | R<br>0<br>AD<br>conversion<br>busy flag<br>sion 0: Conversi<br>ess stopped<br>sion 1: Conversi | 0<br>Always<br>write 0 | O<br>Always<br>write 0 | 0<br>Interrupt<br>specification<br>in conversion<br>channel fixed                                                                                                                                                                       | 0: Single<br>conversion<br>1: Repeat<br>conversion                                      | specification<br>0: Conversion                                                                                                                                                                                       | 0: Don't care<br>1: Start<br>conversion                                          |
|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| After reset 0<br>Function AD<br>conversion<br>end flag<br>0: Conver<br>in progr<br>1: Conver | 0<br>AD<br>conversion<br>busy flag<br>sion 0: Conversi<br>ess stopped<br>sion 1: Conversi      | Always<br>write 0      | Always                 | 0<br>Interrupt<br>specification<br>in conversion<br>channel fixed<br>repeat mode<br>0: Every<br>conversion<br>1: Every<br>fourth                                                                                                        | 0<br>Repeat mode<br>specification<br>0: Single<br>conversion<br>1: Repeat<br>conversion | Scan mode<br>specification<br>0: Conversion<br>channel<br>fixed<br>mode<br>1: Conversion<br>channel                                                                                                                  | AD<br>conversion<br>start<br>0: Don't care<br>1: Start<br>conversion<br>Always 0 |
| Function AD<br>conversion<br>end flag<br>0: Conver<br>in progr<br>1: Conver                  | AD<br>conversion<br>busy flag<br>sion 0: Conversi<br>ess stopped<br>sion 1: Conversi           | Always<br>write 0      | Always                 | Interrupt<br>specification<br>in conversion<br>channel fixed<br>repeat mode<br>0: Every<br>conversion<br>1: Every<br>fourth                                                                                                             | Repeat mode<br>specification<br>0: Single<br>conversion<br>1: Repeat<br>conversion      | Scan mode<br>specification<br>0: Conversion<br>channel<br>fixed<br>mode<br>1: Conversion<br>channel                                                                                                                  | AD<br>conversion<br>start<br>0: Don't care<br>1: Start<br>conversion<br>Always 0 |
| conversio<br>end flag<br>0: Conver<br>in progr<br>1: Conver                                  | conversion<br>busy flag<br>sion 0: Conversi<br>ess stopped<br>sion 1: Conversi                 | write 0                | -                      | specification<br>in conversion<br>channel fixed<br>repeat mode<br>0: Every<br>conversion<br>1: Every<br>fourth                                                                                                                          | specification<br>0: Single<br>conversion<br>1: Repeat<br>conversion                     | specification<br>0: Conversion<br>channel<br>fixed<br>mode<br>1: Conversion<br>channel                                                                                                                               | conversion<br>start<br>0: Don't care<br>1: Start<br>conversion<br>Always 0       |
|                                                                                              |                                                                                                |                        |                        |                                                                                                                                                                                                                                         |                                                                                         | mode                                                                                                                                                                                                                 |                                                                                  |
|                                                                                              |                                                                                                |                        |                        | 0 Don<br>1 Sta<br>Note: Al <sup>1</sup><br>→ AD scan<br>0 AD<br>1 AD<br>→ AD repe<br>0 AD<br>1 AD<br>→ AD repe<br>0 AD<br>1 AD<br>→ Specify<br>repeat c<br>Cha<br><sp<br>0 Ge<br/>1 Ge<br/>1 Ge<br/>→ AD conv<br/>0 AD<br/>1 AD</sp<br> | onversion mo<br>annel fixed re<br>CAN> = 0, <f<br>nerates inter</f<br>                  | s 0.<br>g<br>channel fixed<br>channel scan<br>ing<br>ersion mode<br>ersion mode<br>on interrupt for<br>ode<br>epeat convers<br>REPEAT> = 1<br>rupt every co<br>rupt every for<br>flag<br>stopped<br>n progress<br>ag | n mode<br>or channel fixe<br>sion mode<br>1<br>nversion.<br>urth conversio       |

AD Mode Control Register 0

Figure 3.11.2 AD Converter Related Register

|         |             | 7           | 6          |   | 5                                                                                           | 4                                                                                                   |          | 3           | 2               | 1                                  | 0             |
|---------|-------------|-------------|------------|---|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------|-------------|-----------------|------------------------------------|---------------|
| ADMOD1  | Bit symbol  | VREFON      | I2AD       | / | /                                                                                           |                                                                                                     | AD       | TRGE        | ADCH2           | ADCH1                              | ADCH0         |
| (02B1H) | Read/Write  | R           | /W         | / | /                                                                                           |                                                                                                     |          |             | R/              | W                                  |               |
|         | After reset | 0           | 0          |   | $\sim$                                                                                      |                                                                                                     |          | 0           | 0               | 0                                  | 0             |
|         | Function    | VREF        | IDLE2      |   |                                                                                             |                                                                                                     | AD       | external    | Analog inpu     | it channel se                      | election      |
|         |             | application | 0: Stop    |   |                                                                                             |                                                                                                     | trigg    | ger start   |                 |                                    |               |
|         |             | control     | 1: Operate |   |                                                                                             |                                                                                                     | cont     | trol        |                 |                                    |               |
|         |             | 0: OFF      |            |   |                                                                                             |                                                                                                     | 0: D     | isable      |                 |                                    |               |
|         |             | 1: ON       |            |   |                                                                                             |                                                                                                     | 1: E     | nable       |                 |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     |          |             |                 | •                                  |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | <b>A</b> |             |                 | ↓                                  |               |
|         |             |             |            |   | <                                                                                           | 00                                                                                                  |          |             | ut channel s    |                                    |               |
|         |             |             |            |   |                                                                                             | <sc <="" td=""><td>AN&gt;</td><td>0<br/>(Chanı</td><td></td><td>1<br/>(Chan</td><td>nol )</td></sc> | AN>      | 0<br>(Chanı |                 | 1<br>(Chan                         | nol )         |
|         |             |             |            |   | <adch2< td=""><td>2.0-</td><td></td><td>fixed</td><td></td><td>scanr</td><td></td></adch2<> | 2.0-                                                                                                |          | fixed       |                 | scanr                              |               |
|         |             |             |            | - |                                                                                             | 000                                                                                                 |          | ANC         |                 | Cocarii                            |               |
|         |             |             |            | - |                                                                                             | 001                                                                                                 |          | AN1         |                 | AN1                                |               |
|         |             |             |            |   |                                                                                             | )10                                                                                                 |          | AN2         |                 | $\rightarrow$ AN1 $\rightarrow$ AN | 2             |
|         |             |             |            | - |                                                                                             | )11 (Note)                                                                                          |          | ANS         |                 | $\rightarrow$ AN1 $\rightarrow$ AN |               |
|         |             |             |            |   |                                                                                             | 00                                                                                                  |          | AN4         |                 |                                    |               |
|         |             |             |            |   |                                                                                             | 01                                                                                                  |          | ANS         |                 | AN5                                |               |
|         |             |             |            |   |                                                                                             | 10                                                                                                  |          | ANG         |                 | $\rightarrow$ AN5 $\rightarrow$ AN | 6             |
|         |             |             |            |   |                                                                                             | 11                                                                                                  |          | AN7         |                 | $\rightarrow$ AN5 $\rightarrow$ AN |               |
|         |             |             |            |   |                                                                                             |                                                                                                     |          |             |                 |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     |          |             | ersion start of | control by ex                      | ternal trigge |
|         |             |             |            |   |                                                                                             |                                                                                                     | (<br>T   | ( ADTRG     |                 |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | Ļ        |             | abled           |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | L        | 1 Ena       | abled           |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | >        | IDLE2 c     | ontrol          |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | Ī        |             | pped            |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | Ī        |             | peration        |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | -        |             |                 |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     |          |             | of application  | of reference                       | e voltage to  |
|         |             |             |            |   |                                                                                             |                                                                                                     | ŕ        | AD conv     |                 |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | ŀ        | 0 OF        |                 |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     | L        | 1 ON        |                 |                                    |               |
|         |             |             |            |   |                                                                                             |                                                                                                     |          | Dofers -    | tarting conve   | voion /haf-                        |               |

AD Mode Control Register 1

Note: As pin AN3 also functions as the  $\overline{ADTRG}$  input pin, do not set  $\langle ADCH2:0 \rangle = 011$  when using  $\overline{ADTRG}$  with  $\langle ADTRGE \rangle = 0$ .

Figure 3.11.3 AD Converter Related Registers

/

|          |             | 7           | 6           | 5 | 4 | 3 | 2 | 1 | 0             |
|----------|-------------|-------------|-------------|---|---|---|---|---|---------------|
| ADREG04L | Bit symbol  | ADR01       | ADR00       |   |   |   | / |   | ADR0RF        |
| (02A0H)  | Read/Write  | F           | R           |   |   |   | / |   | R             |
|          | After reset | Unde        | fined       |   |   |   |   |   | 0             |
|          | Function    | Stores lowe | r 2 bits of |   |   |   |   |   | AD            |
|          |             | AD convers  | ion result  |   |   |   |   |   | conversion    |
|          |             |             |             |   |   |   |   |   | data storage  |
|          |             |             |             |   |   |   |   |   | flag          |
|          |             |             |             |   |   |   |   |   | 1: Conversion |
|          |             |             |             |   |   |   |   |   | result        |
|          |             |             |             |   |   |   |   |   | stored        |

## AD Conversion Data Low Register 0/4

## AD Conversion Data Upper Register 0/4

|                                               |            | 7     | 6     | 5        | 4             | 3           | 2         | 1     | 0     |
|-----------------------------------------------|------------|-------|-------|----------|---------------|-------------|-----------|-------|-------|
| ADREG04H                                      | Bit symbol | ADR09 | ADR08 | ADR07    | ADR06         | ADR05       | ADR04     | ADR03 | ADR02 |
| (02A1H) Read/Write R<br>After reset Undefined |            |       |       |          |               |             |           |       |       |
|                                               |            |       |       |          |               |             |           |       |       |
|                                               | Function   |       |       | Stores u | pper 8 bits A | D conversio | n result. |       |       |

## AD Conversion Data Lower Register 1/5

|          |             | 7           | 6            | 5 | 4 | 3 | 2 | 1 | 0             |
|----------|-------------|-------------|--------------|---|---|---|---|---|---------------|
| ADREG15L | Bit symbol  | ADR11       | ADR10        |   |   |   |   |   | ADR1RF        |
| (02A2H)  | Read/Write  | F           | 2            |   |   |   |   |   | R             |
|          | After reset | Unde        | fined        |   |   |   |   |   | 0             |
|          | Function    | Stores lowe | er 2 bits of |   |   |   |   |   | AD            |
|          |             | AD convers  | ion result   |   |   |   |   |   | conversion    |
|          |             |             |              |   |   |   |   |   | result flag   |
|          |             |             |              |   |   |   |   |   | 1: Conversion |
|          |             |             |              |   |   |   |   |   | result        |
|          |             |             |              |   |   |   |   |   | stored        |

## AD Conversion Data Upper Register 1/5

|          |                                |       | AD CON                                       | version Da | ata Opper                                                   | Register                       | /5                                       |                                                  |                                                                |
|----------|--------------------------------|-------|----------------------------------------------|------------|-------------------------------------------------------------|--------------------------------|------------------------------------------|--------------------------------------------------|----------------------------------------------------------------|
|          |                                | 7     | 6                                            | 5          | 4                                                           | 3                              | 2                                        | 1                                                | 0                                                              |
| ADREG15H | Bit symbol                     | ADR19 | ADR18                                        | ADR17      | ADR16                                                       | ADR15                          | ADR14                                    | ADR13                                            | ADR12                                                          |
| (02A3H)  | Read/Write                     |       | R                                            |            |                                                             |                                |                                          |                                                  |                                                                |
|          | After reset                    |       | Undefined                                    |            |                                                             |                                |                                          |                                                  |                                                                |
|          | Function                       |       | Stores upper 8 bits of AD conversion result. |            |                                                             |                                |                                          |                                                  |                                                                |
|          | Channel x<br>conversion result |       |                                              | • B<br>c   | 2 1 0<br>bits 5 to 1 are<br>bit0 is the AD<br>onversion res | conversion c<br>sult is stored | as 1.<br>lata storage f<br>the flag is s | 3 2 1<br>flag <adrxr<br>et to 1. When</adrxr<br> | REGxL<br>0<br>F>. When the<br>n either of the<br>cleared to 0. |

Figure 3.11.4 AD Converter Related Registers

|          |                            |             | AD COIN      | ersion Re  | Suit Lower    | Register        | 2/0           |                                                       |                 |
|----------|----------------------------|-------------|--------------|------------|---------------|-----------------|---------------|-------------------------------------------------------|-----------------|
|          |                            | 7           | 6            | 5          | 4             | 3               | 2             | 1                                                     | 0               |
| ADREG26L | Bit symbol                 | ADR21       | ADR20        |            |               |                 |               |                                                       | ADR2RF          |
| (02A4H)  | <sup>1)</sup> Read/Write R |             |              |            |               |                 |               |                                                       | R               |
|          | After reset                | Unde        | efined       |            |               |                 |               |                                                       | 0               |
|          | Function                   | Stores lowe | er 2 bits of |            |               |                 |               |                                                       | AD conversion   |
|          |                            | AD convers  | sion result. |            |               |                 |               |                                                       | data storage    |
|          |                            |             |              |            |               |                 |               |                                                       | flag            |
|          |                            |             |              |            |               |                 |               |                                                       | 1: Conversion   |
|          |                            |             |              |            |               |                 |               |                                                       | result stored   |
|          |                            |             | AD Con       | version Da | ata upper     | Register 2      | /6            | -                                                     |                 |
|          |                            | 7           | 6            | 5          | 4             | 3               | 2             | 1                                                     | 0               |
| ADREG26H | Bit symbol                 | ADR29       | ADR28        | ADR27      | ADR26         | ADR25           | ADR24         | ADR23                                                 | ADR22           |
| (02A5H)  | Read/Write                 |             |              |            | F             | र               |               |                                                       |                 |
|          | After reset                |             |              |            | Unde          |                 |               |                                                       |                 |
|          | Function                   |             |              | Stores up  | per 8 bits of | AD conversi     | on result.    |                                                       |                 |
|          |                            |             | AD Con       | version Da | ata Lower     | Register 3      | /7            |                                                       |                 |
|          |                            | 7           | 6            | 5          | 4             | 3               | 2             | 1                                                     | 0               |
| ADREG37L | Bit symbol                 | ADR31       | ADR30        |            |               | $\sim$          |               | $\sim$                                                | ADR3RF          |
| (02A6H)  | Read/Write                 |             | R            | $\sim$     | $\sim$        | $\sim$          | $\sim$        | $\sim$                                                | R               |
|          | After reset                |             | efined       |            |               |                 |               |                                                       | 0               |
|          | Function                   | Stores lowe | er 2 bits of |            |               |                 |               |                                                       | AD Conversion   |
|          |                            | AD convers  | sion result. |            |               |                 |               |                                                       | Data Storage    |
|          |                            |             |              |            |               |                 |               |                                                       | flag            |
|          |                            |             |              |            |               |                 |               |                                                       | 1: conversion   |
|          |                            |             |              |            |               |                 |               |                                                       | result stored   |
| -        |                            |             | AD Conv      | ersion Re  | sult Upper    | Register        | 3/7           |                                                       |                 |
|          | /                          | 7           | 6            | 5          | 4             | 3               | 2             | 1                                                     | 0               |
| ADREG37H | Bit symbol                 | ADR39       | ADR38        | ADR37      | ADR36         | ADR35           | ADR34         | ADR33                                                 | ADR32           |
| (02A7H)  | Read/Write                 |             |              |            | F             | र               |               |                                                       |                 |
|          | After reset                |             |              |            | Unde          | fined           |               |                                                       |                 |
|          | Function                   |             |              | Stores up  | per 8 bits of | AD conversi     | on result.    |                                                       |                 |
|          |                            |             | 0 0          | 7 6 5      | 4 0           | 2 1 0           |               |                                                       |                 |
|          | Channel x co               | nversion    | 98           | 7 6 5      | 4 3           | 2 1 0           |               |                                                       |                 |
|          | result                     |             |              |            |               |                 | _             |                                                       |                 |
|          |                            |             | ADREGxH      |            |               |                 |               | AD                                                    | REGxL           |
|          |                            |             | 76           | 5 4 3      | 2 1 0         | <u>7</u> 6      | 54            | 321                                                   | 0               |
|          |                            |             |              |            |               |                 |               | $\longrightarrow$                                     |                 |
|          |                            |             |              | • Pi       | ts 5 to1 are  | always read     |               | ~                                                     |                 |
|          |                            |             |              |            |               |                 |               | flag <adrxf< td=""><td>RF&gt;. When the</td></adrxf<> | RF>. When the   |
|          |                            |             |              | A          | D conversior  | n result is sto | red, the flag | is set to 1. V                                        | When either o   |
|          |                            |             |              | re         | gisters (ADF  | REGxH, ADR      | EGxL) is rea  | id, the flag is                                       | s cleared to 0. |
|          |                            |             |              |            |               |                 |               |                                                       |                 |

## AD Conversion Result Lower Register 2/6

Figure 3.11.5 AD Converter Related Registers

- 3.11.2 Description of Operation
  - (1) Analog reference voltage

A high-level analog reference voltage is applied to the VREFH pin; a low-level analog reference voltage is applied to the VREFL pin. To perform AD conversion, the reference voltage as the difference between VREFH and VREFL, is divided by 1024 using string resistance. The result of the division is then compared with the analog input voltage.

To turn off the switch between VREFH and VREFL, write 0 to ADMOD1  $\langle VREFON \rangle$  in AD mode control register 1. To start AD conversion in the off state, first write 1 to ADMOD1 $\langle VREFON \rangle$ , wait 3 µs until the internal reference voltage stabilizes (This is not related to fc), then set ADMOD0 $\langle ADS \rangle$  to 1.

## (2) Analog input channel selection

The analog input channel selection varies depends on the operation mode of the AD converter.

• In analog input channel fixed mode (ADMOD0<SCAN> = 0)

Setting ADMOD1<ADCH2:0> selects one of the input pins AN0 to AN7 as the input channel.

• In analog input channel scan mode (ADMOD0<SCAN> = 1)

Setting ADMOD1<ADCH2:0> selects one of the 8 scan modes.

Table 3.11.1 illustrates analog input channel selection in each operation mode.

After reset, ADMOD0<SCAN> = 0 and ADMOD1<ADCH2:0> = 000. Thus pin AN0 is selected as the fixed input channel. Pins not used as analog input channels can be used as standard input port pins.

| <adch2:0></adch2:0> | Channel Fixed<br><scan> = 0</scan> | Channel Scan<br><scan> = 1</scan>                     |
|---------------------|------------------------------------|-------------------------------------------------------|
| 000                 | AN0                                | ANO                                                   |
| 001                 | AN1                                | $AN0 \rightarrow AN1$                                 |
| 010                 | AN2                                | $AN0 \rightarrow AN1 \rightarrow AN2$                 |
| 011                 | AN3                                | $AN0 \rightarrow AN1 \rightarrow AN2 \rightarrow AN3$ |
| 100                 | AN4                                | AN4                                                   |
| 101                 | AN5                                | $AN4 \rightarrow AN5$                                 |
| 110                 | AN6                                | $AN4 \rightarrow AN5 \rightarrow AN6$                 |
| 111                 | AN7                                | $AN4 \rightarrow AN5 \rightarrow AN6 \rightarrow AN7$ |

Table 3.11.1 Analog Input Channel Selection

(3) Starting AD conversion

To start AD conversion, write 1 to ADMOD0<ADS> in AD mode control register 0 or ADMOD1<ADTRGE> in AD mode control register 1 and input falling edge on ADTRG pin. When AD conversion starts, the AD conversion busy flag ADMOD0<ADBF> will be set to 1, indicating that AD conversion is in progress.

Writing 1 to ADMOD0<ADS> during AD conversion restarts conversion. At that time, to determine whether the AD conversion results have been preserved, check the value of the conversion data storage flag ADREGxL<ADRxRF>.

During AD conversion, a falling edge input on the ADTRG pin will be ignored.

(4) AD conversion modes and the AD conversion end interrupt

The 4 AD conversion modes are:

- Channel fixed single conversion mode
- Channel scan single conversion mode
- Channel fixed repeat conversion mode
- Channel scan repeat conversion mode

The ADMOD0<REPEAT> and ADMOD0<SCAN> settings in AD mode control register 0 determine the AD mode setting.

Completion of AD conversion triggers an INTAD AD conversion end interrupt request. Also, ADMOD0<EOCF> will be set to 1 to indicate that AD conversion has been completed.

a. Channel fixed single conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 00 selects channel fixed single conversion mode.

In this mode, data on one specified channel is converted once only. When the conversion has been completed, the ADMOD0<EOCF> flag is set to 1, ADMOD0<ADBF> is cleared to 0, and an INTAD interrupt request is generated.

b. Channel scan single conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 01 selects channel scan single conversion mode.

In this mode, data on the specified scan channels is converted once only. When scan conversion has been completed, ADMOD0<EOCF> is set to 1, ADMOD0<ADBF> is cleared to 0, and an INTAD interrupt request is generated.

c. Channel fixed repeat conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 10 selects channel fixed repeat conversion mode.

In this mode, data on one specified channel is converted repeatedly. When conversion has been completed, ADMOD0<EOCF> is set to 1 and ADMOD0<ADBF> is not cleared to 0 but held 1. INTAD interrupt request generation timing is determined by the setting of ADMOD0<ITM0>.

Setting <ITM0> to 0 generates an interrupt request every time an AD conversion is completed.

Setting  $\langle ITM0 \rangle$  to 1 generates an interrupt request on completion of every fourth conversion.

d. Channel scan repeat conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 11 selects channel scan repeat conversion mode.

In this mode, data on the specified scan channels is converted repeatedly. When each scan conversion has been completed, ADMOD0<EOCF> is set to 1 and an INTAD interrupt request is generated. ADMOD0<ADBF> is not cleared to 0 but held 1.

To stop conversion in a repeat conversion mode (e.g., in cases c. and d.), write a 0 to ADMOD0<REPEAT>. After the current conversion has been completed, the repeat conversion mode terminates and ADMOD0<ADBF> is cleared to 0.

Switching to a halt state (IDLE2 mode with ADMOD1<I2AD> cleared to 0, IDLE1 mode or STOP mode) immediately stops operation of the AD converter even when AD conversion is still in progress. In repeat conversion modes (e.g., in cases c. and d.), when the halt is released, conversion restarts from the beginning. In single conversion modes (e.g., in cases a. and b.), conversion does not restart when the halt is released (The converter remains stopped).

Table 3.11.2 shows the relationship between the AD conversion modes and interrupt requests.

| Mode                                 | Interrupt Request                         | ADMOD0        |                   |               |  |  |
|--------------------------------------|-------------------------------------------|---------------|-------------------|---------------|--|--|
| Mode                                 | Generation                                | <itm0></itm0> | <repeat></repeat> | <scan></scan> |  |  |
| Channel fixed single conversion mode | After completion of<br>conversion         | х             | 0                 | 0             |  |  |
| Channel scan single conversion mode  | After completion of scan conversion       | х             | 0                 | 1             |  |  |
| Channel fixed repeat                 | Every conversion                          | 0             | 4                 | 0             |  |  |
| conversion mode                      | Every forth conversion                    | 1             | Ι                 | 0             |  |  |
| Channel scan repeat conversion mode  | After completion of every scan conversion | х             | 1                 | 1             |  |  |

Table 3.11.2 Relationship between AD Conversion Modes and Interrupt Requests

X: Don't care

(5) AD conversion time

84 states (5.1  $\mu s$  at fFPH = 33 MHz) are required for the AD conversion for one channel.

(6) Storing and reading the results of AD conversion

The AD conversion data upper and lower registers (ADREG04H/L to ADREG37H/L) store the AD conversion results. (ADREG04H/L to ADREG37H/L are read-only registers.)

In channel fixed repeat conversion mode, the conversion results are stored successively in registers ADREG04H/L to ADREG37H/L. In other modes, the AN0 and AN4, AN1 and AN5, AN2 and AN6, and AN3 and AN7 conversion results are stored in ADREG04H/L, ADREG15H/L, ADREG26H/L and ADREG37H/L respectively.

Table 3.11.3 shows the correspondence between the analog input channels and the registers which are used to hold the results of AD conversion.

| Table 3.11.3 | Correspondence between Analog Input Channels |
|--------------|----------------------------------------------|
|              | and AD Conversion Result Registers           |

|                                  | AD Conversion Result Register           |                                                                 |  |  |  |  |  |
|----------------------------------|-----------------------------------------|-----------------------------------------------------------------|--|--|--|--|--|
| Analog Input<br>Channel (Port 8) | Conversion Modes<br>Other than at Right | Channel Fixed Repeat<br>Conversion Mode<br>( <itm0> = 1)</itm0> |  |  |  |  |  |
| AN0                              | ADREG04H/L                              | ADREG04H/L ←                                                    |  |  |  |  |  |
| AN1                              | ADREG15H/L                              | $\downarrow$                                                    |  |  |  |  |  |
| AN2                              | ADREG26H/L                              | ADREG15H/L                                                      |  |  |  |  |  |
| AN3                              | ADREG37H/L                              | ↓<br>                                                           |  |  |  |  |  |
| AN4                              | ADREG04H/L                              | ADREG26H/L                                                      |  |  |  |  |  |
| AN5                              | ADREG15H/L                              | ADREG37H/L                                                      |  |  |  |  |  |
| AN6                              | ADREG26H/L                              | ADICE OUT //E                                                   |  |  |  |  |  |
| AN7                              | ADREG37H/L                              |                                                                 |  |  |  |  |  |

<ADRxRF>, bit0 of the AD conversion data lower register, is used as the AD conversion data storage flag. The storage flag indicates whether the AD conversion result register has been read or not. When a conversion result is stored in the AD conversion result register, the flag is set to 1. When either of the AD conversion result registers (ADREGxH or ADREGxL) is read, the flag is cleared to 0.

Reading the AD conversion result also clears the AD conversion end flag ADMOD0<EOCF> to 0.

#### Example:

a. Convert the analog input voltage on the AN3 pin and write the result, to memory address 0800H using the AD interrupt (INTAD) processing routine.

Main routine: 7 6 5 4 3 2 1 0 INTEOAD  $\leftarrow -100 - - -$ Enable INTAD and set it to interrupt level 4. ADMOD1  $\leftarrow$  1 1 X X 0 0 1 1 Set pin AN3 to be the analog input channel. ADMOD0  $\leftarrow$  - - 0 0 X 0 0 1 Start conversion in channel fixed single conversion mode. Interrupt routine processing example: WA ← ADREG37 Read value of ADREG37L and ADREG37H into 16-bit general-purpose register WA. WA >>6 Shift contents read into WA six times to right and zero-fill upper bits. (0800H)  $\leftarrow$  WA Write contents of WA to memory address 0800H.

b. This example repeatedly converts the analog input voltages on the three pins AN0, AN1 and AN2, using channel scan repeat conversion mode.

| [INTE0AD ← - 0 0 0                      | Disable INTAD.                                           |
|-----------------------------------------|----------------------------------------------------------|
| ADMOD1 $\leftarrow$ 1 - X X 0 0 1 0     | Set pins AN0 to AN2 to be the analog input channels.     |
| $ ADMOD0  \leftarrow 0  0  X  1  1  1 $ | Start conversion in channel scan repeat conversion mode. |
| X: Don't care: -: No change             |                                                          |

## 3.12 Watchdog Timer (Runaway detection timer)

The TMP91C824 features a watchdog timer for detecting runaway.

The watchdog timer (WDT) is used to return the CPU to normal state when it detects that the CPU has started to malfunction (Runaway) due to causes such as noise.

When the watchdog timer detects a malfunction, it generates a non-maskable interrupt INTWD to notify the CPU. Connecting the watchdog timer output to the reset pin internally forces a reset. (The level of external  $\overline{\text{RESET}}$  pin is not changed)

#### 3.12.1 Configuration

Figure 3.12.1 is a block diagram of he watchdog timer (WDT).



Figure 3.12.1 Block Diagram of Watchdog Timer

Note: It needs to care designing the total machine set, because watchdog timer can't operate completely by external noise.

The watchdog timer consists of a 22-stage binary counter which uses the system clock (fsys) as the input clock. The binary counter can output  $fsys/2^{15}$ ,  $fsys/2^{17}$ ,  $fsys/2^{19}$  and  $fsys/2^{21}$ .





The runaway is detected when an overflow occurs, and the watchdog timer can reset device. In this case, the reset time will be between 22 and 29 states ( $21.3 \sim 28.1 \,\mu s$  at fOSCH = 33MHz, fFPH =  $2.2 \, MHz$ ) is fFPH/2, where fFPH is generated by diving the high-speed oscillator clock (fOSCH) by sixteen through the clock gear function.



Figure 3.12.3 Reset Mode

## 3.12.2 Control Registers

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

- (1) Watchdog timer mode register (WDMOD)
  - a. Setting the detection time for the watchdog timer in <WDTP1:0>

This 2-bit register is used for setting the watchdog timer interrupt time used when detecting runaway. After reset, this register is initialized to WDMOD < WDTP1:0 > = 00.

The detection times for WDT are shown in Figure 3.12.4.

b. Watchdog timer enable/disable control register <WDTE>

After reset, WDMOD<WDTE> is initialized to 1, enabling the watchdog timer. To disable the watchdog timer, it is necessary to set this bit to 0 and to write the disable code (B1H) to the watchdog timer control register WDCR. This makes it difficult for the watchdog timer to be disabled by runaway.

However, it is possible to return the watchdog timer from the disabled state to the enabled state merely by setting <WDTE> to 1.

c. Watchdog timer out reset connection <RESCR>

This register is used to connect the output of the watchdog timer with the RESET terminal internally. Since WDMOD<RESCR> is initialized to 0 on reset, a reset by the watchdog timer will not be performed.

(2) Watchdog timer control register (WDCR)

This register is used to disable and clear the binary counter for the watchdog timer.

Disable control the watchdog timer can be disabled by clearing WDMOD<WDTE> to 0 and then writing the disable code (B1H) to the WDCR register.

WDMOD $\leftarrow$  0- - XX - - -Clear WDMOD<WDTE> to 0.WDCR $\leftarrow$  1011001Write the disable code (B1H).

• Enable control

Set WDMOD<WDTE> to 1.

• Watchdog timer clear control

To clear the binary counter and cause counting to resume, write the clear code (4EH) to the WDCR register.

WDCR  $\leftarrow 0 \ 1 \ 0 \ 0 \ 1 \ 1 \ 1 \ 0$  Write the clear code (4EH).

Note1: If it is used disable control, set the disable code (B1H) to WDCR after write the clear code (4EH) once. (Please refer to setting example.)

Note2: If it is changed Watchdog timer setting, change setting after set to disable condition once.

|        |                                                                                                                                         | 7                           | 6                                                                                                                                                                                | 5        | 4                  | 3                        | 2                                                 | 1                                              | 0                 |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------|--------------------------|---------------------------------------------------|------------------------------------------------|-------------------|
| DMOD   | Bit symbol                                                                                                                              | WDTE                        | WDTP1                                                                                                                                                                            | WDTP0    |                    |                          | I2WD                                              | T RESC                                         | R –               |
| 0300H) | Read/Write                                                                                                                              | R/W                         | R/                                                                                                                                                                               | R/W      |                    |                          |                                                   | R/W                                            | R/W               |
|        | After reset                                                                                                                             | 1                           | 0                                                                                                                                                                                | 0        |                    |                          | 0                                                 | 0                                              | 0                 |
|        | Function                                                                                                                                | WDT<br>control<br>1: Enable | Select detec<br>00: 2 <sup>15</sup> /f <sub>SYS</sub><br>01: 2 <sup>17</sup> /f <sub>SYS</sub><br>10: 2 <sup>19</sup> /f <sub>SYS</sub><br>11: 2 <sup>21</sup> /f <sub>SYS</sub> | -        |                    |                          | IDLE2<br>0: Stop<br>1: Opera                      | 1: Interna<br>connecte WDL c<br>the res<br>pin | ots write 0       |
|        |                                                                                                                                         |                             |                                                                                                                                                                                  |          |                    | 0 -<br>1 C<br>→ IDLE2 co |                                                   | ut control                                     | reset             |
|        | → Watchdo                                                                                                                               | g timer d                   | letection time                                                                                                                                                                   | e        |                    |                          |                                                   |                                                | z, fs = 32.768 kł |
|        | SYSC                                                                                                                                    | R1                          | SYSC                                                                                                                                                                             | R1       | W                  | /atchdog                 | Timer D                                           | Detection T                                    | ime               |
|        | System Clock                                                                                                                            | k Selection                 | Gear Va                                                                                                                                                                          | alue     |                    | WDM                      | 10D <wi< td=""><td>DTP1:0&gt;</td><td></td></wi<> | DTP1:0>                                        |                   |
|        | <sys0< td=""><td>CK&gt;</td><td><gear< td=""><td>2:0&gt;</td><td>00</td><td>01</td><td></td><td>10</td><td>11</td></gear<></td></sys0<> | CK>                         | <gear< td=""><td>2:0&gt;</td><td>00</td><td>01</td><td></td><td>10</td><td>11</td></gear<>                                                                                       | 2:0>     | 00                 | 01                       |                                                   | 10                                             | 11                |
|        |                                                                                                                                         | 5)                          | XXX                                                                                                                                                                              |          | 2.0 s              | 8.0                      | S                                                 | 32.0 s                                         | 128.0 s           |
|        | 1 (fs                                                                                                                                   | 1 (10)                      |                                                                                                                                                                                  |          |                    | 7.04                     | ms                                                | 31.78 ms                                       | 127.10 ms         |
|        | 1 (fs                                                                                                                                   |                             | 000 (fc)                                                                                                                                                                         |          | 1.99 ms            | 7.94                     | 1110                                              | 01.70 110                                      | 121.101113        |
|        | <u> </u>                                                                                                                                | <i>.</i> ,                  | 000 (fc)<br>001 (fc/                                                                                                                                                             |          | 1.99 ms<br>3.97 ms | 15.89                    |                                                   | 63.55 ms                                       | 254.20 ms         |
|        | <u> </u>                                                                                                                                |                             |                                                                                                                                                                                  | 2)       |                    |                          | ms                                                |                                                |                   |
|        | `                                                                                                                                       |                             | 001 (fc/                                                                                                                                                                         | 2)<br>4) | 3.97 ms            | 15.89                    | ms<br>ms                                          | 63.55 ms                                       | 254.20 ms         |

→ Watchdog timer enable/disable control

| 0 | Disabled |
|---|----------|
| 1 | Enabled  |

Figure 3.12.4 Watchdog Timer Mode Register



| <br>Disable/clea | ar WDT       |
|------------------|--------------|
| B1H              | Disable code |
| 4EH              | Clear code   |
| Others           | Don't care   |

Figure 3.12.5 Watchdog Timer Control Register

## 3.12.3 Operation

The watchdog timer generates an INTWD interrupt when the detection time set in the WDMOD<WDTP1:0> has elapsed. The watchdog timer must be cleared 0 by software before an INTWD interrupt will be generated. If the CPU malfunctions (e.g., if runaway occurs) due to causes such as noise, but does not execute the instruction used to clear the binary counter, the binary counter will overflow and an INTWD interrupt will be generated. The CPU will detect malfunction (Runaway) due to the INTWD interrupt and in this case it is possible to return to the CPU to normal operation by means of an anti-malfunction program.

#### The watchdog timer works immediately after reset.

The watchdog timer does not operate in IDLE1 or STOP mode, as the binary counter continues counting during bus release (when BUSAK goes low).

When the device is in IDLE2 mode, the operation of WDT depends on the WDMOD<I2WDT> setting. Ensure that WDMOD<I2WDT> is set before the device enters IDLE2 mode.

Example:

| a. | Clear | r the bi           | nary | cour | nte | er.  |                                  |
|----|-------|--------------------|------|------|-----|------|----------------------------------|
|    | WDCR  | ← 0 1              | 0 0  | 1 1  | 1   | 0    | Write the clear code (4EH).      |
| b. | Set t | he wate            | hdog | tim  | ner | • de | etection time to $2^{17}$ /fsys. |
|    | WDMOD | $0 \leftarrow 1 0$ | 1 X  | Х –  | _   | _    |                                  |

c. Disable the watchdog timer. WDMOD  $\leftarrow$  0 - - X X - - - Clear WDTE to 0. WDCR  $\leftarrow$  1 0 1 1 0 0 0 1 Write disable code (B1H).

# 3.13 Real Time Clock (RTC)

- 3.13.1 Function Description for RTC
  - (1) Clock function (Second, minute, Hour, day of the week, day, Month and leap year)
  - (2) Calendar function
  - (3) 24- or 12-hour (AM/PM) clock function
  - (4)  $\pm$  30 second adjustment function (by software)
  - (5) Alarm output 1Hz/16Hz (from ALARM pin)
  - (6) Interrupt generate by Alarm output 1Hz/16Hz

## 3.13.2 Block Diagram



Note 1: The Christian era year column:

This product has year column toward only lower two columns. Therefore the next year in 99 works as 00 years. In system to use it, please manage upper two columns with the system side when handle year column in the Christian era.

#### Note 2: Leap year:

A leap year is the year, which is divisible with 4, but the year, which there is exception, and is divisible with 100 is not a leap year. However, the year, which is divisible with 400, is a leap year. But there is not this product for the correspondence to the above exception. Because there are only with the year which is divisible with 4 as a leap year, please cope with the system side if this function is problem.

# 3.13.3 Control Registers

|        |         |                     |                | 00             | TAGE                        | (0.000          |                 | .)eg.e    |                 |                                       |            |
|--------|---------|---------------------|----------------|----------------|-----------------------------|-----------------|-----------------|-----------|-----------------|---------------------------------------|------------|
| Symbol | Address | Bit7                | Bit6           | Bit5           | Bit4                        | Bit3            | Bit2            | Bit1      | Bit0            | Function                              | Read/Write |
| SECR   | 0320H   |                     | 40 s           | 20 s           | 10 s                        | 8 s             | 4 s             | 2 s       | 1 s             | Second column                         | R/W        |
| MINR   | 0321H   |                     | 40 min.        | 20 min.        | 10 min.                     | 8 min.          | 4 min.          | 2 min.    | 1 min.          | Minute column                         | R/W        |
| HOURR  | 0322H   |                     |                | 20<br>/PM/AM   | 10 hours                    | 8 hours         | 4 hours         | 2 hours   | 1 hour          | Hour column                           | R/W        |
| DAYR   | 0323H   |                     |                |                |                             |                 | W2              | W1        | W0              | Day of the week column                | R/W        |
| DATER  | 0324H   |                     |                | Day 20         | Day 10                      | Day 8           | Day 4           | Day 2     | Day 1           | Day column                            | R/W        |
| MONTHR | 0325H   |                     |                |                | Oct.                        | Aug.            | Apr.            | Feb.      | Jan.            | Month column                          | R/W        |
| YEARR  | 0326H   | Year 80             | Year 40        | Year 20        | Year 10                     | Year 8          | Year 4          | Year 2    | Year 1          | Year column<br>(Lower two<br>columns) | R/W        |
| PAGER  | 0327H   | Interrupt<br>enable |                |                | Adjust-<br>ment<br>function | Clock<br>enable | Alarm<br>enable |           | PAGE<br>setting | PAGE register                         | W, R/W     |
| RESTR  | 0328H   | 1HZ<br>enable       | 16HZ<br>enable | Clock<br>reset | Alarm<br>reset              |                 | Always          | write "0" |                 | Reset register                        | Write only |

| Table 0 40 4 |       |                  | Denistana |
|--------------|-------|------------------|-----------|
|              | PAGEU | (Clock function) | Registers |

Note: As for SECR, MINR, HOURR, DAYR, MONTHR, YEARR of PAGE0, current state is read when read it.

|        |         |                     |                | 0              |                | (,              | Turiction       | .)eg.e    |                 |                                        |            |
|--------|---------|---------------------|----------------|----------------|----------------|-----------------|-----------------|-----------|-----------------|----------------------------------------|------------|
| Symbol | Address | Bit7                | Bit6           | Bit5           | Bit4           | Bit3            | Bit2            | Bit1      | Bit0            | Function                               | Read/Write |
| SECR   | 0320H   |                     |                |                |                |                 |                 |           |                 |                                        | R/W        |
| MINR   | 0321H   |                     | 40 min.        | 20 min.        | 10 min.        | 8 min.          | 4 min.          | 2 min.    | 1 min.          | Minute column<br>for alarm             | R/W        |
| HOURR  | 0322H   |                     |                | 20<br>/PM/AM   | 10 hours       | 8 hours         | 4 hours         | 2 hours   | 1 hour          | Hour column<br>for alarm               | R/W        |
| DAYR   | 0323H   |                     |                |                |                |                 | W2              | W1        | W0              | Day of the week<br>column for<br>alarm | R/W        |
| DATER  | 0324H   |                     |                | Day 20         | Day 10         | Day 8           | Day 4           | Day 2     | Day 1           | Day column for<br>alarm                | R/W        |
| MONTHR | 0325H   |                     |                |                |                |                 |                 |           | 24/12           | 24-hour clock<br>mode                  | R/W        |
| YEARR  | 0326H   |                     |                |                |                |                 |                 | Leap-yea  | ar setting      | Leap-year mode                         | R/W        |
| PAGER  | 0327H   | Interrupt<br>enable |                |                |                | Clock<br>enable | Alarm<br>enable |           | PAGE<br>setting | PAGE register                          | W, R/W     |
| RESTR  | 0328H   | 1HZ<br>enable       | 16HZ<br>enable | Clock<br>reset | Alarm<br>reset |                 | Always          | write "0" |                 | Reset register                         | Write only |

Table 3.13.2 PAGE 1 (Alarm function) Registers

Note: As for MINR, HOURR, DAYR, MONTHR, YEARR of PAGE1, current state is read when read it.

#### 3.13.4 Detailed Explanation of Control Register

RTC is not initialized by reset.

Therefore, all registers must be initialized at the beginning of the program.

| (1) | Second column | register | (for ] | PAGE0 only | y) |
|-----|---------------|----------|--------|------------|----|
|-----|---------------|----------|--------|------------|----|

| SECR    |   |
|---------|---|
| (0320H) | ) |

|             | 7            | 6     |     | 5         |     | 4       | 3      | 2      |       | 1    | 0        |  |  |  |
|-------------|--------------|-------|-----|-----------|-----|---------|--------|--------|-------|------|----------|--|--|--|
| Bit symbol  |              | SE    | 6   | SE5       |     | SE4     | SE3    | SE2    | S     | E1   | SE0      |  |  |  |
| Read/Write  | /            |       |     |           |     | R/W     |        |        |       |      |          |  |  |  |
| After reset |              |       |     | Undefined |     |         |        |        |       |      |          |  |  |  |
| Function    | "0" is read. | 40 se | ec. | 20 sec.   |     | 10 sec. | 8 sec. | 4 sec. | 2 :   | sec. | 1 sec.   |  |  |  |
|             |              | colum | nn  | column    |     | column  | column | columr | n col | umn  | column   |  |  |  |
|             | _            |       |     | -         |     | 1       | 1      |        |       | -    | <u> </u> |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 0      | 0      | 0     |      | 0 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 0      | 0      | 1     |      | 1 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 0      | 1      | 0     |      | 2 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 0      | 1      | 1     |      | 3 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 1      | 0      | 0     |      | 4 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 1      | 0      | 1     |      | 5 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 1      | 1      | 0     |      | 6 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 0       | 1      | 1      | 1     |      | 7 s      |  |  |  |
|             |              | 0     | 0   |           | 0   | 1       | 0      | 0      | 0     |      | 8 s      |  |  |  |
|             |              | 0     | 0   | 0         |     | 1       | 0      | 0      | 1     |      | 9 s      |  |  |  |
|             |              | 0     | 0   |           | 1 0 |         | 0      | 0      | 0     |      | 10 s     |  |  |  |
|             |              |       | -   |           |     | T       | :      |        |       |      |          |  |  |  |
|             |              | 0     | 0   |           | 1   | 1       | 0      | 0      | 1     |      | 19 s     |  |  |  |
|             |              | 0     | 1   |           | 0   | 0       | 0      | 0      | 0     |      | 20 s     |  |  |  |
|             | _            |       | 1   |           |     |         | :      |        |       |      |          |  |  |  |
|             |              | 0     | 1   |           | 0   | 1       | 0      | 0      | 1     |      | 29 s     |  |  |  |
|             |              | 0     | 1   |           | 1   | 0       | 0      | 0      | 0     |      | 30 s     |  |  |  |
|             | _            |       | 1   |           |     |         | :      |        |       |      |          |  |  |  |
|             |              | 0     | 1   |           | 1   | 1       | 0      | 0      | 1     |      | 39 s     |  |  |  |
|             |              | 1     | 0   |           | 0   | 0       | 0      | 0      | 0     |      | 40 s     |  |  |  |
|             | _            |       | 1   |           |     |         | :      |        |       |      |          |  |  |  |
|             |              | 1     | 0   |           | 0   | 1       | 0      | 0      | 1     |      | 49 s     |  |  |  |
|             |              | 1     | 0   |           | 1   | 0       | 0      | 0      | 0     |      | 50 s     |  |  |  |
|             |              |       | 1   |           |     |         | :      |        |       |      |          |  |  |  |
|             |              | 1     | 0   |           | 1   | 1       | 0      | 0      | 1     |      | 59 s     |  |  |  |

Note: Do not set the data other than showing above.

|             | 7            | 7 6 5   |       | 5         | 4       | 3      | 2      | 1      | 1      | 0      |  |  |  |
|-------------|--------------|---------|-------|-----------|---------|--------|--------|--------|--------|--------|--|--|--|
| Bit symbol  |              | MI      | 6     | MI5       | MI4     | MI3    | MI2    | М      | 11     | MI0    |  |  |  |
| Read/Write  | /            |         |       | R/W       |         |        |        |        |        |        |  |  |  |
| After reset |              |         |       | Undefined |         |        |        |        |        |        |  |  |  |
| Function    | "0" is read. | 40 min, |       | 0 min,    | 10 min, | 8 min, | 4 min, | 2 m    | nin,   | 1 min, |  |  |  |
|             |              | colur   | nn co | olumn     | column  | column | columr | n colu | ımn d  | column |  |  |  |
|             | -            |         | 1     | 1         | 1       | 1      | r      | [      | 1      |        |  |  |  |
|             |              | 0       | 0     | 0         | 0       | 0      | 0      | 0      | 0 mir  | า.     |  |  |  |
|             |              | 0       | 0     | 0         | 0       | 0      | 0      | 1      | 1 mir  | า.     |  |  |  |
|             |              | 0       | 0     | 0         | 0       | 0      | 1      | 0      | 2 mir  | ۱.     |  |  |  |
|             | Ļ            | 0       | 0     | 0         | 0       | 0      | 1      | 1      | 3 mir  | า.     |  |  |  |
|             | Ļ            | 0       | 0     | 0         | 0       | 1      | 0      | 0      | 4 mir  | ۱.     |  |  |  |
|             |              | 0       | 0     | 0         | 0       | 1      | 0      | 1      | 5 min. |        |  |  |  |
|             | _            | 0       | 0     | 0         | 0       | 1      | 1      | 0      | 6 mir  | า.     |  |  |  |
|             | _            | 0       | 0     | 0         | 0       | 1      | 1      | 1      | 7 mir  |        |  |  |  |
|             | _            | 0       | 0     | 0         | 1       | 0      | 0      | 0      | 8 mir  | า.     |  |  |  |
|             | _            | 0       | 0     | 0         | 1       | 0      |        | 1      | 9 mir  |        |  |  |  |
|             | L            | 0       | 0     | 1         | 0       | 0      | 0      | 0      | 10 mi  | n.     |  |  |  |
|             | Г            |         |       |           |         | 0      |        |        |        |        |  |  |  |
|             | _            | 0       | 0     | 1         | 1       |        | 0      | 1      | 19 mi  |        |  |  |  |
|             |              | 0       | 1     | 0         | 0       | 0      | 0      | 0      | 20 mi  | n.     |  |  |  |
|             | Г            | 0       | 1     | 0         | 1       | . 0    | 0      | 1      | 29 mi  | n      |  |  |  |
|             | F            | 0       | 1     | 1         | 0       | 0      | 0      | 0      | 30 mi  |        |  |  |  |
|             | L            | 0       |       |           | ů       | :      | Ū      | Ū      |        |        |  |  |  |
|             | Γ            | 0       | 1     | 1         | 1       | 0      | 0      | 1      | 39 mi  | n.     |  |  |  |
|             |              | 1       | 0     | 0         | 0       | 0      | 0      | 0      | 40 mi  |        |  |  |  |
|             |              |         |       |           |         | :      |        |        |        |        |  |  |  |
|             |              | 1       | 0     | 0         | 1       | 0      | 0      | 1      | 49 mi  | n.     |  |  |  |
|             |              | 1       | 0     | 1         | 0       | 0      | 0      | 0      | 50 mi  | n.     |  |  |  |
|             |              |         |       |           |         | :      |        |        |        |        |  |  |  |
|             |              | 1       | 0     | 1         | 1       | 0      | 0      | 1      | 59 mi  | n.     |  |  |  |
|             |              |         |       |           |         |        |        |        |        |        |  |  |  |

(2) Minute column register (for PAGE0/1)

(0321H)

MINR

Note: Do not set the data other than showing above.

(3) Hour column register (for PAGE0/1)

|         |             | a. In ca | use of 2 | 4-hour | clock m         | ode (MON          | THR <mc< th=""><th>00&gt;=1) of</th><th>PAGEI</th><th></th><th></th></mc<> | 00>=1) of        | PAGEI       |      |                  |  |  |  |  |
|---------|-------------|----------|----------|--------|-----------------|-------------------|----------------------------------------------------------------------------|------------------|-------------|------|------------------|--|--|--|--|
|         |             | 7        | 6        |        | 5               | 4                 | 3                                                                          | 2                |             | 1    | 0                |  |  |  |  |
| HOURR   | Bit symbol  |          | /        | /      | HO5             | HO4               | HO3                                                                        | HO2              | HO1         |      | HO0              |  |  |  |  |
| (0322H) | Read/Write  |          | /        |        | R/W             |                   |                                                                            |                  |             |      |                  |  |  |  |  |
|         | After reset |          |          |        |                 |                   | Und                                                                        | efined           |             |      |                  |  |  |  |  |
|         | Function    | "0" is   | read.    |        | ) hour<br>blumn | 10 hour<br>column | 8 hour<br>column                                                           | 4 hour<br>column | 2 h<br>colu |      | 1 hour<br>column |  |  |  |  |
|         |             |          | _        |        |                 |                   |                                                                            |                  |             |      |                  |  |  |  |  |
|         |             |          |          | 0      | 0               | 0                 | 0                                                                          | 0                | 0           | 0 0  | 'clock           |  |  |  |  |
|         |             |          |          | 0      | 0               | 0                 | 0                                                                          | 0                | 1           | 1 0  | 'clock           |  |  |  |  |
|         |             |          |          | 0      | 0               | 0                 | 0                                                                          | 1                | 0           | 2 0  | 'clock           |  |  |  |  |
|         |             |          | F        |        |                 |                   | :                                                                          |                  |             |      |                  |  |  |  |  |
|         |             |          |          | 0      | 0               | 1                 | 0                                                                          | 0                | 0           | 8 0  | 'clock           |  |  |  |  |
|         |             |          |          | 0      | 0               | 1                 | 0                                                                          | 0                | 1           | 9 0  | 'clock           |  |  |  |  |
|         |             |          |          | 0      | 1               | 0                 | 0                                                                          | 0                | 0           | 10 o | 'clock           |  |  |  |  |
|         |             |          | г        |        |                 |                   | :                                                                          |                  |             | -    |                  |  |  |  |  |
|         |             |          | -        | 0      | 1               | 1                 | 0                                                                          | 0                | 1           | 19 o | 'clock           |  |  |  |  |
|         |             |          |          | 1      | 0               | 0                 | 0                                                                          | 0                | 0           | 20 o | 'clock           |  |  |  |  |
|         |             |          | г        |        |                 |                   | :                                                                          |                  |             |      |                  |  |  |  |  |
|         |             |          |          | 1      | 0               | 0                 | 0                                                                          | 1                | 1           | 23 o | 'clock           |  |  |  |  |

In case of 24-hour clock mode (MONTHR<MO0>=1) of PAGE1

Note: Do not set the data other than showing above.

b. In case of 12-hour clock mode (MONTHR<MO0>=0) of PAGE1

|         |             | 7      | 6     | 5     | 4       | 3      | 2      | 1      | 0      |
|---------|-------------|--------|-------|-------|---------|--------|--------|--------|--------|
| HOURR   | Bit symbol  | /      |       | HO5   | HO4     | HO3    | HO2    | HO1    | HO0    |
| (0322H) | Read/Write  | /      | /     |       |         | R/     | W      |        |        |
|         | After reset | /      |       |       |         | Unde   | fined  |        |        |
|         | Function    | "0" is | read. |       | 10 hour | 8 hour | 4 hour | 2 hour | 1 hour |
|         |             |        |       | PM/AM | column  | column | column | column | column |

| 0 | 0 | 0 | 0 | 0 | 0 | 0 o'clock<br>(AM) |
|---|---|---|---|---|---|-------------------|
| 0 | 0 | 0 | 0 | 0 | 1 | 1 o'clock         |
| 0 | 0 | 0 | 0 | 1 | 0 | 2 o'clock         |
|   |   |   | : |   |   |                   |
| 0 | 0 | 1 | 0 | 0 | 1 | 9 o'clock         |
| 0 | 1 | 0 | 0 | 0 | 0 | 10 o'clock        |
| 0 | 1 | 0 | 0 | 0 | 1 | 11 o'clock        |

0

0

0

1

0

0

Note: Do not set the data other than showing above.

0

0

0

0

1

1

0 o'clock (PM)

1 o'clock

|         | ( ) = =     |   |   |              | ( |   |     |           |     |
|---------|-------------|---|---|--------------|---|---|-----|-----------|-----|
|         |             | 7 | 6 | 5            | 4 | 3 | 2   | 1         | 0   |
| DAYR    | Bit symbol  | / |   |              |   |   | WE2 | WE1       | WE0 |
| (0323H) | Read/Write  | / | / |              |   |   |     | R/W       |     |
|         | After reset | / |   |              |   |   |     | Undefined |     |
|         | Function    |   |   | "0" is read. |   |   | W2  | W1        | W0  |
|         |             |   |   |              |   |   |     |           |     |

(4) Day of the week column register (for PAGE0/1)

|   |   | _ |           |
|---|---|---|-----------|
| 0 | 0 | 0 | Sunday    |
| 0 | 0 | 1 | Monday    |
| 0 | 1 | 0 | Tuesday   |
| 0 | 1 | 1 | Wednesday |
| 1 | 0 | 0 | Thursday  |
| 1 | 0 | 1 | Friday    |
| 1 | 1 | 0 | Saturday  |

Note: Do not set the data other than showing above.

## (5) Day column register (for PAGE0/1)

DATER (0324H)

|             | 7            | 6 |   | 5         |     | 4      | 3     | 2     |   | 1   |    | 0      |  |  |
|-------------|--------------|---|---|-----------|-----|--------|-------|-------|---|-----|----|--------|--|--|
| Bit symbol  |              | / | / | DA5       | DA4 |        | DA3   | DA2   |   | DA  | .1 | DA0    |  |  |
| Read/Write  |              |   | / | R/W       |     |        |       |       |   |     |    |        |  |  |
| After reset |              |   | / | Undefined |     |        |       |       |   |     |    |        |  |  |
| Function    | "0" is read. |   |   | Day 20    | D   | Day 10 | Day 8 | Day 4 |   | Day | 2  | Day 1  |  |  |
|             |              |   |   |           |     |        | n     |       |   |     |    |        |  |  |
|             |              |   | 0 | 0         |     | 0      | 0     | 0     |   | 0   |    | 0      |  |  |
|             |              |   | 0 | 0         |     | 0      | 0     | 0     |   | 1   | 15 | st day |  |  |
|             |              |   | 0 | 0         |     | 0      | 0     | 1     |   | 0   | 2n | d day  |  |  |
|             |              |   | 0 | 0         |     | 0      | 0     | 1     |   | 1   | 3r | d day  |  |  |
|             |              | J | 0 | 0         |     | 0      | 1     | 0     |   | 0   | 4t | h day  |  |  |
|             |              |   |   |           |     |        | i     | r     |   |     |    | 1      |  |  |
|             |              |   | 0 | 0         |     | 1      | 0     | 0     |   | 1   |    | h day  |  |  |
|             |              |   | 0 | 1         |     | 0      | 0     | 0     |   | 0   |    | th day |  |  |
|             |              |   | 0 | 1         |     | 0      | 0     | 0     |   | 1   | 11 | th day |  |  |
|             |              | i |   | -         |     |        | i     |       | i |     |    | 1      |  |  |
|             |              |   | 0 | 1         |     | 1      | 0     | 0     |   | 1   |    | th day |  |  |
|             |              |   | 1 | 0         |     | 0      | 0     | 0     |   | 0   | 20 | th day |  |  |
|             |              |   |   |           |     |        | I     |       | i |     |    |        |  |  |
|             |              |   | 1 | 0         |     | 1      | 0     | 0     |   | 1   |    | th day |  |  |
|             |              |   | 1 | 1         |     | 0      | 0     | 0     |   |     |    | th day |  |  |
|             |              |   | 1 | 1         |     | 0      | 0     | 0     |   | 1   | 31 | st day |  |  |

Note1: Do not set the data other than showing above.

Note2: Do not set the day which is not existed. (ex: 30<sup>th</sup> Feb)

|         |             | 7 | 6            | 5 | 4         | 3        | 2         | 1        | 0       |
|---------|-------------|---|--------------|---|-----------|----------|-----------|----------|---------|
| MONTHR  | Bit symbol  | / |              |   | MO4       | MO4      | MO2       | MO1      | MO0     |
| (0325H) | Read/Write  | / |              |   |           |          | R/W       |          |         |
|         | After reset | / |              |   |           |          | Undefined |          |         |
|         | Function    |   | "0" is read. |   | 10 months | 8 months | 4 months  | 2 months | 1 month |

| (6) Month column register (for PAGE0 only |
|-------------------------------------------|
|-------------------------------------------|

| 0 | 0 | 0 | 0 | 1 | January   |
|---|---|---|---|---|-----------|
| 0 | 0 | 0 | 1 | 0 | February  |
| 0 | 0 | 0 | 1 | 1 | March     |
| 0 | 0 | 1 | 0 | 0 | April     |
| 0 | 0 | 1 | 0 | 1 | Мау       |
| 0 | 0 | 1 | 1 | 0 | June      |
| 0 | 0 | 1 | 1 | 1 | July      |
| 0 | 1 | 0 | 0 | 0 | August    |
| 0 | 1 | 0 | 0 | 1 | September |
| 1 | 0 | 0 | 0 | 0 | October   |
| 1 | 0 | 0 | 0 | 1 | November  |
| 1 | 0 | 0 | 1 | 0 | December  |

Note: Do not set the data other than showing above.

# (7) Select 24-hour clock or 12-hour clock (for PAGE1 only)

|         |             | 7 | 6 | 5 | 4             | 3 | 2 | 1 | 0          |
|---------|-------------|---|---|---|---------------|---|---|---|------------|
| MONTHR  | Bit symbol  | / |   |   |               | / |   |   | MO0        |
| (0325H) | Read/Write  | / |   | / | /             | / | / | / | R/W        |
|         | After reset | / |   | / | /             | / | / | / | Undefined  |
|         | Function    |   |   |   | "O" := == = d |   |   |   | 1: 24-hour |
|         |             |   |   |   | "0" is read.  |   |   |   | 0: 12-hour |

|             |          | 0       |         |       | 0        |         |       |      |         |          |
|-------------|----------|---------|---------|-------|----------|---------|-------|------|---------|----------|
|             | 7        | 6       |         | 5     | 4        | 3       |       | 2    | 1       | 0        |
| Bit symbol  | YE7      | YE6     | YE6 YE5 |       | YE4      | YE3     | Y     | E2   | YE1     | YE0      |
| Read/Write  |          |         | R/W     |       |          |         |       |      |         |          |
| After reset |          |         |         |       | Unde     | efined  |       |      |         |          |
| Function    | 80 Years | 40 Year | rs 20`  | Years | 10 Years | 8 Years | s 4 Y | ears | 2 Years | 1 Year   |
|             |          |         |         |       |          |         |       |      |         |          |
|             |          | 0       | 0       | 0     | 0        | 0       | 0     | 0    | 0       | 00 years |
|             |          | 0       | 0       | 0     | 0        | 0       | 0     | 0    | 1       | 01 years |
|             |          | 0       | 0       | 0     | 0        | 0       | 0     | 1    | 0       | 02 years |
|             |          | 0       | 0       | 0     | 0        | 0       | 0     | 1    | 1       | 03 years |
|             |          | 0       | 0       | 0     | 0        | 0       | 1     | 0    | 0       | 04 years |
|             |          | 0       | 0       | 0     | 0        | 0       | 1     | 0    | 1       | 05 years |
|             |          |         |         |       |          | :       |       |      |         |          |
|             |          | 1       | 0       | 0     | 1        | 1       | 0     | 0    | 1       | 99 years |

(8) Year column register (for PAGE0 only)

YEARR (0326H)

Note: Do not set the data other than showing above.

(9) Leap-year register (for PAGE1 only)

|         |             | 7 | 6 | 5      | 4     | 3 | 2 | 1          | 0        |
|---------|-------------|---|---|--------|-------|---|---|------------|----------|
| YEARR   | Bit symbol  | / |   | /      | /     | / | / | LEAP1      | LEAP0    |
| (0326H) | Read/Write  |   |   |        |       |   |   | R/         | W        |
|         | After reset |   |   |        |       | / |   | Unde       | efined   |
|         | Function    |   |   |        |       |   |   | 00: Leap y |          |
|         |             |   |   |        |       |   |   | 01: One y  |          |
|         |             |   |   |        |       |   |   | leap y     |          |
|         |             |   |   | 0 is 1 | read. |   |   | 10: Two y  |          |
|         |             |   |   |        |       |   |   | leap y     |          |
|         |             |   |   |        |       |   |   | 11: Three  |          |
|         |             |   |   |        |       |   |   | after le   | eap year |

| 0 | 0 | Current year is leap year      |
|---|---|--------------------------------|
| 0 | 1 | Present is next year of a leap |
| 0 | I | year                           |
| 4 | 0 | Present is two years after a   |
|   | 0 | leap year                      |
| 4 |   | Present is three years after   |
| 1 | 1 | leap year                      |

|             |             | _          | _            |   |              |            |            |              |           |
|-------------|-------------|------------|--------------|---|--------------|------------|------------|--------------|-----------|
|             |             | 7          | 6            | 5 | 4            | 3          | 2          | 1            | 0         |
| PAGER       | Bit symbol  | INTENA     |              |   | ADJUST       | ENATMR     | ENAALM     |              | PAGE      |
| (0327H)     | Read/Write  | R/W        | /            |   | W            | R/         | W          |              | R/W       |
| Read-modify | After reset | 0          |              |   | Undefined    | Unde       | efined     |              | Undefined |
| write       | Function    | INTRTC     |              |   | 0:Don't care | Clock      | ALARM      | "0" is read. | PAGE      |
| instruction |             | 0: Disable | "0" is read. |   | 1:Adjust     | 0: Disable | 0: Disable |              | selection |
| are         |             | 1: Enable  |              |   |              | 1: Enable  | 1: Enable  |              |           |
| prohibited  |             |            |              |   |              |            |            |              |           |

## (10) PAGE register setting (for PAGE0/1)

Note: Pleas keep the setting order below and don't set same time.

(Set difference time to Clock/Alarm setting and interrupt setting)

#### (Example) Clock setting/Alarm setting

ld (pager), 0ch : Clock, Alarm enable

ld (pager), 8ch : Interrupt enable

| DACE   | 0 | Select Page0                                            |  |  |
|--------|---|---------------------------------------------------------|--|--|
| PAGE 1 |   | Select Page1                                            |  |  |
| _      |   |                                                         |  |  |
|        | 0 | Don't care                                              |  |  |
|        | 1 | Adjust sec. counter.                                    |  |  |
|        |   | When set this bit to "1" the sec. counter become to     |  |  |
|        |   | "0" when the value of sec. counter is $0 - 29$ . And in |  |  |
| ADJUST |   | case that value of sec. counter is 30-59, min.          |  |  |
| 70001  |   | counter is carried and become sec. counter to "0".      |  |  |
|        |   | Output Adjust signal during 1 cycle of fsys. After      |  |  |

automatically. (PAGE0 only)

being adjusted once, Adjust is released

#### (11) Reset register setting (for PAGE0/1)

|             |             | 7          | 6          | 5        | 4           | 3   | 2      | 1         | 0   |
|-------------|-------------|------------|------------|----------|-------------|-----|--------|-----------|-----|
| RESTR       | Bit symbol  | DIS1Hz     | DIS16Hz    | RSTTMR   | RSTALM      | RE3 | RE2    | RE1       | RE0 |
| (1328H)     | Read/Write  |            |            |          | V           | /   |        |           |     |
| Read-modify | After reset | Undefined  |            |          |             |     |        |           |     |
| write       | Function    | 1Hz        | 16Hz       | 1: Clock | 1:          |     |        |           |     |
| instruction |             | 0: Enable  | 0: Enable  | reset    | Alarm reset |     | Always | write "O" |     |
| are         |             | 1: Disable | 1: Disable |          |             |     | Always | write 0   |     |
| prohibited  |             |            |            |          |             |     |        |           |     |

|                                                                                                                     | DOTALM | 0 | Unused               |   |  |  |  |
|---------------------------------------------------------------------------------------------------------------------|--------|---|----------------------|---|--|--|--|
| RSTALM                                                                                                              |        | 1 | Reset alarm register |   |  |  |  |
| Note: When write "1", reset alarm during 1 cycle of f <sub>SYS</sub> . After that, reset is released automatically. |        |   |                      |   |  |  |  |
|                                                                                                                     | DOTTMD | 0 | Unused               |   |  |  |  |
|                                                                                                                     | RSTTMR | 1 | Reset divider        | ĺ |  |  |  |

Note: When write "1", reset alarm during 1 cycle of f<sub>SYS</sub>. After that, reset is released automatically.

| <dis1hz></dis1hz> | <dis16hz></dis16hz> | (PAGER)<br><enaalm></enaalm> | Source signal |  |
|-------------------|---------------------|------------------------------|---------------|--|
| 1                 | 1                   | 1                            | Alarm         |  |
| 0                 | 1                   | 0                            | 1Hz           |  |
| 1                 | 0                   | 0                            | 16Hz          |  |
|                   | Output "0"          |                              |               |  |

# 3.13.5 Operational Description

(1) Reading Clock data

There is the case which reads wrong data when carry of the inside counter happens during the operation which Clock data reads. Therefore, please read two times with the following way for reading correct data.



Figure 3.13.2 Flowchart of Clock Data Read

(2) Timing of INTRTC and Clock data

When time is read by interrupt, read clock data within 0.5s(s) after generating interrupt. This is because count up of clock data occurs by rising edge of 1Hz pulse cycle.



Figure 3.13.3 Timing of INTRTC and Clock data

(3) Writing Clock data

When there is carry on the way of write operation, expecting data can not be wrote exactly.

Therefore, in order to write in data exactly please follow the below way.

1. Reset for a divider

Inside of RTC, there is 15-stage divider which generates 1 Hz clock from 32.768 kHz. Carry of a Clock is not done for 0.5 second when reset this divider. So write in data during this interval.



Figure 3.13.4 Flowchart of Data Write

2. Disabling the Clock

Carry of a clock is prohibited when write "0" to PAGER<ENATMR> and can prevent malfunction by 1s carry hold circuit. During a clock prohibited, 1s carry hold circuit holds one second carry signal, which is generated from divider. After becoming clock enable state, output the carry signal to clock and revise time and continue operation. However, clock is late when clock-disabling state continues for one second or more.



Figure 3.13.5 Flowchart of Clock Disable

## 3.13.6 Explanation of the Alarm Function

Can use alarm function by setting of register of PAGE1 and output either of three signals from  $\overline{\text{ALARM}}$  pin as follows by write "1" to PAGER<PAGE>. INTRTC outputs 1shot pulse when the falling edge is detected. RTC is not initializes by RESET. Therefore, when clock or alarm function is used, clear interrupt request flag in INTC (interrupt controller).

- (1) In accordance of alarm register and the Clock, output 0
- (2) Output clock of 1 Hz
- (3) Output clock of 16 Hz

(1) In accordance with alarm register and a clock, output "0"

When value of a clock of PAGE0 accorded with alarm register of PAGE1 with a state of PAGER<ENAALM>= "1", output "0" to ALARM pin and occur INTRTC.

Follows are ways using alarm.

Initialization of alarm is done by writing in "1" at RESTR<RSTALM>, setting value of all alarm becomes don't care. In this case, always accorded with value of a clock and request INTRTC interrupt if PAGER<ENAALM> is "1".

Setting alarm min., alarm hour, alarm day and alarm the day week are done by writing in data at each register of PAGE1.

When all setting contents accorded, RTC generates INTRTC interrupt, if PAGER<INTENA><ENAALM> is "1". However, contents (don't care state) which does not set it up is considered to always accord.

The contents, which set it up once, cannot be returned to don't care state in independence. Initialization of alarm and resetting of alarm register set to "Don't care".

The following is an example program for outputting alarm from ALARM -pin at noon (PM12:00) every day.

|   | LD | (PAGER), 09H | ; | Alarm disable, setting PAGE1 |
|---|----|--------------|---|------------------------------|
|   | LD | (RESTR), D0H | ; | Alarm initialize             |
|   | LD | (DAYR), 01H  | ; | W0                           |
|   | LD | (DATAR),01H  |   | 1 day                        |
|   | LD | (HOURR), 12H | ; | Setting 12 o'clock           |
|   | LD | (MINR), 00H  | ; | Setting 00 min               |
|   |    |              | ; | Set up time 31 µs (Note)     |
|   | LD | (PAGER), 0CH | ; | Alarm enable                 |
| ( | LD | (PAGER), 8CH | ; | Interrupt enable )           |
|   |    |              |   |                              |

When CPU is operated by high frequency oscillation, it may take a maximum of one clock at 32 kHz (about  $30\mu$ s) for the time register setting to become valid. In the above example, it is necessary to set  $31\mu$ s of set up time between setting the time register and enabling the alarm register.

Note: This set up time is unnecessary when you use only internal interruption.

(4) When output clock of 1 Hz

RTC outputs clock of 1 Hz to  $\overline{\text{ALARM}}$  pin by setting up PAGER<ENAALM> = 0, RESTR<DIS1HZ> = 0, <DIS16HZ> = 1. And RTC generates INTRTC interrupt by falling edge of the clock.

(5) When output clock of 16 Hz

RTC outputs clock of 16 Hz to  $\overline{\text{ALARM}}$  pin by setting up PAGER<ENAALM> = 0, RESTR<DIS1HZ> = 1, <DIS16HZ> = 0. And RTC generates INTRTC interrupt by falling edge of the clock.

## 3.14 Melody/Alarm Generator (MLD)

TMP91C824 incorporates melody function and alarm function, both of which are output from the MLDALM pin. 5 kinds of fixed cycle interrupts are generated by the 15-bit free-run counter, which is used for alarm generator.

Features are as follows.

#### • Melody generator

The melody function generates signals of any frequency (4 Hz to 5461 Hz) based on lowspeed clock (32.768 kHz) and outputs several signals from the MLDALM pin.

By connecting a loud speaker outside, melody tone can sound easily.

• Alarm generator

The alarm function generates 8 kinds of alarm waveform having a modulation frequency (4096 Hz) determined by the low-speed clock (32.768 kHz). And this waveform is able to invert by setting a value to a register.

By connecting a loud speaker outside, alarm tone can sound easily.

And also 5 kinds of fixed cycle (1 Hz, 2 Hz, 64 Hz, 512 Hz and 8192 Hz) interrupts are generated by the free-run counter which is used for alarm generator.

This section is constituted as follows.

- 3.14.1 Block Diagram
- 3.14.2 Control Registers
- 3.14.3 Operational Description
  - (1) Melody generator
  - (2) Alarm generator

# 3.14.1 Block Diagram



Figure 3.14.1 MLD Block Diagram

# 3.14.2 Control Registers

| _                | ALM Register |                         |               |                   |                |            |     |     |                    |  |  |
|------------------|--------------|-------------------------|---------------|-------------------|----------------|------------|-----|-----|--------------------|--|--|
|                  |              | 7                       | 6             | 5                 | 4              | 3          | 2   | 1   | 0                  |  |  |
| ALM              | Bit symbol   | AL8                     | AL7           | AL6               | AL5            | AL4        | AL3 | AL2 | AL1                |  |  |
| (0330H)          | Read/Write   |                         |               |                   | R/             | N          |     |     |                    |  |  |
|                  | After reset  | 0                       | 0             | 0                 | 0              | 0          | 0   | 0   | 0                  |  |  |
|                  | Function     |                         |               |                   | Setting ala    | rm pattern |     |     |                    |  |  |
| MELALMC Register |              |                         |               |                   |                |            |     |     |                    |  |  |
|                  |              | 7                       | 6             | 5                 | 4              | 3          | 2   | 1   | 0                  |  |  |
| MELALMC          | Bit symbol   | FC1                     | FC0           | ALMINV            | -              | -          | _   | -   | MELALM             |  |  |
| (0331H)          | Read/Write   | R                       | /W            | R/W               | R/W            | R/W        | R/W | R/W | R/W                |  |  |
|                  | After reset  | 0                       | 0             | 0                 | 0              | 0          | 0   | 0   | 0                  |  |  |
|                  | Function     | Free-run co<br>00: Hold | unter control | Alarm<br>waveform | Always write 0 |            |     |     | Output<br>waveform |  |  |
|                  |              | 01: Restart             |               | invert            |                |            |     |     | select             |  |  |
|                  |              | 10: Clear               |               | 1: Invert         |                |            |     |     | 0: Alarm           |  |  |
|                  |              | 11: Clear an            | nd start      |                   |                |            |     |     | 1: Melody          |  |  |

Note 1: MELALMEC<FC1> is read always 0.

Note 2: When setting MELALMC register except <FC1:0> during the free-run counter is running, <FC1:0> is kept 01.

|         | MELFL Register |     |                                         |     |     |     |     |     |     |  |  |  |
|---------|----------------|-----|-----------------------------------------|-----|-----|-----|-----|-----|-----|--|--|--|
| MELFL   | /              | 7   | 6                                       | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|         | Bit symbol     | ML7 | ML6                                     | ML5 | ML4 | ML3 | ML2 | ML1 | ML0 |  |  |  |
| (0332H) | Read/Write     |     | R/W                                     |     |     |     |     |     |     |  |  |  |
|         | After reset    | 0   | 0                                       | 0   | 0   | 0   | 0   | 0   | 0   |  |  |  |
|         | Function       |     | Setting melody frequency (Lower 8 bits) |     |     |     |     |     |     |  |  |  |

MELFH Register

|         |             | 7         | 6                         | 5 | 4 | 3    | 2           | 1                   | 0   |  |
|---------|-------------|-----------|---------------------------|---|---|------|-------------|---------------------|-----|--|
| MELFH   | Bit symbol  | MELON     | /                         | / | / | ML11 | ML10        | ML9                 | ML8 |  |
| (0333H) | Read/Write  | R/W       |                           |   |   | R/W  |             |                     |     |  |
|         | After reset | 0         |                           |   |   | 0    | 0           | 0                   | 0   |  |
|         | Function    | Control   | I Setting melody frequent |   |   |      | iency (Uppe | ency (Upper 4 bits) |     |  |
|         |             | melody    |                           |   |   |      |             |                     |     |  |
|         |             | counter   |                           |   |   |      |             |                     |     |  |
|         |             | 0: Stop & |                           |   |   |      |             |                     |     |  |
|         |             | clear     |                           |   |   |      |             |                     |     |  |
|         |             | 1: Start  |                           |   |   |      |             |                     |     |  |

| ALMINT | Register |
|--------|----------|
|--------|----------|

|                   |             | 7 | 6 | 5       | 4                                          | 3      | 2      | 1      | 0      |  |
|-------------------|-------------|---|---|---------|--------------------------------------------|--------|--------|--------|--------|--|
| ALMINT<br>(0334H) | Bit symbol  | / | / | _       | IALM4E                                     | IALM3E | IALM2E | IALM1E | IALM0E |  |
|                   | Read/Write  | / |   | R/W     | R/W                                        |        |        |        |        |  |
|                   | After reset | / |   | 0       | 0                                          | 0      | 0      | 0      | 0      |  |
|                   | Europhian.  |   |   | Always  | 1: Interrupt enable for INTALM4 to INTALM0 |        |        |        |        |  |
|                   | Function    |   |   | write 0 |                                            |        |        |        |        |  |

## 3.14.3 Operational Description

(1) Melody generator

The melody function generates signals of any frequency (4 Hz to 5461 Hz) based on low-speed clock (32.768 kHz) and outputs the signals from the MLDALM pin.

By connecting a loud speaker outside, melody tone can sound easily.

### (Operation)

At first, MELALMC<MELALM> have to be set as 1 in order to select melody waveform as output waveform from MLDALM. Then melody output frequency has to be set to 12-bit register MELFH, MELFL.

Followings are setting example and calculation of melody output frequency.

(Formula for calculating of melody waveform frequency)

|                                | at $fs = 32.768 [kHz]$                  |
|--------------------------------|-----------------------------------------|
| melody output waveform         | $f_{MLD} [Hz] = 32768/(2 \times N + 4)$ |
| setting value for melody       | $N = (16384/f_{MLD}) - 2$               |
| (notice: N = 1 to 4095(001H to | o FFFH), 0 is not acceptable)           |

#### (Example program)

In case of outputting La musical scale (440 Hz)

| LD | (MELALMC),XXXX1B | ; select melody waveform         |
|----|------------------|----------------------------------|
| LD | (MELFL), 23H     | ; N= 16384/440 – 2 = 35.2 = 023H |
| LD | (MELFH), 80H     | ; start to generate waveform     |

(Refer to Basic musical scale setting table)

| Scale | Frequency [Hz] | Register Value: N |
|-------|----------------|-------------------|
| С     | 264            | 03CH              |
| D     | 297            | 035H              |
| E     | 330            | 030H              |
| F     | 352            | 02DH              |
| G     | 396            | 027H              |
| А     | 440            | 023H              |
| В     | 495            | 01FH              |
| С     | 528            | 01DH              |

#### (2) Alarm generator

The alarm function generates 8 kinds of alarm waveform having a modulation frequency 4096 Hz determined by the low-speed clock (32.768 kHz). And this waveform is reversible by setting a value to a register.

By connecting a loud speaker outside, alarm tone can sound easily.

5 kinds of fixed cycle (1 Hz, 2 Hz, 64 Hz, 512 Hz and 8192 Hz) interrupts are generated by the free-run counter, which is used for alarm generator.

### (Operation)

At first, MELALMC<MELALM> have to be set as 0 in orders to select alarm waveform as output waveform from MLDALM. Then 10 be set on MELALMC<FC1:0> register, and clear internal counter. Finally alarm pattern has to be set on 8-bit register of ALM. If it is inverted output-data, set <ALMINV> as invert.

Followings are example program, setting value of alarm pattern and waveform of each setting value.

| Setting Value for<br>ALM Register | Alarm Waveform |  |  |
|-----------------------------------|----------------|--|--|
| 00H                               | 0 fixed        |  |  |
| 01H                               | AL1 pattern    |  |  |
| 02H                               | AL2 pattern    |  |  |
| 04H                               | AL3 pattern    |  |  |
| 08H                               | AL4 pattern    |  |  |
| 10H                               | AL5 pattern    |  |  |
| 20H                               | AL6pattern     |  |  |
| 40H                               | AL7 pattern    |  |  |
| 80H                               | AL8 pattern    |  |  |
| Other                             | Undefined      |  |  |
|                                   | (do not set)   |  |  |

(Setting value of alarm pattern)

(Example program)

In case of outputting AL2 pattern (31.25 ms/8 times/1 s)

| LD | (MELALMC), COH | ; set output alarm waveform |
|----|----------------|-----------------------------|
|    |                | ; free-run counter start    |
| LD | (ALM), 02H     | ; set AL2 pattern, start    |
|    |                |                             |



### Example: Waveform of alarm pattern for each setting value: Not invert

# 4. Electrical Characteristics

## 4.1 Maximum Ratings

| Parameter                               | Symbol  | Rating            | Unit |  |
|-----------------------------------------|---------|-------------------|------|--|
| Power supply voltage                    | Vcc     | -0.5 to 4.0       | V    |  |
| Input voltage                           | VIN     | -0.5 to Vcc + 0.5 | v    |  |
| Output current                          | IOL     | 2                 |      |  |
| Output current                          | IOH     | -2                | 0    |  |
| Output current (total)                  | ΣΙΟL    | 80                | mA   |  |
| Output current (total)                  | ΣΙΟΗ    | -80               |      |  |
| Power dissipation (Ta = $85^{\circ}$ C) | PD      | 600               | mW   |  |
| Soldering temperature (10 s)            | TSOLDER | 260               |      |  |
| Storage temperature                     | TSTG    | -65 to 150        | °C   |  |
| Operating temperature                   | TOPR    | -40 to 85         |      |  |

Note: The 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 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 maximum rating value will ever be exceeded.

| Parameter            |                              | Symbol | Condition                       |                 | Min       | Typ.<br>(Note) | Max       | Unit |
|----------------------|------------------------------|--------|---------------------------------|-----------------|-----------|----------------|-----------|------|
| Power supply voltage |                              |        | fc = 2 to 33 MHz                | fs = 30 to      | 2.7       |                |           |      |
| `                    | C = DVCC)<br>S = DVSS = 0 V) | VCC    | fc = 2 to 10 MHz                | 34 kHz          | 1.8       |                | 3.6       | V    |
|                      |                              |        | $Vcc \ge 2.7V$                  |                 |           |                | 0.6       |      |
|                      | D0 to D15                    | VIL    | Vcc < 2.7V                      |                 |           |                | 0.2 Vcc   |      |
| Φ                    | P52 to PD7                   | VIL1   | $Vcc \ge 2.7V$                  |                 |           |                | 0.3 Vcc   |      |
| nput low voltage     | (Except PB3)                 | VIL1   | Vcc < 2.7V                      |                 |           |                | 0.2 Vcc   |      |
| 0 ^ 0                | RESET, NMI, PB3 (INT0)       | VIL2   | $Vcc \ge 2.7V$                  |                 | -0.3      |                | 0.25 Vcc  |      |
| t lov                |                              | VILZ   | Vcc < 2.7V                      |                 | -0.3      |                | 0.15 Vcc  |      |
| Iput                 | AM0 to AM1                   | VIL3   | $Vcc \ge 2.7V$                  |                 |           |                | 0.3       |      |
| -                    |                              | VIL3   | Vcc < 2.7V                      |                 |           |                | 0.3       |      |
|                      | X1                           | VIL4   | Vcc ≥ 2.7V           Vcc < 2.7V |                 |           |                | 0.2 Vcc   |      |
|                      | ~1                           | VIL4   |                                 |                 |           |                | 0.1 Vcc   |      |
|                      |                              |        | $3.6V \ge Vcc > 3.3V$           |                 | 2.4       |                |           | V    |
|                      | D0 to D15                    |        | $3.3V \geq Vcc \geq 2.7V$       |                 | 2.0       |                |           |      |
| _                    |                              |        | Vcc < 2.7V                      |                 | 0.7 Vcc   |                |           |      |
| age                  | P52 to PD7                   | VIH1   | $Vcc \ge 2.7V$                  |                 | 0.7 Vcc   |                |           |      |
| volt                 | (Except PB3)                 | VILLI  | Vcc < 2.7V                      |                 | 0.8 Vcc   |                |           |      |
| igh                  | RESET, NMI, PB3 (INT0)       | VIH2   | $Vcc \ge 2.7V$                  |                 | 0.75 Vcc  |                | Vcc + 0.3 |      |
| Input high voltage   |                              | VINZ   | Vcc < 2.7V                      |                 | 0.85 Vcc  |                |           |      |
| du                   | AM0 to AM1                   | VIH3   | $Vcc \ge 2.7V$                  |                 | Vcc - 0.3 |                |           |      |
|                      |                              | VILIS  | Vcc < 2.7V                      |                 | Vcc - 0.3 |                |           |      |
|                      | X1                           | VIH4   | $Vcc \ge 2.7V$                  |                 | 0.8 Vcc   |                |           |      |
|                      | X1 VIH4 Vcc                  |        | Vcc < 2.7V                      | Vcc < 2.7V      |           |                |           |      |
| Outou                | t low voltage                | VOL    | IOL = 1.6 mA                    | $Vcc \geq 2.7V$ |           |                | 0.45      |      |
| Outpu                | t low voltage                | VOL    | IOL = 0.4 mA                    | Vcc < 2.7V      |           |                | 0.15 Vcc  | v    |
| Outou                | t high voltage               | VOH    | $IOH = -400 \ \mu A$            | $Vcc \geq 2.7V$ | Vcc - 0.3 |                |           | v    |
| Suipu                | t mgn voltage                | VOIT   | IOH = -200 μA                   | Vcc < 2.7V      | 0.8 Vcc   |                |           |      |

## 4.2 DC Characteristics (1/2)

Note: Typical values are for when  $Ta = 25^{\circ}C$  and Vcc = 3.0 V uncles otherwise noted.

# 4.2 DC Characteristics (2/2)

| Parameter                                    | Symbol | Condition                                                       | Min | Typ.<br>(Note1) | Max  | Unit |
|----------------------------------------------|--------|-----------------------------------------------------------------|-----|-----------------|------|------|
| Input leakage current                        | ILI    | $0.0 \le VIN \le Vcc$                                           |     | 0.02            | ±5   |      |
| Output leakage current                       | ILO    | $0.2 \leq VIN \leq Vcc - 0.2$                                   |     | 0.05            | ±10  | μA   |
| Power down voltage<br>(at STOP, RAM back up) | VSTOP  | VIL2 = 0.2 Vcc,<br>VIH2 = 0.8 Vcc                               | 1.8 |                 | 3.6  | V    |
| RESET pull-up resistor                       | RRST   | $3.6 \text{ V} \ge \text{Vcc} \ge 2.7 \text{ V}$                | 80  |                 | 400  | L.O. |
| RESET pull-up resistor                       | RRSI   | $Vcc = 2 V \pm 10\%$                                            | 200 |                 | 1000 | kΩ   |
| Pin capacitance                              | CIO    | fc = 1 MHz                                                      |     |                 | 10   | pF   |
| Schmitt width RESET, NMI,                    |        | $Vcc \ge 2.7 V$                                                 | 0.4 | 0.9             |      | V    |
| INT0                                         | VTH    | Vcc < 2.7 V                                                     | 0.3 | 0.7             |      | V    |
|                                              |        | $3.6 \text{ V} \geq \text{Vcc} \geq 2.7 \text{ V}$              | 80  |                 | 400  | L.O. |
| Programmable pull-up resistor                | RKH    | $Vcc = 2 V \pm 10\%$                                            | 200 |                 | 1000 | kΩ   |
| NORMAL (Note 2)                              |        |                                                                 |     | 14.0            | 20.0 |      |
| IDLE2                                        |        | $3.6 \text{ V} \ge \text{Vcc} \ge 2.7 \text{ V}$<br>fc = 33 MHz |     | 4.0             | 6.1  |      |
| IDLE1                                        |        | IC = 33 MHZ                                                     |     | 1.2             | 2.2  |      |
| NORMAL (Note 2)                              |        | $Vcc = 2 V \pm 10\%$                                            |     | 2.6             | 3.0  | mA   |
| IDLE2                                        |        | fc = 10 MHz                                                     |     | 0.7             | 1.2  |      |
| IDLE1                                        |        | (Typ.: Vcc = 2.0 V)                                             |     | 0.2             | 0.4  |      |
| SLOW (Note 2)                                | Icc    |                                                                 |     | 17.5            | 30.5 |      |
| IDLE2                                        |        | $3.6 \text{ V} \ge \text{Vcc} \ge 2.7 \text{ V}$                |     | 7.0             | 13.5 |      |
| IDLE1                                        |        | fs = 32.768 kHz                                                 |     | 5.0             | 10.0 |      |
| SLOW (Note 2)                                |        | $Vcc = 2 V \pm 10\%$                                            |     | 10.5            | 13.0 | μA   |
| IDLE2                                        | ]      | fs = 32.768 kHz                                                 |     | 4.5             | 6.5  |      |
| IDLE1                                        | ]      | (Typ.: Vcc = 2.0 V)                                             |     | 3.0             | 4.5  |      |
| STOP                                         | ]      | $3.6 \text{ V} \ge \text{Vcc} \ge 1.8 \text{ V}$                |     | 0.2             | 15   |      |

Note 1: Typical values are for when  $Ta = 25^{\circ}C$  and Vcc = 3.0 V unless otherwise noted.

Note 2: Icc measurement conditions (NORMAL, SLOW):

All functions are operational; output pins are open and input pins are fixed. Data and address bus CL = 30 pF loaded.

# 4.3 AC Characteristics

(1)  $Vcc = 3.0 V \pm 10\%$ 

| No.  | Parameter                                                                                                                                                                     | Symbol            | Vari      | able      | f <sub>FPH</sub> = 3 | 33 MHz | Unit |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------|-----------|----------------------|--------|------|
| 110. | T drameter                                                                                                                                                                    | Cymbol            | Min       | Max       | Min                  | Max    | Onit |
| 1    | f <sub>FPH</sub> period ( = x)                                                                                                                                                | t <sub>FPH</sub>  | 30.3      | 31250     | 30.3                 |        | ns   |
| 2    | A0 to A23 valid $\rightarrow \overline{\text{RD}} / \overline{\text{WR}}$ fall                                                                                                | t <sub>AC</sub>   | x – 23    |           | 7                    |        | ns   |
| 3    | $\overline{\text{RD}}$ rise $\rightarrow$ A0 to A23 hold                                                                                                                      | t <sub>CAR</sub>  | 0.5x –13  |           | 2                    |        | ns   |
| 4    | $\overline{\text{WR}}$ rise $\rightarrow$ A0 to A23 hold                                                                                                                      | t <sub>CAW</sub>  | x – 13    |           | 17                   |        | ns   |
| 5    | A0 to A23 valid $\rightarrow$ D0 to D15 input                                                                                                                                 | t <sub>AD</sub>   |           | 3.5x – 24 |                      | 82     | ns   |
| 6    | $\overline{\text{RD}}$ fall $\rightarrow$ D0 to D15 input                                                                                                                     | t <sub>RD</sub>   |           | 2.5x – 24 |                      | 51     | ns   |
| 7    | RD low width                                                                                                                                                                  | t <sub>RR</sub>   | 2.5x – 15 |           | 60                   |        | ns   |
| 8    | $\overline{\text{RD}}$ rise $\rightarrow$ D0 to A15 hold                                                                                                                      | t <sub>HR</sub>   | 0         |           | 0                    |        | ns   |
| 9    | WR low width                                                                                                                                                                  | tww               | 2.0x – 15 |           | 45                   |        | ns   |
| 10   | D0 to D15 valid $\rightarrow \overline{WR}$ rise                                                                                                                              | t <sub>DW</sub>   | 1.5x – 35 |           | 10                   |        | ns   |
| 11   | $\overline{\text{WR}}$ rise $\rightarrow$ D0 to D15 hold                                                                                                                      | t <sub>WD</sub>   | x – 25    |           | 5                    |        | ns   |
| 12   | A0 to A23 valid $\rightarrow \overline{\text{WAIT}}$ input $\begin{pmatrix} (1 + N) \text{ WAIT} \\ \text{mode} \end{pmatrix}$                                                | t <sub>AW</sub>   |           | 3.5x – 60 |                      | 46     | ns   |
| 13   | $\overline{\text{RD}} / \overline{\text{WR}} \text{ fall} \rightarrow \overline{\text{WAIT}} \text{ hold } \begin{pmatrix} (1 + N) \text{ WAIT} \\ \text{mode} \end{pmatrix}$ | t <sub>CW</sub>   | 2.5x + 0  |           | 76                   |        | ns   |
| 14   | A0 to A23 valid $\rightarrow$ Port input                                                                                                                                      | t <sub>APH</sub>  |           | 3.5x – 89 |                      | 17     | ns   |
| 15   | A0 to A23 valid $\rightarrow$ Port hold                                                                                                                                       | t <sub>APH2</sub> | 3.5x      |           | 106                  |        | ns   |
| 16   | A0 to A23 valid $\rightarrow$ Port valid                                                                                                                                      | t <sub>APO</sub>  |           | 3.5x + 60 |                      | 166    | ns   |

AC measuring conditions

- Output level: High = 0.7 Vcc, Low = 0.3 Vcc, CL = 50 pF
- Input level: High = 0.9 Vcc, Low = 0.1 Vcc
- Note: Symbol x in the above table means the period of clock  $f_{FPH}$ , it's half period of the system clock  $f_{SYS}$  for CPU core. The period of  $f_{FPH}$  depends on the clock gear setting or the selection of high/low oscillator frequency.

| No.  | Parameter                                                                                                                                                                                    | Symbol | Var       | iable      | 10  | MHz | Unit |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|------------|-----|-----|------|
| INU. | Falameter                                                                                                                                                                                    | Symbol | Min       | Max        | Min | Max | Onit |
| 1    | f <sub>FPH</sub> period (= x)                                                                                                                                                                | tFPH   | 100       | 31250      | 100 |     | ns   |
| 2    | A0 to A15 valid $\rightarrow \overline{RD} / \overline{WR}$ fall                                                                                                                             | tAC    | x – 46    |            | 54  |     | ns   |
| 3    | $\overline{\text{RD}}$ rise $\rightarrow$ A0 to A23 hold                                                                                                                                     | tCAR   | 0.5x - 30 |            | 20  |     | ns   |
| 4    | $\overline{\text{WR}}$ rise $\rightarrow$ A0 to A23 hold                                                                                                                                     | tCAW   | x – 26    |            | 74  |     | ns   |
| 5    | A0 to A23 valid $\rightarrow \overline{RD} / \overline{WR}$ fall                                                                                                                             | tAD    |           | 3.5x – 48  |     | 302 | ns   |
| 6    | $\overline{RD}$ fall $\rightarrow$ D0 to D15 input                                                                                                                                           | tRD    |           | 2.5x - 48  |     | 202 | ns   |
| 7    | RD low width                                                                                                                                                                                 | tRR    | 2.5x - 30 |            | 220 |     | ns   |
| 8    | $\overline{\text{RD}}$ rise $\rightarrow$ D0 to D15 hold                                                                                                                                     | tHR    | 0         |            | 0   |     | ns   |
| 9    | WR low width                                                                                                                                                                                 | tWW    | 2.0x - 30 |            | 170 |     | ns   |
| 10   | D0 to D15 valid $\rightarrow \overline{WR}$ rise                                                                                                                                             | tDW    | 1.5x – 70 |            | 80  |     | ns   |
| 11   | $\overline{WR}$ rise $\rightarrow$ D0 to D15 Hold                                                                                                                                            | tWD    | x – 50    |            | 50  |     | ns   |
| 12   | A0 to A23 valid $\rightarrow \overline{\text{WAIT}}$ input $\begin{pmatrix} (1 + N) \text{ WAIT} \\ \text{mode} \end{pmatrix}$                                                               | tAW    |           | 3.5x – 120 |     | 230 | ns   |
| 13   | $\overline{\text{RD}} / \overline{\text{WR}} \text{ fall} \rightarrow \overline{\text{WAIT}} \text{ hold } \left[ \begin{pmatrix} (1 + N) \text{ WAIT} \\ \text{mode} \end{pmatrix} \right]$ | tCW    | 2.5x + 0  |            | 250 |     | ns   |
| 14   | A0 to A23 valid $\rightarrow$ Port input                                                                                                                                                     | tAPH   |           | 3.5x – 50  |     | 300 | ns   |
| 15   | A0 to A23 valid $\rightarrow$ Port hold                                                                                                                                                      | tAPH2  | 3.5x      |            | 350 |     | ns   |
| 16   | A0 to A23 valid $\rightarrow$ Port valid                                                                                                                                                     | tAPO   |           | 3.5x + 60  |     | 410 | ns   |

(2)  $Vcc = 2.0 V \pm 10\%$ 

AC measuring conditions

- Output level: High = 0.7 V, Low = 0.3 V, CL = 50 pF
- Input level: High = 0.9 V, Low = 0.1 V
- Note: Symbol x in the above table means the period of clock f<sub>FPH</sub>, it's half period of the system clock f<sub>SYS</sub> for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high/low oscillator frequency.

(3) Read cycle



Note: Since the CPU accesses the internal area to read data from a port, the control signals of external pins such as  $\overline{RD}$  and  $\overline{CS}$  are not enabled. Therefore, the above waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative.

(4) Write cycle



Note: Since the CPU accesses the internal area to write data to a port, the control signals of external pins such as  $\overline{WR}$  and  $\overline{CS}$  are not enabled. Therefore, the above waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative.

# 4.4 AD Conversion Characteristics

|                                            |                       |                                 |                   | A    | Vcc = Vcc, AV     | ss = Vss |
|--------------------------------------------|-----------------------|---------------------------------|-------------------|------|-------------------|----------|
| Parameter                                  | Symbol                | Condition                       | Min               | Тур. | Max               | Unit     |
| Analog reference voltage (+)               | VREFH                 | $3.6~V \geq V_{CC} \geq 2.7~V$  | $V_{CC} - 0.2 V$  | Vcc  | Vcc               |          |
|                                            |                       | $V_{CC} = 2 V \pm 10\%$         | V <sub>CC</sub>   | Vcc  | Vcc               |          |
| Analog reference voltage (-)               | VREFL                 | $3.6~V \geq V_{CC} \geq 2.7~V$  | V <sub>SS</sub>   | Vss  | Vss + 0.2 V       | V        |
| Analog reference voltage (-)               | VKEFL                 | $V_{CC} = 2 \text{ V} \pm 10\%$ | V <sub>SS</sub>   | Vss  | Vss               |          |
| Analog input voltage range                 | VAIN                  |                                 | V <sub>REFL</sub> |      | V <sub>REFH</sub> |          |
| Analog current for analog                  |                       | $3.6~V \geq V_{CC} \geq 2.7~V$  |                   | 0.94 | 1.35              |          |
| reference voltage<br><vrefon> = 1</vrefon> | IREF<br>(VREFL = 0 V) | $V_{CC}=2~V\pm10\%$             |                   | 0.65 | 0.90              | mA       |
| <vrefon> = 0</vrefon>                      |                       | $3.6~V \geq V_{CC} \geq 2.7~V$  |                   | 0.02 | 5.0               | μA       |
| Error                                      |                       | $3.6~V \geq V_{CC} \geq 2.7~V$  |                   | ±1.0 | ±4.0              |          |
| (Not including quantizing errors)          | _                     | $V_{CC} = 2 \text{ V} \pm 10\%$ |                   | ±1.0 | ±4.0              | LSB      |

Note 1:1 LSB = (VREFH - VREFL)/1024 [V]

Note 2: The operation above is guaranteed for  $f_{FPH} \geq 4~MHz.$ 

Note 3: The value for  $I_{CC}$  includes the current which flows through the AVCC pin.

# 4.5 Serial Channel Timing (I/O Internal Mode)

(1) SCLK input mode

| Paramete                                                 | r                                                        | Symbol           | Variable                       | ;                    | 10   | ИНz  | 27 N | ЛНz | Unit |
|----------------------------------------------------------|----------------------------------------------------------|------------------|--------------------------------|----------------------|------|------|------|-----|------|
| Faramete                                                 | 1                                                        | Symbol           | Min                            | Max                  | Min  | Max  | Min  | Max | Unit |
| SCLK period                                              |                                                          | tSCY             | 16X                            |                      | 1.6  |      | 0.59 |     | μs   |
| Output data                                              | $Vcc=3~V\pm10\%$                                         | toss             | t <sub>SCY</sub> /2 - 4X - 110 |                      | 290  |      | 38   |     | ns   |
| $\rightarrow$ SCLK rising/falling edge*                  | $Vcc = 2 \ V \pm 10\%$                                   |                  | t <sub>SCY</sub> /2 - 4X - 180 |                      | 220  |      | I    |     | ns   |
| SCLK rising/falling edge* $\rightarrow$ 0                | Output data hold                                         | t <sub>OHS</sub> | $t_{SCY}/2 + 2X + 0$           |                      | 1000 |      | 370  |     | ns   |
| SCLK rising/falling edge* $\rightarrow$ I                | nput data hold                                           | t <sub>HSR</sub> | 3X + 10                        |                      | 310  |      | 121  |     | ns   |
| SCLK rising/falling edge* $\rightarrow$ Valid data input |                                                          | <sup>t</sup> SRD |                                | t <sub>SCY</sub> – 0 |      | 1600 |      | 592 | ns   |
| Valid data input $\rightarrow$ SCLK risir                | Valid data input $\rightarrow$ SCLK rising/falling edge* |                  | 0                              |                      | 0    |      | 0    |     | ns   |

Note: SCLK rising/falling edge:

The rising edge is used in SCLK rising mode.

The falling edge is used in SCLK falling mode.

### (2) SCLK output mode

| Parameter                                                | Symbol           | Vari                     | 10 N                           | ИНz | 27 1 | MHz  | Unit |      |
|----------------------------------------------------------|------------------|--------------------------|--------------------------------|-----|------|------|------|------|
| Falameter                                                | Symbol           | Min                      | Max                            | Min | Max  | Min  | Max  | Unit |
| SCLK period                                              | tSCY             | 16X                      | 8192X                          | 1.6 | 819  | 0.59 | 303  | μS   |
| Output data $\rightarrow$ SCLK rising/falling edge*      | toss             | t <sub>SCY</sub> /2 - 40 |                                | 760 |      | 256  |      | ns   |
| SCLK rising/falling edge* $\rightarrow$ Output data hold | t <sub>OHS</sub> | t <sub>SCY</sub> /2 - 40 |                                | 760 |      | 256  |      | ns   |
| SCLK rising/falling edge* $\rightarrow$ Input data hold  | t <sub>HSR</sub> | 0                        |                                | 0   |      | 0    |      | ns   |
| SCLK rising/falling edge* $\rightarrow$ Valid data input | tSRD             |                          | t <sub>SCY</sub> – 1X –<br>180 |     | 1320 |      | 375  | ns   |
| Valid data input $\rightarrow$ SCLK rising/falling edge* | t <sub>RDS</sub> | 1X + 180                 |                                | 280 |      | 217  |      | ns   |



# 4.6 Event Counter (TA0IN)

| Parameter              | Symbol            | Varia    | able | 10 N | 10 MHz |     | ИНz | Unit |
|------------------------|-------------------|----------|------|------|--------|-----|-----|------|
| Falanletei             | Symbol            | Min      | Max  | Min  | Max    | Min | Max | Unit |
| Clock period           | t <sub>VCK</sub>  | 8X + 100 |      | 900  |        | 396 |     | ns   |
| Clock low level width  | t <sub>VCKL</sub> | 4X + 40  |      | 440  |        | 188 |     | ns   |
| Clock high level width | t <sub>VCKH</sub> | 4X + 40  |      | 440  |        | 188 |     | ns   |

# 4.7 Interrupt, Capture

(1)  $\overline{\text{NMI}}$ , INT0 to INT3 interrupts

| Parameter                           | Symbol             | Varia   | able | 10 N | ЛНz | 27 N | ИНz | Unit |
|-------------------------------------|--------------------|---------|------|------|-----|------|-----|------|
|                                     | Cymbol             | Min     | Max  | Min  | Max | Min  | Max | Onic |
| NMI , INT0 to INT3 low level width  | t <sub>INTAL</sub> | 4X + 40 |      | 440  |     | 188  |     | ns   |
| NMI , INT0 to INT3 high level width | t <sub>INTAH</sub> | 4X + 40 |      | 440  |     | 188  |     | ns   |

# 4.8 SCOUT Pin AC Characteristics

| Parameter                  | Symbol           | Varial    | ole | 4 N | lHz | 16 N | ИНz | Condition       | Unit |
|----------------------------|------------------|-----------|-----|-----|-----|------|-----|-----------------|------|
| Farameter                  | Symbol           | Min       | Max | Min | Max | Min  | Max | Condition       | Onit |
| Low level width            | taqu             | 0.5T – 10 |     | 90  |     | 27   |     | $Vcc \ge 2.7 V$ | 20   |
|                            | <sup>t</sup> SCH | 0.5T – 30 |     | 70  |     | -    |     | Vcc < 2.7 V     | ns   |
| 1 Patrick Lawrence and the |                  | 0.5T – 10 |     | 90  |     | 27   |     | $Vcc \ge 2.7 V$ |      |
| High level width           | tSCL             | 0.5T – 30 |     | 70  |     | -    |     | Vcc < 2.7 V     | ns   |

Note: T = Period of SCOUT

Measuring conditions

• Output level: High = 0.7 V, Low = 0.3 V, CL = 10 pF

## 4.9 Bus Request/Bus Acknowledge



| Symbol           | Parameter                      | Vari | able | f <sub>FPH</sub> = | 4 MHz | f <sub>FPH</sub> = <sup>-</sup> | 16 MHz | Unit |
|------------------|--------------------------------|------|------|--------------------|-------|---------------------------------|--------|------|
| Cynibol          |                                | Min  | Max  | Min                | Max   | Min                             | Max    | Örm  |
| t <sub>ABA</sub> | Output buffer off to BUSAK low | 0    | 80   | 0                  | 80    | 0                               | 80     | ns   |
| t <sub>BAA</sub> | BUSAK high to output buffer on | 0    | 80   | 0                  | 80    | 0                               | 80     | ns   |

Note 1: Even if the  $\overline{\text{BUSRQ}}$  signal goes low, the bus will not be released while the  $\overline{\text{WAIT}}$  signal is low. The bus will only be released when  $\overline{\text{BUSRQ}}$  goes low while  $\overline{\text{WAIT}}$  is high.

Note 2: This line shows only that the output buffer is in the off state.

It does not indicate that the signal level is fixed.

Just after the bus is released, the signal level set before the bus was released is maintained dynamically by the external capacitance. Therefore, to fix the signal level using an external resister during bus release, careful design is necessary, since fixing of the level is delayed. The internal programmable pull-up/pull-down resistor is switched between the active and non-active states by the internal signal.

## 4.10 Recommended Crystal Oscillation Circuit

 $\rm TMP91C824$  is evaluated by below oscillator vender. When selecting external parts, make use of this information.

- Note: Total loads value of oscillator is sum of external loads (C1 and C2) and floating loads of actual assemble board. There is a possibility of miss-operating using C1 and C2 value in below table. When designing board, it should design minimum length pattern around oscillator. And we recommend that oscillator evaluation try on your actual using board.
- (1) Connection example





High-frequency oscillator

Low-frequency oscillator

(2) TMP91C824 recommended ceramic oscillator: Murata Manufacturing Co., Ltd. (JAPAN)

|             | Oscillation        |                                      | Par        | ameter     | of Elem   | ents      | Running (               | Condition  |
|-------------|--------------------|--------------------------------------|------------|------------|-----------|-----------|-------------------------|------------|
| MCU         | Frequency<br>[MHz] | Item of Oscillator                   | C1<br>[pF] | C2<br>[pF] | Rf<br>[Ω] | Rd<br>[Ω] | Voltage of<br>Power [V] | Tc [°C]    |
|             | 2.00               | CSTLS2M00G56-B0                      | (47)       | (47)       | Open      | 0         |                         |            |
|             | 2.50               | CSTLS2M50G56-B0                      | (47)       | (47)       | Open      | 0         |                         |            |
| TMP91C824   | 10.00              | CSTS1000MG03<br>*CSTLS10M0G53-B0     | (15)       | (15)       | Open      | 0         | 1.8 to 2.2              | 40 to 195  |
| 11012910824 | 10.50              | CSA12.5MTZ093<br>*CSALA12M5T55093-B0 | 30         | 30         | Open      | 0         | 1.8 to 2.2              | -40 to +85 |
|             | 12.50              | CST12.0MTW093<br>*CSTLA12M5T55093-B0 | (30)       | (30)       | Open      | 0         |                         |            |

Circuit parameter recommended

|           | Oscillation        |                                  | Par        | ameter     | of Elem   | ents      | Running (               | Condition   |
|-----------|--------------------|----------------------------------|------------|------------|-----------|-----------|-------------------------|-------------|
| MCU       | Frequency<br>[MHz] | Item of Oscillator               | C1<br>[pF] | C2<br>[pF] | Rf<br>[Ω] | Rd<br>[Ω] | Voltage of<br>Power [V] | Tc [°C]     |
|           | 4.00               | CSTS0400MG06<br>*CSTLS4M00G56-B0 | (47)       | (47)       | Open      | 0         |                         |             |
|           | 6.750              | CSTS0675MG06<br>*CSTLS6M75G56-B0 | (47)       | (47)       | Open      | 0         |                         |             |
|           | 10.50              | CSA12.5MTZ<br>*CSALA12M5T55-B0   | 30         | 30         | Open      | 0         | 0.745.0.0               | 10 45 - 105 |
| TMP91C824 | 12.50              | CST12.0MTW<br>*CSTLA12M5T55-B0   | (30)       | (30)       | Open      | 0         | 2.7 to 3.6              | -40 to +85  |
|           | 20.00              | CSALS20M0X53-B0                  | 5          | 5          | Open      | 0         |                         |             |
|           | 20.00              | CSTLS20M0X51-B0                  | (5)        | (5)        | Open      | 0         |                         |             |
|           | 27.00 C            | CSALS27M0X51-B0                  | Open       | Open       | 10k       | 0         |                         |             |
|           | 32.00              | CSALA32M0X51-B0                  | 3          | 3          | Open      | 0         |                         |             |

NOTE: In CST \*\*\*type oscillator, Capacitance C1, C2 is built in

- \* After 2001/06,new products will be made, and the old products (Now in production) will not be made in Murata Manufacturing Co., Ltd. (JAPAN)
  - 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 URL: http://www.murata.co.jp/search/index.html

# 5. Table of SFRs

The SFRs (Special function registers) include the I/O ports and peripheral control registers allocated to the 4-Kbyte address space from 000FE0H to 000FFFH.

- (1) I/O port
- (2) I/O port control
- (3) Interrupt control
- (4) Chip select/wait control
- (5) Clock gear
- (6) DFM (Clock doubler)
- (7) 8-bit timer
- (8) UART/Serial channel
- (9) I<sup>2</sup>C bus/serial channel
- (10) AD converter
- (11) Watchdog timer
- (12) RTC (Real time clock)
- (13) Melody/alarm generator
- (14) MMU

#### Table layout

| Symbol | Name | Address | 7 | 6        | (        | 7/  |               | ; 1 | 1 | 0 |                           |
|--------|------|---------|---|----------|----------|-----|---------------|-----|---|---|---------------------------|
|        |      |         |   |          | []       | 7   | <u> </u>      |     |   |   | Bit symbol                |
|        |      |         |   |          | <u> </u> |     | $\rightarrow$ | ÷   | _ |   | → Read/Write              |
|        |      |         |   |          |          | 1   | '/            | +   |   |   | Initial value after reset |
|        |      |         |   | <u> </u> | <u> </u> | ' Z |               | 1   | - |   | → Remarks                 |

Note: Prohibit RMW in the table means that you cannot use RMW instructions on these register.

Example: When setting bit0 only of the register PxCR, the instruction SET 0, (PxCR) cannot be used. The LD (Transfer) instruction must be used to write all eight bits.

Read/Write

- R/W: Both read and write are possible.
- R: Only read is possible.
- W: Only write is possible.

W\*: Both read and write are possible (when this bit is read as 1).

Prohibit RMW: Read-modify-write instructions are prohibited. (The EX, ADD, ADC, BUS, SBC, INC, DEC, AND, OR, XOR, STCF, RES, SET, CHG, TSET, RLC, RRC, RL, RR, SLA, SRA, SLL, SRL, RLD and RRD instruction are read-modify-write instructions.)

R/W\*: Read-modify-write instructions are prohibited when controlling the pull-up resistor.

| [1], [2] Port |      |
|---------------|------|
| Address       | Name |
| 0000H         |      |
| 1H            | P1   |
| 2H            |      |
| 3H            |      |
| 4H            | P1CR |
| 5H            |      |
| 6H            | P2   |
| 7H            |      |
| 8H            |      |
| 9H            | P2FC |
| AH            | P5CR |
| BH            | P5FC |
| CH            |      |
| DH            | P5   |
| EH            |      |
| FH            |      |

| Address | Name |
|---------|------|
| 0070H   |      |
| 1H      |      |
| 2H      |      |
| 3H      |      |
| 4H      |      |
| 5H      |      |
| 6H      |      |
| 7H      |      |
| 8H      |      |
| 9H      |      |
| AH      |      |
| BH      |      |
| CH      |      |
| DH      | PZ   |
| EH      | PZCR |
| FH      | PZFC |

| [4] CS/WAIT |       |  |
|-------------|-------|--|
| Address     | Name  |  |
| 00C0H       | B0CS  |  |
| 1H          | B1CS  |  |
| 2H          | B2CS  |  |
| 3H          | B3CS  |  |
| 4H          |       |  |
| 5H          |       |  |
| 6H          |       |  |
| 7H          | BEXCS |  |
| 8H          | MSAR0 |  |
| 9H          | MAMR0 |  |
| AH          | MSAR1 |  |
| BH          | MAMR1 |  |
| CH          | MSAR2 |  |
| DH          | MAMR2 |  |
| EH          | MSAR3 |  |
| FH          | MAMR3 |  |

| Table 5.1 | Address | Map SFRs |
|-----------|---------|----------|
|-----------|---------|----------|

| Address | Name  |
|---------|-------|
| 0010H   |       |
| 1H      |       |
| 2H      | P6    |
| 3H      | P7    |
| 4H      |       |
| 5H      | P6FC  |
| 6H      | P7CR  |
| 7H      | P7FC  |
| 8H      | P8    |
| 9H      |       |
| AH      |       |
| BH      | P6FC2 |
| СН      | P7FC2 |
| DH      |       |
| EH      |       |
| FH      | P7ODE |

| [3] INTC |        |
|----------|--------|
| Address  | Name   |
| 0080H    | DMA0V  |
| 1H       | DMA1V  |
| 2H       | DMA2V  |
| ЗН       | DMA3V  |
| 4H       |        |
| 5H       |        |
| 6H       |        |
| 7H       |        |
| 8H       | INTCLR |
| 9H       | DMAR   |
| AH       | DMAB   |
| BH       |        |
| СН       | IIMC   |
| DH       |        |
| EH       |        |
| FH       |        |

| [5], [6] CGEAR, DFM |        |  |  |
|---------------------|--------|--|--|
| Address             | Name   |  |  |
| 00E0H               | SYSCR0 |  |  |
| 1H                  | SYSCR1 |  |  |
| 2H                  | SYSCR2 |  |  |
| 3H                  | EMCCR0 |  |  |
| 4H                  | EMCCR1 |  |  |
| 5H                  | EMCCR2 |  |  |
| 6H                  | EMCCR3 |  |  |
| 7H                  |        |  |  |
| 8H                  | DFMCR0 |  |  |
| 9H                  | DFMCR1 |  |  |
| AH                  |        |  |  |
| BH                  |        |  |  |
| СН                  |        |  |  |
| DH                  |        |  |  |
| EH                  |        |  |  |
| FH                  |        |  |  |

| Address | Name  |  |  |
|---------|-------|--|--|
| 0022H   |       |  |  |
| 1H      |       |  |  |
| 2H      | PB    |  |  |
| 3H      | PC    |  |  |
| 4H      | PBCR  |  |  |
| 5H      | PBFC  |  |  |
| 6H      | PCCR  |  |  |
| 7H      | PCFC  |  |  |
| 8H      | PCODE |  |  |
| 9H      | PD    |  |  |
| AH      | PDFC  |  |  |
| BH      |       |  |  |
| СН      |       |  |  |
| DH      |       |  |  |
| EH      |       |  |  |
| FH      |       |  |  |

| Address | Name      |
|---------|-----------|
| 0090H   | INTE0AD   |
| 1H      | INTE12    |
| 2H      | INTE3ALM4 |
| 3H      | INTEALM01 |
| 4H      | INTEALM23 |
| 5H      | INTETA01  |
| 6H      | INTETA23  |
| 7H      | INTERTC   |
| 8H      | INTES0    |
| 9H      | INTES1    |
| AH      | INTES2    |
| BH      | INTETC01  |
| СН      | INTETC23  |
| DH      | INTEP01   |
| EH      |           |
| FH      |           |

Note: Do not access to the unnamed addresses, e.g., addresses to which no register has been allocated.

### Table 5.2 Address Map SFRs

#### [7] TMRA

| Address | Name     |
|---------|----------|
| 0100H   | TA01RUN  |
| 1H      |          |
| 2H      | TAOREG   |
| 3H      | TA1REG   |
| 4H      | TA01MOD  |
| 5H      | TA01FFCR |
| 6H      |          |
| 7H      |          |
| 8H      | TA23RUN  |
| 9H      |          |
| AH      | TA2REG   |
| BH      | TA3REG   |
| СН      | TA23MOD  |
| DH      | TA3FFCR  |
| EH      |          |
| FH      |          |

#### [8] UART/SIO

| Address | Name    |
|---------|---------|
| 0200H   | SCOBUF  |
| 1H      | SC0CR   |
| 2H      | SC0MOD0 |
| 3H      | BR0CR   |
| 4H      | BR0ADD  |
| 5H      | SC0MOD1 |
| 6H      |         |
| 7H      | SIRCR   |
| 8H      | SC1BUF  |
| 9H      | SC1CR   |
| AH      | SC1MOD0 |
| BH      | BR1CR   |
| СН      | BR1ADD  |
| DH      | SC1MOD1 |
| EH      |         |
| FH      |         |

| [9] I <sup>2</sup> C bus/SIO |                |  |  |  |  |  |  |
|------------------------------|----------------|--|--|--|--|--|--|
| Address                      | Name           |  |  |  |  |  |  |
| 0240H                        | SBI0CR1        |  |  |  |  |  |  |
| 1H                           | SBI0DBR        |  |  |  |  |  |  |
| 2H                           | I2C0AR         |  |  |  |  |  |  |
| ЗН                           | SBI0CR2/SBI0SR |  |  |  |  |  |  |
| 4H                           | SBI0BR0        |  |  |  |  |  |  |
| 5H                           | SBI0BR1        |  |  |  |  |  |  |
| 6H                           |                |  |  |  |  |  |  |
| 7H                           |                |  |  |  |  |  |  |
| 8H                           |                |  |  |  |  |  |  |
| 9H                           |                |  |  |  |  |  |  |
| AH                           |                |  |  |  |  |  |  |
| BH                           |                |  |  |  |  |  |  |
| СН                           |                |  |  |  |  |  |  |
| DH                           |                |  |  |  |  |  |  |
| EH                           |                |  |  |  |  |  |  |
| FH                           |                |  |  |  |  |  |  |

| [10] 10-bit ADC |          |  |  |  |  |
|-----------------|----------|--|--|--|--|
| Address         | Name     |  |  |  |  |
| 02A0H           | ADREG04L |  |  |  |  |
| 1H              | ADREG04H |  |  |  |  |
| 2H              | ADREG15L |  |  |  |  |
| 3H              | ADREG15H |  |  |  |  |
| 4H              | ADREG26L |  |  |  |  |
| 5H              | ADREG26H |  |  |  |  |
| 6H              | ADREG37L |  |  |  |  |
| 7H              | ADREG37H |  |  |  |  |
| 8H              |          |  |  |  |  |
| 9H              |          |  |  |  |  |
| AH              |          |  |  |  |  |
| BH              |          |  |  |  |  |
| CH              |          |  |  |  |  |
| DH              |          |  |  |  |  |
| EH              |          |  |  |  |  |
| FH              |          |  |  |  |  |

| Address | Name   |
|---------|--------|
| 02B0H   | ADMOD0 |
| 1H      | ADMOD1 |
| 2H      |        |
| 3H      |        |
| 4H      |        |
| 5H      |        |
| 6H      |        |
| 7H      |        |
| 8H      |        |
| 9H      |        |
| AH      |        |
| BH      |        |
| СН      |        |
| DH      |        |
| EH      |        |
| FH      |        |
|         |        |

Note: Do not access to the unnamed addresses, e.g., addresses to which no register has been allocated.

| [11] WDT                                                                                       |                                  | [12] RTC           |
|------------------------------------------------------------------------------------------------|----------------------------------|--------------------|
| Address                                                                                        | Name                             | Addre              |
| 0300H                                                                                          | WDMOD                            | 032                |
| 1H                                                                                             | WDCR                             |                    |
| 2H                                                                                             |                                  |                    |
| 3H                                                                                             |                                  |                    |
| 4H                                                                                             |                                  |                    |
| 5H                                                                                             |                                  |                    |
| 6H                                                                                             |                                  |                    |
| 7H                                                                                             |                                  |                    |
| 8H                                                                                             |                                  |                    |
| 9H                                                                                             |                                  |                    |
| AH                                                                                             |                                  |                    |
| BH                                                                                             |                                  |                    |
| CH                                                                                             |                                  |                    |
| DH<br>EH                                                                                       |                                  |                    |
| FH                                                                                             |                                  |                    |
|                                                                                                |                                  |                    |
|                                                                                                |                                  |                    |
| [13] MLD                                                                                       | 1                                | [14] MMU           |
| [13] MLD<br>Address                                                                            | Name                             | [14] MMU<br>Addres |
|                                                                                                | ALM                              |                    |
| Address<br>0330H<br>1H                                                                         | ALM<br>MELALMC                   | Addres             |
| Address<br>0330H<br>1H<br>2H                                                                   | ALM<br>MELALMC<br>MELFL          | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H                                                             | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H                                                       | ALM<br>MELALMC<br>MELFL          | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H                                                 | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H                                           | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H                                     | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H                               | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H                         | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH                   | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH<br>BH             | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH<br>BH<br>CH       | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH<br>BH<br>CH<br>DH | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |
| Address<br>0330H<br>1H<br>2H<br>3H<br>4H<br>5H<br>6H<br>7H<br>8H<br>9H<br>AH<br>BH<br>CH       | ALM<br>MELALMC<br>MELFL<br>MELFH | Addres             |

| Table 5.3 | Address | Man   | SFRs |
|-----------|---------|-------|------|
|           | Addicoo | iviap | 0113 |

| ZIRIC    |        |
|----------|--------|
| Address  | Name   |
| 0320H    | SECR   |
| 1H       | MINR   |
| 2H       | HOURR  |
| 3H       | DAYR   |
| 4H       | DATER  |
| 5H       | MONTHR |
| 6H       | YEARR  |
| 7H       | PAGER  |
| 8H       | RESTR  |
| 9H       |        |
| AH       |        |
| BH       |        |
| CH       |        |
| DH       |        |
| EH       |        |
| FH       |        |
| 4] MMU   |        |
| A ddraaa |        |

| [14 | ] M | MU |
|-----|-----|----|
|     |     |    |

| Address | Name   |
|---------|--------|
| 0350H   | LOCAL0 |
| 1H      | LOCAL1 |
| 2H      | LOCAL2 |
| 3H      | LOCAL3 |
| 4H      |        |
| 5H      |        |
| 6H      |        |
| 7H      |        |
| 8H      |        |
| 9H      |        |
| AH      |        |
| BH      |        |
| СН      |        |
| DH      |        |
| EH      |        |
| FH      |        |

Note: Do not access to the unnamed addresses, e.g., addresses to which no register has been allocated.

# (1) I/O ports

| Symbol | Name    | Address | 7            | 6                             | 5              | 4              | 3              | 2                            | 1              | 0            |
|--------|---------|---------|--------------|-------------------------------|----------------|----------------|----------------|------------------------------|----------------|--------------|
|        |         |         | P17          | P16                           | P15            | P14            | P13            | P12                          | P11            | P10          |
| P1     | Port 1  | 01H     |              |                               |                | R              | /W             |                              |                |              |
|        |         |         |              | Data                          | from externa   | al port (Outpu | ut latch regis | ter cleared to               | o "0".)        |              |
|        |         |         | P27          | P26                           | P25            | P24            | P23            | P22                          | P21            | P20          |
| P2     | Port 2  | 06H     |              |                               |                | R              | /W             |                              |                |              |
|        |         |         | 1            | 1                             | 1              | 1              | 1              | 1                            | 1              | 1            |
|        |         |         |              | P56                           | P55            | P54            |                |                              |                |              |
|        |         |         |              |                               | R/W            |                |                |                              |                |              |
|        |         |         |              |                               | from externa   |                |                |                              |                |              |
| P5     | Port 5  | 0DH     |              |                               | ch register is |                |                |                              |                |              |
|        |         |         |              |                               | atch register) |                |                |                              |                |              |
|        |         |         |              | -                             | resistor OFF   |                |                |                              |                |              |
|        |         |         |              | 1 (Output la<br>: Pull-up re: | atch register) |                |                |                              |                |              |
|        |         |         | P67          | P66                           |                | P64            | Dec            | P62                          | P61            | Deo          |
| P6     | Port 6  | 12H     | P07          | P00                           | P65            |                | P63<br>/W      | P02                          | POI            | P60          |
| 10     | 1 OIT O | 1211    | 1            | 1                             | 1              | 1              | 1              | 0                            | 1              | 1            |
|        |         |         | -            | _                             | -              | _              | _              | P72                          | P71            | P70          |
|        |         |         | $\backslash$ | $\sim$                        | $\backslash$   | $\sim$         | $\sim$         | 172                          | R/W            | 170          |
|        |         |         |              |                               |                |                |                | Data                         | from externa   | l port       |
|        |         | 13H     |              |                               |                |                |                |                              | ch register is | -            |
| P7     | Port 7  |         | `            |                               | `              |                |                | 0 (Output lat                |                |              |
|        |         |         |              |                               |                |                |                | : Pull-up re                 |                |              |
|        |         |         |              |                               |                |                |                | 1 (Output lat                | tch register)  | -            |
|        |         |         |              |                               |                |                |                | : Pull-up re                 | sistor ON      |              |
|        |         |         | P87          | P86                           | P85            | P84            | P83            | P82                          | P81            | P80          |
| P8     | Port 8  | 18H     |              |                               |                | F              | 2              |                              |                |              |
|        |         |         |              |                               |                | Data from e    | xternal port   |                              |                |              |
|        |         |         |              | PB6                           | PB5            | PB4            | PB3            | PB2                          | PB1            | PB0          |
| PB     | Port B  | 22H     |              |                               |                |                | R/W            |                              |                |              |
|        |         |         |              |                               |                |                |                | h register is                |                |              |
|        |         |         |              |                               | PC5            | PC4            | PC3            | PC2                          | PC1            | PC0          |
| PC     | Port C  | 23H     |              |                               |                |                | R/             |                              |                | <i></i>      |
| ┣───┤  |         |         |              |                               |                | a from extern  | al port (Outp  | out latch regi               | ster is set to | "1".)        |
|        |         | 0011    | PD7          | PD6                           | PD5            |                |                |                              |                |              |
| PD     | Port D  | 29H     |              | R/W                           |                |                |                |                              |                | $\backslash$ |
| ┣───┤  |         |         | 1            | 1                             | 1              |                |                |                              |                |              |
|        |         |         |              | $\sim$                        |                | $\sim$         | PZ3            | PZ2                          |                | RDE          |
|        |         |         | >            |                               |                |                |                | W                            |                | R/W          |
|        |         |         |              |                               |                |                |                | external port<br>ch register |                | 1            |
| ΡZ     | Port Z  | 7DH     |              |                               |                |                |                | to "1".)                     |                | '            |
|        |         |         |              |                               |                |                | 0 (Output la   |                              |                |              |
|        |         |         |              |                               |                |                | : Pull-up re   |                              |                |              |
|        |         |         |              |                               |                |                | 1 (Output lat  |                              |                | _            |
|        |         |         |              |                               |                |                | : Pull-up re   | esistor ON                   |                |              |

|         |                    | t contro          |                              |                              |                         | 1                            |                   |                              |                  |                |  |
|---------|--------------------|-------------------|------------------------------|------------------------------|-------------------------|------------------------------|-------------------|------------------------------|------------------|----------------|--|
| Symbol  | Name               | Address           | 7                            | 6                            | 5                       | 4                            | 3                 | 2                            | 1                | 0              |  |
|         |                    | 04H               | P17C                         | P16C                         | P15C                    | P14C                         | P13C              | P12C                         | P11C             | P10C           |  |
| P1CR    | Port 1             | (Prohibit         |                              |                              | i                       | V                            | V                 | i                            | i                |                |  |
| TION    | control            | RMW)              | 0                            | 0                            | 0                       | 0                            | 0                 | 0                            | 0                | 0              |  |
|         |                    | )                 |                              |                              | ī                       | 0: Input                     | 1: Output         | ī                            | 1                | 1              |  |
|         |                    | 09H               | P27F                         | P26F                         | P25F                    | P24F                         | P23F              | P22F                         | P21F             | P20F           |  |
| P2FC    | Port 2             | (Prohibit         |                              |                              | i                       | V                            | V                 | i                            | i                | i              |  |
| 1210    | function           | RMW)              | 1                            | 1                            | 1                       | 1                            | 1                 | 1                            | 1                | 1              |  |
|         |                    | ,                 |                              |                              | 0: Port                 | 1: Addres                    | s bus (A23 te     | o A16)                       |                  | <u> </u>       |  |
|         |                    | 0AH               |                              | P56C                         | P55C                    | P54C                         |                   |                              |                  |                |  |
| P5CR    | Port 5             | (Prohibit         |                              |                              | W                       | i                            |                   |                              |                  |                |  |
|         | control            | RMW)              |                              | 0                            | 0                       | 0                            |                   |                              |                  |                |  |
|         |                    | ,                 |                              | 0: l                         | nput 1: Out             |                              |                   |                              |                  |                |  |
|         |                    | 0BH               |                              |                              | P55F                    | P54F                         |                   |                              |                  |                |  |
|         | Port 5             | 0011              |                              |                              | W                       | 1                            |                   |                              |                  |                |  |
| P5FC    | function           | (Prohibit         |                              |                              | 0                       | 0                            |                   |                              |                  |                |  |
|         |                    | RMW)              |                              |                              | 0: Port<br>1: BUSAK     | 0: Port<br>1: BUSRQ          |                   |                              |                  |                |  |
|         |                    | 4511              | -                            | _                            | P65F                    | P64F                         | P63F              | P62F                         | P61F             | P60F           |  |
|         | Dort C             | 15H               | W                            | W                            |                         |                              | V                 | W                            |                  |                |  |
| P6FC    | Port 6<br>function | (Prohibit<br>RMW) | 0                            | 0                            | 0                       | 0                            | 0                 | 0                            | 0                | 0              |  |
|         |                    |                   | Always writ                  | e 0                          | 0: Port                 | 0: Port                      | 0: Port           | 0: Port                      | 0: Port          | 0: Port        |  |
|         |                    |                   |                              |                              | 1: EA25                 | 1: EA24                      | 1: CS3            | 1: CS2                       | 1: CS1           | 1: CS0         |  |
|         |                    |                   | P67F2                        | P66F2                        | P65F2                   | P64F2                        | -                 | P62F2                        | -                | -              |  |
|         |                    | 1BH               |                              | V                            | V                       |                              | W                 | W                            | W                | W              |  |
| P6FC2   | Port 6             |                   | 0                            | 0                            | 0                       | 0                            | 0                 | 0                            | 0                | 0              |  |
|         | function 2         | (Prohibit<br>RMW) | 0: <p67f><br/>1: CS2E</p67f> | 0: <p66f><br/>1: CS2D</p66f> | 0: <p65f><br/>1:</p65f> | 0: <p64f><br/>1: CS2B</p64f> | Always<br>write 0 | 0: <p62f><br/>1: CS2A</p62f> | Always writ      | e 0            |  |
|         |                    |                   |                              | $\sim$                       | $\sim$                  |                              | $\sim$            | P72C                         | P71C             | P70C           |  |
| 0700    | Port 7             | 16H<br>(Drahihit  |                              |                              |                         |                              |                   |                              | W                |                |  |
| P7CR    | control            | (Prohibit         |                              |                              |                         |                              |                   | 0                            | 0                | 0              |  |
|         |                    | RMW)              |                              |                              |                         |                              |                   | 0: 1                         | nput 1: Out      | tput           |  |
|         |                    | 17H               |                              |                              |                         |                              |                   | P72F                         | P71F             | P70F           |  |
|         | Dort 7             |                   |                              |                              |                         |                              |                   |                              | W                |                |  |
| P7FC    | Port 7<br>function |                   |                              |                              |                         |                              |                   | 0                            | 0                | 0              |  |
|         |                    | (Prohibit         |                              |                              |                         |                              |                   | 0: Port                      | 0: Port          | 0: Port        |  |
|         |                    | RMW)              |                              |                              |                         |                              |                   | 1: SCL                       | 1: SDA/SO        | 1: SCK         |  |
|         |                    | 1011              |                              |                              |                         |                              |                   | _                            | P71F2            | P70F2          |  |
|         |                    | 1CH               |                              |                              |                         |                              |                   |                              | W                |                |  |
| P7FC2   | Port 7             |                   |                              |                              |                         |                              |                   | 0                            | 0                | 0              |  |
| 1 /1:02 | function 2         | (Prohibit         |                              |                              |                         |                              |                   | Always                       | 0: <p71f></p71f> | PIN SELECT     |  |
|         |                    | RMW)              |                              |                              |                         |                              |                   | write 0                      | 1: OPTTX0        | 0: RXD0 (PC1)  |  |
|         |                    | ,                 |                              |                              |                         |                              |                   |                              |                  | 1: PTRX0 (P70) |  |

(2) I/O port control (1/2)

(2) I/O port control (2/2)

| Symbol | Name     | Address           | 7            | 6               | 5            | 4          | 3          | 2                 | 1          | 0       |
|--------|----------|-------------------|--------------|-----------------|--------------|------------|------------|-------------------|------------|---------|
|        |          |                   | /            | /               | /            | /          | /          | ODEP72            | ODEP71     |         |
|        | Port 7   | 1FH               | /            | $\sim$          | $\sim$       | $\sim$     | $\sim$     | v                 |            | /       |
| P7ODE  | open     | (Drobibit         |              |                 |              |            | /          | 0                 | 0          |         |
|        | drain    | (Prohibit<br>RMW) |              |                 |              |            |            | 0: 3 states       |            |         |
|        |          |                   |              |                 |              |            |            | 1: Open dra       | ain        |         |
|        |          | 0.411             |              | PB6C            | PB5C         | PB4C       | PB3C       | PB2C              | PB1C       | PB0C    |
| PBCR   | Port B   | 24H<br>(Drahihit  | /            |                 |              |            | W          |                   |            |         |
| PBCK   | control  | (Prohibit<br>RMW) |              | 0               | 0            | 0          | 0          | 0                 | 0          | 0       |
|        |          | ((iviv))          |              |                 |              | 0: I       | nput 1: Ou | tput              |            |         |
|        |          | 2511              |              | PB6F            | PB5F         | PB4F       | PB3F       | PB2F              | PB1F       |         |
|        | Port B   | 25H               |              | W               | W            | W          | W          | W                 | W          |         |
| PBFC   | function | (Prohibit         |              | 0               | 0            | 0          | 0          | 0                 | 0          |         |
|        | ranoton  | RMW)              |              | 0: Port         | 0: Port      | 0: Port    | 0: Port    | 0: Port           | 0: Port    |         |
|        |          | ,                 |              | 1: INT3         | 1: INT2      | 1: INT1    | 1: INT0    | 1: TA3OUT         | 1: TA1OUT  |         |
|        |          | 26H               |              |                 | PC5C         | PC4C       | PC3C       | PC2C              | PC1C       | PC0C    |
| PCCR   | Port C   | 26H<br>(Prohibit  |              |                 |              |            |            | V                 |            |         |
|        | control  | RMW)              |              |                 | 0            | 0          | 0          | 0                 | 0          | 0       |
|        |          | ,                 |              |                 |              | < <u> </u> | 0: Input   | 1: Output         | < <u> </u> |         |
|        |          | 27H               |              |                 | PC5F         |            | PC3F       | PC2F              |            | PC0F    |
|        | Port C   | 2/11              |              |                 | W            |            | W          | W                 |            | W       |
| PCFC   | function |                   |              |                 | 0            |            | 0          | 0                 |            | 0       |
|        |          |                   |              |                 | 0: Port      |            | 0: Port    | 0: Port           |            | 0: Port |
|        |          | -                 | <            |                 | 1: SCLK1     | <          | 1: TXD1    | 1: SCLK0          | <          | 1: TXD0 |
|        |          | 28H               |              |                 |              |            | ODEPC3     |                   |            | ODEPC0  |
|        | Port C   |                   |              |                 |              |            | W          |                   |            | W       |
| PCODE  | open     |                   |              |                 |              |            | 0          |                   |            | 0       |
|        | drain    | (Prohibit         |              |                 |              |            | 0: CMOS    |                   |            | 0: CMOS |
|        |          | RMW)              |              |                 |              |            | 1: Open    |                   |            | 1: Open |
|        |          |                   | DD7E         | DDOE            | DDCE         |            | drain      |                   |            | drain   |
|        |          |                   | PD7F         | PD6F            | PD5F         |            |            |                   |            |         |
|        |          |                   | W            | W               | W            |            |            |                   |            |         |
|        |          | 2AH               | 0<br>0: Port | 0<br>0: Port    | 0<br>0: Port |            |            |                   |            |         |
| PDFC   | Port D   |                   | 1: MLDALM    | 1:              | 1: SCOUT     |            |            |                   |            |         |
| 1 01 0 | function | (Prohibit         |              | ALARM           | 1. 30001     |            |            |                   |            |         |
|        |          | RMW)              |              | @ <pd6>=1</pd6> |              |            |            |                   |            |         |
|        |          |                   |              | MLDALM          |              |            |            |                   |            |         |
|        |          |                   |              | @ <pd6>=0</pd6> |              |            |            |                   |            |         |
|        |          | 7EH               |              |                 |              |            | PZ3C       | PZ2C              |            |         |
|        | Port Z   |                   | $\sim$       | $\sim$          | $\sim$       | $\sim$     |            | V                 | $\sim$     | $\sim$  |
| PZCR   | control  | (Prohibit         | $\sim$       | $\sim$          | $\sim$       | $\sim$     | 0          | 0                 | $\sim$     | $\sim$  |
|        |          |                   |              | <u> </u>        |              |            |            |                   |            |         |
|        | control  | RMW)              |              |                 |              |            | 0: Input   |                   |            |         |
|        | control  |                   |              |                 |              |            |            | 1: Output<br>PZ2F |            |         |
|        |          |                   |              |                 |              |            | PZ3F       | PZ2F              |            |         |
| PZFC   | Port Z   | RMW)<br>7FH       |              |                 |              |            | PZ3F<br>V  | PZ2F<br>V         |            |         |
| PZFC   |          | RMW)              |              |                 |              |            | PZ3F       | PZ2F              |            |         |

### (3) Interrupt control (1/3)

| Symbol    | Name              | Address      | 7          | 6                         | 5             | 4                                                                                                              | 3         | 2      | 1             | 0      |
|-----------|-------------------|--------------|------------|---------------------------|---------------|----------------------------------------------------------------------------------------------------------------|-----------|--------|---------------|--------|
|           |                   |              | INTAD      |                           |               |                                                                                                                | INTO      |        |               |        |
|           | INT0              |              | IADC       | IADM2                     | IADM1         | IADM0                                                                                                          | I0C       | 10M2   | I0M1          | I0M0   |
| INTE0AD   | and               | 90H          | R          |                           | R/W           | •                                                                                                              | R         |        | R/W           |        |
|           | INTAD             |              | 0          | 0                         | 0             | 0                                                                                                              | 0         | 0      | 0             | 0      |
|           | enable            |              | 1: INTAD   |                           | nterrupt leve | el                                                                                                             | 1: INT0   | I      | nterrupt leve |        |
|           |                   |              |            |                           | T2            |                                                                                                                |           | IN     |               |        |
|           | INT1              |              | I2C        | I2M2                      | I2M1          | I2M0                                                                                                           | I1C       | I1M2   | I1M1          | I1M0   |
| INTE12    | and               | 91H          | R          |                           | R/W           | •                                                                                                              | R         |        | R/W           |        |
|           | INT2<br>enable    |              | 0          | 0                         | 0             | 0                                                                                                              | 0         | 0      | 0             | 0      |
|           | enable            |              | 1: INT2    |                           | nterrupt leve | el                                                                                                             | 1: INT1   |        | nterrupt leve |        |
|           |                   |              |            | INTA                      | ALM4          |                                                                                                                |           | IN     | Т3            |        |
|           | INT3              |              | IA4C       | IA4M2                     | IA4M1         | IA4M0                                                                                                          | I3C       | I3M2   | I3M1          | I3M0   |
| INTE3ALM4 | and               | 92H          | R          |                           | R/W           | •                                                                                                              | R         |        | R/W           |        |
|           | INTALM            |              | 0          | 0                         | 0             | 0                                                                                                              | 0         | 0      | 0             | 0      |
|           | 4 enable          |              | 1: INTALM4 | I                         | nterrupt leve | el                                                                                                             | 1: INT3   | I      | nterrupt leve |        |
|           |                   |              |            |                           | LM1           |                                                                                                                |           | INTA   | LM0           |        |
|           | INTALM            |              | IA1C       | IA1M2                     | IA1M1         | IA1M0                                                                                                          | IA0C      | IA0M2  | IA0M1         | IA0M0  |
| INTEALM01 | 0 and<br>INTALM   | 93H          | R          |                           | R/W           |                                                                                                                | R         |        | R/W           |        |
|           |                   |              | 0          | 0                         | 0             | 0                                                                                                              | 0         | 0      | 0             | 0      |
|           | 1 enable          |              | 1: INTALM1 |                           | nterrupt leve | el .                                                                                                           | 1:INTALM0 | I      | nterrupt leve |        |
|           |                   | 94H          | INTALM3    |                           |               |                                                                                                                | INTA      | LM2    |               |        |
|           | INTALM2           |              | IA3C       | IA3M2                     | IA3M1         | IA3M0                                                                                                          | IA2C      | IA2M2  | IA2M1         | IA2M0  |
| INTEALM23 | and               |              | R          |                           | R/W           |                                                                                                                | R         |        | R/W           |        |
|           | INTALM3<br>enable |              | 0          | 0                         | 0             | 0                                                                                                              | 0         | 0      | 0             | 0      |
|           | enable            |              | 1:INTALM3  | l                         | nterrupt leve | el de la companya de | 1:INTALM2 | l      | nterrupt leve |        |
|           |                   |              |            | INTTA1                    | (TMRA1)       |                                                                                                                |           | INTTA0 | (TMRA0)       |        |
|           | INTTA0            |              | ITA1C      | ITA1M2                    | ITA1M1        | ITA1M0                                                                                                         | ITA0C     | ITA0M2 | ITA0M1        | ITA0M0 |
| INTETA01  | and<br>INTTA1     | 95H          | R          |                           | R/W           | •                                                                                                              | R         |        | R/W           |        |
|           |                   | TTA1<br>able | 0          | 0                         | 0             | 0                                                                                                              | 0         | 0      | 0             | 0      |
|           | enable            |              | 1: INTTA1  | 1: INTTA1 Interrupt level |               |                                                                                                                | 1: INTTA0 |        | nterrupt leve |        |
|           |                   |              |            | INTTA3                    | (TMRA3)       |                                                                                                                |           | INTTA2 | (TMRA2)       |        |
|           | INTTA2            |              | ITA3C      | ITA3M2                    | ITA3M1        | ITA3M0                                                                                                         | ITA2C     | ITA2M2 | ITA2M1        | ITA2M0 |
| INTETA23  | and               | 96H          | R          |                           | R/W           |                                                                                                                | R         |        | R/W           |        |
|           | INTTA3            |              | 0          | 0                         | 0             | 0                                                                                                              | 0         | 0      | 0             | 0      |
|           | enable            |              | 1: INTTA3  |                           | nterrupt leve | el                                                                                                             | 1: INTTA2 |        | nterrupt leve |        |
|           |                   |              |            | -                         | _             |                                                                                                                |           | INTI   | RTC           |        |
|           |                   |              | _          | _                         | _             | _                                                                                                              | IRC       | IRM2   | IRM1          | IRM0   |
| INTERTC   | INTRTC            | 97H          | _          |                           | _             |                                                                                                                | R         |        | R/W           | _      |
|           | enable            |              | _          | _                         | _             | _                                                                                                              | 0         | 0      | 0             | 0      |
|           |                   |              |            | Always                    | write "0"     |                                                                                                                | 1: INTRTC |        | nterrupt leve |        |

|          | -               |         |                           |        |               |           |                           |               |               |        |
|----------|-----------------|---------|---------------------------|--------|---------------|-----------|---------------------------|---------------|---------------|--------|
| Symbol   | Name            | Address | 7                         | 6      | 5             | 4         | 3                         | 2             | 1             | 0      |
|          |                 |         |                           | INT    | TX0           |           |                           | INT           | RX0           |        |
|          | INTTX0          |         | ITX0C                     | ITX0M2 | ITX0M1        | ITX0M0    | IRX0C                     | IRX0M2        | IRX0M1        | IRX0M0 |
| INTES0   | and<br>INTTRX0  | 98H     | R                         |        | R/W           |           | R                         |               | R/W           |        |
|          | enable          |         | 0                         | 0      | 0             | 0         | 0                         | 0             | 0             | 0      |
|          | onabio          |         | 1: INTTX0                 |        | nterrupt leve | )         | 1: INTRX0 Interrupt level |               |               |        |
|          |                 |         |                           | INT    | TX1           |           |                           | INT           | RX1           |        |
|          | INTTX1<br>and   |         | ITX1C                     | ITX1M2 | ITX1M1        | ITX1M0    | IRX1C                     | IRX1M2        | IRX1M1        | IRX1M0 |
| INTES1   | INTTRX1         | 99H     | R                         |        | R/W           |           | R                         |               | R/W           |        |
|          | enable          |         | 0                         | 0      | 0             | 0         | 0                         | 0             | 0             | 0      |
|          | onabio          |         | 1: INTTX1 Interrupt level |        |               | 1: INTRX1 | I                         | nterrupt leve | el            |        |
|          |                 |         |                           |        | -             |           |                           | INT           | SBI           |        |
|          | INTESBI         | 9AH     | _                         | -      | _             | _         | ISBIC                     | ISBIM2        | ISBIM1        | ISBIM0 |
| INTES2   | enable          |         | _                         |        |               |           | R                         |               | R/W           |        |
|          | Chabic          |         | -                         | -      | -             | -         | 0                         | 0             | 0             | 0      |
|          |                 |         |                           | Always | write "0"     |           | 1: INTSBI                 | I             | nterrupt leve | el     |
|          | INTTC0          |         |                           | INT    | TC1           |           | INTTCO                    |               |               |        |
| INTETC01 | and             | 9BH     | ITC1C                     | ITC1M2 | ITC1M1        | ITC1M0    | ITC0C                     | ITC0M2        | ITC0M1        | ITC0M0 |
|          | INTTC1          | 3011    | R                         |        | R/W           |           | R                         |               | R/W           |        |
|          | enable          |         | 0                         | 0      | 0             | 0         | 0                         | 0             | 0             | 0      |
|          | INTTC2          |         |                           | INT    | ТСЗ           |           |                           | INT           | TC2           |        |
| INTETC23 | and             | 9CH     | ITC3C                     | ITC3M2 | ITC3M1        | ITC3M0    | ITC2C                     | ITC2M2        | ITC2M1        | ITC2M0 |
| 11121020 | INTTC3          | 0011    | R                         |        | R/W           |           | R                         |               | R/W           |        |
|          | enable<br>INTP0 | 0       | 0                         | 0      | 0             | 0         | 0                         | 0             | 0             |        |
|          |                 |         |                           | IN     | [P1           |           |                           | INT           | FP0           |        |
| INTEP01  | and             | ٩DH     | IP1C                      | IP1M2  | IP1M1         | IP1M0     | IP0C                      | IP0M2         | IP0M1         | IP0M0  |
|          | INTP1           | 9DH     | R                         |        | R/W           |           | R                         |               | R/W           |        |
|          | enable          |         | 0                         | 0      | 0             | 0         | 0                         | 0             | 0             | 0      |

## (3) Interrupt control (2/3)

| Symbol  | Name               | Address           | 7       | 6       | 5             | 4               | 3             | 2             | 1             | 0            |
|---------|--------------------|-------------------|---------|---------|---------------|-----------------|---------------|---------------|---------------|--------------|
|         |                    |                   |         |         | DMA0V5        | DMA0V4          | DMA0V3        | DMA0V2        | DMA0V1        | DMA0V0       |
| DMA0V   | DMA 0<br>request   | 80H               |         |         |               |                 | . R/          | <u>/</u> W    |               |              |
| DIVIAUV | vector             | 0011              |         |         | 0             | 0               | 0             | 0             | 0             | 0            |
|         | VCCIO              |                   |         |         |               |                 | DMA0 st       | art vector    |               |              |
|         | DMA 1              |                   |         |         | DMA1V5        | DMA1V4          | DMA1V3        | DMA1V2        | DMA1V1        | DMA1V0       |
| DMA1V   | request            | 81H               |         |         |               |                 | R             | Ŵ             |               |              |
| DIVIATV | vector             | 0111              |         |         | 0             | 0               | 0             | 0             | 0             | 0            |
|         | VCCIO              |                   |         |         |               |                 | DMA1 st       | art vector    |               |              |
|         |                    |                   |         |         | DMA2V5        | DMA2V4          | DMA2V3        | DMA2V2        | DMA2V1        | DMA2V0       |
| DMA2V   | DMA 2<br>request   | 82H               |         |         |               |                 | R             | Ŵ             |               |              |
| DIVIAZV | vector             | 0211              |         |         | 0             | 0               | 0             | 0             | 0             | 0            |
|         | VCCIO              |                   |         |         |               |                 | DMA2 st       | art vector    |               |              |
|         |                    |                   | /       | /       | DMA3V5        | DMA3V4          | DMA3V3        | DMA3V2        | DMA3V1        | DMA3V0       |
| DMA3V   | DMA 3              | 83H               |         |         |               |                 | . R/          | <u>/</u> W    |               |              |
| DIVIASV | request<br>vector  | 030               |         |         | 0             | 0               | 0             | 0             | 0             | 0            |
|         | VECIOI             |                   |         |         |               |                 | DMA3 st       | art vector    |               |              |
|         |                    | 0011              | /       | /       | CLRV5         | CLRV4           | CLRV3         | CLRV2         | CLRV1         | CLRV0        |
| INTCLR  | Interrupt<br>clear | 88H<br>(Prohibit  |         |         |               |                 |               | V             |               |              |
| INTOLK  | control            | RMW)              |         |         | 0             | 0               | 0             | 0             | 0             | 0            |
|         | control            | (((iviv))         |         |         | Clea          | ars interrupt i | request flag  | by writing to | DMA start v   | ector        |
|         | DMA                | 89H               |         |         |               |                 | DMAR3         | DMAR2         | DMAR1         | DMAR0        |
| DMAR    | software           | (Prohibit         |         |         |               |                 | R/W           | R/W           | R/W           | R/W          |
| DIVIAR  | request            | (PTOTIDIC<br>RMW) |         |         |               |                 | 0             | 0             | 0             | 0            |
|         | register           | ((((V)))          |         |         |               |                 | 1             | : DMA reque   | est in softwa | re           |
|         | DMA                |                   | /       | /       |               |                 | DMAB3         | DMAB2         | DMAB1         | DMAB0        |
| DMAB    | burst              | 8AH               | /       | /       |               |                 | R/W           | R/W           | R/W           | R/W          |
| DIVIAD  | request            | одп               |         |         |               |                 | 0             | 0             | 0             | 0            |
|         | register           |                   |         |         |               |                 | 1:            | DMA reques    | st on burst m | ode          |
|         |                    |                   | -       | -       | <b>I3EDGE</b> | I2EDGE          | <b>I1EDGE</b> | <b>I0EDGE</b> | IOLE          | NMIREE       |
|         |                    |                   | W       | W       | W             | W               | W             | W             | W             | W            |
|         | Interrupt          | 8CH               | 0       | 0       | 0             | 0               | 0             | 0             | 0             | 0            |
| IIMC    | input              |                   | Always  | Always  | INT3 edge     | INT2 edge       | INT1 edge     | INT0 edge     | INT0          | 1: Operation |
| mile    | mode               | (Prohibit         | write 0 | write 0 | 0: Rising     | 0: Rising       | 0: Rising     | 0: Rising     | 0: Edge       | even on      |
|         | control            | RMW)              |         |         | 1: Falling    | 1: Falling      | 1: Falling    | 1: Falling    | 1: Level      | NMI          |
|         |                    |                   |         |         |               |                 |               |               |               | rising       |
|         |                    |                   |         |         |               |                 |               |               |               | edge         |

### (3) Interrupt control (3/3)

(4) Chip select/wait control (1/2)

| Symbol | Name                | Address           | 7          | 6       | 5                     | 4             | 3                 | 2           | 1             | 0        |
|--------|---------------------|-------------------|------------|---------|-----------------------|---------------|-------------------|-------------|---------------|----------|
| - ,    |                     |                   | B0E        |         | B0OM1                 | B0OM0         | BOBUS             | B0W2        | B0W1          | B0W0     |
|        |                     | СОН               | W          |         | W                     | W             | <u>вовоз</u><br>W | W           | W             | W        |
|        | Block 0             | COLL              | 0          |         | 0                     | 0             | 0                 | 0           | 0             | 0        |
| BOCS   | CS/WAIT             |                   | 0: Disable |         | 00: ROM/S             | -             | Data bus          | 000: 2 wait |               | Reserved |
|        | control             | (Prohibit         | 1: Enable  |         | 00: ונסווייט<br>01: ר |               | width             | 000: 2 wait |               | 3 waits  |
|        | register            | RMW)              | I. Enable  |         |                       | erved         | 0: 16 bits        |             | l) waits 110: |          |
|        |                     |                   |            |         | 11: J                 |               | 1:8 bits          | 011: 0 wait |               | 8 waits  |
|        |                     |                   | B1E        | /       | B1OM1                 | B1OM0         | B1BUS             | B1W2        | B1W1          | B1W0     |
|        |                     | C1H               | W          |         | W                     | W             | W                 | W           | W             | W        |
|        | Block 1             |                   | 0          |         | 0                     | 0             | 0                 | 0           | 0             | 0        |
| B1CS   | CS/WAIT             |                   | 0: Disable |         | 00: ROM/S             | RAM           | Data bus          | 000: 2 wait | s 100:        | Reserved |
|        | control<br>register | (Prohibit         | 1: Enable  |         | ן :01                 |               | width             | 001: 1 wait | 101:          | 3 waits  |
|        | register            | (FIOHIDIC<br>RMW) |            |         | 10: } Res             | erved         | 0: 16 bits        | 010: (1 + N | I) waits 110: | 4 waits  |
|        |                     | (((iviv))         |            |         | 11: J                 |               | 1:8 bits          | 011: 0 wait | s 111:        | 8 waits  |
|        |                     | 0011              | B2E        | B2M     | B2OM1                 | B2OM0         | B2BUS             | B2W2        | B2W1          | B2W0     |
|        | Block 2             | C2H               | W          | W       | W                     | W             | W                 | W           | W             | W        |
|        | CS/WAIT             |                   | 1          | 0       | 0                     | 0             | 0                 | 0           | 0             | 0        |
| B2CS   | control             |                   | 0: Disable | 0: 16 M | 00: ROM/S             | RAM           | Data bus          | 000: 2 wait | s 100:        | Reserved |
|        | register            | (Prohibit         | 1: Enable  | area    | ן :01                 |               | width             | 001: 1 wait |               | 3 waits  |
|        | - 0                 | RMW)              |            | 1: Area |                       | erved         | 0: 16 bits        |             | I) waits 110: |          |
|        |                     | ,                 |            | set     | 11: J                 |               | 1: 8 bits         | 011: 0 wait | s 111:        | 8 waits  |
|        |                     | СЗН               | B3E        |         | B3OM1                 | B3OM0         | B3BUS             | B3W2        | B3W1          | B3W0     |
|        | Block 3             | 0011              | W          |         | W                     | W             | W                 | W           | W             | W        |
|        | CS/WAIT             |                   | 0          |         | 0                     | 0             | 0                 | 0           | 0             | 0        |
| B3CS   | control             |                   | 0: Disable |         | 00: ROM/S             | RAM           | Data bus          | 000: 2 wait |               | Reserved |
|        | register            | (Prohibit         | 1: Enable  |         | 01:                   |               | width             | 001: 1 wait |               | 3 waits  |
|        |                     | RMW)              |            |         |                       | erved         | 0: 16 bits        |             | l) waits 110: |          |
|        |                     |                   |            |         | 11: J                 |               | 1:8 bits          | 011: 0 wait |               | 8 waits  |
|        |                     | C7H               |            |         |                       |               | BEXBUS            | BEXW2<br>W  | BEXW1         | BEXW0    |
|        | External            |                   | $\sim$     |         | $\sim$                |               | W<br>0            | 0           | 0<br>W        | W<br>0   |
| BEXCS  | CS/WAIT             |                   |            |         |                       |               | Data bus          | 000: 2 wait |               | Reserved |
| 22/100 | control             |                   |            |         |                       |               | width             | 000. 2 wait |               | 3 waits  |
|        | register            | (Prohibit         |            |         |                       |               | 0: 16 bits        |             | l) waits 110: |          |
|        |                     | RMW)              |            |         |                       |               | 1: 8 bits         | 011: 0 wait |               | 8 waits  |
|        | Memory              |                   | S23        | S22     | S21                   | S20           | S19               | S18         | S17           | S16      |
|        | start               | 0.011             |            |         | •                     | R/            |                   |             |               |          |
| MSAR0  | address             | C8H               | 1          | 1       | 1                     | 1             | 1                 | 1           | 1             | 1        |
|        | register 0          |                   |            |         |                       | Start address | s A23 to A16      |             |               |          |
|        | Memory              |                   | V20        | V19     | V18                   | V17           | V16               | V15         | V14 to V9     | V8       |
|        | address             | 0011              |            |         | •                     | R/            |                   | •           | •             |          |
| MAMR0  | mask                | C9H               | 1          | 1       | 1                     | 1             | 1                 | 1           | 1             | 1        |
|        | register 0          |                   |            |         | CS0 area siz          | e 0: enabl    | e to address      | comparison  |               | -        |
|        | Memory              |                   | S23        | S22     | S21                   | S20           | S19               | S18         | S17           | S16      |
|        | start               |                   |            |         |                       | R/            |                   |             |               |          |
| MSAR1  | address             | CAH               | 1          | 1       | 1                     | 1             | 1                 | 1           | 1             | 1        |
|        | register 1          |                   |            |         |                       | Start address | s A23 to A16      |             |               |          |
|        | Memory              |                   | V21        | V20     | V19                   | V18           | V17               | V16         | V15 to V9     | V8       |
|        | address             |                   |            |         |                       | R/            |                   |             |               |          |
| MAMR1  | mask                | CBH               | 1          | 1       | 1                     | 1             | 1                 | 1           | 1             |          |
|        | register 1          |                   |            |         | CS1 area siz          |               | e to address      |             |               |          |
|        | -                   | 1                 | 1          |         |                       |               |                   | 20.11001    | -             |          |

| Symbol     | Name       | Address | 7   | 6                                             | 5   | 4             | 3            | 2   | 1   | 0   |  |  |  |
|------------|------------|---------|-----|-----------------------------------------------|-----|---------------|--------------|-----|-----|-----|--|--|--|
|            | Memory     |         | S23 | S22                                           | S21 | S20           | S19          | S18 | S17 | S16 |  |  |  |
| MSAR2      | start      | ССН     |     |                                               |     | R/            | W            |     |     |     |  |  |  |
| IVISAR2    | address    | ССП     | 1   | 1                                             | 1   | 1             | 1            | 1   | 1   | 1   |  |  |  |
|            | register 2 |         |     | Start address A23 to A16                      |     |               |              |     |     |     |  |  |  |
|            | Memory     |         | V22 | V21                                           | V20 | V19           | V18          | V17 | V16 | V15 |  |  |  |
|            | address    |         | B/W |                                               |     |               |              |     |     |     |  |  |  |
| IVIAIVIRZ  | 1AMR2 mask | CDH     | 1   | 1                                             | 1   | 1             | 1            | 1   | 1   | 1   |  |  |  |
|            | register 2 |         |     | CS2 area size 0: Enable to address comparison |     |               |              |     |     |     |  |  |  |
|            | Memory     |         | S23 | S22                                           | S21 | S20           | S19          | S18 | S17 | S16 |  |  |  |
| MSAR3      | start      | СЕН     |     |                                               |     |               |              |     |     |     |  |  |  |
| MOARO      | address    | CER     | 1   | 1                                             | 1   | 1             | 1            | 1   | 1   | 1   |  |  |  |
|            | register 3 |         |     |                                               |     | Start address | s A23 to A16 | 5   |     |     |  |  |  |
|            | Memory     |         | V22 | V21                                           | V20 | V19           | V18          | V17 | V16 | V15 |  |  |  |
| MAMR3      | address    | CEL     |     |                                               | -   | R/            | W            |     |     |     |  |  |  |
| IVI/AIVIR3 | mask       | CFH     | 1   | 1                                             | 1   | 1             | 1            | 1   | 1   | 1   |  |  |  |
|            | register 3 |         |     | CS3 area size 0: Enable to address comparison |     |               |              |     |     |     |  |  |  |

# (4) Chip select/wait control (2/2)

### (5) Clock gear (1/2)

| Symbol | Name        | Address | 7               | 6                   | 5                        | 4               | 3           | 2            | 1                    | 0          |
|--------|-------------|---------|-----------------|---------------------|--------------------------|-----------------|-------------|--------------|----------------------|------------|
|        |             |         | XEN             | XTEN                | RXEN                     | RXTEN           | RSYSCK      | WUEF         | PRCK1                | PRCK0      |
|        |             |         |                 |                     |                          | R/\             | N           |              |                      |            |
|        |             |         | 1               | 1                   | 1                        | 0               | 0           | 0            | 0                    | 0          |
|        |             |         | High-           | Low-                | High-                    | Low-            | Select      | Warm-up      | Select presc         | aler clock |
|        |             |         | frequency       | frequency           | frequency                | frequency       | clock after | timer        | 00: f <sub>FPH</sub> |            |
|        | System      |         | oscillator (fc) | oscillator (fs)     | oscillator (fc)          | oscillator (fs) | release of  | 0 write:     | 01: Reserved         | ł          |
|        | clock       |         | 0: Stopped      | 0: Stopped          | after release            | after release   | STOP        | Don't care   | 10: fc/16            |            |
| SYSCR0 | control     | E0H     | 1: Oscillation  | 1: Oscillation      | of STOP                  | of STOP         | mode        | 1 write:     | 11: Reserved         | ł          |
|        | register 0  |         |                 |                     | mode                     | mode            | 0: fc       | Start timer  |                      |            |
|        | logicito. o |         |                 |                     | 0: Stopped               | 0: Stopped      | 1: fs       | 0 read:      |                      |            |
|        |             |         |                 |                     | 1: Oscillation           | 1: Oscillation  |             | End          |                      |            |
|        |             |         |                 |                     |                          |                 |             | warm-up      |                      |            |
|        |             |         |                 |                     |                          |                 |             | 1 read:      |                      |            |
|        |             |         |                 |                     |                          |                 |             | Not end      |                      |            |
|        |             |         |                 |                     |                          |                 |             | warm-up      |                      |            |
|        |             |         |                 |                     |                          |                 | SYSCK       | GEAR2        | GEAR1                | GEAR0      |
|        |             |         |                 |                     |                          |                 |             | R/           | W                    |            |
|        |             |         |                 |                     |                          |                 | 0           | 1            | 0                    | 0          |
|        |             |         |                 |                     |                          |                 | System      | High-freque  | ency gear va         | lue        |
|        | System      |         |                 |                     |                          |                 | clock       | selection (f | c)                   |            |
|        | clock       |         |                 |                     |                          |                 | selection   | 000: fc      |                      |            |
| SYSCR1 | control     | E1H     |                 |                     |                          |                 | 0: fc       | 001: fc/2    |                      |            |
|        | register 1  |         |                 |                     |                          |                 | 1: fs       | 010: fc/4    |                      |            |
|        | 0           |         |                 |                     |                          |                 | (Note 2)    |              |                      |            |
|        |             |         |                 |                     |                          |                 |             | 100: fc/16   |                      |            |
|        |             |         |                 |                     |                          |                 |             | 101: (Rese   |                      |            |
|        |             |         |                 |                     |                          |                 |             | 110: (Rese   |                      |            |
|        |             |         |                 |                     |                          |                 |             | 111: (Rese   |                      |            |
|        |             |         |                 | SCOSEL              | WUPTM1                   | WUPTM0          | HALTM1      | HALTM0       | SELDRV               | DRVE       |
|        | <b>a</b> .  |         |                 | R/W                 | R/W                      | R/W             | R/W         | R/W          | R/W                  | R/W        |
|        | System      |         |                 | 0                   | 1                        | 0               | 1           | 1            | 0                    | 0          |
| SYSCR2 | clock       | E2H     |                 | 0: fs               | Warm-up ti               |                 | 00: Reserv  |              | <drive></drive>      | 1: Drive   |
|        | control     |         |                 | 1: f <sub>FPH</sub> | 00: Reserve              |                 | 01: STOP r  |              | mode                 | IDLE1      |
|        | register 2  |         |                 |                     | 01: 2 <sup>8</sup> input | frequency       | 10: IDLE1 I |              | select               | mode       |
|        |             |         |                 |                     | 10: 2 <sup>14</sup>      |                 | 11: IDLE2 1 | mode         | 0: STOP              |            |
|        |             |         |                 |                     | 11: 2 <sup>16</sup>      |                 |             |              | 1: IDLE              |            |

(5) Clock gear (2/2)

| Symbol  | Name        | Address | 7                                                                                                                                   | 6           | 5           | 4           | 3          | 2             | 1             | 0             |
|---------|-------------|---------|-------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|-------------|------------|---------------|---------------|---------------|
|         |             |         | PROTECT                                                                                                                             | -           | -           | -           | -          | EXTIN         | DRVOSCH       | DRVOSCL       |
|         |             |         | R                                                                                                                                   | R/W         | R/W         | R/W         | R/W        | R/W           | R/W           | R/W           |
|         | EMC         |         | 0                                                                                                                                   | 1           | 1           | 0           | 0          | 0             | 1             | 1             |
| EMCCR0  | control     | E3H     | Protection                                                                                                                          | Always      | Always      | Always      | Always     | 1: External   | fc oscillator | fs oscillator |
| LINCORO | register 0  | LOIT    | flag                                                                                                                                | write 0     | write 1     | write 0     | write 0    |               | drivability   | driver        |
|         |             |         | 0: OFF                                                                                                                              |             |             |             |            |               | 1: Normal     | ability       |
|         |             |         | 1: ON                                                                                                                               |             |             |             |            |               | 0: Weak       | 1: Normal     |
|         |             |         |                                                                                                                                     |             |             |             |            |               |               | 0: Weak       |
| EMCCR1  | EMC control | E4H     |                                                                                                                                     |             |             |             |            |               |               |               |
|         | register 1  |         | Switching the protect ON/OFF by write to following : 1st-KEY and 2nd-KEY<br>1st-KEY: EMCCR1 = 5AH, EMCCR2 = A5H in succession write |             |             |             |            |               |               |               |
|         | EMC         |         |                                                                                                                                     |             |             |             |            |               |               |               |
| EMCCR2  | control     | E5H     |                                                                                                                                     | 2nd-KE      | Y: EMCCR1   | = A5H, EM0  | CCR2 = 5AH | I IN SUCCESSI | on write      |               |
|         | register 2  |         |                                                                                                                                     |             |             |             |            |               |               |               |
|         |             |         | /                                                                                                                                   | ENFROM      | ENDROM      | ENPROM      |            | FFLAG         | DFLAG         | PFLAG         |
|         |             |         |                                                                                                                                     | R/W         | R/W         | R/W         |            | R/W           | R/W           | R/W           |
|         |             |         |                                                                                                                                     | 0           | 0           | 0           |            | 0             | 0             | 0             |
|         |             |         |                                                                                                                                     | CS1A        | CS2B-2G     | CS2A        |            | CS1A          | CS2B-2G       | CS2A          |
|         | EMC         |         |                                                                                                                                     | area detect | area detect | area detect |            | Write         | Write         | Write         |
| EMCCR3  | control     | E6H     |                                                                                                                                     | enable      | enable      | enable      |            | operation     | operation     | operation     |
| LINCORO | register 3  | Lon     |                                                                                                                                     | 0: Disable  | 0: Disable  | 0: Disable  |            | flag          | flag          | flag          |
|         | regiotor e  |         |                                                                                                                                     | 1: Enable   | 1: Enable   | 1: Enable   |            | When read n   | node          |               |
|         |             |         |                                                                                                                                     |             |             |             |            | 0: No write   |               |               |
|         |             |         |                                                                                                                                     |             |             |             |            | 1: Write      |               |               |
|         |             |         |                                                                                                                                     |             |             |             |            | When write r  | node          |               |
|         |             |         |                                                                                                                                     |             |             |             |            | 0: Flag area  |               |               |

| Symbol     | Name       | Address |                                                             | 7    |       | 6          | 5                         | 4                         | 3              | 2             | 1   | 0  |  |  |     |  |     |     |     |     |     |     |     |
|------------|------------|---------|-------------------------------------------------------------|------|-------|------------|---------------------------|---------------------------|----------------|---------------|-----|----|--|--|-----|--|-----|-----|-----|-----|-----|-----|-----|
|            |            |         |                                                             | ACT1 | ŀ     | ACT0       | DLUPFG                    | DLUPTM                    |                |               |     |    |  |  |     |  |     |     |     |     |     |     |     |
|            |            |         | R/W                                                         |      |       | R/W        | R                         | R/W                       | /              | /             | /   |    |  |  |     |  |     |     |     |     |     |     |     |
|            | DFM        |         |                                                             | 0    | _     | 0          | 0                         | 0                         |                | /             |     |    |  |  |     |  |     |     |     |     |     |     |     |
| DFMCR0     | control    | E8H     |                                                             | DFM  | LUP   | fFPH       | Lockup flag               | Lockup time               |                |               |     |    |  |  |     |  |     |     |     |     |     |     |     |
| register 0 | EOH        | 00      | STOP                                                        | STOP | fosch | 0: End LUP | 0: 2 <sup>12/</sup> fOSCH |                           |                |               |     |    |  |  |     |  |     |     |     |     |     |     |     |
|            | regiotor o |         | 01                                                          | RUN  | RUN   | fosch      | 1: Do not                 | 1: 2 <sup>10/</sup> fOSCH |                |               |     |    |  |  |     |  |     |     |     |     |     |     |     |
|            |            |         | 10                                                          | RUN  | STOP  | fDFM       |                           |                           |                |               |     |    |  |  |     |  |     |     |     |     |     |     |     |
|            |            |         | 11                                                          | RUN  | STOP  | fosch      |                           |                           |                |               |     |    |  |  |     |  |     |     |     |     |     |     |     |
|            |            |         |                                                             | D7   |       | D6         | D5                        | D4                        | D3             | D2            | D1  | D0 |  |  |     |  |     |     |     |     |     |     |     |
|            | DFM        |         |                                                             |      | Ī     |            |                           |                           |                |               |     |    |  |  | R/W |  | R/W |
|            | control    | E9H     |                                                             | 0    |       | 0          | 0                         | 1                         | 0              | 0             | 1   | 1  |  |  |     |  |     |     |     |     |     |     |     |
|            | register 1 | 2311    |                                                             |      |       |            |                           | DFM co                    | rrection       |               |     |    |  |  |     |  |     |     |     |     |     |     |     |
|            | register i |         |                                                             |      |       | Inpu       | t frequency               | 4 to 8.25 MH              | z (at 2.7 to 3 | 3.6 V): Write | 0BH |    |  |  |     |  |     |     |     |     |     |     |     |
|            |            |         | Input frequency 2 to 2.5 MHz (at 2.0V $\pm$ 10%): Write 1BH |      |       |            |                           |                           |                |               |     |    |  |  |     |  |     |     |     |     |     |     |     |

# (6) DFM (Clock doubler)

### (7) 8-bit timer

| (7–1) TMRA01 |
|--------------|
|--------------|

| (7–1) TMR/ |                                                                 | م جاجا م                          | 7                                                   | <u>^</u>              | -                                                              | A                     | 0                                                                                                                                      | 0                                            | A                                                                                            | ^                                          |
|------------|-----------------------------------------------------------------|-----------------------------------|-----------------------------------------------------|-----------------------|----------------------------------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------|
| Symbol     | Name                                                            | Address                           | 7                                                   | 6                     | 5                                                              | 4                     | 3                                                                                                                                      | 2                                            | 1                                                                                            | 0                                          |
|            |                                                                 |                                   | TA0RDE                                              |                       |                                                                | $ \ge$                | I2TA01                                                                                                                                 | TA01PRUN                                     |                                                                                              | TAORUN                                     |
|            | 8-bit timer                                                     |                                   | R/W                                                 |                       |                                                                | >                     | R/W                                                                                                                                    | R/W                                          | R/W                                                                                          | R/W                                        |
| TA01RUN    | RUN                                                             | 100H                              | 0                                                   |                       |                                                                |                       | 0                                                                                                                                      | 0                                            | 0                                                                                            | 0                                          |
|            | register                                                        |                                   | Double buffer                                       |                       |                                                                |                       | IDLE2                                                                                                                                  |                                              | un/stop con                                                                                  | trol                                       |
|            | 0                                                               |                                   | 0: Disable                                          |                       |                                                                |                       | 0: Stop                                                                                                                                | 0: Stop and                                  | l clear                                                                                      |                                            |
|            |                                                                 |                                   | 1: Enable                                           |                       |                                                                |                       | 1: Operate                                                                                                                             | 1: Run (Co                                   | unt up)                                                                                      |                                            |
|            | 8-bit timer                                                     | 102H                              |                                                     |                       |                                                                |                       | _                                                                                                                                      |                                              |                                                                                              |                                            |
| TA0REG     | register 0                                                      | (Prohibit                         |                                                     |                       |                                                                |                       | W                                                                                                                                      |                                              |                                                                                              |                                            |
|            | register o                                                      | RMW)                              |                                                     |                       |                                                                | Unc                   | defined                                                                                                                                |                                              |                                                                                              |                                            |
|            | O hitti a an                                                    | 103H                              |                                                     |                       |                                                                |                       | -                                                                                                                                      |                                              |                                                                                              |                                            |
| TA1REG     | 8-bit timer                                                     | (Prohibit                         |                                                     |                       |                                                                |                       | W                                                                                                                                      |                                              |                                                                                              |                                            |
|            | register 1                                                      | RMW)                              |                                                     |                       |                                                                | Unc                   | defined                                                                                                                                |                                              |                                                                                              |                                            |
|            |                                                                 |                                   | TA01M1                                              | TA01M0                | PWM01                                                          | PWM00                 | TA1CLK1                                                                                                                                | TA1CLK0                                      | TA0CLK1                                                                                      | TA0CLK0                                    |
|            |                                                                 |                                   |                                                     |                       |                                                                |                       | R/W                                                                                                                                    |                                              |                                                                                              |                                            |
|            | 8-bit timer                                                     |                                   | 0                                                   | 0                     | 0                                                              | 0                     | 0                                                                                                                                      | 0                                            | 0                                                                                            | 0                                          |
| TA01MOD    | source CLK                                                      | 104H                              | 00: 8-bit tim                                       | -                     | 00: Reserv                                                     |                       | 00: TA0TRO                                                                                                                             |                                              | 00: TA0IN                                                                                    |                                            |
|            | & mode                                                          |                                   | 01: 16-bit ti                                       |                       | 01: 2 <sup>6</sup> PW                                          |                       | 01: φT1                                                                                                                                | -                                            | 00: ΤΑΟΠ <b>Ι</b><br>01: φT1                                                                 | F                                          |
|            |                                                                 |                                   | 10: 8-bit PF                                        |                       | 10: 2 <sup>7</sup>                                             |                       | 10: <b></b> ∳T16                                                                                                                       |                                              | 10:                                                                                          |                                            |
|            |                                                                 |                                   | 10: 8-bit PPG<br>11: 8-bit PWM                      |                       | 11: 2 <sup>8</sup>                                             |                       | 11: φT256                                                                                                                              |                                              | 11: <b>∮</b> T16                                                                             |                                            |
|            |                                                                 |                                   |                                                     |                       |                                                                |                       | TA1FFC1                                                                                                                                | TA1FFC0                                      | TA1FFIE                                                                                      | TA1FFIS                                    |
|            |                                                                 |                                   | $\backslash$                                        |                       | $\sim$                                                         | $\overline{}$         | R/                                                                                                                                     |                                              |                                                                                              | /W                                         |
|            | 8-bit timer                                                     | 105H                              |                                                     | $\sim$                |                                                                |                       | 1                                                                                                                                      | 1                                            | 0                                                                                            | 0                                          |
| TA1FFCR    | flip-flop                                                       | (Prohibit                         |                                                     |                       |                                                                |                       | 00: Invert TA                                                                                                                          |                                              | 1: TA1FF                                                                                     | 0: TMRA0                                   |
|            | control                                                         | RMW)                              |                                                     |                       |                                                                |                       | 01: Set TA1                                                                                                                            |                                              | enable                                                                                       | 1: TMRA1                                   |
|            |                                                                 | ,                                 |                                                     |                       |                                                                |                       | 10: Clear TA                                                                                                                           |                                              | onabio                                                                                       | inversion                                  |
|            |                                                                 |                                   |                                                     |                       |                                                                |                       | 11: Don't ca                                                                                                                           |                                              |                                                                                              |                                            |
| (7–2) TMRA | 423                                                             |                                   |                                                     |                       |                                                                |                       |                                                                                                                                        |                                              |                                                                                              |                                            |
| Symbol     | Name                                                            | Address                           | 7                                                   | 6                     | 5                                                              | 4                     | 3                                                                                                                                      | 2                                            | 1                                                                                            | 0                                          |
|            |                                                                 |                                   | TA2RDE                                              |                       |                                                                |                       | I2TA23                                                                                                                                 | TA23PRUN                                     | <b>TA3RUN</b>                                                                                | TA2RUN                                     |
|            | 8-bit timer                                                     |                                   | R/W                                                 |                       |                                                                |                       | R/W                                                                                                                                    | R/W                                          | R/W                                                                                          | R/W                                        |
| TA23RUN    | RUN                                                             | 108H                              | 0                                                   |                       |                                                                |                       | 0                                                                                                                                      | 0                                            | 0                                                                                            | 0                                          |
|            | register                                                        |                                   | Double buffer                                       |                       |                                                                |                       | IDLE2                                                                                                                                  |                                              | un/stop con                                                                                  | trol                                       |
|            | U U                                                             |                                   | 0: Disable                                          |                       |                                                                |                       | 0: Stop                                                                                                                                | 0: Stop and                                  |                                                                                              |                                            |
|            |                                                                 |                                   | 1: Enable                                           |                       |                                                                |                       | 1: Operate                                                                                                                             | 1: Run (Co                                   | unt up)                                                                                      |                                            |
| TAODEO     | 8-bit timer                                                     | 10AH                              |                                                     |                       |                                                                |                       | -                                                                                                                                      |                                              |                                                                                              |                                            |
| TA2REG     | register 0                                                      | (Prohibit<br>RMW)                 |                                                     |                       |                                                                |                       | W                                                                                                                                      |                                              |                                                                                              |                                            |
|            |                                                                 |                                   |                                                     |                       |                                                                | Und                   | lefined                                                                                                                                |                                              |                                                                                              |                                            |
| TAODEO     | 8-bit timer                                                     | 10BH                              |                                                     |                       |                                                                |                       | W                                                                                                                                      |                                              |                                                                                              |                                            |
|            |                                                                 | (Prohihit                         |                                                     |                       |                                                                |                       |                                                                                                                                        |                                              |                                                                                              |                                            |
| TA3REG     | register 1                                                      | (Prohibit<br>RMW)                 |                                                     |                       |                                                                | Line                  |                                                                                                                                        |                                              |                                                                                              |                                            |
| TA3REG     | register 1                                                      | (Prohibit<br>RMW)                 | TA23M1                                              | ΤΔ23ΜΟ                | PW/M21                                                         |                       | lefined                                                                                                                                | TA3CI KO                                     | TA2CLK1                                                                                      | TA2CI KO                                   |
| TASREG     | register 1                                                      | •                                 | TA23M1                                              | TA23M0                | PWM21                                                          | PWM20                 | lefined<br>TA3CLK1                                                                                                                     | TA3CLK0                                      | TA2CLK1                                                                                      | TA2CLK0                                    |
| TASREG     | register 1<br>8-bit timer                                       | •                                 | TA23M1                                              | TA23M0<br>0           | 1                                                              | PWM20                 | lefined<br>TA3CLK1<br>R/W                                                                                                              | TA3CLK0                                      |                                                                                              | TA2CLK0                                    |
|            |                                                                 | RMW)                              |                                                     | 0                     | PWM21<br>0<br>00: Reserv                                       | PWM20<br>F            | lefined<br>TA3CLK1                                                                                                                     | 0                                            | TA2CLK1<br>0<br>00: Reserv                                                                   | 0                                          |
|            | 8-bit timer                                                     | RMW)                              | 0                                                   | 0<br>ner              | 0                                                              | PWM20<br>F<br>0<br>ed | defined<br>TA3CLK1<br>R/W<br>0                                                                                                         | 0                                            | 0                                                                                            | 0                                          |
|            | 8-bit timer<br>source CLK                                       | RMW)                              | 0<br>00: 8-bit tim                                  | 0<br>ner<br>mer       | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW<br>10: 2 <sup>7</sup> | PWM20<br>F<br>0<br>ed | defined<br>TA3CLK1<br>R/W<br>0<br>00: TA2TRG                                                                                           | 0                                            | 0<br>00: Reserv                                                                              | 0                                          |
|            | 8-bit timer<br>source CLK                                       | RMW)                              | 0<br>00: 8-bit tim<br>01: 16-bit ti                 | 0<br>ner<br>mer<br>PG | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW                       | PWM20<br>F<br>0<br>ed | lefined<br>TA3CLK1<br>R/W<br>0<br>00: TA2TRG<br>01: ∳T1                                                                                | 0                                            | 0<br>00: Reserv<br>01: φT1<br>10: φT4<br>11: φT16                                            | 0                                          |
|            | 8-bit timer<br>source CLK                                       | RMW)                              | 0<br>00: 8-bit tim<br>01: 16-bit ti<br>10: 8-bit PF | 0<br>ner<br>mer<br>PG | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW<br>10: 2 <sup>7</sup> | PWM20<br>F<br>0<br>ed | defined<br>TA3CLK1<br>R/W<br>0<br>00: TA2TRG<br>01: φT1<br>10: φT16<br>11: φT256<br>TA3FFC1                                            | 0<br>G<br>TA3FFC0                            | 0<br>00: Reserv<br>01: φT1<br>10: φT4<br>11: φT16<br>TA3FFIE                                 | 0<br>ed<br>TA3FFIS                         |
|            | 8-bit timer<br>source CLK<br>& mode                             | RMW)                              | 0<br>00: 8-bit tim<br>01: 16-bit ti<br>10: 8-bit PF | 0<br>ner<br>mer<br>PG | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW<br>10: 2 <sup>7</sup> | PWM20<br>F<br>0<br>ed | defined<br>TA3CLK1<br>R/W<br>00: TA2TRC<br>01: φT1<br>10: φT16<br>11: φT256                                                            | 0<br>G<br>TA3FFC0                            | 0<br>00: Reserv<br>01: φT1<br>10: φT4<br>11: φT16<br>TA3FFIE                                 | 0<br>ed<br>TA3FFIS<br>/W                   |
| TA23MOD    | 8-bit timer<br>source CLK<br>& mode<br>8-bit timer              | RMW)<br>10CH<br>10DH              | 0<br>00: 8-bit tim<br>01: 16-bit ti<br>10: 8-bit PF | 0<br>ner<br>mer<br>PG | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW<br>10: 2 <sup>7</sup> | PWM20<br>F<br>0<br>ed | lefined<br>TA3CLK1<br>R/W<br>0<br>00: TA2TRG<br>01: φT1<br>10: φT16<br>11: φT256<br>TA3FFC1<br>R/<br>1                                 | 0<br>TA3FFC0<br>W<br>1                       | 0<br>00: Reserv<br>01:                                                                       | 0<br>ed<br>TA3FFIS<br>/W<br>0              |
|            | 8-bit timer<br>source CLK<br>& mode<br>8-bit timer<br>flip-flop | RMW)<br>10CH<br>10DH<br>(Prohibit | 0<br>00: 8-bit tim<br>01: 16-bit ti<br>10: 8-bit PF | 0<br>ner<br>mer<br>PG | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW<br>10: 2 <sup>7</sup> | PWM20<br>F<br>0<br>ed | lefined<br>TA3CLK1<br>R/W<br>0<br>00: TA2TRG<br>01: φT1<br>10: φT16<br>11: φT256<br>TA3FFC1<br>R/<br>1<br>00: Invert T/                | 0<br>TA3FFC0<br>W<br>1<br>A3FF               | 0<br>00: Reserv<br>01: φT1<br>10: φT4<br>11: φT16<br>TA3FFIE<br>R<br>0<br>1: TA3FF           | 0<br>ed<br>TA3FFIS<br>/W<br>0<br>0: TMRA2  |
| TA23MOD    | 8-bit timer<br>source CLK<br>& mode<br>8-bit timer              | RMW)<br>10CH<br>10DH              | 0<br>00: 8-bit tim<br>01: 16-bit ti<br>10: 8-bit PF | 0<br>ner<br>mer<br>PG | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW<br>10: 2 <sup>7</sup> | PWM20<br>F<br>0<br>ed | lefined<br>TA3CLK1<br>R/W<br>0<br>00: TA2TRG<br>01: φT1<br>10: φT16<br>11: φT256<br>TA3FFC1<br>R/<br>1<br>00: Invert T/<br>01: Set TA3 | 0<br>TA3FFC0<br>W<br>1<br>A3FF<br>FF         | 0<br>00: Reserv<br>01: φT1<br>10: φT4<br>11: φT16<br>TA3FFIE<br>R<br>0<br>1: TA3FF<br>invert | 0<br>ed<br>/W<br>0<br>0: TMRA2<br>1: TMRA3 |
| TA23MOD    | 8-bit timer<br>source CLK<br>& mode<br>8-bit timer<br>flip-flop | RMW)<br>10CH<br>10DH<br>(Prohibit | 0<br>00: 8-bit tim<br>01: 16-bit ti<br>10: 8-bit PF | 0<br>ner<br>mer<br>PG | 0<br>00: Reserv<br>01: 2 <sup>6</sup> PW<br>10: 2 <sup>7</sup> | PWM20<br>F<br>0<br>ed | lefined<br>TA3CLK1<br>R/W<br>0<br>00: TA2TRG<br>01: φT1<br>10: φT16<br>11: φT256<br>TA3FFC1<br>R/<br>1<br>00: Invert T/                | 0<br>TA3FFC0<br>W<br>1<br>A3FF<br>FF<br>A3FF | 0<br>00: Reserv<br>01: φT1<br>10: φT4<br>11: φT16<br>TA3FFIE<br>R<br>0<br>1: TA3FF           | 0<br>ed<br>TA3FFIS<br>/W<br>0<br>0: TMRA2  |

### (8) UART/serial channel (1/2)

#### (8-1) UART/SIO channel 0

| Symbol  | Name      | Address   | 7            | 6              | 5          | 4            | 3             | 2       | 1                                  | 0            |  |
|---------|-----------|-----------|--------------|----------------|------------|--------------|---------------|---------|------------------------------------|--------------|--|
|         | Serial    | 200H      | RB7/TB7      | RB6/TB6        | RB5/TB5    | RB4/TB4      | RB3/TB3       | RB2/TB2 | RB1/TB1                            | RB0/TB0      |  |
| SC0BUF  | channel 0 | (Prohibit |              |                | R (F       | Receiving)/M | / (Transmiss  | ion)    |                                    |              |  |
|         | buffer    | RMW)      |              |                |            | Unde         | efined        |         |                                    |              |  |
|         |           |           | RB8          | EVEN           | PE         | OERR         | PERR          | FERR    | SCLKS                              | IOC          |  |
|         | Serial    |           | R            | R/             | W          | R (Clea      | red to 0 by r | eading) | R/                                 | W            |  |
| SC0CR   | channel 0 | 201H      | Undefined    | 0              | 0          | 0            | 0             | 0       | 0                                  | 0            |  |
| 00001   | control   | 20111     | Receiving    | Parity         | 1: Parity  |              | 1: Error      |         | 0: SCLK01                          | 1: Input     |  |
|         | oontroi   |           | data bit8    | 0: Odd         | Enable     | Overrun      | Parity        | Framing | 1: SCLK0↓                          | SCLK0        |  |
|         |           |           |              | 1: Even        |            |              |               |         |                                    |              |  |
|         |           |           | TB8          | CTSE           | RXE        | WU           | SM1           | SM0     | SC1                                | SC0          |  |
|         |           |           |              |                |            | R/           | W             |         | ł                                  |              |  |
|         | Serial    |           | 0            | 0              | 0          | 0            | 0             | 0       | 0                                  | 0            |  |
| SC0MOD0 | channel 0 | 202H      | Transmission | 1: CTS         | 1: Receive | 1: Wakeup    | 00: I/O inte  | rface   | 00: TA0TRO                         | G            |  |
|         | mode0     |           | data bit8    | enable         | enable     | enable       | 01: UART 7    | 7 bits  | 01: Baud rate                      |              |  |
|         |           |           |              |                |            |              | 10: UART 8    |         | 10: Internal clock f <sub>SY</sub> |              |  |
|         |           |           |              |                |            |              | 11: UART 9    | ) bits  | 11: Externa                        | l clock      |  |
|         |           |           | -            | BR0ADDE        | BR0CK1     | BR0CK0       | BR0S3         | BR0S2   | BR0S1                              | BR0S0        |  |
|         |           |           |              |                |            |              | Ŵ             |         | i                                  |              |  |
|         | Baud rate |           | 0            | 0              | (          | )            | 0             | 0       | 0                                  | 0            |  |
| BR0CR   | control   | 203H      | -            | 1: (16 – K)/16 | 00:        |              | Setti         | -       | ed frequency                       | / "N"        |  |
|         |           |           | write 0      | divided        | 01:        |              |               | (0 t    | o F)                               |              |  |
|         |           |           |              |                | 10:        |              |               |         |                                    |              |  |
|         |           |           |              |                | 11:        | <u> </u>     |               |         |                                    |              |  |
|         | Serial    |           |              |                |            |              | BR0K3         | BR0K2   | BR0K1                              | BR0K0        |  |
|         | channel 0 | 00.411    |              |                |            |              |               |         | /W                                 |              |  |
| BR0ADD  | K setting | 204H      |              |                |            |              | 0             | 0       | 0                                  | 0            |  |
|         | register  |           |              |                |            |              |               | •       | ency divisor                       |              |  |
|         |           |           | 10.00        |                |            | <hr/>        |               |         | + (16 – K)/1                       | 0)           |  |
|         |           |           | 12S0         | FDPX0          |            |              |               |         |                                    |              |  |
|         | Serial    |           | R/W          | R/W            |            |              |               |         |                                    | $\backslash$ |  |
| SC0MOD1 | channel 0 | 205H      | 0            | 0              |            |              |               |         |                                    |              |  |
|         | mode1     |           | IDLE2        | Duplex         |            |              |               |         |                                    |              |  |
|         |           | 0:        | 0: Stop      | 0: Half        |            |              |               |         |                                    |              |  |
|         |           |           | 1: Operate   | 1: Full        |            |              |               |         |                                    |              |  |

(8-2) IrDA

| Symbol | Name     | Address | 7            | 6          | 5            | 4          | 3                                              | 2        | 1      | 0      |  |
|--------|----------|---------|--------------|------------|--------------|------------|------------------------------------------------|----------|--------|--------|--|
|        |          |         | PLSEL        | RXSEL      | TXEN         | RXEN       | SIRWD3                                         | SIRWD2   | SIRWD1 | SIRWD0 |  |
|        | IrDA     |         | R/W          | R/W        | R/W          | R/W        |                                                | W        |        |        |  |
|        |          |         | 0            | 0          | 0            | 0          | 0                                              | 0        | 0      | 0      |  |
| SIRCR  | control  | 207H    | Transmission | Receiving  | Transmission | Receiving  | Set the effective SIRRxD pulse width           |          |        |        |  |
| OINOIN | register |         | pulse width  | data       | 0: Disable   | 0: Disable | Pulse width more than $2x \times (Set value +$ |          |        |        |  |
|        | register |         | 0: 3/16      | 0: H pulse | 1: Enable    | 1: Enable  | · ·                                            |          |        |        |  |
|        |          |         | 1: 1/16      | 1: L pulse |              |            | Possible: 1                                    | to 14    |        |        |  |
|        |          |         |              |            |              |            | Not possible                                   | e: 0, 15 |        |        |  |

## (8) UART/serial channel (2/2)

### (8-3) UART/SIO channel1

| Symbol      | Name                | Address   | 7                 | 6                         | 5                   | 4            | 3             | 2             | 1                      | 0        |
|-------------|---------------------|-----------|-------------------|---------------------------|---------------------|--------------|---------------|---------------|------------------------|----------|
|             | Serial              | 208H      | RB7/TB7           | RB6/TB6                   | RB5/TB5             | RB4/TB4      | RB3/TB3       | RB2/TB2       | RB1/TB1                | RB0/TB0  |
| SC1BUF      | channel 1           | (Prohibit |                   |                           | R (F                | Receiving)/W | / (Transmiss  | ion)          |                        |          |
|             | buffer              | RMW)      |                   |                           | ·                   | Unde         | efined        | ·             |                        |          |
|             |                     |           | RB8               | EVEN                      | PE                  | OERR         | PERR          | FERR          | SCLKS                  | IOC      |
|             | Serial              |           | R                 | R/                        | W                   | R (Clea      | red to 0 by r | eading)       | R/                     | W        |
| SC1CR       | channel 1           | 209H      | Undefined         | 0                         | 0                   | 0            | 0             | 0             | 0                      | 0        |
| OUTOIN      | control             | 20311     | Receiving         | Parity                    | 1: Parity           |              | 1: Error      | 1             | 0: SCLK1↑              | 1: Input |
|             | 0011101             |           | data bit8         | 0: Odd                    | Enable              | Overrun      | Parity        | Framing       | 1: SCLK1↓              |          |
|             |                     |           |                   | 1: Even                   |                     |              |               |               |                        |          |
|             |                     |           | TB8               | CTSE                      | RXE                 | WU           | SM1           | SM0           | SC1                    | SC0      |
|             |                     |           |                   |                           |                     | R/           | W             |               | T                      |          |
|             | Serial              |           | 0                 | 0                         | 0                   | 0            | 0             | 0             | 0                      | 0        |
| SC1MOD0     | channel 1           | 20AH      | Transmission      | 1: CTS                    | 1: Receive          | 1: Wakeup    | 00: I/O inter |               | 00: TA0TRG             |          |
|             | mode                |           | data bit8         | enable                    | enable              |              | 01: UART 7    |               | 01: Baud rate generato |          |
|             |                     |           |                   |                           |                     |              | 10: UART 8    |               | 10: Internal c         |          |
|             |                     |           |                   |                           |                     | 55/0//       | 11: UART 9    |               | 11: External           |          |
|             |                     |           | -                 | BR1ADDE                   | BR1CK1              | BR1CK        | BR1S3         | BR1S2         | BR1S1                  | BR1S0    |
|             |                     |           | 0                 | 0                         | 0                   |              | Ŵ             |               |                        |          |
| BR1CR       | Baud rate           | 20BH      | 0                 | 0                         | 0                   | 0            | 0             | 0             | 0                      | 0        |
| DIVIOR      | control             | 20011     | Always<br>write 0 | 1: (16 – K)/16<br>divided | 00:                 |              | Sett          | -             | ed frequency<br>o F)   | / N      |
|             |                     |           | white 0           | enable                    | 01. φT2<br>10: φT8  |              |               | (01           | UF)                    |          |
|             |                     |           |                   | enable                    | 10: φ10<br>11: φT32 |              |               |               |                        |          |
|             |                     |           |                   | $\backslash$              |                     |              | BR1K3         | BR1K2         | BR1K1                  | BR1K0    |
|             | Serial              |           | $\backslash$      | $\backslash$              |                     |              | Bitino        |               | /W                     | Bitinto  |
| BR1ADD      | channel 1           | 20CH      | $\backslash$      | $\backslash$              | /                   | /            | 0             | 0             | 0                      | 0        |
|             | K setting           |           |                   |                           |                     |              |               | ts the freque | ency divisor '         |          |
|             | register            |           |                   |                           |                     |              |               | •             | + (16 – K)/1           |          |
|             |                     |           | I2S1              | FDPX1                     |                     |              |               |               |                        |          |
|             |                     |           | R/W               | R/W                       |                     | /            |               |               |                        |          |
| SC1MOD1     | Serial<br>channel 1 | 20DH      | 0                 | 0                         | $\square$           | $\backslash$ |               |               | $\square$              |          |
| 30 TIVIOD I | mode1               | 2000      | IDLE2             | Duplex                    |                     |              |               |               |                        |          |
| m           | moder               | dei       | 0: Stop           | 0: Half                   |                     |              |               |               |                        |          |
|             |                     |           | 1: Operate        | 1: Full                   |                     |              |               |               |                        |          |

### (9) I<sup>2</sup>C bus/serial interface

| Symbol                                                                                                                                                                         | Nome                                             | Address                           | 7                                                | e                                    | 5                                                                                      | 4                                                    | 3                                                                                                                   | 2                                                                                   | 4                                                       | 0                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|-----------------------------------|--------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------|
| Symbol                                                                                                                                                                         | Name                                             |                                   | -                                                | 6                                    |                                                                                        | -                                                    | 3                                                                                                                   |                                                                                     | 1                                                       | 0<br>SCK0/                                        |
|                                                                                                                                                                                |                                                  | 240H<br>(I <sup>2</sup> C bus     | BC2                                              | BC1                                  | BC0                                                                                    | ACK                                                  |                                                                                                                     | SCK2                                                                                | SCK1                                                    | SWRMON                                            |
| SBIOCR1<br>SBIODBR<br>SBIODBR<br>I2COAR<br>When<br>read<br>SBIOSR<br>When<br>write<br>SBIOCR2<br>When<br>read<br>SBIOSR<br>SBIOCR2<br>SBIOCR2<br>SBIOCR2<br>SBIOCR2<br>SBIOCR2 |                                                  | mode)                             |                                                  | W                                    | 0                                                                                      | R/W                                                  |                                                                                                                     | W                                                                                   | W0                                                      | R/W                                               |
|                                                                                                                                                                                | Serial bus                                       | (Prohibit<br>RMW)<br>240H<br>(SIO | 011: 3, 100                                      | 1: 1, 010: 2<br>0: 4, 101: 5         | 0                                                                                      | 0<br>Acknowledge<br>mode<br>0: Disable               | Setting for the devisor value n<br>000: 4, 001: 5, 010: 6<br>011: 7, 100: 8, 101: 9                                 |                                                                                     |                                                         | 0/1                                               |
| SBI0CR1                                                                                                                                                                        | interface<br>control                             |                                   | 110: 6, 11 <sup>-</sup><br>SIOS                  | 1: 7<br>SIOINH                       | SIOM1                                                                                  | 1: Enable<br>SIOM0                                   |                                                                                                                     | 110: 10, 111:<br>SCK2                                                               | (Reserved)<br>SCK1                                      | SCK0                                              |
| 02:00:01                                                                                                                                                                       | register 1                                       |                                   | W                                                | W                                    | W                                                                                      | W                                                    |                                                                                                                     | W                                                                                   | W                                                       | W                                                 |
|                                                                                                                                                                                | 0                                                | mode)                             | 0                                                | 0                                    | 0                                                                                      | 0                                                    |                                                                                                                     | 0                                                                                   | 0                                                       | 0                                                 |
|                                                                                                                                                                                |                                                  | (Prohibit<br>RMW)                 | Transfer<br>0: Stop<br>1: Start                  | Transfer<br>0: Continue<br>1: Abort  | Transfer mo<br>00: 8-bit tran<br>01: Reserve<br>10: 8-bit tran<br>11: 8-bit rece       | asmit mode<br>d<br>asmit/receive                     |                                                                                                                     | 000: 3, 001:<br>011: 6, 100:<br>110: 9, 111:                                        | 7, 101: 8<br>SCK pin                                    |                                                   |
|                                                                                                                                                                                | SBI                                              | 241H                              | DB7                                              | DB6                                  | DB5                                                                                    | DB4                                                  | DB3                                                                                                                 | DB2                                                                                 | DB1                                                     | DB0                                               |
| SBIODBR                                                                                                                                                                        | buffer<br>register                               | (Prohibit<br>RMW)                 |                                                  |                                      | k                                                                                      | (Receiving)/                                         | W (Transmis<br>defined                                                                                              | ision)                                                                              |                                                         |                                                   |
|                                                                                                                                                                                |                                                  |                                   | SA6                                              | SA5                                  | SA4                                                                                    | SA3                                                  | SA2                                                                                                                 | SA1                                                                                 | SA0                                                     | ALS                                               |
|                                                                                                                                                                                |                                                  | 242H                              | W                                                | W                                    | W                                                                                      | W                                                    | W                                                                                                                   | W                                                                                   | W                                                       | W                                                 |
| 100515                                                                                                                                                                         | I <sup>2</sup> C bus                             |                                   | 0                                                | 0                                    | 0                                                                                      | 0                                                    | 0                                                                                                                   | 0                                                                                   | 0                                                       | 0                                                 |
| I2COAR                                                                                                                                                                         | address<br>register                              | (Prohibit<br>RMW)                 |                                                  |                                      | Se                                                                                     | etting slave ac                                      | ldress                                                                                                              |                                                                                     |                                                         | Address<br>recognition<br>0: Enable<br>1: Disable |
|                                                                                                                                                                                | Serial bus                                       |                                   | MST                                              | TRX                                  | BB                                                                                     | PIN                                                  | AL/SBIM1                                                                                                            | AAS/SBIM0                                                                           | AD0/<br>SWRST                                           | LRB/<br>SWRST0                                    |
|                                                                                                                                                                                | interface                                        | 243H                              | R/W                                              | R/W                                  | R/W                                                                                    | R/W                                                  | R/W                                                                                                                 | R/W                                                                                 | R/W                                                     | R/W                                               |
|                                                                                                                                                                                | status                                           |                                   | 0                                                | 0                                    | 0                                                                                      | 1                                                    | 0                                                                                                                   | 0                                                                                   | 0                                                       | 0                                                 |
|                                                                                                                                                                                | register                                         | (I <sup>2</sup> C bus<br>mode)    | 0: Slave<br>1: Master                            | 0: Receiver<br>1: Transmit           | Bus status<br>monitor<br>0: Free<br>1: Busy                                            | INTSBI request<br>monitor<br>0: Request<br>1: Cancel | Arbitration lost<br>detection<br>monitor<br>1: Detect                                                               | Slave address<br>match detection<br>monitor<br>1: Detect                            | GENERAL<br>CALL detection<br>monitor<br>1: Detect       | Lost receive bit<br>monitor<br>0: 0<br>1: 1       |
| write                                                                                                                                                                          | Serial bus<br>interface<br>control<br>register 2 | (Prohibit<br>RMW)                 |                                                  |                                      | Start/stop<br>condition<br>generation<br>0: Start<br>condition<br>1: Stop<br>condition |                                                      | SBI operating n<br>00: Port mode<br>01: SIO mode<br>10: I2C bus mo<br>11: (Reserved)                                | de                                                                                  | Software reset g<br>and 01, then an<br>signal is genera |                                                   |
|                                                                                                                                                                                |                                                  |                                   |                                                  |                                      |                                                                                        |                                                      | SIOF/SBIM1                                                                                                          | SEF/SBIM2                                                                           | -                                                       | -                                                 |
|                                                                                                                                                                                | Serial bus                                       |                                   |                                                  |                                      |                                                                                        |                                                      | R/W<br>0                                                                                                            | R/W                                                                                 | W                                                       | W                                                 |
| read                                                                                                                                                                           | interface<br>status<br>register                  | 243H<br>(SIO<br>mode)             |                                                  |                                      |                                                                                        |                                                      | Transfer status<br>monitor<br>0: Stopped<br>1: Terminated<br>in process                                             | 0<br>Shift operation<br>status monitor<br>0: Stopped<br>1: Terminated<br>in process | 0                                                       | 0                                                 |
| write                                                                                                                                                                          | Serial bus<br>interface<br>control<br>register 2 | (Prohibit<br>RMW)                 |                                                  |                                      |                                                                                        |                                                      | Serial bus inte<br>operating mod<br>00: Port mode<br>01: SIO mode<br>10: I <sup>2</sup> C bus mode<br>11: (Reserved | de selection<br>ode                                                                 | Always<br>write 0                                       | Always<br>write 0                                 |
|                                                                                                                                                                                | Contelleur                                       |                                   | -                                                | I2SBI0                               |                                                                                        |                                                      |                                                                                                                     |                                                                                     |                                                         |                                                   |
| SBI0BR0                                                                                                                                                                        | Serial bus<br>interface                          | 244H                              | W<br>0                                           | R/W<br>0                             |                                                                                        |                                                      |                                                                                                                     |                                                                                     |                                                         |                                                   |
|                                                                                                                                                                                | baud rate<br>register 0                          | (Prohibit<br>RMW)                 | Always                                           | 0<br>IDLE2<br>0: Abort<br>1: Operate |                                                                                        |                                                      |                                                                                                                     |                                                                                     |                                                         |                                                   |
|                                                                                                                                                                                |                                                  |                                   | P4EN                                             |                                      |                                                                                        |                                                      |                                                                                                                     |                                                                                     |                                                         |                                                   |
|                                                                                                                                                                                | Serial bus                                       | 245H                              | W                                                | W                                    |                                                                                        |                                                      |                                                                                                                     |                                                                                     |                                                         |                                                   |
| SBI0BR1                                                                                                                                                                        | interface<br>baud rate<br>register 1             | (Prohibit<br>RMW)                 | 0<br>Internal<br>Clock<br>0: Abort<br>1: Operate | 0<br>Always<br>write 0               |                                                                                        |                                                      |                                                                                                                     |                                                                                     |                                                         |                                                   |

| Symbol      | Name                              | Address | 7                                      | 6                                         | 5                 | 4                 | 3                              | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                          | 0                                    |
|-------------|-----------------------------------|---------|----------------------------------------|-------------------------------------------|-------------------|-------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
|             |                                   |         | EOCF                                   | ADBF                                      | _                 | _                 | ITM0                           | REPEAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | SCAN                                                                                                                                                                                                                                                                                                                       | ADS                                  |
|             |                                   | 2B0H    | F                                      | र                                         | R/W               | R/W               | R/W                            | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R/W                                                                                                                                                                                                                                                                                                                        | R/W                                  |
|             | AD                                |         | 0                                      | 0                                         | 0                 | 0                 | 0                              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                          | 0                                    |
| ADMOD0      | MODE<br>register 0                | 2001    | AD<br>conversion<br>end flag<br>1: End | AD<br>conversion<br>burst flag<br>1: Busy | Always<br>write 0 | Always<br>write 0 | Interrupt in<br>repeat<br>mode | REPEATSCAN $R/W$ $R/W$ $0$ $0$ $0$ $0$ $0$ $0$ $0$ $0$ $0$ $0$ $0$ $0$ $1$ RepeatScan mod $1$ : Repeat $ADCH2$ $ADCH1$ $R/W$ $R/W$ $0$ $0$ $0$ $0$ $1$ : Repeat $ADCH2$ $ADCH1$ $R/W$ $R/W$ $0$ $0$ $0$ $0$ $1$ $AN1 AN0 \rightarrow AN1$ $010$ : $AN2 AN0 \rightarrow AN1  011$ : $AN3 AN0 \rightarrow AN1  101$ : $AN3 AN0 \rightarrow AN1  101$ : $AN5 AN4 \rightarrow AN5  111$ : $AN7 AN4 \rightarrow AN5  111$ : $AN7 AN4 \rightarrow AN5  111$ : $AN7 AN4 \rightarrow AN5  ADR04$ $ADR03$ $ADR14$ $ADR13$ | Scan mode<br>specification<br>1: Scan                                                                                                                                                                                                                                                                                      | AD<br>conversion<br>Star<br>1: Start |
|             |                                   |         | VREFON                                 | I2AD                                      |                   |                   | ADTRGE                         | ADCH2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ADCH1                                                                                                                                                                                                                                                                                                                      | ADCH0                                |
|             |                                   |         | R/W                                    | R/W                                       | /                 | /                 | R/W                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R/W                                                                                                                                                                                                                                                                                                                        | R/W                                  |
|             |                                   |         | 0                                      | 0                                         | /                 | /                 | 0                              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                          | 0                                    |
| ADMOD1      | AD<br>MODE<br>register 1          | 2B1H    | VREF<br>control<br>1: VREF on          | IDLE2<br>0: Abort<br>1: Operate           |                   |                   | AD control<br>1: Enable for    | 000: ANO AN<br>001: AN1 AN<br>010: AN2 AN<br>011: AN3 AN<br>100: AN4 AN<br>101: AN5 AN<br>110: AN6 AN                                                                                                                                                                                                                                                                                                                                                                                                            | $ \begin{array}{l} \text{IO} \\ \text{IO} \rightarrow \text{AN1} \\ \text{IO} \rightarrow \text{AN1} \rightarrow \text{I} \\ \text{IO} \rightarrow \text{AN1} \rightarrow \text{I} \\ \text{IA} \\ \text{IA} \\ \text{IA} \rightarrow \text{AN5} \\ \text{IA} \rightarrow \text{AN5} \rightarrow \text{I} \\ \end{array} $ | AN2 $\rightarrow$ AN3                |
|             | AD result                         | 2A0H    | ADR01                                  | ADR00                                     |                   |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | ADR0RF                               |
| ADREG04L    | register 0/4<br>Iow               |         | F                                      | २                                         | /                 | /                 |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | R                                    |
|             |                                   |         | Unde                                   | efined                                    |                   |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | 0                                    |
| ADREG04H    | AD result<br>register 0/4<br>high | 2A1H    | ADR09                                  | ADR08                                     | ADR07             |                   | ADR05<br>R                     | ADR04                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ADR03                                                                                                                                                                                                                                                                                                                      | ADR02                                |
|             | AD result                         |         | ADR11                                  | ADR10                                     | /                 |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | ADR1RF                               |
| ADREG15L    | register 1/5                      | 5 2A2H  |                                        | २                                         |                   |                   |                                | $\square$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | $\square$                                                                                                                                                                                                                                                                                                                  | R                                    |
|             | low                               |         | Unde                                   | efined                                    |                   |                   |                                | $\sim$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | $\square$                                                                                                                                                                                                                                                                                                                  | 0                                    |
| ADREG15H    | AD result<br>register 1/5         | 2A3H    | ADR19                                  | ADR18                                     | ADR17             | ADR16             | ADR15                          | ADR14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ADR13                                                                                                                                                                                                                                                                                                                      | ADR12                                |
|             | high                              |         |                                        |                                           |                   | Unde              | efined                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            |                                      |
|             | AD result                         |         | ADR21                                  | ADR20                                     |                   |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | $\sim$                                                                                                                                                                                                                                                                                                                     | ADR2RF                               |
| ADREG26L    | register 2/6                      | 2A4H    | F                                      | ર                                         | $\sim$            | $\sim$            |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | R                                    |
|             | low                               |         |                                        | efined                                    |                   |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | 0                                    |
| ADREG26H    | AD result<br>register 2/6         | 2A5H    | ADR29                                  | ADR28                                     | ADR27             | ADR26             | ADR25                          | ADR24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ADR23                                                                                                                                                                                                                                                                                                                      | ADR22                                |
|             | high                              |         |                                        |                                           |                   | Unde              | efined                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            |                                      |
|             | AD result                         |         | ADR31                                  | ADR30                                     |                   |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | ADR3RF                               |
| ADREG37L    | register 3/7                      | 2A6H    | F                                      | २                                         |                   |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | R                                    |
|             | low                               |         | Unde                                   | efined                                    |                   |                   |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            | 0                                    |
| ADREG37H    | AD result                         | 2A7H    | ADR39                                  | ADR38                                     | ADR37             | ADR36             | ADR35<br>R                     | ADR34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ADR33                                                                                                                                                                                                                                                                                                                      | ADR32                                |
| NDICE 03/11 | high                              | 27111   |                                        |                                           |                   |                   | efined                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            |                                      |

### (10) AD converter

# (11) Watchdog timer

| Symbol | Name             | Address                   | 7                | 6                                                                                                                                                                | 5     | 4 | 3 | 2                               | 1        | 0                 |
|--------|------------------|---------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---|---|---------------------------------|----------|-------------------|
|        |                  |                           | WDTE             | WDTP1                                                                                                                                                            | WDTP0 |   |   | I2WDT                           | RESCR    | -                 |
|        |                  |                           | R/W              | R/W                                                                                                                                                              | R/W   | / |   | R/W                             | R/W      | R/W               |
|        | WDT              |                           | 1                | 0                                                                                                                                                                | 0     | / | / | 0                               | 0        | 0                 |
| WDMOD  | mode<br>register | 300H                      | 1: WDT<br>enable | 00: 2 <sup>15</sup> /f <sub>SYS</sub><br>01: 2 <sup>17</sup> /f <sub>SYS</sub><br>10: 2 <sup>19</sup> /f <sub>SYS</sub><br>11: 2 <sup>21</sup> /f <sub>SYS</sub> |       |   |   | IDLE2<br>0: Abort<br>1: Operate | 1: RESET | Always<br>write 0 |
| WDCR   | WDT<br>control   | 301H<br>(Prohibit<br>RMW) |                  |                                                                                                                                                                  |       |   |   |                                 |          |                   |

| (12) RTC (Real time clock | )  |
|---------------------------|----|
|                           | ./ |

| Symbol | Name              | Address           | 7          | 6          | 5         | 4         | 3          | 2          | 1         | 0                                    |  |
|--------|-------------------|-------------------|------------|------------|-----------|-----------|------------|------------|-----------|--------------------------------------|--|
|        |                   | 320H              |            | SE6        | SE5       | SE4       | SE3        | SE2        | SE1       | SE0                                  |  |
| SECR   | Second            |                   |            |            |           |           | R/W        |            |           |                                      |  |
| SECK   | register          | 32011             |            |            |           |           | Undefined  |            |           |                                      |  |
|        |                   |                   | 0 is read  | 40 s       | 20 s      | 10 s      | 8 s        | 4 s        | 2 s       | 1 s                                  |  |
|        |                   |                   |            | MI6        | MI5       | MI4       | MI3        | MI2        | MI1       | MIO                                  |  |
| MINR   | Minute            | 321H              |            | R/W        |           |           |            |            |           |                                      |  |
|        | register          | 02111             |            |            | i         | i         | Undefined  | 1          | i         | 1                                    |  |
|        |                   |                   | 0 is read  | 40 min     | 20 min    | 10 min    | 8 min      | 4 min      | 2 min     | 1min                                 |  |
|        |                   |                   |            |            | HO5       | HO4       | HO3        | HO2        | HO1       | HO0                                  |  |
|        | Hour              |                   |            |            |           |           | R          | /W         |           |                                      |  |
| HOURR  | register          | 322H              |            |            | -         | i         | Unde       | efined     | i         | 1                                    |  |
|        | 0                 |                   | 0 is       | read       | 20 H      | 10 H      | 8 H        | 4 H        | 2 H       | 1 H                                  |  |
|        |                   |                   |            |            | (PM/AM)   | <         |            |            |           |                                      |  |
|        |                   |                   |            |            |           |           |            | WE2        | WE1       | WE0                                  |  |
| DAYR   | Day               | 323H              |            |            |           |           |            |            | R/W       |                                      |  |
|        | register          |                   |            |            |           |           |            |            | Undefined | 1                                    |  |
|        |                   |                   |            | <          | 0 is read |           |            | W2         | W1        | W0                                   |  |
|        | _                 |                   |            |            | DA5       | DA4       | DA3        | DA2        | DA1       | DA0                                  |  |
| DATER  | Date<br>register  | 324H              |            |            |           |           |            | /W         |           |                                      |  |
|        |                   |                   |            |            |           |           | 1          | efined     |           | 1                                    |  |
|        |                   |                   | 0 is       | read       | 20 days   | 10 days   | 8 days     | 4 days     | 2 days    | 1 day                                |  |
|        | Month<br>register | 325H<br>Page 0    |            |            |           | MO4       | MO3        | MO2        | MO1       | MO0                                  |  |
|        |                   |                   |            |            |           |           |            | R/W        |           |                                      |  |
| MONTHR |                   |                   |            | 0 is read  |           | 10 month  | 0 month    | Undefined  | 2 month   | 1 month                              |  |
|        |                   |                   |            | 0 is read  |           | 10 month  | 8 month    | 4 month    | 2 month   | 1 month                              |  |
|        |                   | Page 1            |            |            |           | 0 is read |            |            |           | 0: Indicator for<br>1: Indicator for |  |
|        |                   |                   | YE7        | YE6        | YE5       | YE4       | YE3        | YE2        | YE1       | YE0                                  |  |
|        |                   | 326H              |            | 120        | 120       |           | /W         | 162        |           | 120                                  |  |
| YEARR  | Year              | 32011             |            |            |           |           | efined     |            |           |                                      |  |
|        | register          | Page 0            | 80 years   | 40 years   | 20 years  | 10 years  | 8 years    | 4 years    | 2 years   | 1 year                               |  |
|        |                   | Page 1            |            |            | 0 is      | read      |            |            |           | ar setting                           |  |
|        |                   |                   | INTENA     |            |           | Adjust    | ENATMR     | ENAALM     |           | PAGE                                 |  |
|        |                   |                   | R/W        | $\sim$     | $\sim$    | W         | 1          | /W         | $\sim$    | R/W                                  |  |
| DAOFD  | Page              | 327H              | 0          | $\sim$     | $\sim$    | Undefined |            | efined     | $\sim$    | Undefined                            |  |
| PAGER  | register          | (Prohibit<br>RMW) | INTRTC     | 0 is       | read      | 0:Don't   | Clock      | Alarm      | 0 is read | select                               |  |
|        |                   | riviv)            | 0: Disable |            |           | care      | 0: Disable | 0: Disable |           | PAGE                                 |  |
|        |                   |                   | 1: Enable  |            |           | 1: Adjust | 1: Enable  | 1: Enable  |           |                                      |  |
|        |                   |                   | DIS1HZ     | DIS16HZ    | RSTTMR    | RSTALM    | RE3        | RE2        | RE1       | RE0                                  |  |
|        |                   | 328H              |            |            |           | ١         | N          |            |           |                                      |  |
| RESTR  | Reset             | (Prohibit         |            | r          | 1         | Unde      | efined     |            |           |                                      |  |
|        | register          | RMW)              | 1 Hz       | 16 Hz      | 1: Clock  | 1:Alarm   |            | Always     | write 0   |                                      |  |
|        |                   | , , ,             | 0: Enable  | 0: Enable  | reset     | reset     |            |            |           |                                      |  |
|        |                   |                   | 1: Disable | 1: Disable |           |           |            |            |           |                                      |  |

| Symbol   | Name                | Address                             | 7           | 6        | 5            | 4           | 3            | 2                                       | 1              | 0        |  |  |
|----------|---------------------|-------------------------------------|-------------|----------|--------------|-------------|--------------|-----------------------------------------|----------------|----------|--|--|
| Alorm    |                     | AL8                                 | AL7         | AL6      | AL5          | AL4         | AL3          | AL2                                     | AL1            |          |  |  |
| AL 14    | Alarm               | 330H                                |             | R/W      |              |             |              |                                         |                |          |  |  |
| ALM      | pattern<br>register | 330H                                | 0           | 0        | 0            | 0           | 0            | 0                                       | 0              | 0        |  |  |
|          | register            |                                     |             |          |              | Alarm pa    | ittern set   |                                         |                |          |  |  |
|          |                     |                                     | FC1         | FC0      | ALMINV       | -           | -            | -                                       | -              | MELALM   |  |  |
|          |                     |                                     | R/          | W        | R/W          | R/W         | R/W          | R/W                                     | R/W            | R/W      |  |  |
|          | Melody/             |                                     | (           | )        | 0            | 0           | 0            | 0                                       | 0              | 0        |  |  |
|          | alarm               | 331H                                | Free-run co | ounter   | Alarm        |             | Always       | write 0                                 |                | Output   |  |  |
| MELALMC  | control             | 00111                               | control     |          | frequency    |             |              | frequency                               |                |          |  |  |
|          | register            |                                     | 00: Hold    |          | invert       |             |              |                                         |                | 0: Alarm |  |  |
|          |                     |                                     | 01: Restart |          | 1: Invert    |             |              | 1: Melody                               |                |          |  |  |
|          |                     |                                     | 10: Clear   |          |              |             |              |                                         |                |          |  |  |
|          |                     |                                     | 11: Clear a | nd start |              |             |              |                                         |                |          |  |  |
| Moloc    | Melody              | Melody<br>equency 332H<br>egister-L | ML7         | ML6      | ML5          | ML4         | ML3          | ML2                                     | ML1            | ML0      |  |  |
| MELFL    | -                   |                                     |             |          | <del>.</del> | R/          | W            | ı — — — — — — — — — — — — — — — — — — — | i              |          |  |  |
|          | register-L          |                                     | 0           | 0        | 0            | 0           | 0            | 0                                       | 0              | 0        |  |  |
|          | 5                   |                                     |             | _        | Melo         | dy frequenc | y set (Low 8 | bits)                                   | 1              |          |  |  |
|          |                     |                                     | MELON       |          |              |             | ML11         | ML10                                    | ML9            | ML8      |  |  |
|          |                     |                                     | R/W         |          |              |             |              | R/                                      | W              | 1        |  |  |
|          |                     |                                     | 0           |          |              |             | 0            | 0                                       | 0              | 0        |  |  |
|          | Melody              |                                     | Melody      |          |              |             | Melo         | ody frequenc                            | y set (High    | 4 bits)  |  |  |
| MELFH    | frequency           | 333H                                | counter     |          |              |             |              |                                         |                |          |  |  |
|          | register-H          |                                     | control     |          |              |             |              |                                         |                |          |  |  |
|          |                     |                                     | 0: Stop and |          |              |             |              |                                         |                |          |  |  |
|          |                     |                                     | clear       |          |              |             |              |                                         |                |          |  |  |
|          |                     |                                     | 1: Start    |          |              |             |              | 1                                       |                | Î.       |  |  |
|          | Alarm               |                                     |             |          | _            | IALM4E      | IALM3E       | IALM2E                                  | IALM1E         | IALM0E   |  |  |
|          | interrupt           |                                     |             |          | R/W          |             | i            | R/W                                     | i              | +        |  |  |
| ALMINT   | enable              | 334H                                |             |          | 0            | 0           | 0            | 0                                       | 0              | 0        |  |  |
|          | register            |                                     |             |          | Always       | INT         | ALM4 to INT  | ALM0 alarm                              | n interrupt er | nable    |  |  |
| register | - 3                 | giotor                              |             |          | write 0      |             |              |                                         |                |          |  |  |

(13) Melody/alarm generator

| Symbol | Name     | Address | 7          | 6 | 5 | 4           | 3                    | 2            | 1              | 0             |
|--------|----------|---------|------------|---|---|-------------|----------------------|--------------|----------------|---------------|
|        |          |         | L0E        |   |   |             |                      | L0EA22       | L0EA21         | L0EA20        |
|        |          |         | R/W        | / | / |             | /                    |              | R/W            |               |
|        | LOCAL0   |         | 0          | / | / |             | /                    | 0            | 0              | 0             |
| LOCAL0 | control  | 350H    | BANK for   |   |   |             |                      | LOCA         | L0 area BAN    | IK set        |
|        | register |         | LOCAL0     |   |   |             |                      |              |                |               |
|        |          |         | 0: Disable |   |   |             |                      | "000" settin | g is prohibite | ed because    |
|        |          |         | 1: Enable  |   |   |             |                      | it preter    | nd COMMON      | l 0 area      |
|        |          |         | L1E        |   |   |             |                      | L1EA23       | L1EA22         | L1EA21        |
|        |          |         | R/W        |   |   |             |                      |              | R/W            |               |
|        | LOCAL1   |         | 0          |   |   |             |                      | 0            | 0              | 0             |
| LOCAL1 | control  | 351H    | BANK for   |   |   |             |                      | LOC          | AL1 area AN    | K set         |
|        | register |         | LOCAL1     |   |   |             |                      |              |                |               |
|        |          |         | 0: Disable |   |   |             |                      |              | g is prohibite |               |
|        |          |         | 1: Enable  |   |   |             |                      | it preter    | nd COMMON      | l 0 area      |
|        |          |         | L2E        |   |   |             |                      | L2EA23       | L2EA22         | L2EA21        |
|        |          |         | R/W        |   |   |             |                      |              | R/W            |               |
|        | LOCAL2   |         | 0          |   |   |             |                      | 0            | 0              | 0             |
| LOCAL2 | control  | 352H    | BANK for   |   |   |             |                      | LOCA         | L2 area BAN    | IK set        |
|        | register |         | LOCAL2     |   |   |             |                      |              |                |               |
|        |          |         | 0: Disable |   |   |             |                      |              | g is prohibite |               |
|        |          |         | 1: Enable  |   |   |             |                      |              | nd COMMON      |               |
|        |          |         | L3E        |   |   | L3EA26      | L3EA25               | L3EA24       | L3EA23         | L3EA22        |
|        |          |         | R/W        |   |   |             | r                    | R/W          | r              |               |
|        | LOCAL3   |         | 0          |   |   | 0           | 0                    | 0            | 0              | 0             |
| LOCAL3 | control  | 353H    | BANK for   |   |   | 01000 to 01 |                      | 01100        | to 01111: C    | S2E           |
|        | register |         | LOCAL3     |   |   |             | 00000 to 00011: CS2B |              |                |               |
|        |          |         | 0: Disable |   |   | 00100 to 00 | 111: CS2C            |              |                |               |
|        |          |         | 1: Enable  |   |   |             |                      | 10000        | to 11111: Se   | t prohibition |

# (14) MMU

# 6. Points of Note and Restrictions

### (1) Notation

a. The notation for built-in I/O registers is as follows register symbol <Bit symbol>

```
e.g.) TA01RUN<TA0RUN> denotes bit TA0RUN of register TA01RUN.
```

b. Read-modify-write instructions

An instruction in which the CPU reads data from memory and writes the data to the same memory location in one instruction.

| Example 1: | SET | 3, (TA01RUN) Set bit3 of TA01RUN. |
|------------|-----|-----------------------------------|
|------------|-----|-----------------------------------|

Example 2: INC 1, (100H) ... Increment the data at 100H.

• Examples of read-modify-write instructions on the TLCS-900

Exchange instruction

| EX                  |                  |     |            | (mem), R |
|---------------------|------------------|-----|------------|----------|
| Arithmetic o        | operations       |     |            |          |
| ADD                 | (mem), R/#       | ADC | (mem), R/# | :        |
| SUB                 | (mem), R/#       | SBC | (mem), R/# | :        |
| INC                 | #3, (mem)        | DEC | #3, (mem)  |          |
| Logic operat        | tions            |     |            |          |
| AND                 | (mem), R/#       | OR  | (mem), R/# | :        |
| XOR                 | (mem), R/#       |     |            |          |
| Bit manipul         | ation operations |     |            |          |
| STCF                | #3/A, (mem)      | RES | #3, (mem)  |          |
| SET                 | #3, (mem)        | CHG | #3, (mem)  |          |
| TSET                | #3, (mem)        |     |            |          |
| Rotate and s        | shift operations |     |            |          |
| RLC                 | (mem)            | RRC | (mem)      |          |
| $\operatorname{RL}$ | (mem)            | RR  | (mem)      |          |
| SLA                 | (mem)            | SRA | (mem)      |          |
| SLL                 | (mem)            | SRL | (mem)      |          |
| RLD                 | (mem)            | RRD | (mem)      |          |

c.  $\,$  fc, fs, fFPH, fSYS and one state  $\,$ 

The clock frequency input on pins X1 and 2 is called fosch. The clock selected by DFMCR0<ACT1:0> is called fc.

The clock selected by SYSCR1<SYSCK> is called fFPH. The clock frequency give by fFPH divided by 2 is called fSYS.

One cycle of fSYS is referred to as one state.

- (2) Points of note
  - a. AM0 and AM1 pins

This pin is connected to the VCC or the VSS pin. Do not alter the level when the pin is active.

b. EMU0 and EMU1

Open pins.

c. Reserved address areas

The TMP91C824 does not have any reserved areas.

d. HALT mode (IDLE1)

When IDLE1 mode is used (in which oscillator operation only occurs), set RTCCR <RTCRUN> to 0 stop the timer for the real-time clock before the HALT instructions is executed.

e. Warm-up counter

The warm-up counter operates when STOP mode is released, even if the system is using an external oscillator. As a result a time equivalent to the warm-up time elapses between input of the release request and output of the system clock.

f. Programmable pull-up resistance

The programmable pull-up resistor can be turned ON/OFF by a program when the ports are set for use as input ports. When the ports are set for use as output ports, they cannot be turned on/off by a program.

The data registers (e.g., Px) are used to turn the pull-up/pull-down resistors ON/OFF. Consequently read-modify-write instructions are prohibited.

g. Bus release function

It is described note point in 3.5 "Port Function" that pin's conditions at bus release condition.

Please refer that.

h. Watchdog timer

The watchdog timer starts operation immediately after a reset is released. When the watchdog timer is not to be used, disable it.

When the bus is released, neither internal memory nor internal I/O can be accessed. However, the internal I/O continues to operate. Hence the watchdog timer continues to run. Therefore be careful about the bus releasing time and set the detection timer of watchdog timer.

i. AD converter

The string resistor between the VREFH and VREFL pins can be cut by a program so as to reduce power consumption. When STOP mode is used, disable the resistor using the program before the HALT instruction is executed.

j. CPU (Micro DMA)

Only the LDC cr, r and LDC r, cr instructions can be used to access the control registers in the CPU (e.g., the transfer source address register (DMASn)).

k. Undefined SFR

The value of an undefined bit in an SFR is undefined when read.

l. POP SR instruction

Please execute the POP SR instruction during DI condition.

m. Releasing the HALT mode by requesting an interruption

Usually, interrupts can release all halts status. However, the interrupts ( $\overline{\text{NMI}}$ , INT0 to INT3, INTRTC, INTALM0 to INTALM4) which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 5 clocks of fFPH) with IDLE1 or STOP mode (IDLE2 is not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficulty. The priority of this interrupt is compared with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

7. Package Dimensions

P-LQFP100-1414-0.50F

Unit: mm

