# **TOSHIBA**

TOSHIBA Original CMOS 8-Bit Microcontroller

TLCS-870 Series

TMP87C446NG TMP87C846NG TMP87CH46NG

### **TOSHIBA CORPORATION**

Semiconductor Company

# **Document Change Notification**

The purpose of this notification is to inform customers about the launch of the Pb free version of the device. The introduction of a Pb-free replacement affects the datasheet. Please understand that this notification is intended as a temporary substitute for a revision of the datasheet.

Changes to the datasheet may include the following, though not all of them may apply to this particular device.

1. Part number

Example: TMPxxxxxxFG TMPxxxxxxFG

All references to the previous part number were left unchanged in body text. The new part number is indicated on the prelims pages (cover page and this notification).

2. Package code and package dimensions

Example: LQFP100-P-1414-0.50C

LQFP100-P-1414-0.50F

All references to the previous package code and package dimensions were left unchanged in body text. The new ones are indicated on the prelims pages.

3. Addition of notes on lead solderability

Now that the device is Pb free, notes on lead solderability have been added.

Ι

4. RESTRICTIONS ON PRODUCT USE

The previous (obsolete) provision might be left unchanged on page 1 of body text. A new replacement is included on the next page.

5. Publication date of the datasheet

The publication date at the lower right corner of the prelims pages applies to the new device.

2008-03-06

### 1. Part number

### 2. Package code and dimensions

| Previous Part Number (in Body Text) | Previous Package Code<br>(in Body Text) | New Part Number | New Package Code  | ОТР         |
|-------------------------------------|-----------------------------------------|-----------------|-------------------|-------------|
| TMP87C446N                          | SDIP42-P-600-1.78                       | TMP87C446NG     | SDIP42-P-600-1.78 | TMP87PH46NG |
| TMP87C846N                          | SDIP42-P-600-1.78                       | TMP87C846NG     | SDIP42-P-600-1.78 | TMP87PH46NG |
| TMP87CH46N                          | SDIP42-P-600-1.78                       | TMP87CH46NG     | SDIP42-P-600-1.78 | TMP87PH46NG |

<sup>\*:</sup> For the dimensions of the new package, see the attached Package Dimensions diagram.

### 3. Addition of notes on lead solderability

The following solderability test is conducted on the new device.

| Lead solderability                                                                                                                                                                                                                                                   | of Pb-free devices (with the G suffix) |                                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------------------|
| Test                                                                                                                                                                                                                                                                 | Test Conditions                        | Remark                                                                |
| (1) Use of Lead (Pb) -solder bath temperature = 230°C -dipping time = 5 seconds -the number of times = once -use of R-type flux (2) Use of Lead (Pb)-Free -solder bath temperature = 245°C -dipping time = 5 seconds -the number of times = once -use of R-type flux |                                        | Leads with over 95% solder coverage till lead forming are acceptable. |
|                                                                                                                                                                                                                                                                      |                                        |                                                                       |

II2008-03-06

#### 4. RESTRICTIONS ON PRODUCT USE

The following replaces the "RESTRICTIONS ON PRODUCT USE" on page 1 of body text.

### RESTRICTIONS ON PRODUCT USE

20070701-EN

- The information contained herein is subject to change without notice.
- 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 Handlook" 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 malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in his document shall be made at the customer's own risk.
- The products described in this document shall not be used or embedded to any downstream products of which manufacture, use and/or sale are prohibited under any applicable laws and regulations.
- The information contained herein is presented only as a guide for the applications of our products. No responsibility
  is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its
  use. No license is granted by implication or otherwise under any patents or other rights of TOSHIBA or the third
  parties.
- Please contact your sales representative for product-by-product details in this document regarding RoHS
  compatibility. Please use these products in this document in compliance with all applicable laws and regulations that
  regulate the inclusion or use of controlled substances. Toshiba assumes no liability for damage or losses occurring
  as a result of noncompliance with applicable laws 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.

### 5. Publication date of the datasheet

The publication date of this datasheet is printed at the lower right corner of this notification.



III 2008-03-06

(Annex)

# Package Dimensions



IV 2008-03-06

#### CMOS 8-Bit Microcontroller

### TMP87C446N, TMP87C846N, TMP87CH46N

87C446/846/H46 are high speed and high performance 8-bit single chip microcomputers. These MCU contain CPU core, ROM, RAM, input/output ports, an A/D converter, six multi-function timer/counters, a serial interface, a high speed serial output, and two clock generators on a chip.

| Part No.   | ROM          | RAM         | Package OTP version          |
|------------|--------------|-------------|------------------------------|
| TMP87C446N | 4 K × 8-bit  |             |                              |
| TMP87C846N | 8 K × 8-bit  | 512 × 8-bit | P-SDIP42-600-1.78 TMP87PH46N |
| TMP87CH46N | 16 K × 8-bit |             |                              |

### **Features**

- ◆8-bit single chip microcomputer TLCS-870 Series
- Instruction execution time: 0.5  $\mu$ s (at 8 MHz), 122  $\mu$ s (at 32.768 kHz)
- 412 basic instructions
  - Multiplication and Division (8 bits x 8 bits, 16 bits x 8 bits)
  - Bit manipulations (Set/Clear/Complement/Move/Test/Exclusive or)
  - 16-bit data operations
  - 1-byte jump/subroutine-call (Short relative jump / Vector/call)
- 14 interrupt sources (External: 6, Internal:
  - All sources have independent latches each, and nested interrupt control is available.
  - 4 edge-selectable external interrupts with noise reject
  - High-speed task switching by register bank changeover
- ◆5 Input/Output ports (35 pins)
  - High current output: 8pins (typ. 20 mA)



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 TQSHIBA 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. devices in general can malfunction or fall 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

- personal equipment, office equipment, measuring equipment, industrial robotics, domestic applications, tempersonal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's
- 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.

87C446-1 2003-09-17

- ◆Two 16-bit Timer/Counters
  - Timer, Event counter, Programmable pulse generator output,
     Pulse width measurement, External trigger timer, Window modes
- ◆Two 8-bit Timer/Counters
  - Timer, Event counter, Capture (Pulse width/duty measurement),
     PWM output, Programmable divider output modes
- ◆Time Base Timer (Interrupt frequency: 1 Hz to 16 kHz)
- ◆Divider output function (frequency: 1 kHz to 8 kHz)
- ◆Watchdog Timer
- ◆8-bit Serial Interface
  - With 8 bytes transmit/receive data buffer
  - Internal/external serial clock, and 4/8-bit mode
- ◆8-bit High Speed Serial Output (rate: max. 1 bit / æs)
- ◆8-bit successive approximate type A/D converter with sample and hold
  - 8 analog inputs
  - Conversion time: 23  $\mu$ s / 92  $\mu$ s at 8 MHz programmable selectable
- ◆ Dual clock operation
- ◆ Five Power saving operating modes\_
  - STOP mode: Oscillation stops. Battery/Capacitor back-up Port output hold/high-impedance.
  - SLOW mode: Low power consumption operation using low-frequency clock (32.768 kHz).
  - IDLE1 mode: ÇPν stops, and Peripherals operate μsing high-frequency clock. Release by interrupts.
  - IDLE2 mode: CPU stops, and Peripherals operate using high and low frequency clock. Release by interrupts.
  - SLEEP mode: CPU stops, and Peripherals operate using low-frequency clock. Release by interrupts.
- ♦ Wide operating voltage: 2.7 to 5.5 ¼ at 4.2 MHz / 32.768 kHz, 4.5 to 5.5 V at 8 MHz / 32.768 kHz
- ◆Emulation Pod: BM87CH47U0A



### Pin Assignments (Top View)

P-SDIP42-600-1.78







### **Pin Function**

| Pin Name                          | Input / Output | Fund                                                                                                                                                   | ction                                                                                                  |  |  |
|-----------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|--|
| P07 to P00                        | I/O            |                                                                                                                                                        |                                                                                                        |  |  |
| P17, P16                          | I/O            | Two 8-bit programmable input/output ports (tri-state).                                                                                                 |                                                                                                        |  |  |
| P15 (TC2)                         | I/O (Input)    | Each bit of these ports can be                                                                                                                         | Timer/Counter 2 input                                                                                  |  |  |
| P14 ( <del>PPG</del> )            |                | 1                                                                                                                                                      | Programmable pulse generator output                                                                    |  |  |
| P13 ( <del>DVO</del> )            | I/O (Output)   | output under software control.  During reset, all bits are configured as                                                                               | Divider output                                                                                         |  |  |
| P12 (INT2 / TC1)                  |                | inputs.                                                                                                                                                | External interrupt input 2 or<br>Timer/Counter 1 input                                                 |  |  |
| P11 (INT1)                        | I/O (Input)    | When used as a divider output or a PPG output, the latch must be set to "1".                                                                           | External interrupt input                                                                               |  |  |
| P10 (ĪNT0)                        | •              |                                                                                                                                                        | External interrupt input 0                                                                             |  |  |
| P22 (XTOUT)                       | I/O (Output)   | 3-bit input/output port with latch.                                                                                                                    | Resonator connecting pins (32.768kHz). For inputting external clock, XTIN is used and XTOUT is opened. |  |  |
| P21 (XTIN)<br><br>P20 (INT5/STOP) | I/O (Input)    | When used as an input port, the latch must be set to "1".                                                                                              | External interrupt input 5 or STOP mode release signal input                                           |  |  |
| P67 (AIN7) to<br>P60 (AIN0)       | I/O (Output)   | 8-bit programmable input/output port (tri-state). Each bit of the port can be individually configured as an input or an output under software control. | A/D converter analog inputs                                                                            |  |  |
| P77 (HSO) P76 (HSCK) P75 (SO)     | · I/O (Output) | 8-bit programable input/output port (tri-state).                                                                                                       | HSO serial data output  HSO serial clock output  SIO serial data output                                |  |  |
| P74 (SI)                          |                | When used as an input port, a SIO                                                                                                                      | SIO serial data input                                                                                  |  |  |
| P73 (SCK)                         | 1/0 (1/0)      | input/output, an external interrupt input                                                                                                              | SIO serial clock input/output                                                                          |  |  |
| P72 (PWM / PDO)                   | I/O (Output)   | or a PWM/PDO output, the latch must be set to "1".                                                                                                     | 8-bit PWM output or<br>8-bit programmable divider output                                               |  |  |
| P71 (INT4)                        |                |                                                                                                                                                        | External interrupt input 4                                                                             |  |  |
| P70 (INT3 / TC3)                  | I/O (Input)    |                                                                                                                                                        | External interrupt input 3 or Timer/Counter 3 input                                                    |  |  |
| XIN, XOUT                         | Input, Output  | Resonator connecting pins for high-frequer For inputting external clock, XIN is used and                                                               | ncy clock.                                                                                             |  |  |
| RESET                             | 1/0            |                                                                                                                                                        | out/address-trap-reset output/system-clock-                                                            |  |  |
| TEST                              | Input          | Test pin for out-going test. Be tied to low.                                                                                                           |                                                                                                        |  |  |
| VDD, VSS                          |                | +5 V, 0 V (GND)                                                                                                                                        |                                                                                                        |  |  |
| VAREF                             | Power Supply   | Analog reference voltage input                                                                                                                         |                                                                                                        |  |  |
| (                                 | / >            |                                                                                                                                                        |                                                                                                        |  |  |

### **OPERATIONAL DESCRIPTION**

### 1. CPU CORE FUNCTIONS

The CPU core consists of a CPU, a system clock controller, an interrupt controller, and a watchdog timer. This section provides a description of the CPU core, the program memory (ROM), the data memory (RAM), and the reset circuit.

### 1.1 Memory Address Map

The TLCS-870 Series is capable of addressing 64K bytes of memory. Figure 1-1 shows the memory address maps of the 87C446/846/H46. In the TLCS-870 Series, the memory is organized 4 address spaces (ROM, RAM, SFR, and DBR). It uses a memory mapped I/O system, and all I/O registers are mapped in the SFR/DBR address spaces. There are 16 banks of general-purpose registers. The register banks are also assigned to the first 128 bytes of the RAM address space.



Figure 1-1. Memory Address Maps

### 1.2 Program Memory (ROM)

The 87C446 has an  $4K \times 8$ -bit (addresses  $F000_H$ -FFFF<sub>H</sub>), the 87C846 has a  $8K \times 8$ -bit (addresses  $E000_H$ -FFFF<sub>H</sub>), and the 87CH46 has a  $16K \times 8$ -bit (address  $C000_H$ -FFFF<sub>H</sub>) of program memory (mask programmed ROM).

Addresses FF00<sub>H</sub>-FFFF<sub>H</sub> in the program memory can also be used for special purposes.

- (1) Interrupt / Reset vector table (addresses FFE0<sub>H</sub>-FFFF<sub>H</sub>)

  This table consists of a reset vector and 15 interrupt vectors (2 bytes/vector). These vectors store a reset start address and interrupt service routine entry addresses.
- (2) Vector table for **vector call** instructions (addresses FFC0<sub>H</sub>-FFDF<sub>H</sub>)

  This table stores call vectors (subroutine entry address, 2 bytes/vector) for the vector call instructions [CALLV n]. There are 16 vectors. The CALLV instruction increases memory efficiency when utilized for frequently used subroutine calls (called from 3 or more locations).
- (3) Entry area (addresses FF00<sub>H</sub>-FFFF<sub>H</sub>) for **page call** instructions.

  This is the subroutine entry address area for the page call instructions [CALLP n]. Addresses FF00<sub>H</sub>-FFB<sub>H</sub> are normally used because address FFC0<sub>H</sub>-FFFE<sub>H</sub> are used for the vector tables.

Programs and fixed data are stored in the program memory. The instruction to be executed next is read from the address indicated by the current contents of the program counter (PC). There are relative jump and absolute jump instructions. The concepts of page or bank boundaries are not used in the program memory concerning any jump instruction.

Example: The relationship between the jump instructions and the PC.

1) 5-bit PC-relative jump [JRS cc, \$+2+d]
E8C4H: JRS T, \$+2+08H
When JF = 1, the jump is made to E8CEH,
which is 08H added to the contents of the
PC. (The PC contains the address of the
instruction being executed + 2;
therefore, in this case, the PC contents
are E8C4H+2=E8C6H.)

2 8-bit PC-relative jump [JR cc, \$+2+d]
E8C4H: JR Z, \$+2+80H
When ZF = 1, the jump is made to E846H,
which is FE80H (-128) added to the
current contents of the PC.

3 16-bit absolute jump [JP a]
E8C4H: JP 0C235H

An unconditional jump is made to address C235H. The absolute jump instruction can jump anywhere within the entire 64K-bytes space.



Figure 1-2. Program Memory Map

In the TLCS-870 Series, the same instruction used to access the data memory (e.g. [LD A, (HL)]) is also used to read out fixed data (ROM data) stored in the program memory. The register-offset PC-relative addressing (PC + A) instructions can also be used, and the code conversion, table look-up and n-way multiple jump processing can easily be programmed.

Example 1 : Loads the ROM contents at the address specified by the HL register pair

contents into the accumulator (87CH46:  $HL \ge C000_H$ ):

LD A, (HL) ; A $\leftarrow$ ROM (HL)

Example 2 : Converts BCD to 7-segment code (common anode LED). When  $A = 05_H$ , 92<sub>H</sub> is

output to port P0 after executing the following programs

ADD A, TABLE - \$ - 4 ; P0 ←ROM (TABLE + A)

ADD A, TABLE - \$ - 4 LD (P0), (PC + A) JRS T, SNEXT

TABLE: DB 0C0H, 0F9H, 0A4H, 0B0H, 99H, 92H, 82H, 0D8H, 80H, 98H

SNEXT:

Notes: "\$" is a header address of ADD instruction.

DB is a byte data difinition instruction.

Example 3 : N-way multiple jump in accordance with the contents of

accumulator ( $0 \le A \le 3$ ):

SHLC A
JP (PC+A)

; if  $A = 00_H$  then  $PC \leftarrow C234_H$ if  $A = 01_H$  then  $PC \leftarrow C378_H$ 

if  $A = 02_H$  then  $PC \leftarrow DA37_H$ 

if A=03<sub>H</sub> then PC←E1B0<sub>H</sub>

DW 0C234H, 0C378H, 0DA37H, 0E1B0H

Note: DW is a word data definition instruction.

|                            | <u> </u>            |
|----------------------------|---------------------|
|                            |                     |
| (                          | HÍC V               |
| JP                         | (PC+A) -            |
|                            | <sup>34</sup><br>C2 |
|                            |                     |
| $\langle Z \Delta \rangle$ | 78                  |
| 1777                       | C3                  |
|                            | 37                  |
|                            | DA                  |
|                            | В0                  |
| [                          | E1                  |
|                            | /                   |

### 1.3 Program Counter (PC)

The program counter (PC) is a 16-bit register which indicates the program memory address where the instruction to be executed next is stored. After reset, the user defined reset vector stored in the vector table (addresses FFFF<sub>H</sub> and FFFE<sub>H</sub>) is loaded into the PC; therefore, program execution is possible from any desired address. For example, when CO<sub>H</sub> and 3E<sub>H</sub> are stored at addresses FFFF<sub>H</sub> and FFFE<sub>H</sub>, respectively, the execution starts from address CO3E<sub>H</sub> after reset.

The TLCS-870 Series utilizes pipelined processing (instruction pre-fetch); therefore, the PC always indicates 2 addresses in advance. For example, while a 1-byte instruction stored at address C123<sub>H</sub> is being executed, the PC contains C125<sub>H</sub>.



Figure 1-3. Program Counter

### 1.4 Data Memory (RAM)

SZERO:

SNEXT:

The 87C446/846/H46 have a  $512K \times 8$ -bit (address  $0040_H$ - $023F_H$ ) of data memory (static RAM). Figure 1-5 shows the data memory map.

Addresses 0000<sub>H</sub>-00FF<sub>H</sub> are used as a direct addressing area to enhance instructions which utilize this addressing mode; therefore, addresses 0040<sub>H</sub>-00FF<sub>H</sub> in the data memory can also be used for user flags or user counters. General-purpose register banks (8 registers × 16 banks) are also assigned to the 128 bytes of addresses 0040<sub>H</sub>-00BF<sub>H</sub>. Access as data memory is still possible even when being used for registers. For example, when the contents of the data memory at address 0040<sub>H</sub> is read out, the contents of the accumulator in the bank 0 are also read out. The stack can be located anywhere within the data memory except the register bank area. The stack depth is limited only by the free data memory size. For more details on the stack, see section "1.7 Stack and Stack Pointer".

With the TLCS-870 series, programs in data memory cannot be executed. If the program counter indicates a specific data memory address (addresses 0040H - 023FH), an address - trap - reset is generated due to bus error. (Output from the RESET pin goes low.)

```
Example 1: If bit 2 at data memory address 00C0H is "1", 00H is written to data memory at address 00E3H; otherwise, FFH is written to the data memory at address 00E3H.
```

```
TEST (00C0H).2 ; if (00C0<sub>H</sub>) _2 = 0 then jump JRS T,SZERO CLR (00E3H) , (00E3<sub>H</sub>) \leftarrow 00<sub>H</sub> JRS T,SNEXT LD (00E3H),0FFH ; (00E3<sub>H</sub>) \leftarrow FF<sub>H</sub>
```

Example 2: Increments the contents of data memory at address 00F5<sub>H</sub>, and clears to 00<sub>H</sub> when 10<sub>H</sub> is exceeded.

```
INC (00F5H) ; (00F5<sub>H</sub>) \leftarrow (00F5<sub>H</sub>) + 1
AND (00F5H), 0FH ; (00F5<sub>H</sub>) \leftarrow (00F5<sub>H</sub>)\wedge 0FH
```

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

Note: The general-purpuse registers are mapped in the RAM; therefore, do not clear RAM at the current bank addresses.

```
Clears RAM to "00H" except the bank 0
Example:
                                     HL, 0048H
                                                             Sets start address to HL register pair
                         LD
                                     A, H
                                                           ; Sets initial data (00<sub>H</sub>) to A register
                                     BC, 01F7H
                         LD
                                                           ; Sets number of byte to BC register pair
          SRAMCLR:
                         LD
                                     (HL+), A
                         DEC
                                     BC
                                     F, SRAMCLR
                         JRS.
```

87C446-8 2003-09-17



### 1.5 General-purpose Register Banks

General-purpose registers are mapped into addresses 0040<sub>H</sub>-00BF<sub>H</sub> in the data memory as shown in Figure 1-4. There are 16 register banks, and each bank contains eight 8-bit registers W, A, B, C, D, E, H, and L. Figure 1-5 shows the general-purpose register bank configuration.



Figure 1-5. General-purpose Register Banks

In addition to access in 8-bit units, the registers can also be accessed in 16-bit units as the register pairs WA, BC, DE, and HL. Besides its function as a general-purpose register, the register also has the following functions:

### (1) A, WA

The A register functions as an 8-bit accumulator and WA the register pair functions as a 16-bit accumulator (W is high byte and A is low byte). Registers other than A can also be used as accumulators for 8-bit operations.

Examples: ① ADD A, B ; Adds B contents to A contents and stores the result into A.

SUB WA, 1234H ; Subtracts 1234<sub>H</sub> from WA contents and stores the result into WA.

SUB E, A ; Subtracts A contents from E contents, and stores the result into E.

### (2) HL, DE

The HL and DE specify a memory address. The HL register pair functions as data pointer (HL) /index register (HL + d) /base register (HL + C), and the DE register pair function as a data pointer (DE). The HL also has an auto-post- increment and auto-pre-decrement functions. This function simplifies multiple digit data processing, software LIFO (last-in first-out) processing, etc.



The TLCS-870 Series can transfer data directly memory to memory, and operate directly between memory data and memory data. This facilitates the programming of block processing.

Example 2: Block transfer

```
LD
                      B, m
                                          ; m = n - 1 (n : Number of bytes to transfer)
            LD
                      HL, DSTA
                                             Sets destination address to HL
                      DE, SRCA
                                            Sets source address to DE
            LD
SLOOP:
            LD
                      (HL), (DE)
                                           ; (HL) ← (DE)
            INC
                      HL
                                             HL \leftarrow HL + 1
            INC
                      DE
                                             DE ← DE + 1
            DEC
                                            B \leftarrow B - 1
            JRS
                      F, SLOOP
                                          ; if B \ge 0 then loop
```

### (3) B, C, BC

Registers B and C can be used as 8-bit buffers or counters, and the BC register pair can be used as a 16-bit buffer or counter. The C register functions as an offset register for register-offset index addressing (refer to example 1 ③ above) and as a divisor register for the division instruction [DIV gg, C].

Example 1: Repeat processing

SREPEAT: processing (n + 1 times processing)

DEC B

JRS F, SREPEAT

Example 2 : Unsigned integer division (16-bit ÷ 8-bit)

WA, C ; Divides the WA contents by the C contents, places the quotient in A and the remainder in W.

The general-purpose register banks are selected by the 4-bit register bank selector (RBS). During reset, the RBS is initialized to "0". The bank selected by the RBS is called the current bank.

Together with the flag, the RBS is assigned to address 003FH in the SFR as the program status word (PSW). There are 3 instructions [LD RBS, n], [PUSH PSW], [POP PSW] to access the PSW. The PSW can be also operated by the memory access instruction.

```
Example 1: Incrementing the RBS (003FH); RBS \leftarrow RBS + 1

Example 2: Reading the RBS

LD A, (003FH); A \leftarrow PSW (A<sub>3-0</sub> \leftarrow RBS, A<sub>7-4</sub>\leftarrow Flags)
```

Highly efficient programming and high-speed task switching are possible by using bank changeover to save registers during interrupt and to transfer parameters during subroutine processing.

During interrupt, the PSW is automatically saved onto the stack. The bank used before the interrupt was accepted is restored automatically by executing an interrupt return instruction [RETI]/[RETN]; therefore, there is no need for the RBS save/restore software processing.

The TLCS-870 Series supports a maximum of 15 interrupt sources. One bank is assigned to the main program, and one bank can be assigned to each source. Also, to increase the efficiency of data memory usage, assign the same bank to interrupt sources which are not nested.

Example: Saving /restoring registers during interrupt task using bank changeover.

PINT1: LD RBS, n ; RBS ← n (Bank changeover)

Interrupt processing ; Maskable interrupt return (Bank restoring)

87C446-11 2003-09-17

### 1.6 Program Status Word (PSW)

The program status word (PSW) consists of a register bank selector (RBS) and four flags, and the PSW is assigned to address 003F<sub>H</sub> in the SFR.

The RBS can be read and written using the memory access instruction (e. g. [LD A, (003FH)], [LD (003FH), A], however the flags can only be read. When writing to the PSW, the change specified by the instruction is made without writing data to the flags. For example, when the instruction [LD (003FH), 05H] is executed, "5" is written to the RBS and the JF is set to "1", but the other flags are not affected. [PUSH PSW] and [POP PSW] are the PSW access instructions.

### 1.6.1 Register Bank Selector (RBS)

The register bank selector (RBS) is a 4-bit register used to select general-purpose register banks. For example, when RBS = 2, bank 2 is currently selected. During reset, the RBS is initialized to "0".



Figure 1-6. PSW (Flags, RBS) Configuration

### 1.6.2 Flags

The flags are configured with the upper 4 bits: a zero flag, a carry flag, a half-carry flag and a jump status flag. The flags are set or cleared under conditions specified by the instruction. These flags except the half carry flag are used as jump condition "cc" for conditional jump instructions [JR cc,  $\frac{1}{2} + \frac{1}{2} + \frac{1}{2}$  [JRS cc,  $\frac{1}{2} + \frac{1}{2} +$ 

### (1) Zero flag (ZF)

The ZF is set to "1" if the operation result or the transfer data is 00½ (for 8-bit operations and data transfers)/0000½ (for 16-bit operations); otherwise the ZF is cleared to "0".

During the bit manipulation instructions [SET, CLR, and CPL], the ZF is set to "1" if the contents of the specified bit is "0"; otherwise the ZF is cleared to "0".

This flag is set to "1" when the upper 8 bits of the product are 00<sub>H</sub> during the multiplication instruction [MUL], and when 00<sub>H</sub> for the remainder during the division instruction [DIV]; otherwise it is cleared to "0".

#### (2) Carry flag (CF)

The CF is set to "1" when a carry out of the MSB (most significant bit) of the result occurred during addition or when a borrow into the MSB of the result occurred during subtraction; otherwise the CF is cleared to "0". During division, this flag is set to "1" when the divisor is  $00_H$  (divided by zero error), or when the quotient is  $100_H$  or higher (overflow error); otherwise it is cleared. The CF is also affected during the shift/rotate instructions [SHLC, SHRC, ROLC, and RORC]. The data shifted out from a register is set to the CF.

This flag is also a 1-bit register (a boolean accumulator) for the bit manipulation instructions. Set/clear/complement are possible with the CF manipulation instructions.

Example 1: Bit manipulation

LD CF, (0007H).5 ;  $(0001_H)_2 \leftarrow (0007_H)_5 \forall (009A_H)_0$  XOR CF, (009AH).0 (0001H).2, CF

Example 2: Arithmetic right shift

LD CF, A.7 ; A←A/2 RORC A

### (3) Half carry flag (HF)

The HF is set to "1" when a carry occurred between bits 3 and 4 of the operation result during an 8-bit addition, or when a borrow occurred from bit 4 into bit 3 of the result during an 8-bit subtraction; otherwise the HF is cleared to "0". This flag is useful in the decimal adjustment for BCD operations (adjustments using the [DAA r], or [DAS r] instructions).

87C446-12 2003-09-17

Example: BCD operation

(The A becomes  $47_H$  after executing the following program when A =  $19_H$ , B =  $28_H$ )

ADD A, B ; A ← 41<sub>H</sub>, HF ← 1

;  $A \leftarrow 41_H + 06_H = 47_H$  (decimal-adjust) DAA

### (4) Jump status flag (JF)

Zero or carry information is set to the JF after operation (e. g. INC, ADD, CMP, TEST).

The JF provides the jump condition for conditional jump instructions  $\sqrt{\frac{1}{1000}}$  T/F, \$ + 2 + d], [JR T/F, \$ + 2 + d] (T or F is a condition code). Jump is performed if the JF is "1" for a true condition (T), or the JF is "0" for a false condition (F).

The JF is set to "1" after executing the load/exchange/swap/nibble rotate/jump instruction, so that [JRS T, \$ + 2 + d] and [JR T, \$ + 2 + d] can be regarded as an unconditional jump instruction.

Example: Jump status flag and conditional jump instruction

INC JRS T, SLABLE1 : A, (HL)

; Jump when a carry is caused by the immediately preceding operation instruction.

LD JRS T, SLABLE2

; JF is set to "1" by the immediately preceding instruction, making it an unconditional jump instruction.

Example: The accumulator and flags become as shown below after executing the following instructions when the WA register pair, the HL register pair, the data memory at address 00C5H, the carry flag and the half carry flag contents being "219ÅH", "00C5H", "D7H", "1" and "0", respectively.

|             |          |            |           | _ / /      |       | _    |
|-------------|----------|------------|-----------|------------|-------|------|
| Instruction |          | Acc. after | Flag      | after      | execu | tion |
|             | a detion | execution  | JF        | _ZF        | CF    | HF   |
| ADDC        | A, (HL)  | 72         | 1         | 0          | ))1   | 1    |
| SUBB        | A, (HL)  | C2 (       | 790       | 0          | 1     | 0    |
| СМР         | A, (HL)  | 94         | (0)       | <i>)</i> o | 1     | 0    |
| AND         | A, (HL)  | 92         | <b>_0</b> | 0          | 4     | 0    |
| LD          | A, (HL)  | <b>D</b> 7 | 1         | 2          | 1_    | 0    |
| ADD         | A, 66H   | 00         | 1         | 1          | 1     | 1    |
|             | \ \ \ /  |            |           |            |       | / /  |

| Instruction    | Acc. after | Flag after execution |    |    |    |
|----------------|------------|----------------------|----|----|----|
| \ \            | execution  | JF                   | ZF | CF | HF |
| INE A          | 9В         | 0                    | 0  | 1  | 0  |
| ROLC A         | 35         | 1                    | 0  | 1  | 0  |
| RORC A         | CD         | 0                    | 0  | 0  | 0  |
| ADD WA, 0F508H | 16A2       | 1                    | 0  | 1  | 0  |
| MUL W, A       | 13DA       | 0                    | 0  | 1  | 0  |
| SET A.5        | ВА         | 1                    | 1  | 1  | 0  |

### Stack and Stack Pointer

### 1.7.1 Stack

The stack provides the area in which the return address or status, etc. are saved before a jump is performed to the processing routine during the execution of a subroutine call instruction or the acceptance of an interrupt. On a subroutine call instruction [CALL a] / [CALLP n] / [CALLV n], the contents of the PC (the return address) is saved; on an interrupt acceptance, the contents of the PC and the PSW are saved (the PSW is pushed first, followed by PCH and PCI). Therefore, a subroutine call occupies two bytes on the stack; an interrupt occupies three bytes.

When returning from the processing routine, executing a subroutine return instruction [RET] restores the contents to the PC from the stack; executing an interrupt return instruction [RETI] / [RETN] restores the contents to the PC and the PSW (the  $PC_L$  is popped first, followed by  $PC_H$  and PSW).

The stack can be located anywhere within the data memory space except the register bank area, therefore the stack depth is limited only by the free data memory size.

### 1.7.2 Stack Pointer (SP)

The stack pointer (SP) is a 16-bit register containing the address of the next free locations on the stack.

The SP is post-decremented when a subroutine call or a push instruction is executed, or when an interrupt is accepted; and the SP is pre-incremented when a return or a pop instruction is executed. Figure 1-8 shows the stacking order.



Figure 1-7. Stack Pointer

The SP is not initialized hardware-wise but requires initialization by an initialize routine (sets the highest stack address). [LD SP, mn], [LD SP, gg] and [LD gg, SP] are the SP access instructions (mn; 16-bit immediate data, gg; register pair).



### 1.8 System Clock Controller

The system clock controller consists of a clock generator, a timing generator, and a stand-by controller.



Figure 1-9. System Clock Controller

#### 1.8.1 Clock Generator

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

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



Figure 1-10. Examples of Resonator Connection

Note: Accurate Adjustment of the Oscillation Frequency:

Although no hardware to externally and directly monitor the basic clock pulse is not provided, the oscillation frequency can be adjusted by making the program to output fixed frequency pulses to the port while disabling all interrupts and monitoring this pulse. With a system requiring adjustment of the oscillation frequency, the adjusting program must be created beforehand.

Example: To output the high-frequency oscillation frequency adjusting monitor pulse to P13 (DVO) pin

SFCCHK: LD (P1CR), 00001000B; Configures port P13 as an output

SET (P1),3; P13 output atch 1

LD (TBTCR), 11/100000B; Enables divider output

JRS T,\$; Loops endless



### 1.8.2 Timing Generator

The timing generator generates from the basic clock the various system clocks supplied to the CPU core and peripheral hardware. The timing generator provides the following functions:

- Generation of main system clock
- @ Generation of divider output (DVO) pulses
- 3 Generation of source clocks for time base timer
- 4 Generation of source clocks for watchdog timer
- ⑤ Generation of internal source clocks for timer/counters TC1 TC5
- © Generation of internal clocks for serial interfaces SIO and high speed serial output HSO
- Generation of warm-up clocks for releasing STOP mode
- Generation of a clock for releasing reset output

### (1) Configuration of Timing Generator

The timing generator consists of a 21-stage divider with a divided-by-4 prescaler, a main system clock generator, and machine cycle counters. An input clock to the 7th stage of the divider depends on the operating mode and DV7CK (bit 4 in TBTCR) shown in Figure 1-11 as follows.

During reset and at releasing STOP mode, the divider is cleared to "0", however, the prescaler is not cleared.

- In the single-clock mode A divided-by-256 of high-frequency clock (fc/28) is input to the 7th/stage of the divider.
- ② In the dual-clock mode

  During NORMAL2 or IDLE2 mode (SYSCK = 0), an input clock to the 7th stage of the divider can be selected either "fc/28" or "fs" with DV7CK.

  During SLOW or SLEEP mode (SYSCK = 1), fs is automatically input to the 7th stage. To input clock to the 1st stage is stopped; output from the 1st to 6th stages is also stopped.



Figure 1-11. Configuration of Timing Generator



Figure 1-12. Timing Generator Control Register

### (2) Machine Cycle

Instruction execution and peripheral hardware operation are synchronized with the main system clock. The minimum instruction execution unit is called an "machine cycle". There are a total of 10 different types of instructions for the TLCS-870 Series: ranging from 1-cycle instructions which require one machine cycle for execution to 10-cycle instructions which require 10 machine cycles for execution.

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

87C446-16



Figure 1-13. Machine Cycle

### 1.8.3 Stand-by Controller

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

Figure 1-14 shows the operating mode transition diagram and Figure 1-15 shows the system control registers. Either the single-clock or the dual-clock mode can be selected by an option during reset.

### (1) Single-clock mode

Only the oscillation circuit for the high-frequency clock is used, and P21 (XT(N)) and P22 (XTOUT) pins are used as input/output ports. In the single-clock mode, the machine cycle-time is 4/fc [s] (0.5  $\mu$ s at fc = 8 MHz).

### ① NORMAL1 mode

In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock. In the case where the single-clock mode has been selected as an option, the 87C446/846/H46 are placed in this mode after reset.

### ② IDLE1 mode

In this mode, the internal oscillation circuit remains active, and the CPU and the watchdog timer are halted; however, on-chip peripherals remain active (operate using the high-frequency clock). IDLE1 mode is started by setting IDLE bit in the system control register 2 (SYSCR2), and IDLE1 mode is released to NORMAL1 mode by an interrupt request from on-chip peripherals or external interrupt inputs. When IMF (interrupt master enable flag) is "1" (interrupt enable), the execution will resume upon acceptance of the interrupt, and the operation will return to normal after the interrupt service is completed. When IMF is "0" (interrupt disable), the execution will resume with the instruction which follows IDLE mode start instruction.

### 3 STOP1 mode

In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with the lowest power consumption during this mode. The output status of all output ports can be set to either output hold or high-impedance under software control.

STOP1 mode is started by setting STOP bit in the system control register 1 (SYSCR1), and STOP1 mode is released by an input (either level-sensitive or edge-sensitive can be programmably selected) to the STOP pin. After the warming-up period is completed, the execution resumes with the next instruction which follows the STOP mode start instruction.

### (2) Dual-clock mode

Both high-frequency and low-frequency oscillation circuits are used in this mode. Pins P21 (XTIN) and P22 (XTOUT) cannot be used as input/output ports. The main system clock is obtained from the high-frequency clock in NORMAL2 and IDLE2 modes, and is obtained from the low-frequency clock in SLOW and SLEEP modes. The machine cycle time is 4/fc [s] (0.5  $\mu$ s at fc = 8 MHz) in NORMAL2 and IDLE2 modes, and 4/fs [s] (122  $\mu$ s at fs = 32.768 kHz) in SLOW and SLEEP modes. Note that the 87PH46/H47 is placed in the single-clock mode during reset. To use the dual-clock mode, the low-frequency oscillator should be turned on by executing [SET (SYSCR2).XTEN] instruction.

### ① NORMAL2 mode

In this mode, the CPU core operates using the high-frequency clock. On-chip peripherals operate using the high-frequency clock and/or low-frequency clock. In case that the dual-clock mode has been selected by an option, the 87C446/846/H46 are placed in this mode after reset.

### ② SLOW mode

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

Switching back and forth between NORMAL2 and SLOW modes is performed by the system control register 2.

#### ③ IDLE2 mode

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

### 4 SLEEP mode

In this mode, the internal oscillation circuit of the low-frequency clock remains active. The CPU, the watchdog timer, and the internal oscillation circuit of the high-frequency clock are halted; however, on-chip peripheral remain active (operate using the low-frequency clock). Starting and releasing of SLEEP mode is the same as for IDLE1 mode, except that operation returns to SLOW mode.

### ⑤ STOP2 mode

As in STOP1 mode, all system operations are halted in this mode.



Figure 1-14. Operating Mode Transition Diagram

#### System Control Register 1 SYSCR1 STOP RELM RETM OUTEN (Initial value: 0000 00\*\*) WUT $(0038_{H})$ 0: CPU core and peripherals remain active **STOP** STOP mode start 1: CPU core and peripherals are halted (start STOP mode) Release method 0: Edge-sensitive release RELM for STOP mode 1: Level-sensitive release Operating mode 0: Return to NORMAL mode RETM R/W after STOP mode 1: Return to SLOW mode Port output control 0: High-impedance OUTEN during STOP mode 1: Remain unchanged $3 \times 2^{13} / fs$ $00: 3 \times 2^{19} / fc$ or [s] Warming-up time at 219 / fc WUT 213 / fs 01: or releasing STOP mode 1\*: Reserved ( Always set RETM to "0" when transiting from NQRMAL1 mode to STOP1 mode and NQRMAL2 mode to Note 1: STOP2 mode. Always set RETM to "1" when transiting form SLOW mode to STOP2 mode. Note 2: When STOP mode is released with RESET pin input, a return is made to NORMAL mode regardless of the RETM contents. Note 3: fc high-frequency clock [Hz] low-frequency clock don't care Note 4: Bits 1 and 0 in SYSCR1 are read in as undefined data when a read instruction is executed. When the STOP mode is started by specifying OUTEN = "0", the internal input of port is fixed to "0" and the interrupt of the folling edge may be set. **System Control Register 2** SYSCR2 (Initial value: 10/100 \*\*\*\*) XTEN SYSCK IDLE XEN $(0039_{H})$ High-frequency oscillator 0: Turn off oscillation XEN 1: Turn on oscillation control Low-frequency oscillator 0/:/Turn off oscillation **XTEN** control :Turn on oscillation R/W Main system clock select 0 : High-frequency clock SYSCK (write)/main system clock 1 : Low-frequency clock monitor (read) CPU and watchdog timer remain active JDŁE IDLE mode start Note 1: A reset is applied (RESET pin output goes low) if both XEN and XTEN are cleared to "0". Note 2: Do not clear XEN to "0" when SYSCK = 0, and do not clear XTEN to "0" when SYSCK = 1. Note∄: \* ; don't care Bits 3 - 0 in SYSCR2 are always read in as "1" when a read instruction is executed. Note 5: An optional initial value can be selected for XTEN. Always specify when ordering ES (engineering sample). Note 6: The instruction for specifying Masking Option (Operating Mode) in ES Order Sheet is described in ADDITIONAL INFORMATION "Notice for Masking Option of TLCS-870 and TLCS-870/X series" section 8. **XTEN** operating mode after reset 0 Single-clock mode (NORMAL1) (NORMAL2) 1 Dual-clock mode

Figure 1-15. System Control Registers

### 1.8.4 Operating Mode Control

### (1) STOP mode (STOP1, STOP2)

SINT5:

STOP mode is controlled by the system control register 1 (SYSCR1) and the STOP pin input. The STOP pin is also used both as a port P20 and an INT5 (external interrupt input 5) pin. STOP mode is started by setting STOP (bit 7 in SYSCR1) to "1". During STOP mode, the following status is maintained.

- ① Oscillations are turned off, and all internal operations are halted.
- ② The data memory, registers (except for DBR) and port output latches are all held in the status in effect before STOP mode was entered. The port output can be select either output hold or high-impedance by setting OUTEN (bit 4 in SYSCR1).
- 3 The divider of the timing generator is cleared to "0".
- The program counter holds the address of the instruction following the instruction which started the STOP mode.

STOP mode includes a level-sensitive release mode and an edge-sensitive release mode, either of which can be selected with RELM (bit 6 in SYSCR1).

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

In this mode, STOP mode is released by setting the STOP pin high. This mode is used for capacitor back-up when the main power supply is cut off and long term battery back-up. When the STOP pin input is high, executing an instruction which starts the STOP mode will not place in STOP mode but instead will immediately start the release sequence (warm-up). Thus, to start STOP mode in the level-sensitive release mode, it is necessary for the program to first confirm that the STOP pin input is low. The following method can be used for confirmation:

Using an external interrupt input INTS (INTS is a falling edge-sensitive input).

Example: Starting STOP mode with an INT5 interrupt.

(RE/T/

(P2) . 0 PINT5: **TEST** To reject noise, the STOP mode does not start if JRS E, SHNTS port P20 is at high (SYSCR1), 01000000B LD Sets up the level-sensitive release mode. SET (SYSCR1) . 7 Starts STOP mode (HL), 1110011101010111B JL12, 11, 7, 5, 3  $\leftarrow$  0 (clears interrupt latches) FDW



Figure 1-16 Level-sensitive Release Mode

Note: When changing to the level sensitive release mode from the edge-sensitive release mode, the release mode is not switched until a rising edge of the STOP pin input is detected.

87C446-21 2003-09-17

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

In this mode, STOP mode is released by a rising edge of the STOP pin input. This is used in applications where a relatively short program is executed repeatedly at periodic intervals. This periodic signal (for example, a clock from a low-power consumption oscillator) is input to the STOP pin.

In the edge-sensitive release mode, STOP mode is started even when the STOP pin input is high.

Example: Starting STOP mode operation in the edge-sensitive release mode

LD (SYSCR1), 00000000B ; OUTEN←0 (specifies high-inpedance)
DI ; IMF←0 (disables interrupt service)
SET (SYSCR1).STOP ; STOP←1 (activates stop mode)

LDW (IL),1110011101010111B ; IL12,11,7,5,3←0 (clears interrupt latches)

El ; IMF←1 (enables interrupt service)



Figure 1-17. Edge-sensitive Release Mode

### STOP mode is released by the following sequence:

- When returning to NORMAL2, both the high-frequency and low-frequency clock oscillators are turned on; when returning to SLOW mode, only the low-frequency clock oscillator is turned on. When returning to NORMAL 1, only the high-frequency clock oscillator is turned on.
- ② A warming-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Two different warming-up times can be selected with WUT (bits 2 and 3 in SYSCR1) as determined by the resonator characteristics.
- When the warming-up time has elapsed, normal operation resumes with the instruction following the STOP mode start instruction (e.g. [SET (SYSCR1). 7]). The start is made after the divider of the timing generator is cleared to "0".

|   | \ \                       | Table 1 1.           | Traing up Time      | z example                    |                    |  |
|---|---------------------------|----------------------|---------------------|------------------------------|--------------------|--|
|   | Retu                      | irn to NORMAL1 mode  | Return to SLOW mode |                              |                    |  |
| _ | WUT                       | At fc = 4.194304 MHz | At fc = 8 MHz       | WUT                          | At fs = 32.768 kHz |  |
| < | 3×2 <sup>19</sup> 7fc [s] | 375 [ms]             | 196.6 [ms]          | 3 × 2 <sup>13</sup> / fs [s] | 750 [ms]           |  |
| _ | 2 <sup>19</sup> / fc      | ( ^ \125_ ) )        | 65.5                | 2 <sup>13</sup> / fs         | 250                |  |

Table 1-1. Warming-up Time example

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

considered an approximate value.

STOP mode can also be released by setting the RESET pin low, which immediately performs the normal reset operation. In this case, even if the setting is to return to the SLOW mode, it starts from the NORMAL2 mode. (in case of 87PH46, starts from NORMAL1 mode)

87C446-22 2003-09-17



Note: When STOP mode is released with a low hold voltage, the following cautions must be observed.

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

### (2) IDLE mode (IDLE1, IDLE2, SLEEP)

IDLE mode is controlled by the system control register 2 and maskable interrupts. The following status is maintained during IDLE mode.

- ① Operation of the CPU and watchdog timer is halted. On-chip peripherals continue to operate.
- ② The data memory, CPU registers and port output latches are all held in the status in effect before IDLE mode was entered.
- 3 The program counter holds the address of the instruction following the instruction which started IDLE mode.

IDLE mode includes a normal release mode and an interrupt release mode. Selection is made with the interrupt master enable flag (IMF). Releasing the IDLE mode returns from IDLE1 to NORMAL1, from IDLE2 to NORMAL2, and from SLEEP to SLOW mode.

### a. Normal release mode (IMF = "0")

IDLE mode is released by any interrupt source enabled by the individual interrupt enable flag (EF) or an external interrupt 0 (INTO pin) request. Execution resumes with the instruction following the IDLE mode start instruction (e.g. [SET (SYSCR2).4]).



Figure 1-19. IDLE Mode

The interrupt latch (IL) of the interrupt source for releasing the IDLE mode must be cleared to "0" by load instruction.

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

IDLE mode is released and interrupt processing is started by any interrupt source enabled with the individual interrupt enable flag (EF) or an external interrupt 0 (INTO pin) request. After the interrupt is processed, the execution resumes from the instruction following the instruction which started IDLE mode.

IDLE mode can also be released by setting the RESET pin low, which immediately performs the reset operation. After reset, the 87C446/846/H46 are placed in NORMAL mode after reset release.

Note: When a watchdog timer interrupt is generated immediately before the IDLE mode is started, the watchdog timer interrupt will be processed but IDLE mode will not be started.



87C446-25 2003-09-17

#### (3) SLOW mode

SLOW mode is controlled by the system control register 2 and the timer/counter 2.

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

First, set SYSCK (bit 5 in SYSCR2) to switch the main system clock to the low-frequency clock. Next, clear XEN (bit 7 in SYSCR2) to turn off high-frequency oscillation.

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

Note: The high frequency clock can be continued oscillation in order to return to NORMAL2 mode from SLOW mode quickly. Always turn off oscillation of high frequency clock when switching from SLOW mode to STOP mode.

Example 1: Switching from NORMAL2 mode to SLOW mode.

SET (SYSCR2).5 ; SYSCK+) (Switches the main system clock to the

low-frequency clock)

CLR (SYSCR2).7 ; XEN←0 (turns off high-frequency oscillation)

Example 2: Switching to SLOW mode after low-frequency clock oscillation has stabilized.

LD (TC2CR), 14H ; Sets TC2 mode

(timer mode, source clock : fs)

LDW (TREG2), 8000H ; Sets warming-up time

(according to Xtal characteristics)

LD (TC2CR), 34H ; Starts TC2

PINTTC2 : LD (TC2€R), 10H ; Stops TC2

SET (SYSCR2) . 5 ; SYSCK←1

CLR (SYSCR2) . 7 ; XÈN←0

CLR (SYSCR2).7 XÈN←0

VINTTC2: DW PINTTC2 ; INTTC2 vector table

### b. Switching from SLOW mode to NORMAL2 mode

1

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

Note1: After the SYSCK is cleared to "0", the CPU core operate using low frequency clock when the main system clock is switching from low frequency clock to high frequency clock.

Note2: SLOW mode can also be released by setting the RESET pin low, which immediately performs the reset operation. After reset, the 87C446/846/H46 are placed in NORMAL2 mode. (The PH46 is placed in NORMAL1 mode)

87C446-26 2003-09-17

Example: Switching from SLOW mode to NORMAL2 mode (fc = 8 MHz, warming-up time is about 7.9 ms).

SET (SYSCR2).7 ; XEN←1 (turns on high-frequency oscillation)

LD (TC2CR), 10H ; Sets TC2 mode

(timer mode, source clock: fc)

LD (TREG2 + 1), 0F8H ; Sets the warming-up time

(according to frequency and resonator characteristics)

SET (EIRH). EF14 ; Enable INTTC2

ΕI

LD (TC2CR), 30H ; Starts TC2

1

PINTTC2: LD (TC2CR), 10H ; Stops/TC2

CLR (SYSCR2) . 5 ; SYSCK—0 (Switches the main system clock to the

high-frequency clook)

RETI

VINTTC2: DW PINTTC2 INTTC2 vector table



87C446-28 2003-09-17

### 1.9 Interrupt Controller

The 87C446/846/H46 each have a total of 14 interrupt sources: 6 externals and 8 internals. Nested interrupt control with priorities is also possible. Two of the internal sources are pseudo non-maskable interrupts; the remainder are all maskable interrupts.

Interrupt latches (IL) that hold the interrupt requests are provided for interrupt sources. Each interrupt vector is independent.

The interrupt latch is set to "1" when an interrupt request is generated and requests the CPU to accept the interrupt. The acceptance of maskable interrupts can be selectively enabled and disabled by the program using the interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). When two or more interrupts are generated simultaneously, the interrupt is accepted in the highest priority order as determined by the hardware. Figure 1-22 shows the interrupt controller.

Table 1-2. Interrupt Sources

|                       | Interrupt Source                    | Enable Condition           | Interrupt<br>Latch | Vector Table<br>Address | Priority |
|-----------------------|-------------------------------------|----------------------------|--------------------|-------------------------|----------|
| Internal/<br>External | (Reset)                             | Non-Maskable               | $\Leftrightarrow$  | EEFEH                   | High 0   |
| Internal              | INTSW (Software interrupt)          | Pseudo                     | _ <                | FFFCH                   | 1        |
| Internal              | INTWDT (Watchdog Timer interrupt)   | non-maskable               | (L2                | FFFA <sub>H</sub>       | 2        |
| External              | INTO (External interrupt 0)         | IMF = 1, INT0EN = 1        | IL <sub>3</sub> ~  | FFF8 <sub>H</sub>       | 3        |
| Internal              | INTTC1 (16-bit TC1 interrupt)       | $IMF \cdot EF_4 = 1$       | (//IL4)            | FFF6 <sub>H</sub>       | 4        |
| External              | INT1 (External interrupt 1)         | JMF · EF <sub>5</sub> = 1  | 115                | FFF4 <sub>H</sub>       | 5        |
| Internal              | INTTBT (Time Base Timer interrupt)  | IMF · EF <sub>6</sub> = 1  | IL <sub>6</sub>    | FFF2 <sub>H</sub>       | 6        |
| External              | INT2 (External interrupt 2)         | $IMF \cdot EF_7 = 1$       | IL <sub>7</sub>    | FFF0 <sub>H</sub>       | 7        |
| Internal              | INTTC3 (8-bit TC3 interrupt)        | IMF · EF <sub>8</sub> = 1  | IL <sub>8</sub>    | FFEE <sub>H</sub>       | 8        |
| Internal              | INTSIO (Serial Interface interrupt) | IMF · EF9 = 1              | IL9                | FFEC <sub>H</sub>       | 9        |
| Internal              | INTTC5 (8-bit TC5 interrupt)        | /MF · EF 10 = 1            | IL <sub>10</sub>   | FFEA <sub>H</sub>       | 10       |
| External              | INT3 (External interrupt 3)         | IMF · EF <sub>11</sub> = 1 | IL <sub>11</sub>   | FFE8 <sub>H</sub>       | 11       |
| External              | INT4 (External interrupt 4)         | IMF . EF <sub>12</sub> = 1 | IL <sub>12</sub>   | FFE6 <sub>H</sub>       | 12       |
|                       | reserved                            | IMF · EF <sub>13</sub> = 1 | IL <sub>13</sub>   | FFE4 <sub>H</sub>       | 13       |
| Internal              | INTTC2 (16-bit TC2 interrupt)       | IMF • EF <sub>14</sub> = 1 | IL <sub>14</sub>   | FFE2 <sub>H</sub>       | 14       |
| External              | NT5 (External interrupt 5)          | IMF • EF <sub>15</sub> = 1 | IL <sub>15</sub>   | FFEO <sub>H</sub>       | Low 15   |



### (1) Interrupt Latches (IL 15~2)

Interrupt latches are provided for each source, except for a software interrupt. The latch is set to "1" when an interrupt request is generated, and requests the CPU to accept the interrupt. The latch is cleared to "0" just after the interrupt is accepted. All interrupt latches are initialized to "0" during reset.

The interrupt latches are assigned to addresses  $003C_H$  and  $003D_H$  in the SFR. Each latch can be cleared to "0" individually by an instruction; however, the read-modify-write instruction such as bit manipulation or operation instructions cannot be used (Do not clear IL2 for a watchdog timer interrupt to "0"). Thus, interrupt requests can be cancelled and initialized by the program. Note that interrupt latches cannot be set to "1" by any instruction.

The contents of interrupt latches can be read out by an instruction. Therefore, testing interrupt requests by software is possible.

LDW (IL), 1110100000111111B ; 
$$L_{12}$$
,  $L_{10} \sim L_{6} \leftarrow$ 

TEST (IL).7 ; if 
$$IL_7 = 1$$
 then jump JR F, SSET

# JR (2) Interrupt Enable Register (EIR)

The interrupt enable registers (EIR) enable and disable the acceptance of interrupts except for the pseudo non-maskable interrupts (software and watchdog timer interrupts). Pseudo non-maskable interrupts are accepted regardless of the contents of the EIR; however, the pseudo non-maskable interrupts cannot be nested more than once at the same time. For example, the watchdog timer interrupt is not accepted during the software interrupt service.

The EIR consists of an interrupt master enable flag (IMF) and individual interrupt enable flags (EF). These registers are assigned to addresses 003A<sub>H</sub> and 003B<sub>H</sub> in the SFR, and can be read and written by an instruction (including read-modify-write instructions such as bit manipulation instructions).

### 1 Interrupt Master enable Flag (IMF)

The interrupt master enable flag (IMF) enables and disables the acceptance of all interrupts, except for pseudo non-maskable interrupts. Clearing this flag to "0" disables the acceptance of all maskable interrupts. Setting to "1" enables the acceptance of interrupts. When an interrupt is accepted, this flag is cleared to "0" to temporarily disable the acceptance of maskable interrupts. After execution of the interrupt service program, this flag is set to "1" by the maskable interrupt return instruction [RETI] to again enable the acceptance of interrupts. If an interrupt request has already been occurred, interrupt service starts immediately after execution of the [RETI] instruction.

Pseudo non-maskable interrupts are returned by the [RETN] instruction. In this case, the IMF is set to "1" only when pseudo non-maskable interrupt service is started with interrupt acceptance enabled (IMF = 1). Note that IMF remains "0" when cleared in the interrupt service program.

The IMF is assigned to bit 0 at address 003A<sub>H</sub> in the SFR, and can be read and written by an instruction. IMF is normally set and cleared by the [EI] and [DI] instructions, and the IMF is initialized to "0" during reset.

Note: Do not set IMF to "1" during non-maskable interrupt service programs.

### ② Individual interrupt Enable Flags (EF<sub>15</sub> to EF<sub>4</sub>)

These flags enable and disable the acceptance of individual maskable interrupts, except for an external interrupt 0. Setting the corresponding bit of an individual interrupt enable flag to "1" enables acceptance of an interrupt, setting the bit to "0" disables acceptance.

Example 1: Sets EF for individual interrupt enable, and sets IMF to "1".

(EIRH).4

(EIR), 1110100010100001B ; EF<sub>15</sub>~EF<sub>13</sub>, EF<sub>11</sub>, EF<sub>7</sub>, EF<sub>5</sub>, IMF←1

Example 2: Sets an individual interrupt enable flag to "1".



Figure 1-23. Interrupt Latch (IL) and Interrupt Enable Register (EIR)

## 1.9.1 Interrupt Sequence

An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to "0" by a reset or an instruction. Interrupt acceptance sequence requires 8 machine cycles (4 \( \nu \)s at fc = 8 MHz in NORMAL mode) after the completion of the current instruction execution. The interrupt service task terminates upon execution of an interrupt return instruction [RETI] (for maskable interrupts) or [RETN] (for pseudo non-maskable interrupts).

### (1) Interrupt acceptance processing

- 1) The interrupt master enable flag (IMF) is cleared to "0" to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled.
- ② The interrupt latch (IL) for the interrupt source accepted is cleared to "0".
- 3 The contents of the program counter (return address) and the program status word are saved (pushed) onto the stack. The stack pointer (SP) is three decrements.
- The entry address of the interrupt service program is read from the vector table address, and the entry address is loaded to the program counter.
- (5) The instruction stored at the entry address of the interrupt service program is executed.



Figure 1-24. Timing Chart of Interrupt Acceptance and Interrupt Return Instruction

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



A maskable interrupt is not accepted until the IMF is set to "1" even if a maskable interrupt of higher priority than that of the current interrupt being serviced.

When nested interrupt service is necessary, the IMF is set to "1" in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags. However, an acceptance of external interrupt 0 cannot be disabled by the EF; therefore, if disablement is necessary, either the external interrupt function of the INTO pin must be disabled with INTOEN in the external interrupt control register (EINTCR) or interrupt processing must be avoided by the program.

(When INTOEN = 0, the interrupt latch IL3 is not set, therefore, the falling edge of the INTO pin input cannot be detected.)

Example 1: Disables an external interrupt 0 using INTOEN:

LD (EINTCR), 00000000B; INT0EN←0

Example 2: Disables the processing of external interrupt 0 under the software control (using bit 0 at address 00F0<sub>H</sub> as the interrupt processing disable switch):



(2) General-Purpose register save / restore processing

During interrupt acceptance processing, the program counter and the program status word are automatically saved on the stack, but not the accumulator and other registers. These registers are saved by the program if necessary. Also, when nesting multiple interrupt services, it is necessary to avoid using the same data memory area for saving registers.

The following method is used to save/restore the general-purpose registers:

① General-purpose register save/restore by register bank changeove:

General-purpose registers can be saved at high-speed by switching to a register bank that is not in use. Normally, bank 0 is used for the main task and banks 1 to 15 are assigned to interrupt service tasks. To increase the efficiency of data memory utilization, the same bank is assigned for interrupt sources which are not nested.

The switched bank is automatically restored by executing an interrupt return instruction [RETI] or [RETN]. Therefore, it is not necessary for a program to save the RBS.



Figure 1-25. Saving/Restoring General-purpose Registers

② General-purpose register save/restore using push and pop instructions: To save only a specific register, and when the same interrupt source occurs more than once, the general-purpose registers can be saved/restored using push/pop instructions.



© General-purpose registers save/restore using data transfer instruction:

Data transfer instructions can be used to save only a specific general-purpose register during processing of a single interrupt.

Example: Saving/restoring a register using data transfer instructions

PINTxx: LD (GSAVA), A ; Save A register

interrupt processing ;

LD A, (GSAVA) ; Restore A register

RETI ; Return

The interrupt return instructions [RETI] / [RETN] perform the following operations.

|   | [RETI] Maskable interrupt return                                                                                                        | [RETN] Non-maskable interrupt return |                                                                                                                                     |  |
|---|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|
| 1 | The contents of the program counter and the program status word are restored from the stack.  The stack pointer is incremented 3 times. | 1                                    | The contents of the program counter and program status word are restored from the stack.  The stack pointer is incremented 3 times. |  |
| 3 | '                                                                                                                                       | 3                                    | The interrupt master enable flag is set to "1" only when a non-maskable interrupt is accepted in interrupt enable status.           |  |
|   |                                                                                                                                         |                                      | However, the interrupt master enable flag remains at "0" when so clear by an interrupt service program.                             |  |

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

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

## 1.9.2 External Interrupts

The 87C446/846/H46 each have six external interrupt inputs (INTO, INT1, INT2, INT3, INT4, and INT5). Four of these are equipped with digital noise rejection circuits (pulse inputs of less than a certain time are eliminated as noise). Edge selection is also possible with INT1, INT2, INT3 and INT4.

The INTO/P10 pin can be configured as either an external interrupt input pin or an input/output port, and is configured as an input port during reset.

Edge selection, noise rejection control and INTO/P10 pin function selection are performed by the external interrupt control register (EINTCR). When INTOEN = 0, the IL3 will not be set even if the falling edge of INTO pin input is detected.

Table 1-3. External Interrupts

| Source | Pin  | Secondary<br>function pin | Enable conditions            | Edge               | Digital noise reject                                                                                                                          |
|--------|------|---------------------------|------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| INT0   | ĪNT0 | P10                       | IMF = 1, INT0EN ≠1           | falling edge       | — (hysteresis input)                                                                                                                          |
| INT1   | NIT  | PIT                       | IMF · ÈF <sub>5</sub> = 1    | falling edge<br>or | Pulses less than 15/fc [s] or 63/fc [s] are cancelled as noise. Pulses equal to or more than 48/fc [s] or 192/fc [s] are regarded as signals. |
| INT2   | INT2 | P12/TC1                   | IMF · EF <sub>7</sub> = 1    | rising edge        | Pulses less than 7/fc [s] are cancelled as noise. Pulses equal to or more                                                                     |
| INT3   | INT3 | P70/TC3                   | IMF • EF <sub>11</sub> = 1   |                    | than 24/fc [s] are regarded as                                                                                                                |
| INT4   | INT4 | P71                       | $IMF \cdot EF_{12} = 1$      |                    | signals. Same applies to pins TC1, TC3 and TC4.                                                                                               |
| INT5   | NT5  | P20/STOP                  | IIVIF · EF <sub>15</sub> = 1 | falling edge       | — (hysteresis input)                                                                                                                          |





Figure 1-26. External Interrupt Control Register

# 1.9.3 Software Interrupt (INTSW)

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

Note: Software interrupt generates during non-maskable interrupt processing to use SWI instruction for software break in a development tool.

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

① Address Error Detection

FF<sub>H</sub> is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address. Code FF<sub>H</sub> is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing FF<sub>H</sub> to unused areas of the program memory. Address-trapreset is generated for instruction fetch from a part of RAM area (addresses 0040<sub>H</sub>-023F<sub>H</sub>) or SFR area (0000<sub>H</sub>-003F<sub>H</sub>).

Note: The fetch data from addresses, BF80<sub>H</sub> to BFFF<sub>H</sub> for 87C446/846/H46 is not "FF<sub>H</sub>".

② Debugging

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



## 1.10 Watchdog Timer (WDT)

The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or the like, and resumes the CPU to the normal state.

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

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

# 1.10.1 Watchdog Timer Configuration



Figure 1-27. Watchdog Timer Configuration

## 1.10.2 Watchdog Timer Control

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

- (1) Malfunction detection methods using the watchdog timer
  - The CPU malfunction is detected as follows.
    - ① Setting the detection time, selecting output, and clearing the binary counter.
    - ② Repeatedly clearing the binary counter within the setting detection time.

If the CPU malfunction occurs for any cause, the watchdog timer output will become active at the rising of an overflow from the binary counters unless the binary counters are cleared. At this time, when WDTOUT = 1 a reset is generated, which drives the  $\overline{\text{RESET}}$  pin low to reset the internal hardware and the external circuits. When WDTOUT = 0, a watchdog timer interrupt (INTWDT) is generated.

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



Figure 1-28. Watchdog Timer Control Registers

To clear binary counter doesn't initialize the source clock, therefore, it is recommended to clear

read/write to this register.

binary counter within 3/4 of the detection period.

Note/4

>Table 1-4. Watchdog Timer Detection Time

| ⟨                          | Operating mode                             | Detection time       |               |                    |
|----------------------------|--------------------------------------------|----------------------|---------------|--------------------|
| NORMAL1                    | NORMAL2                                    | SLOW                 | At fc = 8 MHz | At fs = 32.768 kHz |
| 2 <sup>25</sup> / fc [sec] | 2 <sup>25</sup> / fc, 2 <sup>17</sup> / fs | 2 <sup>17</sup> / fs | 4.194 s       | 4 s                |
| 2 <sup>23</sup> / fc       | 2 <sup>23</sup> / fc, 2 <sup>15</sup> / fs | 2 <sup>15</sup> / fs | 1.048 s       | 1 s                |
| 2 <sup>21</sup> / fc       | 2 <sup>21</sup> / fc, 2 <sup>13</sup> / fs |                      | 262.1 ms      | 250 ms             |
| 2 <sup>19</sup> / fc       | 2 <sup>19</sup> / fc, 2 <sup>11</sup> / fs |                      | 65.5 ms       | 62.5 ms            |

87C446-39 2003-09-17

#### (2) Watchdog Timer Enable

The watchdog timer is enabled by setting WDTEN (bit 3 in WDTCR1) to "1". WDTEN is initialized to "1" during reset, so the watchdog timer operates immediately after reset/is released.

Example: Enables watchdog timer

LD (WDTCR1), 00001000B ; WDTEN←1

#### (3) Watchdog Timer Disable

The watchdog timer is disabled by writing the disable code (B1H) to WDTCR2 after clearing WDTEN (bit 3 in WDTCR1) to "0". The watchdog timer is not disabled if this procedure is reversed and the disable code is written to WDTCR2 before WDTEN is cleared to "0". The watchdog timer is halted temporarily in STOP mode (including warm-up) and IDLE mode, and restarts automatically after STOP or IDLE mode is released.

During disabling the watchdog timer, the binary counters are cleared to "0".

Example: Disables watchdog timer

LDW (WDTCR1), 0B101H ; WDTEN←0, WDTCR2←disable code

## 1.10.3 Watchdog Timer Interrupt (INTWDT)

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

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

Example: Watchdog timer interrupt setting up.

LD SP, 023F<sub>H</sub> ; Sets the stack pointer

LD (WDTCR1), 00001000B ; WDTOUT←0

# 1.10.4 Watchdog Timer Reset

If the watchdog timer output becomes active, a reset is generated, which drives the RESET pin (sink open drain output) low to reset the internal hardware and the external circuits. The reset output time is 2<sup>20</sup>/fc [s] (131 ms at fc = 8 MHz). The high-frequency clock oscillator also turns on when a watchdog timer reset is generated in \$LOW mode.

Note: The high-frequency clock oscillator also turns on when a watchdog timer reset is generated in SLOW mode. Thus, the reset output time is 2<sup>20</sup>/fc.

The reset output time include a certain amount of error if there is any function of the oscillation frequency when the high-frequency clock oscillator turns on. Thus, the reset, output time must be considered approximate value.



Figure 1-29. Watchdog Timer Interrupt / Reset

87C446-40 2003-09-17

#### 1.11 Reset Circuit

The 87C446/846/H46 each have four types of reset generation procedures: an external reset input, an address trap reset, a watchdog timer reset and a system clock reset. Table 1-5 shows on-chip hardware initialization by reset action. The internal source reset circuit (watchdog timer reset, address trap reset, and system clock reset) is not initialized when power is turned on. Thus, output from the RESET pin may go low (2<sup>20</sup>/fc [s.] (131 ms at 8 MHz) when power is turned on.

| Tab | le 1-5. | Initializing | Internal | Status | by R | eset A | \ct/iq | ίη/ |
|-----|---------|--------------|----------|--------|------|--------|--------|-----|
|-----|---------|--------------|----------|--------|------|--------|--------|-----|

| On-chip Hardware                 |        | Initial Value                             | On-chip Hardware            | Initial Value                     |
|----------------------------------|--------|-------------------------------------------|-----------------------------|-----------------------------------|
| Program counter                  | (PC)   | (FFFF <sub>H</sub> )⋅(FFFE <sub>H</sub> ) | Divider of Timing generator | 0                                 |
| Register bank selector           | (RBS)  | 0                                         |                             |                                   |
| Jump status flag                 | (JF)   | 1                                         | Watchdog timer              | Enable                            |
| Interrupt master enable flag     | (IMF)  | 0                                         | Output latches of I/O ports | Refer to I/O port                 |
| Interrupt individual enable flag | s (EF) | 0                                         |                             | circuitry                         |
| Interrupt latches                | (IL)   | 0                                         | Control registers           | Refer to each of control register |

# 1.11.1 External Reset Input

When the RESET pin is held at low for at least 3 machine cycles (12/fc [s]) with the power supply voltage within the operating voltage range and oscillation stable, a reset is applied and the internal state is initialized.

When the RESET pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFE<sub>H</sub> - FFFF<sub>H</sub>

The RESET pin contains a Schmitt trigger (hysteresis) with an internal pull-up resistor. A simple power-on-reset can be applied by connecting an external capacitor and a diode.



Figure 1-30. Simple Power-on-Reset Circuitry

# 1.11.2 Address-Trap-Reset

An address-trap-reset is one of fail-safe function that detects CPU malfunction caused by noise or the like, and returns the CPU to the normal state.

If the CPU attempts to fetch an instruction from addresses 0000<sub>H</sub> to 023F<sub>H</sub> (a part of RAM or SFRs), an internal reset (called address-trap-reset) will be generated. Then, the RESET pin output will go low. The reset time is 220/fc [s] (131 ms at 8 MHz).



Figure 1-31. Address-Trap-Reset

# 1.11.3 Watchdog Timer Reset

Refer to Section "1.10 Watchdog Timer".

# 1.11.4 System-Clock-Reset

Clearing both XEN and XTEN (bits 7 and 6 in SYSCR2) to "0" stops both high-frequency and low-frequency oscillation, and causes the MCU to deadlock. This can be prevented by automatically generating a reset signal whenever XEN = XTEN = 0 is detected to continue the oscillation. Then, the RESET pin output goes low from high-impedance. The reset time is  $22^{0}$ /fc [s]  $\sqrt{131}$  ms at 8 MHz).



87C446-42 2003-09-17

### 2. ON-CHIP PERIPHERALS FUNCTIONS

# 2.1 Special Function Registers (SFR) and Data Buffer Registers (DBR)

The TLCS-870 Series uses the memory mapped I/O system, and all peripheral control and data transfers are performed through the special function registers (SFR) and data buffer registers (DBR). The SFR are mapped to addresses 0000<sub>H</sub> to 003F<sub>H</sub>, and the DBR to addresses 0F80<sub>H</sub> to 0FFF<sub>H</sub>.

Figure 2-1 shows the 87C446/846/H46 SFRs and DBRs.



Figure 2-1. SFR & DBR

#### 2.2 **I/O Ports**

The 87C446/846/H46 have 5 parallel input/output ports (35pins) each as follows:

|         | Primary Function | Secondary Functions                                                                               |
|---------|------------------|---------------------------------------------------------------------------------------------------|
| Port P0 | 8-bit I/O port   |                                                                                                   |
| Port P1 | 8-bit I/O port   | external interrupt input, timer/counter input/output, and divider output                          |
| Port P2 | 3-bit I/O port   | low-frequency resonator connections, external interrupt input, and STOP mode release signal input |
| Port P6 | 8-bit I/O port   | analog input                                                                                      |
| Port P7 | 8-bit I/O port   | serial interface, external interrupt, and timer/counter input/output                              |

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

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

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



Figure 2-2. Input/Output Timing (Example)

When reading an I/O port except programmable I/O ports, whether the pin input data or the output latch contents are read depends on the instructions, as shown below:

- (1) Instructions that read the output latch contents
  - ① XCH r, (src)
- ⑤ LD′ (pp) . b, CF
- 2 CLR/SET/CPL (src).b
- 6 ADD/ADDC/SUB/SUBB/AND/OR/XOR
- ③ CLR/SET/CPL (pp).g
- ⑦ (src) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL)

(src), n

- 4 LD (src).b, CF
- (2) Instructions that read the pin input data
  - ① Instructions other than the above (1)
    - ② (HL) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL)

87C446-44 2003-09-17

## 2.2.1 Port P0 (P07 - P00)

Port P0 is an 8-bit general-purpose input/output port which can be configured as either an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P0 input/output control register (P0CR). Port P0 is configured as an input if its corresponding P0CR bit is cleared to "0", and as an output if its corresponding P0CR bit is set to "1".

During reset, POCR is initialized to "0", which configures port PO as input. The Ro output latches are also initialized to "0". Data is written into the output latch regardless of the POCR contents. Therefore initial output data should be written into the output latch before setting POCR.

- Note 1: Ports set to the input mode read the pin states. When input pin and output in exist in port PO together, the contents of the output latch of parts set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch.
- Note 2: The POCR is a write-only register. It can not be operated by the read-modify instruction (Bit manipulation instruction of SET, CLR, etc. and Arithmetic instructions of AND, OR, etc.)



Figure 2-3. Port P0 and P0CR

Example: Setting the upper 4 bits of port P0 as an input port and the lower 4 bits as an output port (Initial output data are 1010<sub>B</sub>).

LD (P0), 00001010B ; Sets initial data to P0 output latches LD (P0CR), 00001111B ; Sets the port P0 input/output mode

87C446-45 2003-09-17

## 2.2.2 Port P1 (P17 - P10)

Port P1 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P1 input/output control register (P1CR). Port P1 is configured as an input if its corresponding P1CR bit is cleared to "0", and as an output if its corresponding P1CR bit is set to "1". During reset, the P1CR is initialized to "0", which configures port P1 as an input. The P1 output latches are also initialized to "0". Data is written into the output latch regardless of P1CR contents. Therfore initial output data should be written into the output latch before setting P1CR. Port P1 is also used as an external interrupt input, a timer/counter input, and a divider output. When used as secondary function pin, the input pins should be set to the input mode, and the output pins should be set to the output mode and beforehand the output latch should be set to "1".

It is recommended that pins P11 and P12 should be used as external interrupt inputs, timer/counter input, or input ports. The interrupt latch is set at the rising or falling edge of the output when used as output ports.

Pin P10 (INTO) can be configured as either an I/O port or an external interrupt input with INTOEN (bit 6 in EINTCR). During reset, pin P10 (INTO) is configured as an input port P10.

- Note 1: Ports set to the input mode read the pin states. When input pin and output in exist in port P1 together, the contents of the output latch of ports set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch.
- Note 2: The P1CR is a write-only register. It can not be operated by the read-modify instruction (Bit manipulation instruction of SET, CLR, etc. and Arithmetic instructions of AND, OR, etc.)



Figure 2-4. Port P1 and P1CR

Example: Sets P17, P16 and P14 as output ports, P13 and P11 as input ports, and the others as function pins. Internal output data is "1" for the P17 and P14 pins, and "0" for the P16 pin.

LD (EINTCR), 01000000B ; INT0EN←1

LD (P1), 10111111B ; P17←1, P14←1, P16←0

LD (P1CR), 11010000B

## 2.2.3 Port P2 (P22 - P20)

Port P2 is a 3-bit input/output port. It is also used as an external interrupt input, and low-frequency crystal connection pins. When used as an input port, or a secondary function pin, the output latch should be set to "1". During reset, the output latches are initialized to "1".

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

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

When a read instruction is executed for port P2, bits 7 to 3 read in as "1".



Figure 2-5. Port P2

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

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

Port P6 is also used as an analog input for the A/D converter. When used as an analog input, AINDS (bit 4 in the ADCCR) must be cleared to "0" and its corresponding P6CR bit must be set to "0". In this case, unuse pin as analog input is configured as only input port.

During reset, AINDS is initialized to "0" and all bits of P6CR are initialized to "0", which configures port P6 as analog input. The P6 output latches are initialized to "0". Data is written into the output latch regardless of the P6CR contents. Therefore initial output data should be written into the output latch before setting P6CR.

87C446-47 2003-09-17



Figure 2-6. Port P6

# 2.2.5 Port P7 (P77 to P70)

Port P7 is an 8-bit general-purpose input/output port which can be configured as either input or output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P7 input/output control register (P7CR1/P7CR2). For example, port P7 is configured as an input if its corresponding P7CR bit is cleared to "0", and as an output if its corresponding bit is set to "1". During reset, P7CR is initialized to "0", which configures port P7 as input. The output latches are initialized to "0". Data is written into the output latch regardless of the P7CR contents. Therefore initial output latch before setting P7CR.

Note: P7CR is a write-only register and must not be used with any of the read-modify-write instructions.



87C446-48 2003-09-17



Figure 2-7. Port 7 and P7CR

# 2.3 Time Base Timer (TBT)

The time-base timer is used to generate the base time for key scan and dynamic display processing. For this purpose, it generates a time-base timer interrupt (INTIBI) at predetermined intervals.

This interrupt is generated beginning with the first rising edge of the source clock (the timing generator's divider output selected by TBTCK) after the time-base timer is enabled. Note that since the divider cannot be cleared by a program, the first interrupt only may occur earlier than the set interrupt period. (See Figure 2-8 (b).)

When selecting the interrupt frequency, make sure the time-base timer is disabled. (Do not change the selected interrupt frequency when disabling the active timer either.) However, you can select the interrupt frequency simultaneously when enabling the timer.



87C446-49 2003-09-17



tc; High-frequency clock [Hz], fs; Low-frequency clock [Hz], \*; don't care
Figure 2-9. Time Base-Timer and Divider Output Control Register

Note:

Table 2-1. Time Base Timer Interrupt Frequency

|   | твтск               | NORMAL1/2,           | IDLE1/2 mode        | SLOW, SLEEP mode     | Interrupt Frequency |       |  |
|---|---------------------|----------------------|---------------------|----------------------|---------------------|-------|--|
|   | DV7CK = 0 DV7CK = 1 |                      | 3LOW, 3LEEP Mode    | At fc = 8 MHz        | At fs = 32.768 kHz  |       |  |
|   | 000                 | fc / 2 <sup>23</sup> | fs/2 <sup>15</sup>  | fs / 2 <sup>15</sup> | 0.95 Hz             | 1 Hz  |  |
|   | 001                 | fc / 2 <sup>21</sup> | fs/2 <sup>13</sup>  | fs / 2 <sup>13</sup> | 3.81                | 4     |  |
| _ | 010                 | fc / 2 <sup>16</sup> | fs / 2 <sup>8</sup> | -                    | 122.07              | 128   |  |
|   | 011                 | fc / 2 <sup>14</sup> | fs/2 <sup>6</sup>   | -                    | 488.28              | 512   |  |
|   | 100                 | fc / 2 <sup>13</sup> | fs / 2 <sup>5</sup> | -                    | 976.56              | 1024  |  |
|   | 101                 | fc / 2 <sup>12</sup> | fs / 2 <sup>4</sup> | -                    | 1953.12             | 2048  |  |
|   | 110                 | fc / 2 <sup>11</sup> | fs / 2 <sup>3</sup> | -                    | 3906.25             | 4096  |  |
|   | 111                 | fc / 2 <sup>9</sup>  | fs / 2              | -                    | 15625               | 16384 |  |

87C446-50 2003-09-17

# 2.4 Divider Output (DVO)

A 50% duty pulse can be output using the divider output circuit, which is useful for piezo-electric buzzer drive. Divider output is from pin P13 (DVO). The P13 output latch should be set to "1" and then the P13 should be configured as an output mode.

Divider output circuit is controlled by the control register (TBTCR) shown in Figure 2-11.



Figure 2-10. Divider Output Control Register

Example: 1 kHz pulse output (at fc = 8 MHz)

SET (P1).3 ; P13 output latch ←1 LD (P1CR), 00001000B ; Configures P13 as an output mode

LD (TBTCR), 10000000B ; DVØEN←1, DVØCK←00

Table 2-2. Frequency of Divider Output

| DVOCK    | Frequency of<br>Divider Output           | At fc = 8 MHz | At fs = 32.768 kHz   |
|----------|------------------------------------------|---------------|----------------------|
| 00<br>01 | $fc/2^{13}$ or $fs/2^5$ $fs/2^4$         | 0.976 [kHz]   | 1.024 [kHz]<br>2.048 |
| 10       | fc/2 <sup>11</sup> fs/2 <sup>3</sup>     | 3.906         | 4.096                |
| 11( (    | fc / 2 <sup>10</sup> fs / 2 <sup>2</sup> | 7.812         | 8.192                |



Figure 2-11. Divider Output

# 2.5 16-bit Timer/Counter 1 (TC1)



#### 2.5.2 Control

The timer/counter 1 is controlled by a timer/counter 1 control register (TC1CR) and two 16-bit timer registers (TREG1A and TREG1B). Reset does not affect TREG1A and TREG1B.



Figure 2-13. Timer Registers and TC1 Control Register

#### 2.5.3 Function

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

## (1) Timer Mode

In this mode, counting up is performed using the internal clock. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0". Counting up resumes after the counteriscleared. The current contents of up-counter can be transferred to TREG1B by setting SCAR1 (bit 6 in TC1CR) to "1" (software capture function). SCAP1 is automatically cleared to "0" after capaturing.

Table 2-3. Timer/Counter 1 Source Clock (Internal Clock)

|                          | Source clo               | ck                       | Res           | olution                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Maximum time setting             |  |
|--------------------------|--------------------------|--------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--|
| NORMAL1/2, IDLE1/2 modes |                          | CLOW CLEED               |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                  |  |
| DV7CK = 0                | DV7CK = 1                | SLOW, SLEEP modes        | At fc = 8 MHz | At fs = 32.768 kHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | At fc = 8 MHz At fs = 32.768 kHz |  |
| fc / 2 <sup>3</sup> [Hz] | fc / 2 <sup>3</sup> [Hz] | _                        | 1 μs          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 65.5 ms –                        |  |
| fc / 2 <sup>7</sup>      | fc / 2 <sup>7</sup>      | -                        | 16 μs         | $(\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}_{\mathcal{L}}}}}}}}}}$ | 1.0 s                            |  |
| fc / 2 <sup>11</sup>     | fs / 2 <sup>3</sup>      | fs / 2 <sup>3</sup> [Hz] | 256 μs        | 244.14 μs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 16.8 s 16.0 s                    |  |

Example 1 : Sets the timer mode with source clock fs/23[Hz] and generates an interrupt 1 s. later (at fs = 32.768 kHz).

LD (TC1CR), 00000000B ; Sets the TC1 mode and source clock

LDW (TREG1A), 1000H ; Sets the timer register (1) ÷ 23 / fs = 1000<sub>H</sub>)

SET (EIRL). EF4 ; Enables INTIC interrupt

EI

LD (TC1CR), 00010000B ; Starts TC1

Note: The TC1CR is write-only register and can not be started by [SET (TC1CR). 4] instruction.



Figure 2-14. Timer Mode Timing Chart

#### (2) External Trigger Timer mode

In this mode, counting up is started by an external trigger. This trigger is the edge of the TC1 pin input. Either the rising or falling edge can be selected with INT2ES. Edge selection is the same as for the external interrupt input INT2 pin. Source clock is used an internal clock selected with TC1CK. The contents of TREG1A is compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0" and halted. The counter is restarted by the selected edge of the TC1 pin input.

The TC1 pin input has the same noise rejection as the INT2 pin; therefore pulses of 7/fc [s] or less are rejected as noise. A pulse width of 24/fc [s] or more is required for edge detection in NORMAL1/2 or IDLE1/2 mode. The noise rejection circuit is turned off in SLOW and SLEEP modes. But, a pulse width of 4/fs [s] or more is required.



Figure 2-15. External Trigger Timer Mode Timing Chart

87C446-55 2003-09-17

#### (3) Event Counter Mode

In this mode, events are counted on the edge of the TC1 pin input. Either the rising or falling edge can be selected with INT2ES in EINTCR. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. The maximum applied frequency is fc/2<sup>4</sup> [Hz] in NORMAL1/2 or IDLE1/2 mode and fs/2<sup>4</sup> [Hz] in SLOW or SLEEP mode.

Setting SCAP1 to "1" transferres the current contents of up-counter to TREG1B (software capture function). SCAP is automatically cleared after capturing.



Figure 2-16. Event Counter Mode Timing Chart (INT2ES = 1)

## (4) Window mode

Counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC1 pin input (window pulse) and an internal clock. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Positive or negative logic for the TC1 pin input can be selected with INT2ES. Setting SCAP1 to "1" transferes the current contents of up-counter to TREG1B. It is necessary that the maximum applied frequency (TC1 input) be such that the counter value can be analyzed by the program. That is, the frequency must be considerably slower than the selected internal clock.



Figure 2-17. Window Mode Timing Chart

#### (5) Pulse width measurement mode

Counting is started by the external trigger (set to external trigger start by TC1S). The trigger can be selected either the rising or falling edge of the TC1 pin input. The source clock is used an internal clock. On the next falling (rising) edge, the counter contents are transferred to TREG1B and an INTTC1 interrupt is generated. The counter is cleared when the single edge capture mode is set. When double edge capture is set, the counter continues and, at the next rising (falling) edge, the counter contents are again transferred to TREG1B. If a falling (rising) edge capture value is required, it is necessary to read out TREG1B contents until a rising (falling) edge is detected. Falling or rising edge is selected with MCAP1 (bit 6 in TC1CR).



87C446-57 2003-09-17

```
Duty measurement (Resolution fc/2<sup>7</sup> [Hz])
                     (INTTC1C). 0
             CLR
                                                    INTTC1 service switch initial setting
             LD
                     (EINTCR), 00000000B
                                                    Sets the rise edge at the JNT2 edge
                     (TC1CR), 00000110B
                                                    Sets the TC1 mode and source clock
             LD
             SET
                     (EIRL). 4
                                                    Enables INTTC1
             ΕI
             LD
                     (TC1CR), 00110110B
                                                    Starts TC1 with an external trigger
              :
  PINTTC1: CPL
                     (INTTC1C). 0
                                                    Complements INTTC1 service switch
             JRS
                     F, SINTTC1
             LD
                     (HPULSE), (TREG1BL)
                                                    Reads TREG 1B
             LD
                     (HPULSE + 1), (TREG1BH)
             RETI
                                                    Reads TREG1B (Period)
  SINTTC1: LD
                     (WIDTH), (TREG1BL)
             LD
                     (WIDTH + 1), (TREG1BH)
              ÷
             RET1
  VINTTC1: DW
                     PINTTC1
```

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

Example:

Counting is started by an edge of the TC1 pin input (either the rising or falling edge can be selected) or by a command. The source clock is used an internal clock. First, the contents of TREG1B are compared with the contents of the up-counter. If a match is found, timer F/F1 output is toggled. Next, timer F/F1 is again toggled and the counter is cleared by matching with TREG1A. An INTTC1 interrupt is generated at this time. Timer F/F output is connected to the P14 (PPG) pin. In the case of PPG output, set the P14 output latch to "1" and configure as an output with P1CR4. Timer F/F1 is cleared to "0" during reset. The timer F/F1 value can also be set by program and either a positive or negative logic pulse output is available. Also, writing to the TREG1B is not possible unless the timer / counter 1 is set to the PPG output mode with TC1M.



87C446-58 2003-09-17



Figure 2-19. PPG Output Mode Timing Chart

Example: Pulse output ("H" level  $\leftarrow$  800  $\mu$ s, "L" level  $\leftarrow$  200  $\mu$ s) (at fc = 8 MHz) (P1). 4 ; P14 output latch ← 1 ŁÞ (P1CR), 0001000B ; Sets the P14 output mode LD (TC1CR), 10000011B ; Sets the PPG output mode TFF = 1 (TREG1A), 03E8H LDW ; Sets the period (1 ms  $\div$  1  $\mu$ s = 03E8<sub>H</sub>) (TREG1B), 00C8H ; Sets the "L" level pulse width (200  $\mu$ s ÷ 1  $\mu$ s = 00C8<sub>H</sub>) LDW/ (TC1CR), 10010011B LD ; Command start

87C446-59 2003-09-17



# 2.6 16-bit Timer/Counter 2 (TC2)

# 2.6.1 Configuration



Figure 2-21. Timer/Counter 2 (TC2)

#### 2.6.2 Control

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

| TREG2                      | 15 14                                                  | 13 12 11 10<br>TREG2 <sub>H</sub> (0017 <sub>H</sub> ) | 9 8 7 6 5 4 3 2 1 0<br>TREG2L(0016H)         |               |  |  |  |
|----------------------------|--------------------------------------------------------|--------------------------------------------------------|----------------------------------------------|---------------|--|--|--|
| (0016, 0017 <sub>H</sub> ) |                                                        | , ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,                 | writeonly                                    |               |  |  |  |
| TC2CR :                    | 7 6                                                    | 5 4 3 2<br>TC2S TC2CK                                  | 1 0<br>TC2M (Initial value : **00.00*0)      |               |  |  |  |
|                            | TC2M                                                   | Timer/counter 2 operating mode select                  | 0 : Timer/Event counter mode 1 : Window mode |               |  |  |  |
|                            | TC2CK                                                  | Timer/counter 2 source clock select                    | 000 : Internal clock                         | write<br>only |  |  |  |
| L                          | TC2S Timer/counter 2 0 Stop and counter clear 5: Start |                                                        |                                              |               |  |  |  |
|                            | Start                                                  |                                                        |                                              |               |  |  |  |
|                            |                                                        | modify-write instructions.                             |                                              |               |  |  |  |

Figure 2-22. Timer Register 2 and TC2 Control Register

#### 2.6.3 Function

The timer/counter 2 has three operating modes: timer, event counter and window modes. Also timer/counter/2 is used for warm-up when switching from SLOW mode to NORMAL2 mode.

## (1) Timer Mode

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

Also, when fc is selected as the source clock during SLOW mode, the lower 11 bits of TREG2 are ignored and an INTIC2 interrupt is generated by matching the upper 5 bits. Thus, in this case, only the TREG2<sub>H</sub> setting is necessary.

87C446-61 2003-09-17

|                           | Source clock              |                           |                           |               | Resolution         |                      | ✓ Maximum time setting |  |
|---------------------------|---------------------------|---------------------------|---------------------------|---------------|--------------------|----------------------|------------------------|--|
| NORMAL1/2, IDLE1/2 mode   |                           |                           |                           | inc.          |                    | Maximum time setting |                        |  |
| DV7CK = 0                 | DV7CK = 1                 | SLOW mode                 | SLEEP mode                | At fc = 8 MHz | At fs = 32.768 kHz | At fc = 8 MHz        | At fs = 32.768 kHz     |  |
| fc / 2 <sup>23</sup> [Hz] | fs / 2 <sup>15</sup> [Hz] | fs / 2 <sup>15</sup> [Hz] | fs / 2 <sup>15</sup> [Hz] | 1.05 s        | 1 s                | 19.1 hour            | 18.2 hour              |  |
| fc / 2 <sup>13</sup>      | fs / 2 <sup>5</sup>       | fs / 2 <sup>5</sup>       | fs / 2 <sup>5</sup>       | 1.02 ms       | 1 ms /             | 1,1 min              | 1 min                  |  |
| fc / 2 <sup>8</sup>       | fc / 2 <sup>8</sup>       | -                         | -                         | 32 μs         | ₹ (I               | (// 2,1) s           | =                      |  |
| fc / 2 <sup>3</sup>       | fc / 2 <sup>3</sup>       | -                         | -                         | 1 <i>μ</i> s  | -///               | 65.5 ms              | -                      |  |
| -                         | -                         | fc (Note)                 | -                         | 125 ns        | -                  | 7.9 ms               | -                      |  |
| fs                        | fs                        | _                         | -                         |               | 30.5 ks            |                      | 2 s                    |  |

Table 2-4. Source Clock (Internal Clock) for Timer/Counter 2

Note: "fc" can be used only in the timer mode.

Example: Sets the timer mode with source clock fc/23 [Hz] and generates an interrupt every 25 ms (at fc = 8 MHz).

LD (TC2CR), 00001100B ; Sets the TC2 mode and source clock

LDW (TREG2), 61A8H ; Sets TREG2 (25ms ÷ 2³/fc ≥ 61A8H)

SET (EIRH). EF14 ; Enables INTTC2

EI

LD (TC2CR), 00101100B ; Starts TC2

#### (2) Event Counter Mode

In this mode, events are counted on the rising edge of the TC2 pin input. The contents of TREG2 are compared with the contents of the up-counter. If a match is found, an INTTC2 interrupt is generated, and the counter is cleared. The maximum frequency applied to the TC2 pin is fc/2<sup>4</sup> [Hz] in NORMAL1/2 or IDLE1/2 mode, and fs/2<sup>4</sup> [Hz] in SLOW or SLEEP mode.

Example: Sets the event counter mode and generates an INTT2 interrupt 640 counts later.

 LD
 (TC2CR), 00011100B
 ; Sets the TC2 mode

 LDW
 (TREG2), 0640H
 ; Sets TREG2

 SET
 (EIRH). EF14
 ; Enables INTTC2

 EI
 LD
 (TC2CR), 00111100B
 ; Starts TC2

## (3) Window Mode

In this mode, counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC2 pin input (window pulse) and an internal clock. The internal clock is selected with TC2CK. The contents of TREG2 are compared with the contents of up-counter. If a match is found, an INTTC2 interrupt is generated, and the up-counter is cleared to "0". It is necessary that the maximum applied frequency (TC2 input) be such that the counter value can be analyzed by the program. That is, the frequency must be considerably slower than the selected internal clock.



Figure 2-23. Window Mode Timing Chart

# 2.7 8-Bit Timer/Counter 3 (TC3)

# 2.7.1 Configuration



Figure 2-24. Timer/Counter 3

## 2.7.2 Control



Figure 2-25. Timer Register 3A/3B and TC3 Control Register

The timer/counter 3 is controlled by a timer/counter 3 control register (TC3CR) and two 8-bit timer registers (TREG3A and TREG3B). Reset does not affect these timer registers.

#### 2.7.3 Function

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

#### (1) Timer Mode

In this mode, the internal clock is used for counting up. The contents of TREG3A are compared with the contents of up-counter. If a match is found, a timer/counter 3 interrupt (INTTC3) is generated, and the up-counter is cleared. Counting up resumes after the up-counter is cleared. The current contents of up-counter are loaded into TREG3B by setting SCAP (bit 6 in TC3CR) to "1". SCAP is automatically cleared after capturing.

| Table 2-5. | Source Clock | (Internal Clock) | for Timer | Counter 3 |
|------------|--------------|------------------|-----------|-----------|
|            |              |                  |           |           |

| Source clock                                 |                          | Resolution       |                 | Maximum setting time       |
|----------------------------------------------|--------------------------|------------------|-----------------|----------------------------|
| NORMAL1/2, IDLE1/2 mode                      | SLOW, SLEEP mode         | fc = 8 MHz       | fs = 32.768 kHz | fc = 8 MHz fs = 32.768 kHz |
| fc/2 <sup>12</sup> or fs/2 <sup>4</sup> [Hz] | fs / 2 <sup>4</sup> [Hz] | 512 μs           | 488.28 μs       | 131.1 ms 125 ms            |
| $fc/2^{10}$ or $fs/2^{2}$                    | _                        | 128 μ <b>s</b> ( | $1/22.07 \mu s$ | 32.8 ms 31.25 ms           |
| fc / 2 <sup>7</sup>                          | -                        | 16 μs            | <i>( ) ) -</i>  | 4.1 ms -                   |

### (2) Event Counter Mode

In this mode, the TC3 pin input pulses are used for counting up. Either the rising or falling edge can be selected with INT3ES (bit 3 in EINTCR). The contents of TREG3A are compared with the contents of the up-counter. If a match is found, an INTTC3 interrupt is generated and the counter is cleared. The maximum applied frequency is fc/2<sup>4</sup> [Hz] in the NORMAL1/2 or IDLE1/2 mode, and fs/2<sup>4</sup> [Hz] in SLOW or SLEEP mode. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width.

The current contents of up-counter are loaded into TREG3B by setting SCAP (bit 6 in TC3CR) to "1". SCAP is automatically cleared after capturing.

Example: Generates an interrupt every 0.5 (inputing 50 Hz pulses to the TC3 pin.

LD (TC3CR), 0000 100B; Sets TC3 mode and source clock

LD (TREG3A), 19H ;  $0.5 s \div 1750 = 25 = 19_{H}$ SET (EIRH) EF8 ; Enables INTTC3

EI (TC3CR), 00011100B ; Start (TC3

## (3) Capture Mode

The pulse width, period and duty of the TC3 pin input are measured in this mode, which can be used in decoding the remote control signals, etc. The counter is free running by the internal clock. On the rising (falling) edge of the TC3 pin input, the current contents of counter is loaded into TREG3A, then the up-counter is cleared and an INTTC3 interrupt is generated. On the falling (rising) edge of the TC3 pin input, the current contents of the counter is loaded into the TREG3B. In this case, counting continues. At the next rising (falling) edge of the TC3 pin input, the current contents of counter are loaded into TREG3A, then the counter is cleared again and an interrupt is generated. If the counter overflows before the edge is detected, FF<sub>H</sub> is set to the TREG3A and an overflow interrupt (INTTC3) is generated. During interrupt processing, it can be determined whether or not there is an overflow by checking whether or not the TREG3A value is FF<sub>H</sub>. Also, after an interrupt (capture to TREG3A, or overflow detection) is generated, capture and overflow detection are halted until TREG3A has been read out; however, the counter continues.

After TREG3A has been read out, capture and overflow detection are resumed, usually, TREG3B is read out first.



# 2.8 8-bit Timer/Counter 5 (TC5)

# 2.8.1 Configuration



Figure 2-27. Timer/Counter 5 (TC5)

### 2.8.2 Control

The TC5 is controlled by a timer/counter 5-control register (TC5CR) and an 8-bit timer register 5 (TREG5).



Figure 2-28. Timer/Counter 5 Timer Register, Control Register

#### 2.8.3 Function

TC 5 has 3 operating modes: timer, programmable divider output, and PWM output mode.

#### (1) Timer mode

In this mode, the internal clock is used for counting up. The contents of the timer register 5 (TREG5) is compared with the contents of the up-counter. Matching with TREG5 generates a timer/counter 5 interrupt (INTTC5) and clears the counter. Counting up resumes after the counter is cleared.

Table 2-6. Source Clock (Internal clock) for TC5

| Source clock            |                  | resolution maximum setting time |
|-------------------------|------------------|---------------------------------|
| NORMAL1/2, IDLE1/2 mode | SLOW, SLEEP mode | fc = 8 MHz                      |
| fc/2 <sup>7</sup> [Hz]  | -                | 16 µs 4 ms                      |
| fc/2 <sup>5</sup>       | -                | 4 24 1 ms                       |
| fc/2 <sup>3</sup>       | _                | 1 µs 255 µs                     |

#### (2) Programmable divider output (PDO) mode

The internal clock is used for counting up. The contents of the TREG5 are compared with the contents of the up-counter. The timer F/F5 output is toggled and the counter is cleared each time a match is found. The timer F/F5 output is inverted and output to the PDO (P72) pin. This mode can be used for 50% duty pulse output. INTTC5 interrupt is generated each time the PDO output is toggled.

Example : 1024 Hz pulse output (at fc = 4.194304 MHz) Sets to TC5 modes and source clock

LD (TC5CR), 00001010B

Sets TREG5 (TREG5), 10H

SET (EIRH). EF15 Enables INTTC5

ΕI

LD

(TC5CR), 00101010B Starts the measurement



Figure 2-29. PDO Mode Timing Chart

### (3) Pulse width modulation (PWM) output mode

PWM output with a resolution of 8-bits is possible. The internal clock is used for counting up. The contents of the TREG5 is compared with the contents of the up-counter. If a match is found, the timer F/F5 output is toggled. The counter continues counting and, when an overflow occurs, the timer F/F5 output is again toggled and the counter is cleared. The timer F/F5 output is inverted and output to the PWM (P72) pin. An INTTC5 interrupt is generated when an overflow occurs.

TREG5 is configured a 2- stage shift register and, during output, will not switch until one output cycle is completed even if TREG5 is overwritten; therefore, output can be altered continuously. Also, the first timer, TREG5 is shifted by setting TC5S (bit 5 in TC5CR) to "1" after data are loaded to TREG5.

Note 1: Do not overwrite TREG4 only when an INTTC4 interrupt is generated. Usually, TREG4 is overwritten in the routine of INTTC4 interrupt service.

Note 2: PWM output mode can be used only in the NORMAL1, 2, and IDLE1, 2 mode.



Figure 2-30. PWM Output Mode Timing Chart

Table 2-7. PWM Output Mode

|            | Søurce       | e clock          | At fc = 8 MHz |                  |  |
|------------|--------------|------------------|---------------|------------------|--|
| NORMAL1/2, | IDLE1/2 mode | SLOW, SLEEP mode | resolution    | Repeat cycle     |  |
| DV7CK = 0  | DV7CK = 1    | SLOW, SLEEP Mode | resolution    | Repeat Cycle     |  |
| fd);       | 2² [Hz]      | <u> </u>         | 500 ns        | 127.5 <i>μ</i> s |  |
| fc/2       | 2            |                  | 250 ns        | 63.8 μs          |  |
| fc )       |              | <u> </u>         | 125 ns        | 31.9 <i>μ</i> s  |  |

## 2.9 Serial Interface (SIO)

The 87C446/846/H46 each have two clocked-synchronous 8-bit serial interfaces (SIO). Each serial interface has an 8-byte transmit and receive data buffer that can automatically and continuously transfer up to 64 bits of data.

The serial interfaces are connected to external devices via pins P75 (SO), P74 (\$1), P73 (SCK) for SIO. The serial interface pins are also used as port P7. When used as serial interface pins, the output latches of these pins should be set to "1". In the transmit mode, pins P74 can be used as normal I/O ports, and in the receive mode, the pins P75 can be used as normal I/O ports.

## 2.9.1 Configuration

The SIO have the same configuration, except for the addresses/bit positions of the control/ status registers and buffer registers.



Figure 2-31. Secial Interfaces

### 2.9.2 Control

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

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

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



87C446-70 2003-09-17



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

Note 5: Transmitting starts at the lowest address. Received data are also stored starting from the lowest address to the highest address.

Note 6: The value to be loaded to BUF is held after transfer is completed.

Note 7: SIOCR2 are write-only registers and must not be used with any of read-modify-write instructions.

Figure 2-32. SIO Control Registers and Status Registers

### (1) Serial Clock

### a. Clock Source

SCK (bits 2 - 0 in SIOCR1) is able to select the following:

### 1 Internal Clock

Any of four frequencies can be selected. The serial clock is output to the outside on the SCK pin. The SCK pin goes high when transfer starts.

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

| NORMAL1/2,              | Serial clock                                    |                          | Maximum transfer rate |                    |  |
|-------------------------|-------------------------------------------------|--------------------------|-----------------------|--------------------|--|
| DV7CK = 0               | DV7CK = 1                                       | SLOW, SLEEP mode         | At fc = 8 MHz         | At fs = 32.768 kHz |  |
| fc/2 <sup>13</sup> [Hz] | fs / 2 <sup>5</sup> [Hz]<br>fc / 2 <sup>8</sup> | fs / 2 <sup>5</sup> [Hz] | 0.95 Kbit/s<br>30.5   | 1 Kbit/s           |  |
| fc/26<br>fc/25          | fc / 2 <sup>6</sup><br>fc / 2 <sup>5</sup>      | -<br>-                   | 122<br>244            |                    |  |

Note: 1 Kbit = 1024 bit



Figure 2-33. Clock Source (Internal Clock)

#### 2 External Clock

An external clock connected to the  $\overline{SCK}$  pin is used as the serial clock. In this case, the P73 ( $\overline{SCK1}$ ) output latch must be set to "1". To ensure shifting, a pulse width of at least 4 machine cycles is required. Thus, the maximum transfer speed is 244K-bit/s. (at fc = 8 MHz).



## b. Shift edge

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

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

② Trailing Edge

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



Figure 2-34. Shift Edge

## (2) Number of Bits to Transfer

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

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

### (3) Number of Words to Transfer

Up to 8 words consisting of 4 bits of data (4-bit serial transfer) or 8 bits (8-bit serial transfer) of data can be transferred continuously. The number of words to be transferred is loaded to BUF in SIOBCR. An INTSIO interrupt is generated when the specified number of words has been transferred. If the number of words is to be changed during transfer, the serial interface must be stopped before making the change.

87C446-72 2003-09-17



Figure 2-35. Number of Bits to Transfer (Example : 4-bit serial transfer)

### 2.9.3 Transfer Mode

SIOM (bits 5 - 3 in SIOCR1) is used to select the transmit, receive, or transmit/receive mode.

#### (1) 4-bit and 8-bit Transmit Modes

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

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

Note: Waits are also canceled by writing to a DBR not being used as a transmit data buffer register; therefore, during \$10 do not use such DBR for other applications.

When an external clock is used, the data must be written to the data buffer register before shifting next data. Thus, the transfer speed is determined by the maximum delay time from the generation of the interrupt request to writing of the data to the data buffer register by the interrupt service program.

When the transmit is started, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the SCK.

The transmission is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer empty interrupt service program to end transmitting. That the transmission has ended can be determined from the status of SIOF (bit 7 in SIOSR) because SIOF is cleared to "0" when a transfer is completed.

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

When an external clock is used, it is also necessary to clear SIOS to "0" before shifting the next data; otherwise, dummy data will be transmitted and the operation will end.

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



Figure 2-36. Transmitted Data Hold Time at End of Transmit

87C446-74 2003-09-17

#### (2) 4-bit and 8-bit Receive Modes

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

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

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

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

The receiving is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer full interrupt service program. When SIOINH is set, the receiving is immediately ended and SIOF is cleared to "0". When SIOS is cleared, the current data are transferred to the buffer in 4-bit or 8-bit blocks. The receiving mode ends when the transfer is completed. SIOF is cleared to "0" when receiving is ended and thus can be sensed by program to confirm that receiving has ended.

Note: The buffer contents are lost when the transfer mode is switched. If it should become necessary to switch the transfer mode, end receiving by clearing SIOS to "0", read the last data and then switch the transfer mode.

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

If it is necessary to change the number of words in internal clock operation, during automatic-wait which occurs after completion of data receiving, BUF must be rewritten before the received data is read out.



Figure 2-37. Receive Mode (Example: 8-bit, 1 word, internal clock)

#### (3) 8-bit Transmit/Receive Mode

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

When the internal clock is used, a wait is initiated until the received data are read and the next data are written.

A wait will not be initiated if even one data word has been written.

Note: Waits are also canceled by writing to a DBR not being used as the transmit/received data buffer register; therefore, do not use such DBR for other applications.

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

When the transmit is started, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the SCK

The transmit/receive operation is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer full interrupt service program.

When SIOS is cleared, the current data are transferred to the data buffer register in 8-bit blocks. The transmit mode ends when the transfer is completed. SIOF is cleared to "0" when receiving is ended and thus can be sensed by program to confirm that receiving has ended.

Note: The buffer contents are lost when the transfer mode is switches. If it should become necessary to switch the transfer mode, end receiving by clearing SIOS to "0", read the last data and then switch the transfer mode.

When SIOINH is set, the transmit/receive operation is immediately ended and SIOF is cleared to "0". If it is necessary to change the number of words in external clock operation, SIOS should be cleared to "0", then BUF must be rewritten after confirming that SIOF has been cleared to "0".

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

87C446-76 2003-09-17



Figure 2-38. Transmit/Receive Mode (Example: 8-bit, 1 word, internal clock)



Figure 2-39. Transmitted Data Hold Time at End of Transmit/Receive



87C446-77 2003-09-17

## 2.10 8-bit High-speed Serial Output (HSO)

The 87C446/846/H46 each have a clock-synchronous 8-bit serial output (HSO). The HSO has a 1-byte transmit data buffer register (HSODR). The HSODR is assigned to address 0FF8H in the DBR area. The HSO is connected to the external devices via pins P76 (HSCK) and P77 (HSO). These pins are also used as the port P7. When used as pins HSCK/HSO, the P76/P77 output latches should be set to "1".

2.10.1 Configuration



Figure 2-40. High-speed Serial Output

### 2.10.2 Control

The HSO is controlled by a HSO control register (HSOCR). The transfer status can be determined by reading a HSO status register (HSOSR).



Figure 2-41. HSO Control Register and Status Register

### 2.10.3 Transmit Operations

SCK (bits 1 and 0 in HSOCR) is used to select the transfer rate. Transmission is started by writing one byte of data to the HSODR. The transmit data are output sequentially to the HSO pin in synchronized with the falling edges of the serial clock, starting with the least significant bit (LSB). Writing to the buffer is disabled by the hardware during data transfers. The shift register is empty after one byte of data has been transferred, so writing to the buffer is again enabled at that point. SEF (bit 6 in HSOSR) is set to "1" during transfers (write to buffer disabled) and is cleared to "0" when a transfer is completed (write to buffer enabled); therefore, whether or not a transfer has been completed can be confirmed with a program that reads SEF. The HSCK pin is raised to "high" at the start and end of transfers.

87C446-78 2003-09-17

Note: To continue a transfer without sensing SEF, write the next data to be transferred after 9 cycles (11 cycles when fc/23 [Hz] is selected only) at the transfer rate selected with SCK after writing to the buffer.



Figure 2-42. High-speed Serial Output Timing Chart



87C446-79 2003-09-17

## 2.11 8-bit A/D Converter (ADC)

The 87C446/846/H46 each have an 8-channel multiplexed-input 8-bit successive approximate type A/D converter with sample and hold.

2.11.1 Configuration Ladder resistors R/2 R/2 VAREF \_\_\_ ₩ ₩ U VASS Tap Decoder Analog input Sample & Hold Reference Multiplexer Voltage AIN0 🗖 AIN1 D В c AIN2 🖵 Analog D AIN3 🗖 Comparator Ε AIN4 🗖 AIN5 🗗 Sampling AIN6 🗗 G Successive Approximate Circuit clock AIN7 🗗  $H\ \overline{EN}$ Shift clock EN S AINDS Control Circuit 8` SAIN ACK ADS EOCF P6CR ADCCR ADCDR

Figure 2-43. A/D Converter

A/D Converter control register

## **2.11.2 Control**

P6 input / output control register

The A/D converter is controlled by an A/D converter control register (ADCCR) and a port P6 input/output control register (P6CR).



87C446-80 2003-09-17

A/D Conversion result register



Figure 2-44. A/D Converter Control Register and A/D Conversion Result Register

## 2.11.3 Operation

Apply analog reference voltage to pins VAREF and VASS.

### (1) Start of A/D conversion

First, set the corressponding P6CR bit to "1" for analog input. Clear the AINDS (bit 4 in ADCCR) to "0" and select one of eight analog input AIN7-AIN0 with the SAIN (bits 3-0 in ADCCR).

A/D conversion is started by setting the ADS (bit 6 in ADCCR) to "1".

Conversion is accomplished in 46 machine cycles (184/fc [s] at ACK = 0).

The EQCF (bit 7 in ADCCR) is set to "1" at end of conversion.

Note 1: The pin that is not used as an analog input can be used as regular input/output pins.

During conversion, do not perform output instruction to maintain a precision for all of the pins.

Note 2: To keep the same level of an analog input during 4 Machine Cycle Time is necessary for charging the electron to the sample hold circuit which has a resistor (typ.5k  $\Omega$ ) and a capacitor (typ.12pF)

### (2) Reading of A/D conversion result

After the end of conversion, read the conversion result from the ADCDR.

The EOCF is automatically cleared to "0" when reading the ADCDR.

## (3) A/D conversion in STOP mode

When the MCU places in the STOP mode during the A/D conversion, the conversion is terminated and the ADCDR contents become indefinite.

However, if the STOP mode is started after the end of conversion (EOCF =1), the ADCDR contents are held.



Figure 2-45. A/D Conversion Timing Chart





Figure 2-46. Analog Input Voltage vs A/D Conversion Result (typ.)

87C446-82 2003-09-17

### INPUT/OUTPUT CIRCUITRY

Note: The instruction for specifying Masking Option (Operating Mode) in ES Order Sheet is described in ADDITIONAL INFORMATION "Notice for Masking Option of TLCS-870 and TLCS-870X series" section 8.

## (1) Control pins

The input/output circuitries of the 87C446/846/H46 control pins are shown below, any one of the circuitries can be chosen by a code (NM1 or NM2) as a mask option.



Note 1: The 87PH46 does not have a pull-down resistor ( $R_{IN}$ ) and diode ( $D_I$ ) for TEST pin.

Be sure to fix the TEST pin to low.

Note 2: The input/output circuitries of the 87PH46 is the code NM1 type.

## (2) Input/Output Ports

The input/output circuitries of the 87C446/846/H46 input/output ports are shown below.



## **Electrical Characteristics**

**Absolute Maximum Ratings** 

 $(V_{SS} = 0 V)$ 

| Parameter                       | Symbol              | Conditions           | Ratings                        | Unit |
|---------------------------------|---------------------|----------------------|--------------------------------|------|
| Supply Voltage                  | $V_{DD}$            |                      | -0.3 to 6.5                    | V    |
| Input Voltage                   | V <sub>IN</sub>     | ^ (7/                | ~ 0.3 to V <sub>DD</sub> + 0.3 | ٧    |
| Output Voltage                  | V <sub>OUT</sub>    |                      | - 0.3 to V <sub>DD</sub> + 0.3 | ٧    |
| Output Compant (Par 1 min)      | I <sub>OUT1</sub>   | Ports P1, P2, P6, P7 | 3.2                            |      |
| Output Current (Per 1 pin)      | I <sub>OUT2</sub>   | Port P0              | 30                             | mA   |
| Outroot Comment (Tatal)         | Σ I <sub>OUT1</sub> | Ports P1, P2, P6, P7 | 100                            | 4    |
| Output Current (Total)          | Σ I <sub>OUT2</sub> | Port P0              | 120                            | mA   |
| Power Dissipation [Topr = 70°C] | PD                  | 87C446/846/H46       | 600                            | mW   |
| Soldering Temperature (time)    | Tsld                | (7/^                 | 260 (10 s)                     | °C   |
| Storage Temperature             | Tstg                |                      | - 55 to 125                    | °C   |
| Operating Temperature           | Topr                |                      | - 30 to 70                     | °C   |

Note: The absolute maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded.

**Recommended Operating Conditions** 

 $(V_{SS} = 0 \text{ V, Topr} = -30 \text{ to 70°C})$ 

| Parameter          | Symbol           | Pins                    | C                                                                                    | conditions      | Min                  | Max                    | Unit  |
|--------------------|------------------|-------------------------|--------------------------------------------------------------------------------------|-----------------|----------------------|------------------------|-------|
|                    |                  |                         | fc = 8 MHz                                                                           | NORMAL1, 2 mode | 4.5                  |                        |       |
|                    |                  |                         | f. 4.2 NALL                                                                          | NORMAL1, 2 mode |                      |                        |       |
| Supply Voltage     | $V_{DD}$         |                         | fc = 4.2 MHz                                                                         | IDLE1, 2 mode   | 2.7                  | 5.5                    | V     |
|                    |                  |                         | fs/=                                                                                 | SLOW mode       | 2.7                  |                        |       |
|                    |                  |                         | 32.768 kHz                                                                           | SLEEP mode      |                      |                        |       |
|                    | \\/\/            |                         |                                                                                      | STOP mode       | 2.0                  |                        |       |
|                    | V <sub>IH1</sub> | Except hysteresis input | V <sub>DD</sub> ≥ 4.5 V<br>V <sub>DD</sub> <4.5 V                                    |                 | $V_{DD} \times 0.70$ | ]                      | V     |
| Input High Voltage | V <sub>IH2</sub> | Hysteresis input        |                                                                                      |                 | $V_{DD} \times 0.75$ | $V_{DD}$               |       |
|                    | V <sub>IH3</sub> |                         |                                                                                      |                 | $V_{DD} \times 0.90$ |                        |       |
|                    | VILI             | Except hysteresis input | V <sub>DD</sub> ≥ 4.5 V<br>V <sub>DD</sub> <4.5 V                                    |                 |                      | $V_{DD} \times 0.30$   |       |
| Input Low Voltage  | $V_{IL2}$        | Hysteresis input        |                                                                                      |                 | 0                    | V <sub>DD</sub> × 0.25 | V     |
|                    | $)$ $V_{IL3}$    |                         |                                                                                      |                 |                      | $V_{DD} \times 0.10$   |       |
|                    | fc XIN, XQUT     | XIN, XOUT               | $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$<br>$V_{DD} = 2.7 \text{ to } 5.5 \text{ V}$ |                 | 1.0                  | 8.0                    | MHz   |
| Clock Frequency    | 10 (             | AIN. XOOT               |                                                                                      |                 | 1.0                  | 4.2                    | IVITZ |
|                    | fs               | XTIN, XTOUT             |                                                                                      |                 | 30.0                 | 34.0                   | kHz   |

Note: The recommended operating conditions for a device are operating conditions under which it can be guaranteed that the device will operate as specified. If the device is used under operating conditions other than the recommended operating conditions (supply voltage, operating temperature range, specified AC/DC values etc.), malfunction may occur. Thus, when designing products which include this device, ensure that the recommended operating conditions for the device are always adhered to.

### D.C. Characteristics

 $(V_{SS} = 0 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C})$ 

| Parameter           | Symbol           | Pins                              | Conditions                                            | Min      | Тур.           | Max  | Unit |
|---------------------|------------------|-----------------------------------|-------------------------------------------------------|----------|----------------|------|------|
| Hysteresis Voltage  | V <sub>HS</sub>  | Hysteresis inputs                 | V <sub>DD</sub> = 5.0 V                               | ( - )    | €0.9           | -    | ٧    |
|                     | I <sub>IN1</sub> | TEST                              | V <sub>DD</sub> = 5.5 V                               |          |                |      |      |
| Input Current       | I <sub>IN2</sub> | Open drain ports, Tri-state ports | $V_{IN} = 5.5 \text{ V/O V}$                          | <u> </u> | -              | ± 2  | μA   |
|                     | I <sub>IN3</sub> | RESET, STOP                       | VIN = 3.3 V/O V                                       |          |                |      |      |
| Input Resistance    | R <sub>IN2</sub> | RESET                             |                                                       | 100      | 220            | 450  | kΩ   |
| Output Leakage      | I <sub>LO1</sub> | Sink open drain ports             | $V_{DD} = 5.5 \text{ V}, V_{OUT} = 5.5 \text{ V}$     | _        | _              | 2    | μΑ   |
| Current             | I <sub>LO2</sub> | Tri-state ports                   | $V_{DD} = 5.5 \text{ V}, V_{OUT} = 5.5 \text{ V/O V}$ | _        | _              | ± 2  | μA   |
| Output High Voltage | V <sub>OH2</sub> | Tri-state ports                   | $V_{DD} = 4.5 \text{ V}, V_{OH} = -0.7 \text{ mA}$    | 4.1      | (F)            | /    | V    |
| Output Low Voltage  | $V_{OL}$         | Except XOUT and P0                | $V_{DD} = 4.5 \text{ V}, I_{OL} = 1.6 \text{ mA}$     | - <      | C1             | 0.4  | V    |
| Output Low current  | I <sub>OL3</sub> | Р0                                | $V_{DD} = 4.5 V, V_{OL} = 1.0 V$                      | -56      | 20             | <br> | mA   |
| Supply Current in   |                  |                                   | V <sub>DD</sub> = (5.5 V                              |          | ))8            | 14   |      |
| NORMAL 1, 2 modes   |                  |                                   | fc=8MHz                                               |          | ( <b>)°</b> () | ) 14 | mΑ   |
| Supply Current in   |                  |                                   | fs = 32.768 kHz                                       |          |                | 6    | IIIA |
| IDLE 1, 2 modes     |                  |                                   | $V_{IN} = 5.3 \text{ V}/0.2 \text{ V}$                |          | 7              | 0    |      |
| Supply Current in   |                  | (1)                               | V <sub>DD</sub> = 3.0 V                               | ()       | 2.5            | 3.5  |      |
| NORMAL 1, 2 modes   |                  |                                   | fc = 4.19 MHz                                         |          | 2.5            | 3.5  |      |
| Supply Current in   | 1.               |                                   | fs = 32.768 kHz                                       |          | 1.5            | 2.0  | mA   |
| IDLE 1, 2 modes     | I <sub>DD</sub>  |                                   | V <sub>IN</sub> = 2.8 V/0.2 V                         | -        | 1.5            | 2.0  |      |
| Supply Current in   | 1                |                                   | V 2011                                                |          | 20             |      |      |
| SLOW mode           |                  |                                   | V <sub>DD</sub> = 3.0 V                               | -        | 30             | 60   | μA   |
| Supply Current in   | 1                |                                   | fs = 32.768 kHz                                       |          | 4-             |      |      |
| SLEEP mode          |                  |                                   | $V_{IN} = 2.8 \text{ V}/0.2 \text{ V}$                | _        | 15             | 30   |      |
| Supply Current in   | 1                |                                   | V <sub>DD</sub> ≠ 5,5 V                               |          |                | 40   | μA   |
| STOP mode           |                  |                                   | V <sub>IN</sub> = 5.3 V(0.2 V                         |          | 0.5            | 10   |      |

Note 1: Typical values show those at Topr = 25℃.

Note 2: Input Current I<sub>IN1</sub>, I<sub>IN3</sub>; (The current through resistor is not included, when the input resistor (pull-upor pull-down) is contained.

Note 3: I<sub>DD</sub>; Except for I<sub>REF</sub>

## A / D Conversion Characteristics

 $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{Topr} = -30 \text{ to } 70^{\circ}\text{C})$ 

| Parameter                | Symbol           | Conditions                                                              | Min              | Тур.     | Max               | Unit |
|--------------------------|------------------|-------------------------------------------------------------------------|------------------|----------|-------------------|------|
| Analog Reference Voltage | VAREE            |                                                                         | 2.7              | _        | V <sub>DD</sub>   | v    |
| Analog Reference Voltage | V <sub>ASS</sub> |                                                                         |                  | $V_{SS}$ |                   | ]    |
| Analog Input Voltage     | VAIN             | $\triangleright$                                                        | V <sub>ASS</sub> | _        | V <sub>AREF</sub> | V    |
| Analog Supply Current    | (\\I_REF         | $V_{AREF} = 5.5 \text{ V}, V_{ASS} = 0.0 \text{ V}$                     | _                | 0.5      | 1.0               | mA   |
| Nonlinearity Error       |                  | V <sub>DD</sub> = 5.0 V                                                 | _                | _        | ± 1               |      |
| Zero Point Error         |                  | $V_{AREF} = 5.000 \text{ V}$<br>$V_{ASS} (V_{SS}) = 0.000 \text{ V}$ or | _                | _        | ± 1               |      |
| Full Scale Error         |                  | $V_{DD} = 2.7 V$                                                        | _                | _        | ± 1               | LSB  |
| Total Error              |                  | $V_{AREF} = 2.700 \text{ V}$<br>$V_{ASS} (V_{SS}) = 0.000 \text{ V}$    | _                | -        | ± 2               |      |

Note: Quantizing Error is not contained in total Errors.

87C446-86 2003-09-17

### A.C. Characteristics

 $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C})$ 

| Parameter                    | Symbol           | Conditions                    | Min                                    | Тур.  | Max    | Unit |
|------------------------------|------------------|-------------------------------|----------------------------------------|-------|--------|------|
|                              |                  | In NORMAL 1, 2 mode           | 0.5                                    |       | 10     |      |
| Ma abina Guala Tima          |                  | In IDLE 1, 2 mode             | 0.5                                    |       |        |      |
| Machine Cycle Time           | t <sub>cy</sub>  | In SLOW mode                  | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | (/ () | μS     |      |
|                              |                  | In SLEEP mode                 | 117.6                                  |       | 133.3  |      |
| High Level Clock Pulse Width | t <sub>WCH</sub> | For external clock operation  | (F0                                    |       |        |      |
| Low Level Clock Pulse Width  | t <sub>WCL</sub> | (XIN input), fc = 8 MHz       | 50                                     | ~ -   | _      | ns   |
| High Level Clock Pulse Width | t <sub>WSH</sub> | For external clock operation  |                                        |       |        |      |
| Low Level Clock Pulse Width  | t <sub>WSL</sub> | (XTIN input), fs = 32.768 kHz | 14.7                                   | _ <   | 11 ->> | μS   |

## **Recommended Oscillating Conditions**

 $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{ C}$ 

| Parameter      | Oscillator         | Erecuses       | Recommended Oscillator                                                                                 | Recommende | Recommended Condition |  |  |
|----------------|--------------------|----------------|--------------------------------------------------------------------------------------------------------|------------|-----------------------|--|--|
| rarameter      | Oscillator         | Frequency      | Recommended Oscillator                                                                                 |            | C <sub>2</sub>        |  |  |
| High-frequency | Ceramic Resonator  | 8 MHz          | KYOCERA KBR8.0M MURATA CSA8.00MTz CSACS8.00MT CSTCS8.00MT KYOCERA KBR4.0MS MURATA CSAC4.00MG CSA4.00MG | 30 pF      | 30 pF                 |  |  |
|                | Crystal Oscillator | 8 MHz<br>4 MHz | TOYOCOM 210B 8.0000 TOYOCOM 204B 4.0000                                                                | — 20 pF    | 20 pF                 |  |  |
| Low-frequency  | Crystal OsciNator  | 32.768 kHz     | NDK MX-38T                                                                                             | 15 pF      | 15 pF                 |  |  |



(1) High-frequency Oscillation



(2) Low-frequency Oscillation

- Note 1: An electrical shield by metal shield plate on the surface of the IC package should be recommendable in order to prevent the device from the high electric fiedstress applied from CRT (Cathode Ray Tube) for continuous reliable operation.
- Note 2: The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following URL:

http://www.murata.co.jp/search/index.html

# **Package Dimensions**

