#### CMOS 8-Bit Microcontroller ### TMP86CH06N/TMP86CH06U The TMP86CH06 is the 8-bit single chip microcomputer, which contains ROM, RAM, multi-function timer/counters, serial interface (UART/SIO) with high speed, high performance and low power consumption. | Product No. | ROM | RAM | Package | OTP MCU | |-------------|-------------|-------------|---------------------|------------| | TMP86CH06N | 16K × 8-bit | E120 hit | P-SDIP42-600-1.78 | TMP86PH06N | | TMP86CH06U | 10K X 0-DIL | 512 × 8-bit | P-LQFP44-1010-0.80A | TMP86PH06U | #### **Features** - ♦ 8-bit single chip microcomputer TLCS-870/C Series - ♦ Minimum Instruction execution time: 0.25 μs (at 16.0 MHz) - Power consumption is reducible by means of conversion of instruction execution time 0.25 $\mu$ s, 0.50 $\mu$ s, 1.0 $\mu$ s, 2.0 $\mu$ s, 4.0 $\mu$ s, 8.0 $\mu$ s, 122 $\mu$ s (at 16.0 MHz, 32.768 kHz operation) - ◆ External Bus Interface - up to 64 Kbytes (for both Program and Data memory) - Multiplexed between Lower Address-bus and Data-bus - ◆ 21 Interrupt factors (6 for External, 15 for Internal) - ◆ Input/Output Ports: 35 pins - High-Current Output (Typ. 20 mA, LED direct drive): 8 pins - ◆ 16-bit Timer/Counter: 1 channel - Timer, Event counter, Pulse Width measurement and External-triggered timer 000707EBP1 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. Quality and Reliability Assurance? Handling Precautions. 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 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, ● The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. The products described in this document are subject to the foreign exchange and foreign trade laws. The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA CORPORATION for any infringements of intellectual property or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any intellectual property or other rights of TOSHIBA CORPORATION or others. The information contained herein is subject to change without notice. 86CH06-1 2002-10-08 - ◆ 8-bit Timer/Counter: 2 channels - Available for 16-bit timer by cascade connection - Timer, Event counter, Pulse Width Modulation, Programmed Pulse Generator and Programmable Divider Output, Warming-up Counter - ♦ Serial Interface - 8-bit UART: 2 channels - 8-bit SIO (synchronized): 1 channel - ♦ Clock Oscillation circuit: 2 units - For Single or Dual clock mode - Nine power saving operating modes - STOP mode: Oscillation stops. Battery/Capacitor back-up. Port output hold/High-impedance. - SLOW 1, 2 mode: Low power consumption operation using low-frequency clock (32.768 kHz) - IDLE 0 mode: CPU stops, and peripherals operate using high-frequency clock of Time-Base- - Timer. Release by falling edge of TBTCR < TBTCK > setting. - IDLE 1 mode: CPU stops, and peripherals operate using high-frequency clock. Release by - interruputs. - IDLE 2 mode: CPU stops, and peripherals operate using high and low frequency clock. Release - by interruputs. - SLEEP 0 mode: CPU stops, and peripherals operate using low-frequency clock of Time-Base- - Timer. Release by falling edge of TBTCR < TBTCK > setting. - SLEEP 1 mode: CPU stops, and peripherals operate using low-frequency clock. Release by - interrupts. - SLEEP 2 mode: CPU stops, and peripherals operate using high and low frequency clock. Release - by interrupts. - ◆ Operating Voltage: 4.5 to 5.5 V at 16.0 MHz/32.768 kHz, 2.7 to 5.5 V at 8 MHz/32.768 kHz, - 1.8 to 5.5 V at 4.2 MHz/32.768 kHz. 86CH06-2 2002-10-08 ## Pin Assignments (Top View) 86CH06-3 2002-10-08 # **Block Diagram** ## Pin Names And Functions (1/3) | Pin Name | No. of Pins | Input/Output | Functions | | | | |--------------------------|-------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | P00 to P07<br>AD0 to AD7 | 8 | I/O<br>3-states | Port 0: 8-bit I/O port that allows selection of input/output on bit basis. Address/Data bus: Functions as 8-bit bidirectional address/data bus for external memory (TTL input). | | | | | P10 | 1 | I/O | Port 10: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | INTO<br>CLK | | Input<br>Output | External Interrupt Request 0 Clock: Clock output | | | | | <b>P11</b> | 1 | I/O | Port 11: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | INT1<br>WAIT | ' | Input<br>Input | External Interrupt Request 1 Wait: Wait request from external Memory | | | | | P12 | 1 | I/O | Port 12: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | ETC0 | | Input | Extended Timer Input 0 | | | | | P13 | 1 | I/O | Port 13: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | DVO | | Output | Divider Output | | | | | P14 | 1 | I/O | Port 14: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | TO1 | | Output | 8-bit Timer 1 Output | | | | | P15 | 1 | I/O | Port 15: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | WR | | Output | Write: Generates strobe signal to write data on External Memory. | | | | | P16 | 1 | 1/0 | Port 16: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | RD | | Output | Read: Generates strobe signal to read data from External Memory. | | | | | P17 | 1 | 1/0 | Port 17: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | ALE | • | Output | Address Latch Enable: The negative edge of ALE supplies an address latch timing on AD0 to AD7 for External Memory. | | | | | P20 | | 1/0 | Port 20: I/O port that allows selection of input/output on bit basis. Open-Drain Output. | | | | | STOP | 1 | Input | STOP Releasing: The rising edge or High Level Releases STOP mode. (Schmidt Input) | | | | | ĪNT5 | | Input | External Interrupt Request 5 | | | | | P21 | 1 | I/O | Port 21: I/O port that allows selection of input/output on bit basis. Open-Drain Output. (Schmidt Input) | | | | | XTIN | | Input | Low Frequency Clock Input | | | | | P22 | 1 | I/O | Port 22: I/O port that allows selection of input/output on bit basis. Open-Drain Output. (Schmidt Input) | | | | | XTOUT | | Output | Low Frequency Clock Output | | | | | P30 to P34 | 5 | I/O | Port 30 to 34: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | | | | A8 to A12 | | Output | Address Bus 8 to 12 | | | | ww.DataSheet4U # Pin Names And Functions (2/3) | Pin Name | No. of Pins | Input/Output | Functions | |--------------------|-------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P35 | | 1/0 | Port 35: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | TO0<br>A13 | 1 | Output<br>Output | 8-bit Timer Output 0 Address Bus 13 | | P36<br>IC0<br>A14 | 1 | I/O<br>Input<br>Output | Port 36: I/O port that allows selection of input/output on bit basis. Capture Input 0 for Extended Timer Address Bus 14 (Schmidt Input) | | P37 | | I/O | Port 37: I/O port that allows selection of input/output on bit basis. | | OC0<br>INT2<br>A15 | 1 | Output<br>Input<br>Output | (Schmidt Input) Output Compare 0 for Extended Timer External Interrupt Request 2 (Schmidt Input) Address Bus 15 | | P40 | 1 | I/O<br>Input | Port 40: I/O port that allows selection of input/output on bit basis. Programmable Open-Drain Output. 8-bit Timer Input 0 (Schmidt Input) | | P41 | 1 | I/O | Port 41: I/O port that allows selection of input/output on bit basis. Programmable Open-Drain Output. 8-bit Timer Input 1 | | P42<br>SCK | 1 | 1/0 | Port 42: I/O port that allows selection of input/output on bit basis. Programmable Open-Drain Output. Clock input/output for SIO (Schmidt Input) | | P43<br>SI, RXD0 | 1 | I/O<br>Input | Port 43: I/O port that allows selection of input/output on bit basis. Programmable Open-Drain Output. Data Input for UART/SIO channel 0 | | P44 | 1 | I/O | Port 44: I/O port that allows selection of input/output on bit basis. (Schmidt Input) | | SO, TXD0 | , | Output | Data Output for UART/SIO channel 0. Programmable Open-Drain Output. | | P45 | 1 | I/O | Port 45: I/O port that allows selection of input/output on bit basis. Programmable Open-Drain Output. | | P46 RXD1 INT3 | 1 | I/O<br>Input<br>Input | Port 46: I/O port that allows selection of input/output on bit basis. Programmable Open-Drain Output. Data Input for UART channel 1 External Interrupt Request 3 (Schmidt Input) | | P47 TXD1 | 1 | I/O<br>Output | Port 47: I/O port that allows selection of input/output on bit basis. (Schmidt Input) Data Output for UART channel 1. Programmable Open-Drain Output. | | INT4 | | Input | External Interrupt Request 4 (Schmidt Input) | www.DataSheet4L # Pin Names And Functions (3/3) | Pin Name | No. of Pins | Input/Output | Functions | |----------|-------------|--------------|----------------------------------------------------------------------------------------------------------| | ĒĀ | 1 | Input | External Access: Fix to HIGH level to utilize internal ROM. Fix to LOW level to utilize external memory. | | TEST | 1 | Input | to be fixed to LOW level | | RESET | 1 | I/O | RESET signal input or watchdog timer output/address trap output/system-clock-reset-output | | XIN/XOUT | 2 | 1/0 | High-frequency resonator is to be connected. | | VSS | 1 | Input | Ground | | VDD | 1 | Input | Power Supply | www.DataSheet4U.d ### **Operational Description** #### 1. CPU Core Functions The CPU core consists of a CPU, a system clock controller, and an interrupt controller. This section provides a description of the CPU core, the program memory, the data memory, the external memory interface, and the reset circuit. #### 1.1 Memory Address Maps The TMP86CH06 memory consists of 3 blocks: ROM, RAM and SFR (Special Function Register). They are all mapped in 64K-byte address space. Figure 1-1 shows the TMP86CH06 memory address maps. The general-purpose register banks are not assigned to the RAM address space. Figure 1-1. Memory Address Maps ## 1.2 Program Memory (ROM) The TMP86CH06 can address up to 64 Kbytes of external program memory space except the SFR area and the internal RAM. However, placing program memory on the internal RAM is deregulated if a certain procedure is executed (See 2.4.5 Address trap). The TMP86CH06 contains a 16-Kbyte program memory (mask ROM) at addresses from $C000_{\rm H}$ to FFFFH. ## 1.3 Data Memory (RAM) The TMP86CH06 is available up to 64 Kbytes of data memory area. Data memory consists of internal data memory (internal ROM or RAM) and external data memory (ROM or RAM). The TMP86CH06 has 512 bytes of internal RAM. The first 192 bytes ( $0040_{\rm H}$ to $00FF_{\rm H}$ ) of the internal RAM are located in the direct area; instructions with shorten operations are available against such an area. 86CH06-8 2002-10-08 ### 1.4 External Memory Interfaces The TMP86CH06 can be connected with the external memory through address bus, a data bus, and the control bus. It is available up to 64 Kbytes of data memory area except the area where the internal RAM and SFR are located. Data bus and the lower bits of address bus are multiplexed. • The operation mode is selected from the following three by setting $\overline{EA}$ terminal and control register EXPCR. 1) Single chip mode: $(\overline{EA} = 1, EXPCR < RDOE, WROE > = "0, 0")$ The TMP86CH06 operates within internal memory (ROM, RAM and SFR). Each terminal for connecting external memory is available for input/output port. 2) Expansion mode: $(\overline{EA} = 1, EXPCR < either or both RDOE, WROE > = "1")$ After releasing reset, the TMP86CH06 is starts to operate within internal memory (ROM, RAM and SFR). If either or both RDOE and WROE are enabled, terminals for external memory start to function as ALE and AD7 to 0. 3) ROM-less mode: $(\overline{EA} = 0)$ After releasing reset, the TMP86CH06 operates with external memory instead of internal ROM. The internal RAM and SFR are still be used. • Wait Control The operation mode is selected from the following three: Non wait, 1-cycle wait or (1+n)-cycle wait mode. • Internal ROM security function The TMP86CH06 can keep CPU from reading the data on internal ROM, while its read instruction is located in external memory. Note: The transfer destination data of the vector table (located from FFC0H to FFFFH) is not protected. 86CH06-9 2002-10-08 www.DataSheet4U.com ## 1.4.1 Controlling The external memory interfaces are controlled by expansion control register (EXPCR) and wait control register (WAITCR). EXPCR directly manages $\overline{RD}$ , $\overline{WR}$ and address bus output. And, assigning terminals to $\overline{RD}$ or $\overline{WR}$ subsequently provides AD7 to 0 and ALE. In order to utilize external memory, port directions whether to be input or output is determined regardless of each bit on control register. After reset, EXPCR is a register which can be written only once. Therefore, the second and the following write operation cannot modify the data on EXPCR. **External Access Control Register** 6 3 EXPCR (Initial value: 111\* 11\*\*) EA ← "0" ABUSEN RDOE WROE $(0031_{H})$ (Initial value: 000\* 00\*\*) ABUSEN Upper bits on address bus output enable 000: input/output port WR 001: A9 to A8 output [A15 to A8] 1 time 010: A10 to A8 output 011: A11 to A8 output other terminals on P3 port keep their 100: A12 to A8 output input/output mode. 101: A13 to A8 output 110: A14 to A8 output 111: A15 to A8 output RDOE **RD** strobe output enable 0: RD strobe output Disable Write 1: RD strobe output Enable only WROE WR strobe output enable Write 0: WR strobe output Disable 1: WR strobe output Enable only Note 1: Once either RDOE or WROE or both are enabled to "1", the following terminals are utilized for external memory interface; therefore they cannot be used for general-purpose input/output ports. - AD7 to 0 (P07 to P00) - ALE (P17) - RD (P16: if RDOE = "1") or WR (P15:if WROE = "1") - CLK (P10) Note 2: EXPCR is a write only register and must not be used with any of the read-modify-write instructions. 86CH06-10 WAITCR manages security for internal ROM, number of waiting cycles and waiting clock output. When control waiting cycles, WAITCR selects waiting mode from three: no-wait, 1-state wait or (1+n)-state wait. WAITCR selects output mode from the following: High output by controlling waiting clock output when an external bus is used, $\overline{\text{CLK}}$ output during waiting cycles, $\overline{\text{CLK}}$ output at all times. When the internal ROM is disabled while programs on the external memory and the internal RAM are operating, data in C000H to FFBFH on the ROM cannot be read under software control. WAITCR is a register which can be written only once. Therefore, the second and the following write operation cannot modify this bit. | VAITCR 7 | 6 | 5 4 3 2 1 0 | | | | | | | "0" | | | | |--------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|------------|-----------|------------------------------------------------------------------------------------------------------------|----------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------|--|--| | 032 <sub>H</sub> ) | WA | AIT | _ | "0" | CL | KV | _ | RDMEM | (Initial value: $01*0$ $11*1$ ) $\overline{EA} \leftarrow$ (Initial value: $00*0$ $00*1$ ) $\overline{EA} \leftarrow$ | | | | | | WAIT | | Control w | aiting cy | cles | 00: Wait Disable 01: (Fixed) 1-cycle wait Enable 10: (1 + n)-cycle wait Enable (WAIT pin) 11: Wait Disable | | | | Write | | | | | CLKV CLK output mode 0*: "H"output (CLK output disable) 10: CLK output enable during waiting cy 11: always CLK output Enable | | | | | utput enable during waiting cycles | R/W | | | | | | | | RDMEM | | security fo | or interna | al ROM re | eading o | ut | 0: Read out Disable 1: Read out Enable | | | | | | | Note 1: | The t | iming char | t during C | CLK outp | ut enable | e is des | scribed belo | w. | • | | | | | fc | gck | | 几 | Л | | | | | | | | | | CLK | | | | | | | | | | | | Note 3: WAITCR include a write only register and must not be used with any of the read-modify-write Note 5: When external memory is used, the P10 pin cannot be used as an external interrupt input (INTO) or an instructions. Note 4: Make sure to set "0" on bit 4. I/O port as CLK is output from this pin. 86CH06-11 #### 1.4.2 External Bus Controller The TMP86CH06 is interfaced to an external memory via following buses. (1) Address/Databus: A15 to 8, AD7 to 0 There are 16-bit output address bus and 8-bit bidirectional databus. The lower 8 bits for address bus and 8 bits for databus are multiplexed. All of the terminals, AD15 to 8 and AD7 to 0, are used also for port. These ports functions as address/databus by setting register EXPCR. Upper bits of address bus can be output either partially or totally. (2) Control signals: RD, WR, ALE $\overline{RD}$ pulse indicates for reading, $\overline{WR}$ pulse indicates for writing, and ALE pulse indicates for address latch enable. These terminals are used also for timing for port, and these ports operate as such control signals. $\overline{RD}$ becomes "L" level on external memory read cycle, and $\overline{WR}$ becomes "L" level on external memory write cycle. Both $\overline{RD}$ and $\overline{WR}$ keep "H" level on both dummy cycle and internal memory read/write cycle. a) Timing chart on external memory interface #### b) Example for connecting external ROM/RAM #### 1.4.3 Wait Controller The number of wait cycles is selected from three: no wait, fixed 1-cycle wait and (1+n)-cycle wait. ### (1) Fixed 1-cycle wait 1-state wait operation is executed regardless of WAIT terminal condition. The following diagram indicates the wait cycle, under WAIT = "01" and /CLK outputs during waiting cycles. ### (2) (1 + n)-cycle wait Continuous wait operation is executed as far as "L" input is detected from $\overline{WAIT}$ terminal, after 1-cycle wait operation is executed. The following diagram indicates the wait cycle, under WAIT="10" and $\overline{CLK}$ outputs during waiting cycles. 86CH06-13 2002-10-08 ### 1.5 System Clock Controller The system clock controller consists of a clock generator, a clock gear, a timing generator, and a standby controller. Figure 1-2. System Clock Control #### 1.5.1 Clock Generator The Clock generator generates the basic clock which provides the system clocks supplied to the CPU core and peripheral hardware. It contains two oscillation circuits: one for the high-frequency clock and one for the low-frequency clock. Power consumption can be reduced by switching of the standby controller to low-power operation based on the low-frequency clock. The high-frequency (fc) and low-frequency (fs) clocks can easily be obtained by connecting a resonator between the XIN/XOUT and XTIN/XTOUT pins respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to XIN/XTIN pin with XOUT/XOUT pin not connected. Figure 1-3. Examples of Resonator Connection Note: The function to monitor the basic clock directly at external is not provided for hardware, however, with disabling all interrupts and watchdog timers, the oscillation frequency can be adjusted by monitoring the pulse which the fixed frequency is outputted to the port by the program. The system to require the adjustment of the oscillation frequency should create the program for the adjustment in advance. 86CH06-14 2002-10-08 ## 1.5.2 Clock gear The clock gear is a circuit to select a gear clock fcgck, that is the basis of the main system clock supplied to the timing generator, from high-frequency clock fc, or the divided clock fc/2, fc/4 or fc/8 and fc/16. Power consumption can be reduced by switching of the high-frequency from fc to fc/2, fc/4, fc/8 and fc/16 with the clock gear using. The clock gear consists of a 4-stage prescaler with a multiplexer. Note: The TMP86CH06 starts the reset release or initialization status from fc Figure 1-4. Configuration of Clock Gear Figure 1-5. Clock Gear Control Register 86CH06-15 2002-10-08 Figure 1-6. Example of Clock Exchangeable Timing by Clock Gear ### 1.5.3 Timing Generator The timing generator generates the various system clocks supplied to the CPU core and peripheral hardware from the gear clock (fcgck) or the basic clock (fc or fs). The timing generator provides the following functions. - ① Generation of main system clock (fm) - ② Generation of divider output ( $\overline{DVO}$ ) pulses - 3 Generation of source clocks for time base timer - 4 Generation of source clocks for watchdog timer - (5) Generation of internal source clocks for timer/counters - 6 Generation of warm-up clocks for releasing STOP mode ### (1) Configuration of timing generator The timing generator consists of a 3-stage prescaler, a 21-stage divider, a main system clock generator, and machine cycle counters. The clock fc/4 or fc/8, that is output from the 2nd stage or the 3rd stage of the prescaler, can be selected as the clock to input to the 1st stage of the divider by DV1CK (bit 5 in CGCR). Inputting fc/8 to the 1st stage of the divider operates the peripheral circuit without the setting change when the operation clock is multiplied by 2. (Example: 8 MHz to 16 MHz) Even if the main system clock is changed by the clock gear, the output from the divider is not changed. However, the peripheral circuits utilizing high-speed divider output (first to fourth stage) cannot be used if the main system clock slows down on the clock gear. In such a case, setting DVCK (bit 7, 6 in CGCR) enables reducing speed, while high-speed operating parts remain their paces. DVCK should be set in accordance with the divider output providing for peripheral circuits and the system should be kept the minimum operating frequency. DVCK should be set before the peripheral circuits start operating. Do not change the set value after DVCK is set. An input clock to the 7th stage of the divider depends on the operating mode, DV1CK (bit 5 in CGCR), and DV7CK (bit 4 in TBTCR), that is shown in Table 1-2. As reset and STOP mode started/canceled, the prescaler and the divider are cleared to "0". 86CH06-16 2002-10-08 Table 1-1. Divider Output Capability | | | Dinder Output Capability | | | | | | | | | | |------|----------------------|--------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------| | DVCK | Gear Clock frequency | | | V1CK = | | | | | V1CK = | | | | | | DV1G | DV2G | DV3G | DV4 | DV5 | DV1G | DV2G | DV3G | DV4 | DV5 | | | fcgck = fc | fc/2 <sup>3</sup> | fc/2 <sup>4</sup> | fc/2⁵ | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>4</sup> | fc/2⁵ | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>8</sup> | | | reger = re | × | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 00 | fcgck = fc/2 | × | × | 0 | 0 | 0 | × | 0 | 0 | 0 | 0 | | " | fcgck = fc/4 | × | × | × | 0 | 0 | × | × | 0 | 0 | 0 | | | fcgck = fc/8 | × | × | × | × | 0 | × | × | × | 0 | 0 | | | fcgck = fc/16 | × | × | × | × | × | × | × | × | × | 0 | | | fcgck = fc | fc/2 <sup>4</sup> | fc/2 <sup>4</sup> | fc/2 <sup>5</sup> | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>5</sup> | fc/2⁵ | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>8</sup> | | | reger = re | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 01 | fcgck = fc/2 | × | × | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | " | fcgck = fc/4 | × | × | × | $\circ$ | 0 | × | × | 0 | 0 | 0 | | | fcgck = fc/8 | × | × | × | × | 0 | × | × | × | 0 | 0 | | | fcgck = fc/16 | × | × | × | × | × | × | × | × | × | 0 | | | fcgck = fc | fc/2 <sup>5</sup> | fc/2⁵ | fc/2⁵ | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>6</sup> | fc/2 <sup>6</sup> | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>8</sup> | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 10 | fcgck = fc/2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 10 | fcgck = fc/4 | × | × | × | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | fcgck = fc/8 | × | × | × | × | 0 | × | × | × | 0 | 0 | | | fcgck = fc/16 | × | × | × | × | × | × | × | × | × | 0 | | | to a to | fc/2 <sup>6</sup> | fc/2 <sup>6</sup> | fc/2 <sup>6</sup> | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>7</sup> | fc/2 <sup>7</sup> | fc/2 <sup>7</sup> | fc/2 <sup>7</sup> | fc/2 <sup>8</sup> | | | fcgck = fc | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1 11 | fcgck = fc/2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 11 | fcgck = fc/4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | fcgck = fc/8 | × | × | × | × | 0 | 0 | 0 | 0 | 0 | 0 | | | fcgck = fc/16 | × | × | × | × | × | × | × | × | × | 0 | Note: When selecting DV1G, DV2G, DV3G, DV4 or DV5 for the operating clock of timer, SIO, etc, check Table 1-1 to see that the divider output is possible (marked with $\bigcirc$ ). If the divider output is not possible (marked with $\times$ ), do not select them for the operating clock. Table 1-2. Input Clock to 7th Stage of The Divider | Single | -clock mode | Dual-clock mode | | | | | | |-------------------|-------------------|-------------------|-------------------|------------|---------------------|--|--| | NORMA | L1, IDLE1 mode | NORMAL2 | 2, IDLE2 mode (S | SYSCK = 0) | SLOW, SLEEP | | | | DV4CK 0 | DV45K 0 BV45K 4 | | CK = 0 | D)/76K 1 | mode<br>(SYSCK = 1) | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | DV7CK = 1 | (SYSCK = 1) | | | | fc/2 <sup>8</sup> | fc/2 <sup>9</sup> | fc/2 <sup>8</sup> | fc/2 <sup>9</sup> | fs | fs | | | Note 1: Do not set "1" on DV7CK while the low-frequency clock is not operated stably. Note 2: In SLOW and SLEEP mode, the input clock to the 1st stage of the divider is stopped; output from the 1st to 6th stages is also stopped. Note 3: Do not set DV7CK to "1" when single clock mode is selected. Figure 1-7. Configuration of Timing Generator Table 1-3. Division Ratio of Divider | | DV7C | CK = 0 | DV7C | CK = 1 | | DV7C | :K = 0 | DV70 | CK = 1 | |------|--------------------|--------------------|-------------------|-----------------------|------|--------------------|--------------------|-----------|-------------------------| | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | | DV1 | fc/2³ | fc/2 <sup>4</sup> | fc/2 <sup>3</sup> | fc/2 <sup>4</sup> | DV12 | fc/2 <sup>14</sup> | fc/2 <sup>15</sup> | fs/ | ′2 <sup>6</sup> | | DV2 | fc/2 <sup>4</sup> | fc/2 <sup>5</sup> | fc/2 <sup>4</sup> | fc/2 <sup>5</sup> | DV13 | fc/2 <sup>15</sup> | fc/2 <sup>16</sup> | fs/ | ′ <b>2</b> <sup>7</sup> | | DV3 | fc/2 <sup>5</sup> | fc/2 <sup>6</sup> | fc/2 <sup>5</sup> | fc/2 <sup>6</sup> | DV14 | fc/2 <sup>16</sup> | fc/2 <sup>17</sup> | fs/ | ′2 <sup>8</sup> | | DV4 | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | fc/2 <sup>6</sup> | fc/2 <sup>7</sup> | DV15 | fc/2 <sup>17</sup> | fc/2 <sup>18</sup> | fs/ | ′2 <sup>9</sup> | | DV5 | fc/2 <sup>7</sup> | fc/2 <sup>8</sup> | fc/2 <sup>7</sup> | fc/2 <sup>8</sup> | DV16 | fc/2 <sup>18</sup> | fc/2 <sup>19</sup> | fs/ | <b>2</b> <sup>10</sup> | | DV6 | fc/2 <sup>8</sup> | fc/2 <sup>9</sup> | fc/2 <sup>8</sup> | fc/2 <sup>9</sup> | DV17 | fc/2 <sup>19</sup> | fc/2 <sup>20</sup> | fs/ | <b>2</b> <sup>11</sup> | | DV7 | fc/2 <sup>9</sup> | fc/2 <sup>10</sup> | fs | /2 | DV18 | fc/2 <sup>20</sup> | fc/2 <sup>21</sup> | fs/ | <b>2</b> <sup>12</sup> | | DV8 | fc/2 <sup>10</sup> | fc/2 <sup>11</sup> | fs/ | <b>2</b> <sup>2</sup> | DV19 | fc/2 <sup>21</sup> | fc/2 <sup>22</sup> | fs/ | <b>2</b> <sup>13</sup> | | DV9 | fc/2 <sup>11</sup> | fc/2 <sup>12</sup> | fs/ | <b>2</b> <sup>3</sup> | DV20 | fc/2 <sup>22</sup> | fc/2 <sup>23</sup> | fs/ | <b>2</b> <sup>14</sup> | | DV10 | fc/2 <sup>12</sup> | fc/2 <sup>13</sup> | fs/ | <b>2</b> <sup>4</sup> | DV21 | fc/2 <sup>23</sup> | fc/2 <sup>24</sup> | fs/ | <b>2</b> <sup>15</sup> | | DV11 | fc/2 <sup>13</sup> | fc/2 <sup>14</sup> | fs/ | <b>2</b> <sup>5</sup> | | | | | | Figure 1-8. Clock Gear Control Register Figure 1-9. Timing Generator Control Register #### Machine cycle (2) Instruction execution and peripheral hardware operation are synchronized with the main system clock. The minimum instruction execution unit is called an "machine cycle". There are a total of 10 different types of instructions for the TLCS-870/C Series: ranging from 1-cycle instructions which require one machine cycle for execution to 10-cycle instructions which require 10 machine cycles for execution. A machine cycle consists of 4 states (S0 to S3), and each state consists of one main system clock. Figure 1-10. Machine Cycle Table 1-4. Example of Machine Cycle | Freque | ency | Machine cycle | | | | | | |---------------------|---------------|-----------------------|-----------------|-----------------|-----------------|---------------|--| | | | fcgck = fc | fcgck = fc/2 | fcgck = fc/4 | fcgck = fc/8 | fcgck = fc/16 | | | High-frequency | fc = 16.0 MHz | $0.25~\mu \mathrm{s}$ | 0.5 μs | 1.0 <i>μ</i> s | 2.0 μs | 4.0 μs | | | clock | fc = 12.5 MHz | $0.32~\mu$ s | 0.64 <i>μ</i> s | 1.28 <i>μ</i> s | 2.56 <i>μ</i> s | _ | | | | fc = 4.2 MHz | $0.95~\mu \mathrm{s}$ | 1.9 <i>μ</i> s | 3.8 μs | _ | _ | | | | fc = 1 MHz | 4 μs | _ | _ | _ | _ | | | Low-frequency clock | fs = 32.8 kHz | | | 122 <i>μ</i> s | | | | Note: "-" is movement outside guaranteed range. ### 1.5.4 Standby Controller The standby 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 and SYSCR2). Figure 1-11 shows the operating mode transition diagram and Figure 1-12 shows the system control registers. ### (1) Single-clock mode Only the oscillation circuit for the high-frequency clock is used, and P21 (XTIN) and P22 (XTOUT) pins are used as input/output ports. The main-system clock is obtained from the high-frequency clock. In the single-clock mode, the machine cycle time is 4/fcgck [s]. #### ① NORMAL1 mode In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock. The TMP86CH06 is placed in this mode after reset. #### ② IDLE1 mode In this mode, the internal oscillation circuit remains active. The CPU and the watchdog timer are halted; however on-chip peripherals remain active (operate using the high-frequency clock). IDLE1 mode is started by the system control register 2 (SYSCR2), and IDLE1 mode is released to NORMAL1 mode by an interrupt request from the on-chip peripherals or external interrupt inputs. When the IMF (interrupt master enable flag) is "1" (interrupt enable), the execution will resume with the acceptance of the interrupt, and the operation will return to normal after the interrupt service is completed. When the IMF is "0" (interrupt disable), the execution will resume with the instruction which follows the IDLE1 mode start instruction. #### ③ IDLE0 mode In this mode, All the circuit, except oscillator and the Timer-Base-Timer, stops operation. This mode is enabled by setting "1" on bit TGHALT on the system control register 2 (SYSCR2). As IDLE0 mode is enabled, the timing generator halts (the system clock halts) and the CPU and other peripherals are stopped. As IDLE0 mode is enabled, the count on the Time-Base-Timer is cleared and the Time-Base-Timer restart counting. When the count reaches the rate on TBTCR, SLEEP0 releasing signal, which restarts the timing generator, is generated and the hardware restores NORMAL1 mode. MAN DataShoot/III.com #### (2) Dual-clock mode Both the high-frequency and low-frequency oscillation circuits are used in this mode. P21 (XTIN) and P22 (XTOUT) pins cannot be used as input/output ports. The main system clock is obtained from the high-frequency clock in NORMAL2 and IDLE2 modes, and is obtained from the low-frequency clock in SLOW and SLEEP modes. The machine cycle time is 4/fcgck [s] in the NORMAL2 and IDLE2 modes, and 4/fs [s] ( $122~\mu s$ at 1s = 32.768 kHz) in the SLOW and SLEEP modes. The TLCS-870/C is placed in the signal-clock mode after reset is released. To use the dual-clock mode, the low-frequency oscillator should be turned on at the start of a program. Note: With the TLCS-870/C Series, no option is provided to select the clock mode after release of reset. When reset is released, it becomes the single mode. UIII #### ① NORMAL2 mode In this mode, the CPU core operates with the high-frequency clock. On-chip peripherals operate using the high-frequency clock and/or low-frequency clock. #### ② SLOW2 mode In this mode, the CPU core operates with the low-frequency clock, while both the high-frequency clock and the low-frequency clock are operated. On-chip peripherals are triggered by the low-frequency clock. As the SYSCK on SYSCR2 becomes "0", the hardware changes into NORMAL2 mode. As the XEN on SYSCR2 becomes "0", the hardware changes into SLOW1 mode. Do not clear XTEN to "0" during SLOW2 mode. #### ③ SLOW1 mode This mode can be used to reduce power-consumption by turning off oscillation of the high-frequency clock. The CPU core and on-chip peripherals operate using the low-frequency clock. Switching back and forth between SLOW1 and SLOW2 modes are performed by XEN bit on the system control register 2 (SYSCR2). In SLOW1 and SLEEP1 mode, the input clock to the 1st stage of the divider is stopped; output from the 1st to 6th stages is also stopped. ### 4 IDLE2 mode In this mode, the internal oscillation circuit remain active. The CPU and the watchdog timer are halted; however, on-chip peripherals remain active (operate using the high-frequency clock and/or the low-frequency clock). Starting and releasing of IDLE2 mode are the same as for IDLE1 mode, except that operation returns to NORMAL2 mode. #### 5 SLEEP1 mode In this mode, the internal oscillation circuit of the low-frequency clock remains active. The CPU, the watchdog timer, and the internal oscillation circuit of the high-frequency clock are halted; however, on-chip peripherals remain active (operate using the low-frequency clock). Starting and releasing of SLEEP1 mode are the same as for IDLE1 mode, except that operation returns to SLOW1 mode. In SLOW1 and SLEEP1 mode, the input clock to the 1st stage of the divider is stopped; output from the 1st to 6th stages is also stopped. ### 6 SLEEP2 mode The SLEEP2 mode is the idle mode corresponding to the SLOW2 mode. The status under the SLEEP2 mode is same as that under the SLEEP1 mode, except for the oscillation circuit of the high-frequency clock. 86CH06-21 2002-10-08 #### (7) SLEEP0 mode In this mode, All the circuit, except oscillator and the Time-Base-Timer, stops operation. This mode is enabled by setting "1" on bit TGHALT on the system control register2 (SYSCR2) during SLOW1. As SLEEP0 mode is enabled, the timing generator halts (the system clock halts) and the CPU and other peripherals are stopped. As SLEEP0 mode is enabled, the count on the Time-Base-Timer is cleared and the Time-Base-Timer restart counting. When the count reaches the rate on TBTCR, SLEEP0 releasing signal, which restarts the timing generator, is generated and the hardware restores SLOW1 mode. #### (3) STOP mode In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with a lowest power consumption during STOP mode. STOP mode is started by the system control register 1 (SYSCR1), and STOP mode is released by a inputting (either level-sensitive or edge-sensitive can be programmably selected) to the $\overline{\text{STOP}}$ pin. After the warming-up period is completed, the execution resumes with the instruction which follows the STOP mode start instruction. ww.DataSheet4U.com Figure 1-11. Operating Mode Transition Diagram 86CH06-23 2002-10-08 #### System Control Register 1 SYSCR1 (Initial value: 0000 00\*\*) OUTEN STOP RELM RETM WUT $(0038_{H})$ 0: CPU core and peripherals remain active STOP STOP mode start 1: CPU core and peripherals are halted (start STOP mode) 0: Edge-sensitive release (STOP pin) Release method RELM 1: Level-sensitive release (STOP pin) for STOP mode 0: Return to NORMAL mode Operating mode R/W RETM after STOP mode 1: return to SLOW mode 0: High Impedance Port output during OUTEN 1: Output kept www.DataSheet4U.com STOP mode Return to NORMAL mode Return to DV1CK = 1 Warming-up time at DV1CK = 0 SLOW mode 00 $3 \times 2^{16}$ /fc $3 \times 2^{17}/fc$ $3 \times 2^{13}/fs$ releasing STOP mode WUT 216/fc 217/fc 2<sup>13</sup>/fs 01 $3 \times 2^{14}/fc$ $3 \times 2^{15}/fc$ $3 \times 2^6/fs$ 10 214/fc 215/fc 26/fs Note 1: Always set RETM to "0" when transiting from NORMAL mode to STOP mode. Always set RETM to "1" when transiting from SLOW mode to STOP mode. Note 2: When STOP mode is released with RESET pin input, a return is made to NORMAL1 regardless of the RETM contents. Note 3: fc: High-frequency clock [Hz] fs: Low-frequency clock [Hz] \*: Don't care Note 4: Bits 1 and 0 in SYSCR1 are read as undefined data when a read instruction is executed. Note 5: As the hardware becomes STOP mode under OUTEN = "0", input value is fixed to "0"; therefore it may cause interrupt request on account of falling edge. Note 6: As the hardware becomes STOP mode under OUTEN = "0" from external bus mode, P17, P16, P15 keep their output and they do not become high impedance. Note 7: The P20 pin is shared with the STOP pin, so that when it enters STOP mode, its output goes to a highimpedance state regardless of how OUTEN is set. System Control Register 2 SYSCR2 (Initial value: 1000 \*0\*\*) XEN XTEN SYSCK IDLE TGHALT $(0039_{H})$ 0: Turn off oscillation High-frequency oscillator XEN control 1: Turn on oscillation Low-frequency oscillator 0: Turn off oscillation **XTEN** control 1: Turn on oscillation Main system clock select 0: High-frequency clock (NORMAL1/NORMAL2/IDLE1/IDLE2) **SYSCK** (write)/main system clock R/W 1: Low-frequency clock (SLOW/SLEEP) monitor (read) 0: CPU and watchdog timer remain active IDLE IDLE mode start 1: CPU and watchdog timer are stopped (start IDLE mode) TG stops 0: TG keeps its operation **TGHALT** (SLEEPO, IDLEO mode) 1: TG stops (SLEEP0, IDLE0 mode) - Note 1: A reset is applied (RESET pin output goes low) if both XEN and XTEN are cleared to "0", XEN is cleared to "0" when SYSCK = "0", or XTEN is cleared to "0" when SYSCK = "0". - Note 2: \*; Don't care, TG; Timing generator - Note 3: Bits 3, 1 and 0 in SYSCR2 are always read as undefined value. - Note 4: Do not set IDLE and TGHALT to "1" simultaneously. - Note 5: Because returning from IDLE0/SLEEP0 to NORMAL1/SLOW1 is executed by the asynchronous internal clock, the period of IDLE0/SLEEP0 mode might be shorter than the period setting by TBTCR < TBTCK >. - Note 6: When IDLE1/2 or SLEEP1/2 mode is released, IDLE is automatically cleared to "0". - Note 7: When IDLEO or SLEEPO mode is released, TGHALT is automatically cleared to "0". Figure 1-12. System Control Registers 86CH06-24 2002-10-08 ### 1.5.5 Operating Mode Control #### (1) STOP mode 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, the program status word and port output latches are all held in the status in effect before STOP mode was entered. - ③ The prescaler and the divider of the timing generator are cleared to "0". - ④ The program counter holds the address 2 ahead of the instruction (e.g. [SET (SYSCR1).7]) which started STOP mode. STOP mode includes a level-sensitive release mode and an edge-sensitive release mode, either of which can be selected with the RELM (bit 6 in SYSCR1). Note: During STOP period (from start of STOP mode to end of warming-up), due to changes in the external interrupt pin signal, interrupt latches may be set to "1" and interrupts may be accepted immediately after STOP mode is released. Before starting STOP mode, therefore, disable interrupts. Also, before enabling interrupts after STOP mode is released, clear unnecessary interrupt latches. a. Level-sensitive release mode (RELM="1") In this mode, STOP mode is released by setting the 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 STOP mode will not place in STOP mode but instead will immediately start the release sequence (warm-up). Thus, to start STOP mode in the level-sensitive release mode, it is necessary for the program to first confirm that the STOP pin input is low. The following two methods can be used for confirmation. - ① Testing a port P20. - ② Using an external interrupt input INT5 (INT5 is a falling edge-sensitive input). Example 1: Starting STOP mode from NORMAL mode by testing a port P20. LD (SYSCR1), 01010000B; Sets up the level-sensitive release mode SSTOPH:TEST (P2R). 0 ; Wait until the STOP pin input goes low level JRS F, SSTOPH $\mathbf{DI}$ SET (SYSCR1). 7 ; Starts STOP mode Example 2: Starting STOP mode from NORMAL mode with an INT5 interrupt. PINT5: TEST (P2R). 0 ; To reject noise, STOP mode does not start if JRS F, SINT5 port P20 is at high LD(SYSCR1), 01010000B; Sets up the level-sensitive release mode. DΙ SET (SYSCR1). 7 ; Starts STOP mode SINT5: RETI 86CH06-25 2002-10-08 www.DataSheet4U.com v DataSheet4U.com Figure 1-13. Level-sensitive release mode Note 1: Even if the STOP pin input is low after warming up start, the STOP mode is not restarted. Note 2: In this case of changing to the level-sensitive 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. ### 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 level. Example: Starting STOP mode from NORMAL mode $\mathbf{DI}$ LD(SYSCR1), 10010000B; Starts after specified to the edge-sensitive release mode Figure 1-14. Edge-sensitive release mode STOP mode is released by the following sequence. ① In the dual-clock mode, when returning to NORMAL2 or SLOW2, both the high-frequency and low-frequency clock oscillators are turned on; when returning to SLOW1 mode, only the low-frequency clock oscillator is turned on. In the signal-clock mode, only the high-frequency clock oscillator is turned on. - ② A warm-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Four different warm-up times can be selected with the WUT (bits 2 and 3 in SYSCR1) in accordance with the resonator characteristics. - 3 When the warm-up time has elapsed, normal operation resumes with the instruction following the STOP mode start instruction. The start is made after the prescaler and the divider of the timing generator are cleared to "0". | WUT | Return to NO | RMAL mode | Return to SLOW mode | |-----|--------------|-----------|---------------------| | | DV1CK = 0 | DV1CK = 1 | Return to 3LOW mode | | 00 | 12.288 | 24.576 | 750 | | 01 | 4.096 | 8.192 | 250 | | 10 | 3.072 | 6.144 | 5.9 | | 11 | 1.024 | 2.048 | 2.0 | Table 1-5. Warm-up Time Example (at fc = 16.0 MHz, fs = 32.768 kHz) Note: The warm-up time is obtained by dividing the basic clock by the divider: therefore, the warm-up time may include a certain amount of error if there is any fluctuation of the oscillation frequency when STOP mode is released. Thus, the warm-up time must be considered an approximate value. STOP mode can also be released by inputting low level on the $\overline{RESET}$ pin, which immediately performs the normal reset operation. 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 "H" level, rising together with the power supply voltage. In this case, if an external time constant circuit has been connected, the RESET pin input voltage will increase at a slower pace than the power supply voltage. At this time, there is a danger that a reset may occur if input voltage level of the RESET pin drops below the non-inverting high-level input voltage (hysteresis input). www.DataSheet4LL.com 86CH06-28 ### (2) IDLE mode (IDLE1, IDLE2, SLEEP1, SLEEP2) IDLE mode is controlled by the system control register 2 (SYSCR2) and maskable interrupts. The following status is maintained during IDLE mode. - ① Operation of the CPU and watchdog timer (WDT) is halted. On-chip peripherals continue to operate. - ② The data memory, CPU registers, program status word and port output latches are all held in the status in effect before IDLE mode was entered. - ③ The program counter holds the address 2 ahead of the instruction which starts IDLE mode. Example: Starting IDLE mode. SET (SYSCR2). 4 ; IDLE $\leftarrow 1$ Figure 1-16. IDLE Mode 86CH06-29 2002-10-08 IDLE mode includes a normal release mode and an interrupt release mode. Selection is made with the interrupt master enable flag (IMF). Releasing IDLE mode returns from IDLE1 to NORMAL1, from IDLE2 to NORMAL2, from SLEEP1 to SLOW1 mode, and from SLEEP2 to SLOW2 mode. - (I) Normal release mode (IMF="0") - IDLE mode is released by any interrupt source enabled by the individual interrupt enable flag (EF). Execution resumes with the instruction following the IDLE mode start instruction. The interrupt latches (IL) of the interrupt source used for releasing must be cleared to "0" by load instructions. However, only TBT interrupt can release IDLE0/SLEEP0 mode. - ( $\Pi$ ) 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). After the interrupt is processed, the execution resumes from the instruction following the instruction which starts IDLE mode. However, only TBT interrupt can release IDLE0/SLEEP0 mode. IDLE mode can also be released by inputting low level on the $\overline{RESET}$ pin, which immediately performs the reset operation. After reset, the TMP86CH06 is placed in NORMAL 1 mode. Note: When a watchdog timer interrupt is generated immediately before IDLE mode is started, the watchdog timer interrupt will be processed but IDLE mode will not be started. MAN DataSheet411 com 86CH06-31 2002-10-08 #### (3) IDLEO/SLEEPO mode (IDLEO, SLEEPO) IDLE0/SLEEP0 mode is controlled by the system control register 2 (SYSCR2) and TBT. The following status is maintained during IDLE0 mode/SLEEP0 mode. - ① All the circuit, except oscillator and the TBT, stops operation. - ② The data memory, CPU registers, program status word and port output latches are all held in the status in effect before IDLE0/SLEEP0 mode was entered. - 3 The program counter holds the address 2 ahead of the instruction which starts IDLE0/SLEEP0 mode. Example: Starting IDLE mode. SET (SYSCR2).2 Figure 1-18. IDLE mode When the count reaches the rate stated on TBTCR after starting IDLE0/SLEEP0 mode, this mode is released, and the device restore the operation. On restarting, the interrupt processing is accepted if the TBT interrupt is enable. If its interrupt is disable, the instruction, which follows the instruction to enable IDLE0 mode, is executed. IDLE0 mode can also be released by inputting low level on the $\overline{\text{RESET}}$ pin, which immediately performs the reset operation. After reset, the TMP86CH06 is placed in NORMAL1 mode. Note: When a watchdog timer interrupt is generated immediately before IDLEO/SLEEPO mode is started, the watchdog timer interrupt will be processed but IDLEO/SLEEPO mode will not be started. 86CH06-33 #### (4) SLOW mode SLOW mode is controlled by the system control register 2 (SYSCR2). The following is the methods to switch the mode with the warming-up counter (TC1, 0). a. Switching from NORMAL2 mode to SLOW1 mode First, set SYSCK (bit 5 in SYSCR2) to switch the main system clock to the low-frequency clock for SLOW2 mode. Next, clear XEN (bit 7 in SYSCR2) to turn off high-frequency oscillation. Note: The high-frequency clock oscillation can be continued to return quickly to NORMAL2 mode. However, halt high frequency clock in order to enable STOP mode from SLOW mode. When the low-frequency clock oscillation is unstable, wait until oscillation stabilizes before performing the above operations. The timer/counter 1, 0 (TC1, TC0) can conveniently be used to confirm that low-frequency clock oscillation has stabilized. Example 1: Switching from NORMAL2 mode to SLOW1 mode. SET (SYSCR2). 5 ; SYSCK $\leftarrow 1$ (switches the main system clock to the low-frequency clock for SLOW2) CLR (SYSCR2). 7; $XEN \leftarrow 0$ (turns off high-frequency oscillation) Example2: Switching to the SLOW1 mode after low-frequency clock has stabilized. LD (TC0CR), 43H; Sets mode for TC0, TC1 (16-bit TC, fs for source) LD (TC1CR), 05H LDW (TTREG0), 8000H; Sets warming-up time (depend on oscillator accompanied) $\mathbf{DI}$ SET (EIRL). 7 ; Enables INTTC1 $\mathbf{EI}$ SET (TC1CR). 3 ; Starts TC1, 0 : PINTTC1: CLR (TC1CR), 3 ; Stops TC1, 0 SET (SYSCR2). 5 ; SYSCK $\leftarrow$ 1 (Switches the main system clock to the low-frequency clock) CLR (SYSCR2). 7 ; XEN $\leftarrow$ 0 (Turns off high-frequency oscillation) RETI : VINTTC1: DW PINTTC1 ; INTTC1 vector table 86CH06-34 2002-10-08 www.DataSheet4U.com ### b. Switching from SLOW1 mode to NORMAL2 mode 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 1, 0 (TC1, 0), clear SYSCK (bit 5 in SYSCR2) to switch the main system clock to the high-frequency clock. Note 1: After SYSCK is cleared to "0", executing the instructions is continued by the low-frequency clock for the period synchronized with low-frequency and high-frequency clocks. High-frequency clock Low-frequency clock Main system clock SYSCK Note 2: SLOW mode can also be released by inputting low level on the RESET pin, which immediately performs the reset operation. After reset, the TMP86CH06 is placed in NORMAL1 mode. Example: Switching from the SLOW1 mode to the NORMAL2 mode (fc = 16 MHz, fcgck = fc, warm-up time is 4.0 ms). SET (SYSCR2). 7 ; XEN $\leftarrow$ 1 (Starts high-frequency oscillation) LD (TC0CR), 63H ; Sets mode for TC0, TC1 (16-bit TC, fc for source) LD (TC1CR), 05H LD (TTREG1), 0F8H; Sets warming-up time $\mathbf{DI}$ SET (EIRL). 7 ; Enables INTTC1 $\mathbf{EI}$ SET (TC1CR). 3 ; Starts TC1, 0 ÷ PINTTC1: CLR (TC1CR). 3 ; Stops TC1, 0 CLR (SYSCR2). 5 ; SYSCR $\leftarrow$ 0 (Switches the main system clock to the high-frequency clock) RETI : VINTTC1: DW PINTTC1 ; INTTC1 vector table 86CH06-35 2002-10-08 # 1.6 Interrupt Control Circuit The TMP86CH06 has a total (Reset is excluded) of 21 interrupt sources; 5 of the sources are multiplexed. Multiple interrupt with priorities is available. 4 of the internal factors are non-maskable interrupts, and the rest of them are maskable interrupts. Interrupt sources are provided with interrupt latches (IL), which hold interrupt requests, and independent vectors. The interrupt latch is set to "1" by the generation of its interrupt request which requests the CPU to accept its interrupts. Interrupts are enabled or disabled by software using the interrupt master enable flag (IMF) and interrupt enable flag (EF). If more than one interrupts are generated simultaneously, interrupts are accepted in order which is dominated by hardware. However, there are no prioritized interrupt factors among non-maskable interrupts. w.DataSheet4U.com Table 1-6. Interrupt Sources | | Interrupt Factors | Enable Condition | Interrupt<br>Latch | Vector<br>Address | Priority | |-----------------------|------------------------------------------------------------------------|---------------------------------------------|--------------------|-------------------|----------| | Internal/<br>External | (Reset) | Non-maskable | _ | FFFE <sub>H</sub> | High 1 | | Internal | INTSW (Software interrupt) | Non-maskable | _ | FFFC <sub>H</sub> | 2 | | Internal | INTUNDEF (Executed the Undefined Instruction interrupt) | Non-maskable | _ | FFFC <sub>H</sub> | 2 | | Internal | INTATRAP (Address Trap interrupt) | Non-maskable | IL <sub>2</sub> | FFFA <sub>H</sub> | 2 | | Internal | INTWDT (Watchdog Timer interrupt) | Non-maskable | IL <sub>3</sub> | FFF8 <sub>H</sub> | 2 | | External | INT0 (External interrupt0) | IMF = 1, EF <sub>4</sub> = 1,<br>INT0EN = 1 | IL <sub>4</sub> | FFF6 <sub>H</sub> | 5 | | External | INT1 (External interrupt1) | IMF = 1, EF <sub>5</sub> = 1 | IL <sub>5</sub> | FFF4 <sub>H</sub> | 6 | | Internal | INTTBT (Time Base Timer interrupt) | IMF = 1, EF <sub>6</sub> = 1 | IL <sub>6</sub> | FFF2 <sub>H</sub> | 7 | | Internal | INTTC1 (8-bit Timer1 (16-bit mode) interrupt) | IMF = 1, EF <sub>7</sub> = 1 | IL <sub>7</sub> | FFF0 <sub>H</sub> | 8 | | Internal, | INTRXD0 | IMF = 1, EF <sub>8</sub> = 1 | IL <sub>8</sub> | FFEE <sub>H</sub> | 9 | | Internal | (UART (ch0) Received interrupt), INTSIO (SIO interrupt) | | | | | | Internal | INTTXD0 (UART (ch0) Transmitted interrupt) | IMF = 1, EF <sub>9</sub> = 1 | IL <sub>9</sub> | FFEC <sub>H</sub> | 10 | | Internal | INTET0 (ETC0 Full-Count interrupt) | IMF = 1, EF <sub>10</sub> = 1 | IL <sub>10</sub> | FFEA <sub>H</sub> | 11 | | Internal | INTIC0 (ETC0 Input Capture interrupt) | IMF = 1, EF <sub>11</sub> = 1 | IL <sub>11</sub> | FFE8 <sub>H</sub> | 12 | | Internal, | INTOC0 (ETC0 Output Compare interrupt), | IMF = 1, EF <sub>12</sub> = 1 | IL <sub>12</sub> | FFE6 <sub>H</sub> | 13 | | External | INT2 (External interrupt2) | | | | | | Internal,<br>External | INT3 (External interrupt3), INTRXD1 (UART (ch1) Received interrupt) | IMF = 1, EF <sub>13</sub> = 1 | IL <sub>13</sub> | FFE4 <sub>H</sub> | 14 | | Internal,<br>External | INT4 (External interrupt4), INTTXD1 (UART (ch1) Transmitted interrupt) | IMF = 1, EF <sub>14</sub> = 1 | IL <sub>14</sub> | FFE2 <sub>H</sub> | 15 | | Internal,<br>External | INTTC0 (8-bit Timer0 interrupt), INT5 (External interrupt5) | IMF = 1, EF <sub>15</sub> = 1 | IL <sub>15</sub> | FFEO <sub>H</sub> | Low 16 | - Note 1: The following interrupt factors share their interrupt source; the factor is selected on the register INTSEL. - 1) INTRXD0 and INTSIO share the source whose priority is 9. - 2) INTOCO and INT2 share the source whose priority is 13. - 3) INT3 and INTRXD1 share the source whose priority is 14. - 4) INT4 and INTTXD1 share the source whose priority is 15. - 5) INTTCO and INT5 share the source whose priority is 16. - Note 2: 2 alternatives are to be chosen in case INTATRAP (Address Trap interrupt) is executed: interrupt or reset. (for detail, see 1.6.4 Address trap interrupt (INTATRAP) 86CH06-38 2002-10-08 # (1) Interrupt Latches (IL<sub>15</sub> to IL<sub>2</sub>) An interrupt latch is provided for each interrupt source, except for a software interrupt. When interrupt request is generated, the latch is set to "1", and the CPU is requested to accept the interrupt if its interrupt is enabled. All interrupt latches are initialized to "0" during reset. The interrupt latches are located on address $003C_H$ and $003D_H$ in SFR area. Except for $IL_3$ and $IL_2$ , each latch can be cleared to "0" individually by instruction (However, the read-modify-write instructions such as bit manipulation or operation instructions cannot be used. Interrupt request would be cleared inadequately if interrupt is requested while such instructions are executed.). Thus interrupt request can be canceled /initialized by software. Interrupt latches are not set to "1" by an instruction. Since interrupt latches can be read, the status for interrupt requests can be monitored by software. Note: <u>Before you change each enable flag (EF) and/or each interrupt latch (IL)</u>, be sure to clear the interrupt master enable flag IMF) to "0" (to disable interrupts). - a. After a DI instruction is executed. - b. When an interrupt is accepted, IMF is automatically cleared to "0". However, to enable nested interrupts, change EF and/or IL before setting IMF to "1" (to enable interrupts). If the individual enable flags (EF) and interrupt latches (IL) are set under conditions other than the above, the proper operation cannot be guaranteed. ### Example 1: Clears interrupt latches ``` \begin{array}{lll} DI & ; IMF \leftarrow 0 \\ LDW & (ILL), \ 11101000001111111B & ; IL_{12}, \ IL_{10} \ to \ IL_{6} \leftarrow 0 \\ LD & (ILH), \ 11111000B & ; IL10 \ to \ IL8 \leftarrow 0 \\ EI & ; IMF \leftarrow 1 \end{array} ``` Example 2: Reads interrupt latches LD WA, (ILL) ; $W \leftarrow IL_H$ , $A \leftarrow IL_L$ Example 3: Tests an interrupt latches TEST (ILL). 7 ; if IL $_7$ =1 then jump JR F, SSET ### (2) Interrupt Enable Register (EIR) The interrupt enable register (EIR) enables and disables the acceptance of interrupts, except for the non-maskable interrupts (software interrupt, undefined instruction interrupt, address trap interrupt and watchdog interrupt). Non-maskable interrupt is accepted regardless of the contents of the EIR. The EIR consists of an interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). These registers are located on address $003C_{\rm H}$ and $003D_{\rm H}$ in SFR area, and they can be read and written by an instructions (including read-modify-write instructions such as bit manipulation or operation instructions). Note: <u>Before you change each enable flag (EF) and/or each interrupt latch (IL)</u>, be sure to clear the interrupt master enable flag IMF) to "0" (to disable interrupts). - a. After a DI instruction is executed. - b. When an interrupt is accepted, IMF is automatically cleared to "0". However, to enable nested interrupts, change EF and/or IL before setting IMF to "1" (to enable interrupts). If the individual enable flags (EF) and interrupt latches (IL) are set under conditions other than the above, the proper operation cannot be guaranteed. 86CH06-39 2002-10-08 # a) Interrupt master enable flag (IMF) The interrupt enable register (IMF) enables and disables the acceptance of the whole maskable-interrupt. While IMF="0", all maskable interrupts are not accepted regardless of the status on each individual interrupt enable flag (EF). By setting IMF to "1", the interrupt becomes acceptable if the individuals are enabled. When an interrupt is accepted, IMF is cleared to "0" after the latest status on IMF is stacked. Thus the maskable interrupts which follow are disabled. By executing return interrupt instruction [RETI/RETN], the stacked data, which was the status before interrupt acceptance, is loaded on IMF again. The IMF is located on bit0 in EIRL (address: $003A_H$ in SFR), and can be read and written by an instruction. The IMF is normally set and cleared by [EI] and [DI] instruction respectively. During reset, the IMF is initialized to "0", and maskable interrupts are not accepted until it is set to "1". b) Individual interrupt enable flags (EF<sub>15</sub> to EF<sub>4</sub>) Each of these flags enables and disables the acceptance of its maskable interrupt. Setting the corresponding bit of an individual interrupt enable flag to "1" enables acceptance of its interrupt, and setting the bit to "0" disables acceptance. The individual interrupt enable flags ( $EF_{15}$ to $EF_4$ ) are located on EIRL to EIRH (address: $003A_H$ to $003B_H$ in SFR), and can be read and written by an instruction. During reset, all the individual interrupt enable flags ( $EF_{15}$ to $EF_4$ ) are initialized to "0" and all maskable interrupts are not accepted until they are set to "1". Example 1: Sets individual interrupt enable flags 86CH06-40 2002-10-08 Figure 1-22 (1). Interrupt Latch (IL), Interrupt Enable Registers (EIR) # (3) Selecting interrupt factor (INTSEL) Each interrupt factor, that shares its interrupt source with other factors, enables its interrupt latch (IL) only if it is selected on INTSEL. The interrupt controller does not hold the interrupt request, while the factor generates the interrupt request is not selected on INTSEL. Therefore, set INTSEL appropriately before interrupt factors arises. Figure 1-22 (2). Interrupt Selecting Register (INTSEL) 86CH06-41 2002-10-08 # 1.6.1 Interrupt Sequence An interrupt request, which raised interrupt latch, is held, until interrupt is accepted or interrupt latch is cleared to "0" by resetting or an instruction. Interrupt acceptance sequence requires 8 machine cycles (2 $\mu$ s at 16 MHz) after the completion of the current instruction. The interrupt service task terminates upon execution of an interrupt return instruction [RETI] (for maskable interrupts) or [RETN] (for non-maskable interrupts). Figure 1-23 shows the timing chart of interrupt acceptance processing. - (1) Interrupt acceptance processing is packaged as follows. - a) The interrupt latch (IL) for the interrupt source accepted is cleared to "0". - b) The contents of the program counter (PC) and the program status word, including the interrupt master enable flag (IMF), are saved (pushed) on the stack in sequence of PSW+IMF, PCH,PCL. Meanwhile, the stack pointer (SP) is decremented by 3. - c) The interrupt master enable flag (IMF) is cleared to "0" in order to disable the acceptance of any following interrupt. - d) The entry address (interrupt vector) of the corresponding interrupt service program, loaded on the vector table, is transferred to the program counter. - e) The instruction stored at the entry address of the interrupt service program is executed. Figure 1-23. Timing chart of Interrupt Acceptance/Return Interrupt instruction 86CH06-42 2002-10-08 Example: Correspondence between vector table address for INTTBT and the entry address of the interrupt service program A maskable interrupt is not accepted until the IMF is set to "1" even if the maskable interrupt higher than the level of current servicing interrupt is requested. In order to utilize nested interrupt service, the IMF is set to "1" in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags. To avoid overloaded nesting, clear the individual interrupt enable flag whose interrupt is currently serviced, before setting IMF to "1". As for non-maskable interrupt, keep interrupt service shorten compared with length between interrupt requests; otherwise the status cannot be recovered as non-maskable interrupt would simply nested. # (2) Saving/Restoring general -purpose registers During interrupt acceptance processing, the program counter (PC) and the program status word (PSW, includes IMF) are automatically saved on the stack, but the accumulator and others are not. These registers are saved by software if necessary. When multiple interrupt services are nested, it is also necessary to avoid using the same data memory area for saving registers. The following methods are used to save/restore the general-purpose registers. # a) Using PUSH and POP instructions To save only a specific register, PUSH and POP instructions are available. Example: save/store register using PUSH and POP instructions 86CH06-43 # b) Using data transfer instructions To save only a specific register without nested interrupts, data transfer instructions are available. Example: save/store register using data transfer instructions PINTxx: LD (GSAVA), A ; Save A register (interrupt processing) LD A, (GSAVA); Restore A register RETI ; RETURN Figure 1-24. Saving/Restoring general-purpose registers under interrupt processing ### (3) Interrupt return Interrupt return instructions [RETI]/[RETN] perform as follows. [RETI]/[RETN] Interrupt Return Program Counter (PC) and program status word (PSW, includes IMF) are restored from the stack. Stack pointer (SP) is incremented by 3. As for Address Trap interrupt (INTATRAP), it is required to alter stacked data for program counter (PC) to restarting address, during interrupt service program. Otherwise returning interrupt causes INTATRAP again. When interrupt acceptance processing has completed, stacked data for $PC_L$ and $PC_H$ are located on address (SP+1) and (SP+2) respectively. 86CH06-44 2002-10-08 Example 1: Returning from address trap interrupt (INTATRAP) service program PINTxx: POP WA ; Recover SP by 2 LD WA, Return Address PUSH WA ; Alter stacked data (interrupt processing) RETN ; RETURN # Example 2: Restarting without returning interrupt (In this case, PSW (includes IMF) before interrupt acceptance is discarded.) PINTxx: INC SP ; Recover SP by 3 INC SP ; INC SP ; (interrupt processing) LD EIRL, data ; Set IMF to "1" or clear it to "0" JP Restart Address ; Jump into restarting address It is recommended that stack pointer be return to rate before INTATRAP (increment 3 times), if return interrupt instruction [RETN] is not utilized during interrupt service program under INTATRAP (such as Example 2). Interrupt requests are sampled during the final cycle of the instruction being executed. Thus, the next interrupt can be accepted immediately after the interrupt return instruction is executed. Note: When the interrupt processing time is longer than the interrupt request generation time, the interrupt service task is performed but not the main task. ### 1.6.2 Software Interrupt (INTSW) Executing the [SWI] instruction generates a software interrupt and immediately starts interrupt processing (INTSW is highest prioritized interrupt). Use the [SWI] instruction only for detection of the address error or for debugging. ### ① Address error detection $FF_H$ is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address during single chip mode. Code $FF_H$ is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing $FF_H$ to unused areas of the program memory. Address-trap reset is generated in case that an instruction is fetched from RAM or SFR areas. # 2 Debugging Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address. 86CH06-45 2002-10-08 # 1.6.3 Undefined instruction interrupt (INTUNDEF) Taking code which is not defined as authorized instruction for instruction causes INTUNDEF. INTUNDEF is generated when the CPU fetches such a code and tries to execute it. INTUNDEF is accepted even if non-maskable interrupt is in process. Contemporary process is broken and INTUNDEF interrupt process starts, soon after it is requested. Note: The undefined instruction interrupt (INTUNDEF) forces CPU to jump into vector address, as software interrupt (SWI) does. # 1.6.4 Address trap interrupt (INTATRAP) Fetching instruction from unauthorized area for instructions (address trapped area) causes reset-output or address trap interrupt (INTATRAP). INTATRAP is accepted even if non-maskable interrupt is in process. Contemporary process is broken and INTATRAP interrupt process starts, soon after it is requested. The address trapped area is alternative: SFR and RAM, or SFR only. - The operating mode under address trapped, whether to be reset-output or interrupt processing, is selected on watchdog timer control register (WDTCR). - Note 2: When the SWI instruction or undefined instruction located in address immediately preceding the address trap area is executed, address trap interrupt accept processing is executed immediately after the SWI/undefined instruction interrupt is accepted. # 1.6.5 External Interrupts The TMP86CH06 has six external interrupt inputs. These inputs are equipped with digital noise reject circuits (pulse inputs of less than a certain time are eliminated as noise). Edge selection is also possible with INT1 to INT4. The INT0/P10 pin can be configured as either an external interrupt input pin or an input/output port, and is configured as an input port during reset. Edge selection, noise reject control and INTO/P10 pin function selection are performed by the external interrupt control register (EINTCR). Secondary Source Pin **Enable conditions** Edge Digital noise reject function pin Pulses of less than 2/fc [s] are eliminated as noise. Pulses of 7/fc [s] or more are considered $IMF = 1, EF_4 = 1,$ to be signals. In the SLOW or the SLEEP mode, ĪNT0 INT0 P10 Falling edge INTOEN = 1 pulses of less than 1/fs [s] are eliminated as noise. Pulses of 3.5/fs [s] or more are considered to be signals. Pulses of less than 15/fc or 63/fc [s] are INT1 NT1 P11 $IMF \cdot EF_5 = 1$ eliminated as noise. Pulses of 49/fc or 193/fc [s] or more are considered to be signals. In the SLOW or the SLEEP mode, pulses of less $IMF \cdot EF_{12} = 1$ INT2 INT2 P37/OC0 than 1/fs [s] are eliminated as noise. Pulses of INTOCOER = 1 Falling edge 3.5/fs [s] or more are considered to be signals. Pulses of less than 7/fc [s] are eliminated as Rising edge $IMF \cdot EF_{13} = 1$ INT3 INT3 P46/SI1/RXD1 noise. Pulses of 25/fc [s] or more are INTRXDER = 0 considered to be signals. In the SLOW or the SLEEP mode, pulses of less $IMF \cdot EF_{14} = 1$ INT4 INT4 P47/SO1/TXD1 than 1/fs [s] are eliminated as noise. Pulses of INTTXDER = 0 3.5/fs [s] or more are considered to be signals. Pulses of less than 2/fc [s] are eliminated as noise. Pulses of 7/fc [s] or more are considered $IMF \cdot EF_{15} = 1$ to be signals. In the SLOW or the SLEEP mode, INT5 ĪNT5 P20/STOP Falling edge INT5ER = 1 pulses of less than 1/fs [s] are eliminated as noise. Pulses of 3.5/fs [s] or more are considered to be signals. Table 1-7. External Interrupts - Note 1: If a noiseless signal is input to the external interrupt pin in the NORMAL 1/2 or IDLE 1/2 mode, the maximum time from the edge of input signal until the IL is set is as follows: - ① INT1 pin 55/fc[s] (INT1NC = 1), 199/fc[s] (INT1NC = 0) - 2 INT2 to 4 pin 31/fc [s] - Note 2: Even if the falling edge of $\overline{\text{INTO}}$ pin input is detected at INTOEN = 0, the interrupt latch IL<sub>4</sub> is not set. - Note 3: When data changed and did a change of I/O when used external interrupt ports as a normal ports, interrupt request signal occurs incorrectly. Handling of prohibition of interrupt enable register (EIR) is necessary. - Note 4: The maximum time from modifying INT1NC until a noise reject time is changed is 26/fc. ww DataSheet411 com | EINTCR<br>(0037 <sub>H</sub> ) | 7<br>INT1NC IN | 6 5<br>TOEN IN | 4<br>IT4ES | 3<br>INT3ES | 2<br>INT2ES | 1<br>INT1ES | 0 | (Initial value: 0000 000*) | | |--------------------------------|-------------------------------|----------------------------------------------------------------------------------|------------|-------------|------------------------|---------------------------|---|------------------------------------------------------------|--| | | INT1NC | 11NC I Noise reject time select I | | | 1 | | | [s] are eliminated as noise<br>[s] are eliminated as noise | | | | INT0EN | P10/INT0 pin configuration | | | | nput/outpu<br>pin (Port P | | lld be set to an input mode) | | | | INT4 ES | INT4 edge select O0: Rising edge O1: Falling edge 10: Both edges 11: High level | | | R/W | | | | | | | INT3 ES<br>INT2 ES<br>INT1 ES | INT3 to INT | 1 edge sel | ect | 0: Rising<br>1: Fallin | g edge<br>ng edge | | | | - Note 1: fc : High-frequency clock [Hz] \* : Don't care - Note 2: When the system clock frequency is switched between high and low or when the external interrupt control register (EINTCR) is overwritten, the noise canceller may not operate normally. It is recommended that external interrupts are disabled using the interrupt enable register (EIR). Figure 1-25. External Interrupt Control Register #### 1.7 Reset Circuit The TMP86CH06 has four types of reset generation procedures: an external reset input, an address trap reset output, a watchdog timer reset output and a system clock reset output. Table 1-8 shows on-chip hardware initialization by reset action. The malfunction reset output circuit such as watchdog timer reset, address trap reset and system clock reset is not initialized when power is turned on. The $\overline{\text{RESET}}$ pin can output level "L" at the maximum 24/fcgck[s] (1.5 $\mu$ s at 16.0 MHz) when power is turned on. | On-chip hardware | | Initial value | On-chip hardware | Initial value | | |-------------------------------------------------------|-----------|----------------------|---------------------------------|-----------------------------|--| | Program counter (PC) | | (FFFE <sub>H</sub> ) | | 0 | | | Stack pointer (SP) | | Not initialized | Prescaler and Divider of timing | | | | General-purpose registers | | Not initialized | generator | 0 | | | (W, A, B, C, D, E, H, L | , IX, IY) | | | | | | Jump status flag | (JF) | Not initialized | Watchdog timer | Enable | | | Zero flag | (ZF) | Not initialized | | | | | Carry flag (CF) | | Not initialized | | | | | Half carry flag | (HF) | Not initialized | 0 | Refer to I/O port circuitry | | | Sign flag | (SF) | Not initialized | Output latches of I/O ports | | | | Overflow flag (VF) Interrupt master enable flag (IMF) | | Not initialized | | | | | | | 0 | | | | | Interrupt individual enable flags | | 0 | | Defeate and of | | | | (EF) | | Control registers | Refer to each of | | | Interrupt latches | (IL) | 0 | | control register | | | | | | RAM | not initialized | | Table 1-8. Initializing Internal Status by Reset Action ### 1.7.1 External Reset Input The RESET pin contains a Schmitt trigger (hysteresis) with an internal pull-up resistor. When the RESET pin is held at "L" level for at least 3 machine cycles (12/fcgck [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 $\overline{RESET}$ pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFE to FFFF<sub>H</sub>. Figure 1-26. Reset Circuit # 1.7.2 Address-Trap-Reset If the CPU should start looping for some cause such as noise and an attempt be made to fetch an instruction from the on-chip RAM or the SFR area, address-trap-reset will be generated. Then, the RESET pin output will go low. The reset time is about 8/fcgck to 24/fcgck [s] (0.5 to 1.5 $\mu$ s at 16.0 MHz). Figure 1-27. Address-Trap-Reset Note: The operating mode under address trapped is alternative of reset or interrupt. The address trap area is alternative. # 1.7.3 Watchdog Timer Reset Refer to Section "2.4 Watchdog Timer". # 1.7.4 System-Clock-Reset Clearing both XEN and XTEN (bits 7 and 6 in SYSCR2) to "0", clearing XEN to "0" when SYSCK=0, or clearing XTEN to "0" when SYSCK=1 stops system clock, and causes the microcomputer to deadlock. This can be prevented by automatically generating a reset signal whenever XEN = XTEN = 0, XEN = SYSCK = 0, or XTEN = 0/SYSCK = 1 is detected to continue the oscillation. The, the $\overline{RESET}$ pin output goes low from high-impedance. The reset time is about 8/fcgck to 24/fcgck [s] (0.5 to 1.5 $\mu$ s at 16.0 MHz). #### 2.1 **Special Function Register (SFR)** The TMP86CH06 adopts the memory mapped I/O system, and all peripheral control and data transfers are performed through the special function register (SFR). A series of SFR is mapped on address $0000_{\rm H}$ to $003F_{H}$ . Figure 2-1 (a) to 2-1 (b) indicate the special function register (SFR) for TMP86CH06. | Address | Read | Write | | | | | | |--------------------------------------------|------------------------------------|-----------------------------------------|--|--|--|--|--| | 0000 <sub>H</sub> | PODR | (P0 Port output latch) | | | | | | | 0001 <sub>H</sub> | P1DR | (P1 Port output latch) | | | | | | | 0002 <sub>H</sub> | P2DR | (P2 Port output latch) | | | | | | | eet4U.d <del>om</del><br>0003 <sub>H</sub> | P3DR | (P3 Port output latch) | | | | | | | 0004 <sub>H</sub> | P4DR | (P4 Port output latch) | | | | | | | 0005 <sub>H</sub> | Reserved | | | | | | | | 0006 <sub>H</sub> | Reserved | | | | | | | | 0007 <sub>H</sub> | Reserved | | | | | | | | 0008 <sub>H</sub> | POCR | (P0 Port input/output Control Register) | | | | | | | 0009 <sub>H</sub> | P1CR | (P1 Port input/output Control Register) | | | | | | | 000A <sub>H</sub> | P3CR | (P3 Port input/output Control Register) | | | | | | | 000B <sub>H</sub> | P4CR | (P4 Port input/output Control Register) | | | | | | | 000C <sub>H</sub> | P4ODE | (P4 Port Open-Drain control Register) | | | | | | | 000D <sub>H</sub> | P2R (P2 Port terminal input) | <del></del> | | | | | | | 000E <sub>H</sub> | P4R (P4 Port terminal input) | | | | | | | | 000F <sub>H</sub> | Reserved | | | | | | | | 0010 <sub>H</sub> | ETOCR | (ETC0 Control Register) | | | | | | | 0011 <sub>H</sub> | ET0MIO | (ETC0 Capture/Compare Mode Register) | | | | | | | 0012 <sub>H</sub> | ETORL | (ETC0 Register L) | | | | | | | 0013 <sub>H</sub> | ETORH | (ETC0 Register H) | | | | | | | 0014 <sub>H</sub> | ETOICAL (ETCO Capture Register AL) | | | | | | | | 0015 <sub>H</sub> | ET0ICAH (ETC0 Capture Register AH) | | | | | | | | 0016 <sub>H</sub> | ETOICBL (ETC0 Capture Register BL) | PME (Pulse Measure Enable) | | | | | | | 0017 <sub>H</sub> | ETOICBH (ETC0 Capture Register BH) | | | | | | | | 0018 <sub>H</sub> | ET0OCRL | (ETC0 Compare Register L) | | | | | | | 0019 <sub>H</sub> | ET0OCRH | (ETC0 Compare Register H) | | | | | | | 001A <sub>H</sub> | UARTOSR (UARTO status register) | UARTOCRA (UARTO control register A) | | | | | | | 001B <sub>H</sub> | <u> </u> | UARTOCRB (UARTO control register B) | | | | | | | 001C <sub>H</sub> | RDOBUF | TD0BUF | | | | | | | 001D <sub>H</sub> | RD1BUF | TD1BUF | | | | | | | 001E <sub>H</sub> | UART1SR (UART1 status register) | UART1CRA (UART1 control register A) | | | | | | | 001F <sub>H</sub> | <del></del> | UART1CRB (UART1 control register B) | | | | | | Figure 2-1 (a). the special function register (SFR) for TMP86CH06 | Address | Read | Write | |-------------------|-----------------------------|------------------------------------------| | 0020 <sub>H</sub> | TCOCR | (Timer0 Control Register) | | 0021 <sub>H</sub> | TC1CR | (Timer1 Control Register) | | 0022 <sub>H</sub> | TTREG0 | (Timer Term register0) | | 0023 <sub>H</sub> | TTREG1 | (Timer Term register 1) | | 0024 <sub>H</sub> | PWREG0 | (Pulse Width register0) | | 0025 <sub>H</sub> | PWREG1 | (Pulse Width register1) | | 0026 <sub>H</sub> | | SIOCR1 (SIO Control Register 1) | | 0027 <sub>H</sub> | SIOSR (SIO Status Register) | SIOCR2 (SIO Control Register 2) | | 0028 <sub>H</sub> | | | | 0029 <sub>H</sub> | | | | 002A <sub>H</sub> | | | | 002B <sub>H</sub> | SIODBR (SIO Receive/Tran | smit Data Buffer (8 byte) | | 002C <sub>H</sub> | | | | 002D <sub>H</sub> | | | | 002E <sub>H</sub> | | | | 002F <sub>H</sub> | | | | 0030 <sub>H</sub> | CGCR | (Clock Gear Control Register) | | 0031 <sub>H</sub> | _ | EXPCR (External Access) | | 0032 <sub>H</sub> | WAITCR | (Wait Control register) | | 0033 <sub>H</sub> | Rese | erved | | 0034 <sub>H</sub> | <del></del> | WDTCR1 (WDT Control 1) | | 0035 <sub>H</sub> | <del>_</del> | WDTCR2 (WDT Control 2) | | 0036 <sub>H</sub> | TBTCR | (TBT/TG/DVO control register) | | 0037 <sub>H</sub> | EINTCR | (External Interrupt Control Register) | | 0038 <sub>H</sub> | SYSCR1 | (System Control 1) | | 0039 <sub>H</sub> | SYSCR2 | (System Control 2) | | 003A <sub>H</sub> | EIRL | (The lower of interrupt enable register) | | 003B <sub>H</sub> | EIRH | (The upper of interrupt enable register) | | 003CH | ILL | (The lower of interrupt latch) | | 003D <sub>H</sub> | ILH | (The upper of interrupt latch) | | 003E <sub>H</sub> | INTSEL | (Interrupt Factor Selector) | | 003F <sub>H</sub> | PSW | (Program Status Word) | Figure 2-1 (b). the special function register (SFR) for TMP86CH06 Note 1: Do not access reserved areas by software. Note 2: - : Cannot be accessed. Note 3: Write only register and interrupt latches cannot use the read-modify-write instructions (bit manipulation instructions such as SET, CLR, etc. and logical operations such as AND, OR, etc.). Note 4: Address 0032<sub>H</sub>: Only bit 2 and 3 on WAITCR can be read. 86CH06-51 2002-10-08 ### 2.2 I/O Ports The TMP86CH06 has 5 parallel input/output ports (35 pins) as follows. ① Port PO ; 8-bit I/O port (utilized also for Address/Data bus) ② Port P1; 8-bit I/O port (utilized also for External interrupt input, Timer input/output and External memory management output) ③ Port P2; 3-bit I/O port (utilized also for Low frequency resonator connections, External interrupt input and STOP mode releasing signal input) ④ Port P3; 8-bit I/O port (utilized also for Address bus output, Timer input/output and External interrupt input) 5 Port P4; 8-bit I/O port (utilized also for Timer input and Serial interface 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 be externally held until the input data is read from outside or reading should be performed several timer 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 cannot be recognized from outside, so that transient input such as chattering must be processed by the program. Output data changes in the S2 state of the write cycle during execution of the instruction which writes to an I/O port. Figure 2-2. Input/Output Timing (Example) 86CH06-52 2002-10-08 #### 2.2.1 Port P0 Port P0 is the 8-bit I/O port that allows selection of input/output on bit basis. Input/output mode is specified on the P0 port input/output control register (P0CR). During reset, all the bits on P0CR are initialized to "0" and P0 becomes input port. Reset operation also initializes all the bits on P0 port output latch (P0DR) to "0". Besides input/output port, Port P0 functions as multiplexed Address/Data bus (AD7 to 0). Port P0 becomes 8-bit bidirectional Address/Data bus (AD7 to 0) when the CPU accesses to the external memory. When it functions as data bus, the judgment on its input rate is based on TTL level. Note: Input status is read while the port is input mode. Therefore the contents of output latch, that belongs to the terminal for input, may alter if both input and output are mixed in PO port. w.DataSheet4U.com Figure 2-3. Port P0 (1/2) Figure 2-3. Port P0 (2/2) unu DataShoot/III oom #### 2.2.2 Port P1 Port P1 is the 8-bit I/O port that allows selection of input/output on bit basis. Input/output mode is specified on the P1 port input/output control register (P1CR). During reset, all the bits on P1CR are initialized to "0" and P1 becomes input port. Reset operation also initializes all the bits on P1 port output latch (P1DR) to "0". Besides input/output port, the terminals in Port P1 functions as follows. P15, P16 and P17 have $\overline{WR}$ , $\overline{RD}$ and ALE function respectively. These terminals output signals for $\overline{WR}$ , $\overline{RD}$ and ALE when the CPU accesses to the external memory. In order to utilize $\overline{WR}$ and $\overline{RD}$ functions, set WROE and RDOE, located on the EXPCR, respectively. If WROE, RDOE or both are enabled, P17 functions as ALE. If the device is released from reset while $\overline{EA}$ terminal is low, $\overline{CLK}$ signal is uttered every machine cycle. P10, P11 and P12 have $\overline{INT0}$ , INT1, and ETC0 function respectively. In order to utilize these functions, the terminal should be set for input. Furthermore, pll has the function of $\overline{\text{WAIT}}$ while the external memory is begin connected. If the $\overline{\text{WAIT}}$ function is not necessary as external memory is utilized, clear the WAIT bits (bit 7, 6) on WAITCR to "00". P13 and P14 have $\overline{DVO}$ and TO1 function respectively. In order to utilize these functions, the output latch belongs to each terminal should be set to "1" before the terminal is set for output. Note1: Input status is read while the port is input mode. Therefore the contents of output latch, that belongs to the terminal for input, may alter if both input and output are mixed in P1 port. Note2: When the external memory is used, P10 pin cannot be used as external interrupt pin (INTO) or input/output port because CLK is output from P10. Figure 2-4. P10 Figure 2-5. P11, P12 Figure 2-6. P13, P14 Figure 2-7. P15, P16 Figure 2-8. P17 Figure 2-9. Port P1DR and P1CR register #### 2.2.3 Port P2 Port P2 is a 3-bit input/output port. It is also used as an external interrupt, a STOP mode release signal input, and low-frequency Xtal connection pins. When they are used as an input port or a secondary function pins, the respective output latch should be set to "1". A low-frequency Xtal (32.768 kHz) is connected to pins P21 (XTIN) and P22 (XTOUT) in the dual-clock mode. In the single-clock mode, pins P21 and P22 can be used as normal input/output ports. It is recommended that pin P20 should be used as an external interrupt input, a STOP mode release signal input, or an input port. If it is used as an output port, the interrupt latch is set on the falling edge of the output pulse. When a read instruction is executed for port P2, bits 7 to 3 are read as undefined values. P2 port output latch (P2DR) and P2 port terminal input (P2R) are located on their respective addresses. Therefore, if input and output pins are mixed in P2 port, Read Write Modify instructions do not affect the output latch belongs to the terminal for input. w DataSheet4U com Figure 2-10. Port P2 Note1: Port P20 is used as STOP pin. Therefore, when stop mode is started, OUTEN does not affect to P20, and P20 becomes High-Z mode. Note2: Bit 7 through bit 3 in P2R contain unstable values. Note3: \*: Don't care. #### 2.2.4 Port P3 Port P3 is the 8-bit I/O port that allows selection of input/output on bit basis. Input/output mode is specified on the P3 port input/output control register (P3CR). During reset, all the bits on P3CR are initialized to "0" and P3 becomes input port. Reset operation also initializes all the bits on P3 port output latch (P3DR) to "0". Besides input/output port, the terminals in Port P3 functions as follows. P36 and P37 have IC0 and INT2 function respectively. In order to utilize these functions, the terminal should be set for input. P35 and P37 have TO0 and OC0 function respectively. In order to utilize these functions, the output latch belongs to each terminal should be set to "1" before the terminal is set for output. Port P3 also functions as address bus (A15 to 8). Port P3 becomes 8-bit bidirectional address bus (A15 to 8) when the CPU accesses to the external memory. In order to utilize address bus (A15 to 8) function, set ABUSEN, located on the EXPCR. Note: Input status is read while the port is input mode. Therefore the contents of output latch, that belongs to the terminal for input, may alter if both input and output are mixed in P3 port. Figure 2-11. Port P3 (1/2) Figure 2-11. Port P3 (2/2) unu DataShoot/III oom #### 2.2.5 Port P4 Port P4 is the 8-bit I/O port that allows selection of input/output on bit basis. Input/output mode is specified on the P4 port input/output control register (P4CR). During reset, all the bits on P4CR are initialized to "0" and P4 becomes input port. Reset operation also initializes all the bits on P4 port output latch (P4DR) to "1". Port P4 has programmable open-drain output function. The data on P4 port open-drain control register (P4ODE) determines whether open-drain output is enabled or disabled on bit basis. During reset, all the bits on P4ODE are initialized to "0", and under the circumstances P4 becomes CMOS output port if P4CR is set to "1". Besides input/output port, the terminals in Port P4 functions as follows. P40 and P41 have TI0 and TI1 function respectively: both TI0 and TI1 are for 8-bit timers. In order to utilize these functions, the terminal should be set for input. P46 and P47 have INT3 and INT4 function respectively: both INT3 and INT4 are for interrupts. In order to utilize these functions, the terminal should be set for input. The bundles, one consists of P42, P43 and P44 and the other consists of P46 and P47, have serial interface function respectively. P4 output latch (P4DR) and P4 port terminal input (P4R) are located on their respective addresses. Therefore, if input and output pins are mixed in P4 port, Read Write Modify instructions do not affect the output latch belongs to the terminal for input. w DataSheet4U com Figure 2-12. Port P4 (1/2) Figure 2-12. Port P4 (2/2) ### 2.3 Time Base Timer (TBT) The time base timer generates time base for key scanning, dynamic displaying, etc. It also provides a time base timer interrupt (INTTBT). An INTTBT is generated on the first falling edge of source clock (the divider output of the timing generator) after the time base timer has been enabled. The divider is not cleared by the program; therefore, only the first interrupt may be generated ahead of the set interrupt period (Figure 2-9.(b)). The interrupt frequency (TBTCK) must be selected with the time base timer disabled (the interrupt frequency must not be changed with the disable from the enable state). Both frequency selection and enabling can be performed simultaneously. Figure 2-13. Time Base Timer Example: Sets the time base timer frequency to fc/216 [Hz] and enables an INTTBT interrupt. 86CH06-66 2002-10-08 Figure 2-14. Time Base Timer Control Register Table 2-1. Time Base Timer Interrupt Frequency (Example: fc = 16.0 MHz, fs = 32.768 kHz) | | Time base timer interrupt frequency [Hz] | | | | | | | | |-------|------------------------------------------|------------|-----------|-------------|------|--|--|--| | твтск | | CLOW CLEED | | | | | | | | | DV70 | CK = 0 | DV70 | SLOW, SLEEP | | | | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | mode | | | | | 000 | 1.91 | 0.95 | 1 | 1 | 1 | | | | | 001 | 7.63 | 3.81 | 4 | 4 | 4 | | | | | 010 | 244.14 | 122.07 | 128 | 128 | _ | | | | | 011 | 976.56 | 488.28 | 512 | 512 | _ | | | | | 100 | 1953.13 | 976.56 | 1024 | 1024 | _ | | | | | 101 | 3906.25 | 1953.13 | 2048 | 2048 | - | | | | | 110 | 7812.5 | 3906.25 | 4096 | 4096 | - | | | | | 111 | 31250 | 15625 | 16384 | 16384 | - | | | | # 2.4 Watchdog Timer (WDT) The watchdog timer is a fail-safe system to rapidly detect the CPU malfunctions such as endless looping caused by noise or the like, or deadlock and resume the CPU to the normal state. The watchdog timer signal for detecting malfunction can be selected either a reset 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. Note: The functions of the watchdog timer may not be fully realized due to disturbance noise, etc. Therefore, careful consideration is required in the designing stage. ataSheet4U.com # 2.4.1 Watchdog Timer Configuration Figure 2-15. Watchdog Timer Configuration # 2.4.2 Watchdog Timer Control Figure 2-16 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 at follows. - ① Setting the detection time, selecting output, and clearing the binary counter. - 2 Repeatedly clearing the binary counter within the setting detection time Note: The watchdog timer consists of an internal divider and a two-stage binary counter. When clear code 4E<sub>H</sub> is written, only the binary counter is cleared, not the internal divider. Depending on the timing at which clear code 4E<sub>H</sub> is written on the WDTCR2 register, the overflow time of the binary counter may be at minimum 3/4 of the time set in WDTCR1 < WDTT>. Thus, write the clear code using a shorter cycle than 3/4 of the time set in WDTCR1 < WDTT>. If the CPU malfunctions such as endless looping or deadlock occur for any cause, the watchdog timer output will become active at the rising of an overflow from the binary counters unless the binary counters are cleared. At this time, when WDTOUT=1 a reset is generated, which drivers the $\overline{RESET}$ pin low to reset the internal hardware and the external circuit. When WDTOUT=0, a watchdog timer interrupt (INTWDT) is generated. The watchdog timer temporarily stops counting in STOP mode including warm-up or IDLE mode, and automatically restarts (continues counting) when the STOP/IDLE mode is released. Example: Sets the watchdog timer detection time to $2^{21}/\text{fc}$ [s] and resets the CPU malfunction. 86CH06-69 2002-10-08 Figure 2-16. Watchdog Timer Control Registers ### (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. #### (3) Watchdog timer disable The watchdog timer is disabled by writing the disable code (B1<sub>H</sub>) 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". During disabling the watchdog timer, the binary counters are cleared to "0". 86CH06-70 2002-10-08 Example: Disables watchdog timer DI : $IMF \leftarrow 0$ LD(WDTCR2), 04EH ; Clear the binary counter LDW (WDTCR1), 0B101H; WDTEN $\leftarrow 0$ , WDTCR2 $\leftarrow$ Disable code EI ; $IMF \leftarrow 1$ Table 2-2. Watchdog Timer Detection Time (Example: fc = 16.0 MHz, fs = 32.768 kHz) | | Watchdog timer detection time [s] | | | | | | | | |------|-----------------------------------|-----------|-----------|-----------|--------|--|--|--| | WDTT | | | | | | | | | | 1,00 | DV7C | :K = 0 | DV70 | SLOW mode | | | | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | | | | | | 00 | 2.097 | 4.194 | 4 | 4 | 4 | | | | | 01 | 524.288 m | 1.049 | 1 | 1 | 1 | | | | | 10 | 131.072 m | 262.144 m | 250 m | 250 m | 250 m | | | | | 11 | 32.768 m | 65.536 m | 62.5 m | 62.5 m | 62.5 m | | | | # 2.4.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, 0023FH ; Sets the stack pointer LD (WDTCR1), 00001000B ; WDTOUT $\leftarrow$ 0 # 2.4.4 Watchdog Timer Reset If the watchdog timer output becomes active, a reset is generated, which drivers the $\overline{RESET}$ pin (sink open drain input/output with pull-up) low to reset the internal hardware. The reset output time is about 8/fcgck to 24/fcgck [s] (0.5 to 1.5 $\mu$ s at fc=16.0 MHz). Note: The high-frequency clock oscillator also turns on when a watchdog timer reset is generated in SLOW mode. The reset output time is 8/fcgck to 24/fcgck [s]. Therefore, the reset time may include a certain amount of error if there is any fluctuation of the oscillation frequency at starting the high-frequency clock oscillation. Thus, the reset time must be considered an approximated value. Figure 2-17. Watchdog Timer Interrupt/Reset # 2.4.5 Address trap The Watchdog Timer Control Register 1, 2 shares its addresses with the control registers in case of address trap. These control registers for address trap are shown on Figure 2-18. Whether internal RAM area should be trapped or not is selected on bit ATAS on WDTCR1. The written data becomes valid after the control code D2H is written on WDTCR2. If the instructions are to be placed on internal RAM area, internal RAM area should be excepted from the area to be trapped before such instructions are executed. The operating mode under address trapped, whether to be reset-output or interrupt processing, is selected on bit ATOUT on WDTCR1. Example: Setting in order that the CPU normally executes instruction in internal RAM area and the address trap causes interrupt LD (WDTCR1), 0D200H Figure 2-18. Watchdog Timer Control Registers 86CH06-72 2002-10-08 ## 2.5 Divider Output (DVO) Approximately 50% duty pulse can be output using the divider output circuit, which is useful for piezoelectric buzzer drive. Divider output is from pin P13 ( $\overline{DVO}$ ). The P13 output latch (P1DR bit 3=1) should be set to "1" and then the P13 should be configured as an output mode (P1CR bit 3=1). Note: The divider output frequency should be selected with divider output disabled. (The divider output frequency should not also be changed when divider output is changed from enabled state to disabled state.) Figure 2-19. Divider Output Control Register Example: 1.95 kHz pulse output (at fc = 16 MHz, DV1CK = 1) SET (P1DR). 3 ; P13 output latch←1 SET (P1CR). 3 ; Configures P13 as an output mode LD (TBTCR), 100000000B; DVOEN $\leftarrow$ 1, DVOCK $\leftarrow$ 00 Table 2-3. Divider Output Frequency (Example: at fc = 16.0 MHz, fs = 32.768 kHz) | DVOCK | | NORMAL1/2, I | DLE1/2 mode | | | |-------|---------------------|--------------|-------------|-----------|------------------| | DVOCK | DV7CK = 0 DV7CK = 1 | | | | SLOW, SLEEP mode | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | | | 00 | 1.953 k | 976.6 | 1.024 k | 1.024 k | 1.024 k | | 01 | 3.906 k | 1.953 k | 2.048 k | 2.048 k | 2.048 k | | 10 | 7.813 k | 3.906 k | 4.096 k | 4.096 k | 4.096 k | | 11 | 15.625 k | 7.813 k | 8.192 k | 8.192 k | 8.192 k | Figure 2-20. Divider Output 86CH06-73 2002-10-08 # 2.6 8-bit Timer/Counter (TC0, 1) The TMP86CH06 contains 2 channels of 8-bit timer/counter (TC0, 1). These are available for a 16-bit timer/counter by cascade connection. This timer/counter is available for timer, event counter, PWM, PPG, PDO, or warming-up counter. # 2.6.1 Configuration Figure 2-21. 8-bit Timer 0, 1 86CH06-74 2002-10-08 #### 2.6.2 Control The timer/counter 0 is controlled by a timer/counter 0 control register (TC0CR) and two 8-bit timer registers (TTREG0 and PWREG0). Figure 2-22. Timer 0 Register and Timer/Counter 0 Control Register 86CH06-75 2002-10-08 The timer/counter 1 is controlled by a timer/counter 1 control register (TC1CR) and two 8-bit timer registers (TTREG1 and PWREG1). Figure 2-23. Timer 1 Register and Timer/Counter 1 Control Register 86CH06-76 2002-10-08 Table 2-4. Operating mode and available source clock (NORMAL1/2, IDLE1/2 mode) | TCnCK<br>Operating Mode | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | |-------------------------|-----|-----|-----|-----|-----|-----|-----|-----| | 8-bit Timer | 0 | 0 | 0 | 0 | 0 | _ | _ | _ | | 8-bit Event Counter | _ | _ | _ | _ | _ | _ | _ | 0 | | 8-bit PDO | 0 | 0 | 0 | 0 | 0 | _ | _ | 0 | | 8-bit PWM | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 16-bit Timer | 0 | 0 | 0 | 0 | 0 | _ | _ | _ | | 16-bit Event Counter | _ | _ | _ | _ | _ | _ | _ | 0 | | fs Warming-up Counter | _ | _ | _ | _ | 0 | _ | _ | _ | | 16-bit PWM | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 16-bit PPG | 0 | 0 | 0 | 0 | 0 | _ | _ | 0 | Note 1: For 16-bit operation (16-bit Timer/Event Counter, fc Warming-up Counter, 16-bit PWM and 16-bit PPG), set its source clock on lower bits (TCOCK). Note 2: n = 0, 1 Note 3: When used as the NORMAL1 and IDLE1 modes, the source clock can not use the "fs". Table 2-5. Operating mode and available source clock (Under SLOW1/2 mode, SLEEP1/2 mode) | TCnCK<br>Operating Mode | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | |-------------------------|-----|-----|-----|-----|-----|-----|-----|-----| | 8-bit Timer | 0 | _ | _ | _ | _ | _ | _ | _ | | 8-bit Event Counter | _ | _ | _ | _ | _ | _ | _ | 0 | | 8-bit PDO | 0 | _ | _ | _ | _ | _ | _ | 0 | | 8-bit PWM | 0 | _ | _ | _ | 0 | _ | _ | 0 | | 16-bit Timer | 0 | _ | _ | _ | _ | _ | _ | _ | | 16-bit Event Counter | _ | _ | _ | _ | _ | _ | _ | 0 | | fc Warming-up Counter | _ | _ | _ | _ | _ | _ | 0 | _ | | 16-bit PWM | 0 | _ | _ | _ | 0 | _ | _ | 0 | | 16-bit PPG | 0 | _ | _ | _ | _ | _ | _ | 0 | Note 1: For 16-bit operation (16-bit Timer/Event Counter, fc Warming-up Counter, 16-bit PWM and 16-bit PPG), set its source clock on lower bits (TCOCK). Note 2: n = 0, 1 Table 2-6. Restriction against the Rate for Comparing Registers | Operating Mode | Authorized Rate for Register | | | |----------------------------|--------------------------------------------------|--|--| | 8-bit Timer/Event Counter | 1 ≤ (TTREGn) ≤ 255 | | | | 8-bit PDO | 1 ≤ (TTREGn) ≤ 255 | | | | 8-bit PWM | 2 ≤ (PWREGn) ≤ 254 | | | | 16-bit Timer/Event Counter | $1 \le (TTREG1, 0) \le 65535$ | | | | fc Warming-up Counter | $256 \le (TTREG1, 0) \le 65535 \text{ (Note 2)}$ | | | | 16-bit PWM | $2 \le (PWREG1, 0) \le 65534$ | | | | 16-bit PPG | $1 \le (PWREG1, 0) < (TTREG1, 0) \le 65535$ | | | Note 1: n = 0, 1 Note 2: When used at the "fc Warming-up counter" mod, the timer operating mode must use the 16-bit timer mode. That time, the timer register uses higher 8-bits and the lower 8-bits are ignored. But the timer register must be set both of high and low bits. #### 2.6.3 Function Timer/Counter 0 and 1 have eight operating modes: 8-bit timer, 8-bit external trigger timer, 8-bit programmable divider output mode, 8-bit pulse width modulation output mode, 16-bit timer, 16-bit external trigger timer, 16-bit pulse width modulation output mode, 16-bit programmable pulse generator output mode. 16-bit timer mode can use Timer counter 0 and 1 by cascade connection. ### (1) 8-bit Timer Mode (Timer/Counter 0 and 1) In this mode, counting up is performed using the internal clock. The contents of TTREGi are compared with the contents of up-counter. If a match is found, an INTTCi interrupt is generated, and the counter is cleared to "0". Counting up resumes after the counter is cleared. Note 1: In the timer mode, always write TCiCR < TFFi > to "0". If TFFi is set to "1", unexpected pulse may be output from $\overline{TOi}$ pin. Note 2: In the timer mode, do not change the setting of timer registers (TTREGI) while timer/counter is operating. Since TTREGI is configured as one-stage register, a newly set value is immediately reflected on the timer register. Note 3: i = 0, 1 Table 2-7. Timer/Counter 0 and 1 Source Clock (Internal Clock, DV1CK = 0, DVCK = 01) | Source clock | | | Res | olution | Maximum time setting | | |--------------------------|------------------------|-------------------|----------------|--------------------|------------------------|--------------------| | NORMAL1/2, I | DLE1/2 modes | SLOW1/2, SLEEP1/2 | At fcgck = | At fs = 32.768 kHz | At fcgck = | At fs = 32.768 kHz | | DV7CK = 0 | DV7CK = 1 | modes | 16 MHz | At 13 = 32.700 KHZ | 16 MHz | At 13 = 32.700 KHZ | | fc/2 <sup>11</sup> [Hz] | fs/2 <sup>3</sup> [Hz] | fs/2³ [Hz] | 128 <i>μ</i> s | 244.14 μs | 32.8 ms | 62.5 ms | | fc/2 <sup>7</sup> (DV5) | _ | - | 8 μs | - | 2.0 ms | - | | fc/2 <sup>5</sup> (DV3G) | _ | - | 2 μs | _ | 510 μs | - | | fc/24 (DV1G) | _ | - | 1 <i>μ</i> s | _ | <b>2</b> 55 μ <b>s</b> | - | Example: Sets the timer mode with source clock fc/27 [Hz] and generates an interrupt 80 $\mu$ s later (at fc = 16 MHz). LDW (TTREG1), 0AH ; Sets the timer register (80 $\mu$ s ÷ 27/fc = 0A<sub>H</sub>) DI SET (EIRL). EF7 ; Enables INTTC1 interrupt $\mathbf{EI}$ LD (TC1CR), 00010000B; Sets the 8-bit timer mode and source clock (fc/2<sup>7</sup>) LD (TC1CR), 00011000B ; Starts TC1 Figure 2-24. 8-bit Timer Mode Timing Chart (In Case of Timer/Counter 1) 86CH06-78 2002-10-08 ## (2) 8-bit Event Counter Mode (Timer/Counter 0 and 1) In this mode, events are counted on the falling edge of TIi pin input. The contents of TTREGi are compared with the contents of up-counter. If a match is found, an INTTCi interrupt is generated, and the counter is cleared. The maximum applied frequency is fcgck/2<sup>4</sup> [Hz] in NORMAL 1/2 or IDLE 1/2 mode, and fs/2<sup>4</sup> [Hz] in SLOW 1/2 or SLEEP 1/2 mode. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width. | | NORMAL/IDLE | SLOW/SLEEP | |------------------|----------------------|-------------------| | High level width | fcgck/2 <sup>3</sup> | fs/2 <sup>3</sup> | | Low level width | fcgck/2 <sup>3</sup> | fs/2 <sup>3</sup> | Note 1: In the event counter mode, always write TCiCR < TFFi > to "0". If TFFi is set to "1", unexpected pulse may be output from $\overline{TOi}$ pin. Note 2: In the event counter mode, do not change the setting of timer registers (TTREGI) while timer/counter is operating. Since TTREGI is configured as one-stage register, a newly set value is immediately reflected on the timer register. Note 3: i = 0, 1 Figure 2-25. Event Counter Mode Timing Chart (In Case of Timer/Counter 1) #### (3) Programmable Divider Output (PDO) Mode (Timer/Counter 0 and 1) The internal clock is used for counting up. The contents of TTREGi are compared with the contents of the up-counter. Timer F/F i output is toggled and the counter is cleared each time a match is found. Timer F/F i output is inverted and output to the $\overline{TOi}$ pin. When used as a this mode, respective output latch should be set to "1". This mode can be used for 50% duty pulse output. Timer F/F i can be initialized by program, and it is initialized to "0" during reset. An INTTCi interrupt is generated each time the $\overline{TOi}$ output is toggled. Note 1: In the programmable divider output (PDO) mode, do not change the setting of timer registers (TTREGi) while timer/counter is operating. Since TTREGi is configured as one-stage register, a newly set value is immediately reflected on the timer register. Note 2: If PDO output is stopped during output operation, the output state is maintained at the state immediately before timer/counter is stopped. For changing the level of TOi pin, modify TCiCR<TTFi> after timer/counter has been stopped. Do not execute halt of timer/counter and modification of TFFi simultaneously. Example: Fixes TOi output at high level after timer/counter is stopped CLR (TCiCR).3; Stops timer/counter. CLR (TCiCR).7; Sets TOi output to high level output Note 3: i = 0, 1 86CH06-79 2002-10-08 Example: Output a 1024 Hz pulse (at fc = 16 MHz, in case of TC1) SET (P1DR). 4 ; P14 output latch $\leftarrow 1$ SET (P1CR). 4 LD (TTREG1), 7AH ; $(1/1024 \div 2^{7}/\text{fc}) \div 2 = 7A_{\text{H}}$ LD (TC1CR), 00010001B; Sets the 8-bit PDO mode and source clock (fc/2<sup>7</sup>) LD (TC1CR), 00011001B ; Starts TC1 Figure 2-26. 8-bit Timing Chart for PDO Mode (In Case of Tmer/Counter 1) (4) 8-bit Pulse Width Modulation (PWM) Output Mode (Timer/Counter 0 and 1) PWM output with a resolution of 8 bits is possible. The internal clock is used for counting up. The contents of PWREGi are compared with the contents of up-counter. If a match is found, the timer F/F i output is toggled. The counter continues counting. And, when an overflow occurs, the timer F/F i output is again toggled and the counter is cleared. Timer F/F i output is inverted and output to the $\overline{TOi}$ pin. An INTTCi interrupt is generated when an overflow occurs. PWREGi is configured a 2-stage shift register and, during output, will not switch until one output cycle is completed even if PWREGi is overwritten; therefore, output can be altered continuously. Also, the first time, PWREGi is shifted by setting TCiS (bit 4 in TCiCR) to "1" after data are loaded to PWREGi. Note 1: In PWM mode, write to the timer register PWREGi immediately after an INTTCi interrupt is generated (normally during the INTTCi interrupt service routine). If writing to PWREGi and INTTCi interrupt occur at the same time, the unstable value being written is shifted. This may cause pulses different from the set value to be output until the next INTTCi interrupt is generated. Note 2: If PWM output is stopped during output operation, the output state is maintained at the state immediately before timer/counter is stopped. For changing the level of TOi, modify TCiCR<TTFi> after timer/counter has been stopped. Do not execute halt of timer/counter and modification of TFFi simultaneously. Example: Fixes TOi output at high level after timer/counter is stopped CLR (TCiCR).3; Stops timer/counter. CLR (TCiCR).7; Sets $\overline{TOi}$ output to high level output Note 3: Before starting STOP mode, disable PWM output. When the timer/counter is enabled and fc, fc/2 or fs is selected as the source clock, pulse is output from PWM pin during warming-up after releasing STOP mode. Note 4: i = 0, 1 Figure 2-27. Timing Chart for PWM Mode (In Case of TC1) Table 2-8. PWM Output Mode (DV1CK = 0, DVCK = 01) | Source clock | | | Res | olution | Maximum setting time | | | |--------------------------|------------------------|------------------------|----------------|-------------------|----------------------|-------------------|--| | NORMAL1/2, | IDLE1/2 mode | SLOW1/2, SLEEP1/2 | fc = 16 MHz | fs = 32.768 kHz | fc = 16 MHz | fs = 32.768 kHz | | | DV7CK = 0 | DV7CK = 1 | mode | 16 = 10 101112 | 13 = 32.700 KHZ | 10 - 10 1011 12 | 13 = 32.7 00 KT12 | | | fc/2 <sup>11</sup> [Hz] | fs/2 <sup>3</sup> [Hz] | fs/2 <sup>3</sup> [Hz] | 128 <i>μ</i> s | 244.14 <i>μ</i> s | 32.8 ms | 62.5 ms | | | fc/2 <sup>7</sup> (DV5) | - | _ | 8 μs | _ | 2.05 ms | - | | | fc/2 <sup>5</sup> (DV3G) | _ | = | 2 $\mu$ s | _ | 512 μs | - | | | fc/24 (DV1G) | _ | - | 1 <i>μ</i> s | _ | 256 μs | - | | | fs | fs | fs | 30.5 $\mu$ s | 30.5 <i>μ</i> s | 7.81 ms | 7.81 ms | | | fc/2 | fc/2 | _ | 125 ns | _ | 32 μs | - | | | fc | fc | _ | 62.5 ns | _ | 16 <i>μ</i> s | _ | | ## (5) 16-bit Timer Mode (Timer/counter 0 and 1) In this mode, counting up is performed using the internal clock. Timer/counter 0 and 1 are also available as a 16-bit timer mode by cascade connection. ## 16 bit timer mode of Timer/counter 0 and 1 If a match is found, the INTTC1 interrupt is generated and the counter is cleared to "0". Counting up resumes after the counter is cleared. The timer register should write to the TTREG0 more first than TTREG1. The timer register must not write only either TTREG0 or TTREG1. - Note 1: In the 16-bit timer mode, always write TCiCR < TFFi > to "0". If TFFi is set to "1", unexpected pulse may be output from $\overline{TOi}$ pin. - Note 2: In the timer mode, do not change the setting of timer registers (TTREGI) while timer/counter is operating. Since TTREGI is configured as one-stage register, a newly set value is immediately reflected on the timer register. Note 3: i = 0, 1 Table 2-9. Source Clock of 16-bit Timer Mode (DV1CK = 0, DVCK = 01) | Source clock | | | Res | olution | Maximum setting time | | | |--------------------------|------------------------|-------------------|-----------------|--------------------|----------------------|----------------------|--| | NORMAL1/2, | IDLE1/2 mode | SLOW1/2, SLEEP1/2 | At fc = 16 MHz | At fs = 32.768 kHz | At fc = 16 MHz | At fs = 32.768 kHz | | | DV7CK = 0 | DV7CK = 1 | mode | Acres To Willia | AC13 = 32.700 KHZ | At 16 = 10 101112 | AC 13 = 32.7 00 K112 | | | fc/2 <sup>11</sup> | fs/2 <sup>3</sup> [Hz] | fs/2³ | 128 <i>μ</i> s | 244.1 μs | 8.38 s | 16 s | | | fc/2 <sup>7</sup> (DV5) | _ | _ | 8 μs | - | 524.3 ms | - | | | fc/2⁵ (DV3G) | _ | - | 2 μs | - | 131.1 ms | - | | | fc/2 <sup>4</sup> (DV1G) | _ | - | 1 <i>μ</i> s | <del>-</del> | 65.5 ms | - | | | _ | _ | _ | _ | - | - | - | | | fc/2 | fc/2 | - | 125 ns | - | 8.2 ms | - | | | fc fc | fc | _ | 62.5 ns | - | 4.1 ms | _ | | Example: Set the 16-bit timer mode with source clock fc/27 (DV5) [Hz] and generates an interruput 300 [ms] later (at fc = 16 [MHz]) LDW (TTREG0), 927CH; Sets the timer register (300 ms $\div$ 27/fc = 927C<sub>H</sub>) $\mathbf{DI}$ SET (EIRL). EF7 ; Enable INTTC1 interrupt $\mathbf{EI}$ $\begin{array}{lll} LD & (TC0CR), 13H & ; & Sets the \, TC0 \, mode \, and \, source \, clock \\ LD & (TC1CR), 04H & ; & Set \, the \, 16\text{-bit timer mode (upper)} \end{array}$ LD (TC1CR), 0CH; Starts timer/counter Figure 2-28. Timing Chart for 16-bit Timer Mode (Timer/Counter 0 and 1) ## (6) 16-bit Event Counter Mode (Timer/counter 0 and 1) In this mode, event are counted on the falling edge of the TI0 pin input. Timer/counter 0 and 1 are also available as a 16-bit Event counter mode by cascade connection. ### 16 bit event counter mode of Timer/counter 0 and 1 If a match is found, the INTTC1 interrupt is generated and the counter is cleared to "0". After the counter is cleared, counting up resumes every falling edge of TI0 input. The timer register should write to the TTREG0 more first than TTREG1. The timer register must not write only either TTREG0 or TTREG1. When the TTREG1 is written during counter continuation, the timer register is changed by next falling edge of TI0 input at TTREG0 and TTREG1 same time. The timer/counter is counting by value of last timer register until the TTREG1 is written. Also, the first time, the timer register is changed by the TC1S (bit 3 in TC1CR) set to "1" after data are loaded to TTREG0/1. 86CH06-83 2002-10-08 - Note 1: In the event counter mode, always write TCOCR < TFF0 > to "0". If TFF0 is set to "1", unexpected pulse may be output from $\overline{TOi}$ pin. - Note 2: In the event counter mode, do not change the setting of timer registers (TTREGI) while timer/counter is operating. Since TTREGI is configured as one-stage register, a newly set value is immediately reflected on the timer register. Note 3: i = 0, 1 (7) 16-bit Pulse Width Modulation (PWM) Output Mode (Timer/counter 0 and 1) PWM output with a resolution of 16 bits is possible. Timer/counter 3 and 4 (5 and 6) are also available as a 16-bit PWM output mode by cascade connection #### 16 bit PWM output mode of Timer/counter 0 and 1 The contents of PWREG0/1 are compared with the contents of up-counter. If a match is found, the timer F/F 1 output is toggled. The counter continues counting. And, when an overflow occurs, the timer F/F 1 output is again toggled and the counter is cleared. Timer F/F 1 output is inverted and output to the $\overline{TO1}$ pin. An INTTC1 interrupt is generated when an overflow occurs. When used as $\overline{TO1}$ pin, respective output latch should be set to "1". PWREG0/1 are configured a 2-stage shift register and, during output, will not switch until one output cycle is completed even if PWREG0/1 are overwritten. Therefore, output can be altered continuously. Also, the first time, the timer register is changed by the TC1S (bit 3 in TC1CR) set to "1" after data are loaded to PWREG0/1. The timer register should write to the PWREG0 more first than PWREG1. The timer register must not write only either PWREG0 or PWREG1. - Note 1: In PWM mode, write to the timer register PWREG1, 0 immediately after an INTTC1 interrupt is generated (normally during the INTTC1 interrupt service routine). If writing to PWREG1, 0 and INTTC1 interrupt occur at the same time, the unstable value being written is shifted. This may cause pulses different from the set value to be output until the next INTTC1 interrupt is generated. - Note 2: If PWM output is stopped during output operation, the output state is maintained at the state immediately before timer/counter is stopped. For changing the level of TO1 modify TC1CR<TTF1> after timer/counter has been stopped. Do not execute halt of timer/counter and modification of TFF1 simultaneously. Example: Fixes TO1 output at high level after timer/counter is stopped CLR (TC1CR).3; Stops timer/counter CLR (TC1CR).7; Sets TO1 output to high level output Note 3: Before starting STOP mode, disable PWM output. When the timer/counter is enabled and fc, fc/2 or fs is selected as the source clock, pulse is output from $\overline{\text{TO1}}$ pin during warming-up after releasing STOP mode. 86CH06-84 2002-10-08 | Source clock | | | Res | olution | Maximum setting time | | | |--------------------------|------------------------|------------------|----------------|--------------------|----------------------|--------------------|--| | NORMAL1/2, IDLE1/2 mode | | CLOW CLEED woods | A+f- 16 NULL | At fs = 32.768 kHz | At fc = 16 MHz | A+ (- 22.700 LLL | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP mode | At fc = 16 MHz | At 15 = 32.700 KHZ | At IC = 16 MHZ | At fs = 32.768 kHz | | | fc/2 <sup>11</sup> | fs/2 <sup>3</sup> [Hz] | fs/2³ | 128 μs | 244.1 μs | 8.38 s | 16 s | | | fc/2 <sup>7</sup> (DV5) | _ | - | 8 μs | _ | 524.3 ms | - | | | fc/2 <sup>5</sup> (DV3G) | _ | = | 2 μs | = | 131.1 ms | - | | | fc/2⁴ (DV1G) | _ | - | 1 <i>μ</i> s | _ | 65.5 ms | - | | | fs | fs | fs | 30.5 μs | 30.5 <i>μ</i> s | 2 s | 2 s | | | fc/2 | fc/2 | _ | 125 ns | _ | 8.2 ms | _ | | | om <sup>fc</sup> | fc | _ | 62.5 ns | _ | 4.1 ms | _ | | Table 2-10. 16-bit PWM Output Mode (DV1CK = 0, DVCK = 01) Example: Extract the pulse, whose term and "high" width is 131.1 ms and 4 ms respectively, from P14 width 16-bit PWM mode (at fc=16 MHz, DV7CK=0) SET (P1DR). 4 ; Sets P14 output data latch to "1" SET (P1CR). 4 LDW (PWREG0), 07D0H; Sets pulse width LD (TC0CR), 23H ; Sets the mode and source clock (DV3G) LD (TC1CR), 56H ; Sets the TFF1 to "1" and sets the 16-bit PWM mode (upper) LD (TC1CR), 5EH; Starts timer/counter Figure 2-29. Timing Chart of 16-bit PWM Mode (Timer/Counter 3 and 4) (8) 16-bit Programmable Pulse Generate (PPG) output mode (TC0 + 1) PPG output with a resolution of 16 bits is possible. Timer/counter 0 and 1 are also available as a 16-bit PPG output mode by cascade connection. 16 bit PPG output mode of Timer/counter 0 and 1 First, the contents of PWREG0/1 are compared with the contents of up-counter. If a match is found, the timer F/F 1 output is toggled. The INTTC1 interrupt is generated at this time. Next, timer F/F 1 is again toggled and the counter is cleared by matching with TTREG0/1. The INTTC1 interrupt is again generated when an overflow occurs. When used as $\overline{PPG1}$ pin, respective output latch should be set to "1". During reset, the F/F 1 is initialized to "0". The F/F 1 output is configured by TFF1 (bit 7 in TC1CR). Therefore, the $\overline{TO1}$ can output either output high or output low at first time. The timer register should write to the PWREG0/TTREG0 more first than PWREG1/TTREG1. The timer register must not write only either PWREG0/TTREG0 or PWREG1/TTREG1. When the TTREG1/PWREG1 are written during counter continuation, the timer register is changed by next falling edge of source clock at PWREG0/TTREG0 and PWREG1/TTREG1 same time. The timer/counter is counting by value of last timer register until the PWREG1/TTREG1 is written. Example: Extract the pulse, whose term and "high" width is 65.54 ms and 4 ms respectively, from P14 with 16-bit PPG mode (at fc=16 MHz, DV7CK=0) (P1DR). 4 SET ; Sets P14 output data latch to "1" SET (P1CR), 4 LDW (PWREG0), 07D0H Sets pulse width LDW (TTREG0), 8002H Sets pulse term LD(TC0CR), 23H Sets the mode and source clock (DV3G) Sets the TFF1 to "1" and sets the 16-bit PPG mode LD(TC1CR), 57H (upper) LD(TC1CR), 5FH Starts timer/counter Note 1: In the programmable pulse generate (PPG) mode, do not change the setting of timer registers (PWREGi, TTREGi) while timer/counter is operating. Since PWREGi, TTREGi are configured as one-stage register, a newly set value is immediately reflected on the timer register. Note 2: If PPG output is stopped during output operation, the output state is maintained at the state immediately before timer/counter is stopped. For changing the level of TO1, modify TCiCR<TTFi> after timer/counter has been stopped. Do not execute halt of timer/counter and modification of TFFi simultaneously. Example: Fixes TO1 output at high level after timer/counter is stopped CLR (TC1CR).3; Stops timer/counter CLR (TC1CR).7; Sets TO1 output to high level output Note 3: i = 0, 1 86CH06-86 2002-10-08 Figure 2-30. Timing Chart of 16-bit PPG Mode (Timer/Counter 0 and 1) #### (9) Warming-up counter mode In this mode, the warming-up period for switching the main system clock can be generated. Timer/counter 0 and 1 are used as a 16-bit timer by cascade connection. There are 2 modes in warming-up counter mode, one is a mode from NORMAL to SLOW and the other is a mode from SLOW to NORMAL. Note 1: In the warming-up mode, always write TCiCR < TFFi > to "0". If TFFi is set to "1", unexpected pulse may be output from $\overline{TOi}$ pin. Note 2: In the warming-up mode, the lower 8 bits of TTREG1, 0 are ignored and an interrupt is generated by matching the upper 8 bits. Note 3: i = 0, 1 a. Warming-up counter mode for low-frequency (NORMAL1→NORMAL2→SLOW2→SLOW1) In this mode, it can obtain the warming-up period till the oscillation for low-frequency (fs) is stabilized. Before timer/counter is started, turn on low-frequency oscillation by setting SYSCR2<XTEN> to "1". After timer/counter is started by setting TC1CR<TC1S>, the contents of TTREG1, 0 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". In the interrupt service program, stop the timer/counter and change the system clock to low-frequency clock by setting SYSCR2<SYSCK> to "1". After that, halt the high-frequency oscillation by clearing SYSCR2<XEN> to "0". Table 2-13. Warming-up period for low-frequency oscillation (at fs = 32.768 kHz) | Min (at TTREGm, n = 0100H) | Max (at TTREGm, n = FF00H) | |----------------------------|----------------------------| | 7.8 ms | 1.99 s | Example: Switching to the SLOW1 mode after low-frequency clock has stabilized by using TC1, 0. ``` ; SYSCR2<XTEN>\leftarrow"1" SET (SYSCR2).6 ; TFF0 = "0", fs for source clock, sets 16-bit mode LD (TC0CR), 43H LD (TC1CR), 05H ; TFF1="0", sets warming-up counter mode LD (TTREG0), 8000H ; sets warming-up time (depend on oscillator characteristics) DI : IMF ← "0" SET (EIRL).7 ; Enables INTTC1 \mathbf{EI} : IMF ← "1" SET ; Starts TC1, 0 (TC1CR). 3 PINTTC1: CLR (TC1CR).3 : Stops TC1, 0 SET (SYSCR2).5 :SYSCR2 < SYSCK > \leftarrow "1" (Switches the main system clock to the low-frequency clock) (SYSCR2).7 SYSCR2 < XEN > \leftarrow "0" (Turns off low-frequency oscillation) CLR RETI VINTTC1: DW PINTTC1 ; INTTC1 vector table ``` 86CH06-88 2002-10-08 b. Warming-up counter mode for high-frequency (SLOW1-SLOW2-NORMAL2-NORMAL1) In this mode, it can obtain the warming-up period till the oscillation for high-frequency (fc) is stabilized. Before timer/counter is started, turn on high-frequency oscillation by setting SYSCR2<XEN> to "1". After timer/counter is started by setting TC1CR<TC1S>, the contents of TTREG1, 0 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". In the interrupt service program, stop the timer/counter and change the system clock to high-frequency clock by clearing SYSCR2<SYSCK> to "0". After that, halt the low-frequency oscillation by clearing SYSCR2<XTEN> to "0". Table 2-12. Warming-up period for high-frequency (at fc = 16 MHz) | Min (at TTREGm, n = 0100H) | Max (at TTREGm, n = FF00H) | |----------------------------|----------------------------| | 16 μs | 4.08 ms | Example: Switching to the NORMAL1 mode after high-frequency clock has stabilized by using TC1, 0. ``` ;SYSCR2 < XEN > \leftarrow "1" SET (SYSCR2).7 ; TFF0="0", fc for source clock, sets 16-bit mode LD (TC0CR), 63H (TC1CR), 05H ; TFF1="0", sets warming-up counter mode LD LD (TTREG0), 0F800H; Sets warming-up time (depend on oscillator characteristics) ; IMF ← "0" DI SET (EIRL).7 ; Enables INTTC1 ; IMF ← "1" \mathbf{EI} SET (TC1CR).3 ; Starts TC1, 0 PINTTC1: CLR (TC1CR).3 : Stops TC1, 0 ;SYSCR2 < SYSCK > \leftarrow "0" CLR (SYSCR2).5 (Switches the main system clock to the high-frequency clock) ;SYSCR2 < XTEN > \leftarrow "0" CLR (SYSCR2).6 (Turns off high-frequency oscillation) RETI VINTTC1: DW PINTTC1 ; INTTC1 vector table ``` # 2.7 Extended Timer-Counter (ETC0) The TMP86CH06 contains 16-bit extended timer-counter, which is accompanied by terminals for capturing input and outputting comparison. The alternative of internal or external input is to be source clock. # 2.7.1 Configuration Figure 2-31. Extended Timer-Counter 0 (ETC0) # 2.7.2 Controlling The extended timer-counter (ETC0) is controlled on the following registers. Figure 2-32. Registers on Extended Timer-Counter 0 (1/2) Note 3: PME is a write only register and must not be used with any of the read-modify-write instructions. edge is detected or the device is totally reset. 86CH06-91 2002-10-08 Figure 2-33. Registers on Extended Timer-Counter 0 (2/2) 86CH06-92 2002-10-08 #### 2.7.3 Source Clock The source clock for the extended timer-counter (ETC0) has 2 sorts of operating mode: the free-running mode whose source clock is provided from internal clock, and event-counter mode whose source clock is provided from external clock (through terminal ETC0). Source Clock and Accuracy for ETC0 (at fcgck = 8 MHz, fs = 32.768 kHz) | Operating Made | Source Clock | Edma | Accuracy | | | |-----------------------|---------------|-------------------|-------------------|---------------------|--| | Operating Mode | Source Clock | ource Clock Edge | | (fs) | | | Free Running<br>Timer | Internal | Rising | 500 ns to 32 μs | 122 μs to 3.91 ms | | | Event Counter | ETCO terminal | Rising or falling | 1 $\mu$ s or more | 244 $\mu$ s or more | | ## (1) Free Running Timer Mode The internal clock increase the extended timer-counter (ETC0). The interrupt INTET0 is requested when the counter reaches FFFFH, meanwhile the counter is still counting up. The source clock is selected on the bit ET0CKS in ETC0 control register (ET0CR). The counter becomes event-counter mode if ET0CKS="111". In order to generate interrupt after a certain period, subtract a rate from FFFFH and set its result on the ETC0 register (ET0R). The ET0R is cleared if $0000_{\rm H}$ is written on ETC0R. Both writing and reading against the ET0R are available, while the counter is in motion or halt. By executing read instruction against the ET0R, the current rate on the counter is extracted. Notice that reading and writing against the ET0R should be done from lower byte to upper byte consecutively. Since the counter extract the whole data for the ETOR as data is written on upper byte, the exclusive writing against lower byte of ETOR is not valid. As for reading, data on the counter is latched on reading against lower byte. Example 1: Generate interrupt of ETC0 in 8 s, from source clock of fs/4 (fs = 32.768 kHz) LD (ETOCR), 00000001B ; Stop the counter, and assign $fs/2^2$ to source clock LD (ETOR), 0000H; Set timer register (8 s ÷ 122 $\mu$ s = FFFF<sub>H</sub>) DI SET (EIRH).2 ; Enable interrupt INTET0 $\mathbf{EI}$ SET (ETOCR).7 ; ETC0 start Example 2: Generate interrupt of ETC0 in 256 $\mu$ s, from source clock of fcgck/8 (fcgck = 8 MHz, DV1CK = 0) LD (ETOCR), 00000001B; Stop the counter, and assign fcgck/8 to source clock LDW (ET0R), 0FEFFH; Set timer register (FFFF $_{\rm H}$ – 100 $_{\rm H}$ ) $\mathbf{DI}$ SET (EIRH).2 ; Enable interrupt INTET0 $\mathbf{EI}$ SET (ETOCR).7 ; ETC0 start 86CH06-93 2002-10-08 Figure 2-34. Example for Free-running mode operation Table 2-13. ETC0 Internal clock (fc = 8 MHz, FCGCK = 000, fs = 32.768 kHz) | ET0CKS | NORMAL 1/2, I | DLE 1/2 mode | SLOW, SLEEP mode | | | |--------|---------------|--------------|------------------|-------|--| | ETUCKS | Accuracy | Range | Accuracy | Range | | | 000 | 500 ns | 32.77 ms | - | - | | | 001 | 1 <i>μ</i> s | 65.54 ms | 122.0 <i>μ</i> s | 8 s | | | 010 | 2 μs | 131.07 ms | 244.1 μs | 16 s | | | 011 | 4 <i>μ</i> s | 262.14 ms | 488.3 μs | 32 s | | | 100 | 8 <i>μ</i> s | 524.29 ms | 976.6 μs | 64 s | | | 101 | 16 <i>μ</i> s | 1.05 s | 1.953 ms | 128 s | | | 110 | 32 $\mu$ s | 2.10 s | 3.906 ms | 256 s | | Note: ETOCKS is a group of bits, which manages the source clock of ETCO. # (2) Event-counter Mode The edge of ETC0 terminal input increase the extended timer-counter (ETC0). The counter becomes event-counter mode if ET0CKS="111". In order to utilize event-counter mode, set ETC0 terminal to input mode on P1CR. The type of capturing edge, either rising or falling, can be selected on ET0ES located on bit 3 on ET0CR. The counter operates similar to free running counter mode, except for the source clock: internal clock or terminal input. Example: Generate interrupt of ETC0 after counting 100 (64<sub>H</sub>) times of rising edge | CLR | (ET0CR). 7 | ; | stops the counter | |---------------|----------------|---|--------------------------------------------------------| | $_{ m CLR}$ | (P1CR). 2 | ; | sets P12 (ETC0) for input | | LD | (ET0CR), 07H | ; | event counter mode, detecting rising edge | | LDW | (ET0R), 0FF9BH | ; | sets timer register (FFFF $_{ m H}$ to $0064_{ m H}$ ) | | DI | | | <del>-</del> | | SET | (EIRH). 2 | ; | enables interrupt INTET0 | | $\mathbf{EI}$ | | ; | <del>-</del> | | SET | (ET0CR). 7 | ; | starts the counter | Note: Altering source clock and edge type under event counter mode is allowed only if the extended timer has been stopped. Since ETC0 input terminal has digital noise cancellor, only pulse width of 2 machine cycles or longer is accepted. Pulse width of 1 machine cycle or shorter is neglected. It is unstable to acknowledge pulse width of between 1 and 2, as valid input. ``` (input pulse width) < (1 machine cycle) \rightarrow not counted (1 machine cycle) \leq (input pulse width) < (2 machine cycles) \rightarrow counted or not counted (depend on timing) (2 machine cycle) \leq (input pulse width) \rightarrow counted 4/fcgck = 1 machine cycle (0.5 \mus at fcgck = 8 MHz) ``` After detecting a rising (falling) edge, it is required to detect falling (rising) edge before detecting another rising (falling) edge. Figure 2-35. Edge Filtering in Event Counter Mode (Rising Edge Detection) Figure 2-36. Example of Event Counter Mode Operation (ETCO Rising Edge Detection) 86CH06-95 2002-10-08 # 2.7.4 Capturing input, Output comparing The extended timer-counter (ETC0) involves terminals for capturing input IC0 (P36) and output comparing OC0 (P37). Both IC0 and OC0 are available for general input/output ports if they are not involved in the extended timer-counter (ETC0). | | Shared function | Operation | Accuracy | Data register | |----------------|-----------------|-------------------------------------------|-----------------|---------------| | Capture input | P36 | Rising edge<br>Falling edge<br>Both edges | | 2 | | Output compare | P37 | "1" output<br>"0" output<br>toggle<br>NOP | Depend on timer | 1 | When capturing input function is to be used, assign input mode to P36 (set "0" on bit6 on P3CR). When output comparing function is to be used, assign output mode to P37 (set "1" on bit7 on P3CR) after P37 output latch (bit7 on P3DR) is set to "1". ## (1) Capturing input It is the function to measure matters, such as pulse width, frequency or duty. At the time the capturing acknowledged input changed, the contemporary rate on the extended timer-counter (ETC0) is loaded on the capture register. The capturing contains a digital noise-cancellor circuit in its block. A stable pulse of fcgck/8 or longer is required in order to inform the hardware of input, otherwise the pulse would not be acknowledged normally. Since the rate on the extended timer-counter (ETC0) is loaded on the capture register after the capturing samples every fcgck/4 with sampling clock, there is a lag of fcgck/4 to fcgck/8 between terminal input and capture register record. After detecting edge, the following capture operation is prohibited, until the data on the capture register ET0ICA. As for reading ET0ICA, read lower byte first then read upper byte. The capturing operates normally regardless of overflow of the counter, since the counter is still counting-up after overflow. ww.bataSneet40.com Figure 2-37. Example of Event Counter Mode Operation (ICO rising edge detection, Source clock of fcgck/4) Example 1: Capturing IC0 on rising edge with ETC0 CLR (P3CR).6 ; Assigns input mode to P36 LD (ET0MIO),0101\*\*\*\*B ; Enables capturing on rising edge Example 2: Capturing positive pulse width IC0, with ETC0 (without using ET0ICB) CLR (P3CR). 6; Assigns input mode to P36 $\mathbf{DI}$ SET (EIRH).3; Enables individual interrupt enable flag for INTIC0 $\mathbf{EI}$ LD (ET0MIO), 0111\*\*\*\*B ; Enables capturing on both edges LP: TEST (ILH).3 ; Waits until IC0 rises (IL11 rises) JR T, LP $\mathbf{DI}$ LD (ILH), F7H; Clears IL11 $\mathbf{EI}$ LD A, (ETOICAL) ; Reads ETOICA LD W, (ET0ICAH) LP2: TEST (ILH).3 ; Waits until IC0 falls (IL11 rises) JR T, LP2 SUB WA, (ETOICA); Calculates pulse width and loads it on HL register LD HL, 0000H SUB HL, WA $\mathbf{DI}$ LD (ILH), F7H; Clears IL11 $\mathbf{EI}$ 86CH06-97 2002-10-08 If the data "1" is set on register PME located on the address same as ET0ICBL, the interrupt INTIC0 is requested as the second valid edge is detected. As this interrupt is requested, the first detected time (loaded on ET0ICB) and the second (loaded on ET0ICA) can be read consecutively. PME is cleared to "0" by hardware, after the edge is detected. Therefore, after the interrupt INTIC0 is requested, it is required to set "1" on PME again in order to continue extracting the 2-word data on capture register. As the second detected time (loaded on ET0ICA) is read, the capture operation is enabled again. As for extracting the 2-word data on capture register, read the first detected time (loaded on ET0ICB) before reading the second (loaded on ET0ICA). In order to extract the 2-word data normally, the data "1" should be set on PME before the first edge detection, if the capture operation has already been enabled Example 3: Calculate (Second risen time) - (First risen time) and then calculate (Fourth risen time) - (Third risen time), as for IC0 input | CLR | (P3CR).6 | ; | Assigns IC0 to P36 | |----------------|----------------|---|----------------------------------------------------| | SET | (PME).0 | ; | Rises PME (interrupt after second edge detection) | | $\mathbf{DI}$ | | | | | $\mathbf{SET}$ | (EIRH).3 | ; | Enables individual interrupt enable flag for | | | | | INTIC0 | | LD | (ET0MIO),0101B | ; | Enables capturing on rising edge | | ${f EI}$ | | | | | JR | LP | | | | SET | (ET0ICBL).0 | : | Raises PME (interrupt after second edge detection) | ICO: SET (ETOICBL).0 ; Raises PME (interrupt after second edge detected time) LD HL,(ETOICBL) ; Reads the first (third) detected time) LD BC,(ETOICAL) ; Reads the second (fourth) detected time, ; Enables capturing again SUB BC,HL ; Calculates time RETI LP: 86CH06-98 2002-10-08 ## (2) Output Comparing The output level alters at the time stated. The output mode is selected on the bits OCMODE on register ETOMIO whether to be output "1", output "0", invert or NOP. The initial value that the comparator outputs is set on bit OCID in register ETOMIO. Once the comparator is enabled, namely during comparison, bit OCIDEN should be cleared to "0" for fear that other than data matching alter OC0 output. The time to alter output is set on the ETC0 compare register (ETC0OCR). This register should be consecutively written from the lower byte to the upper. As the upper byte is set, the 2-byte data is loaded on the ETC0OCR effectively. Writing only to the lower byte is prohibited. As the rate of the timer-counter and comparator matches, the stated data depends on OCMODE is output on P37, and the interrupt INTOC0 is requested. If OCMODE has been set for NOP, the terminal keeps its value and only the interrupt request is required. If OCMODE has been "11", the terminal inverts its output value. Note: While the timer-counter is not in motion (ETOS = "0"), the comparator outputs "1" regardless of the rate on register ETOMIO. Figure 2-38. Examples for comparing operation ``` Example 1: Change OC0 output from "0" to "1" when ETOR = 0C80<sub>H</sub>. ("1" output mode) SET (P3DR).7 SET (P3CR).7 ; assigns OC0 output mode to P37 LDW (ETOOCRL), 0C80H; sets time for changing output (ET0MIO), 1---0101B; initializes OC0 to "0" and assign "1" output mode to it CLR (ET0MIO).7 prohibits OCID revising Example 2: Change OC0 output from "1" to "0" when ET0R = 0C80H. (toggle output mode) SET (P3DR).7 SET (P3CR).7 assigns OC0 output mode to P37 sets time for changing output LDW (ETOOCRL), 0C80H : (ETOMIO), 1---1111B; initializes OC0 to "1" and assigns toggle output mode to it LD CLR (ETOMIO).7 prohibits OCID revising Example 3: Output the pulse with "0" for 1ms and "1" for 2ms, through OC0 terminal. (at fcgck = 8[MHz] (ETOCR), 01H LD selects fcgck/8 (1\mus) for source clock clears the counter LDW (ETOR), 0000H LD BC, 03E8H substitutes "0" width (1 ms) for BC LD DE, 07D0H substitutes "1" width (2 ms) for DE LD WA, 03E8H substitutes "initial value" width (1 ms) for WA SET (P3DR).7 SET (P3CR).7 assigns OC0 output mode to P37 LD (ETOOCRL), A sets time for changing output LD (ETOOCRH), W initializes OC0 to "0" and assigns toggle output mode to it (ET0MIO), 1---0111B; LD prohibits OCID revising CLR (ET0MIO).7 SET (ETOCR).7 ETC0 starts counting OUT0: ADD WA, DE calculates time to change output from "1" to "0" LP: waits for changing output from "0" to "1" (sets IL12) TEST (ILH).4 JR T, LP DI LD (ILH), 0EFH clears IL12 \mathbf{EI} LD (ETOOCRL), A LD (ETOOCRH), W sets time for changing output from "1" to "0" OUT1: calculates time to change output from "0" to "1" ADD WA,BC LP1: TEST (ILH).4 waits for changing output from "1" to "0" (sets IL12) JR T, LP1 DI LD (ILH), 0EFH clears IL12 \mathbf{EI} LD (ETOOCRL), A LD (ETOOCRH), W ; sets time for changing output from "0" to "1" JR OUT0 Example 4: Generate only interrupt request when ETOR = 0C80<sub>H</sub>; without OC0 terminal output. LDW (ETOOCRL), 0C80H sets time for interrupt request LD (ET0MIO),1---1100B ; initializes OC0 to "1" and assigns NOP output mode to it CLR (ETOMIO).7 prohibits OCID revising ``` 86CH06-100 2002-10-08 # 2.7.5 Interrupting There are 3 sorts of interrupt requesting: for extended timer (INTET0), for capture input (INTIC0) and for output compare (INTOC0). (1) INTETO The interrupt requesting is generated as the counter reaches $FFFF_H$ ; meanwhile the counter is still counting up. (2) INTICO Interrupt requesting is triggered by capture input pin (IC0). The interrupt is requested when the timer value at edge detection is loaded on the capture register. (3) INTOCO Interrupt requesting is triggered by comparator. The interrupt is requested when the rate of the timer-counter and comparator matches. 86CH06-101 2002-10-08 ## 2.8 UART (Asynchronous serial interface) The TMP86CH06 has 2 channels of UART (asynchronous serial interface). The UART is connected to external devices via RxD and TxD. RxD0 and RxD1 are also used as P43 and P46, respectively; TxD0 and TxD1 as P44 and P47 respectively. To use P44 or P47 as the TxD pin, set corresponding bit in P4 port output latches to 1 and set the terminal to output mode. To use P43 or P46 as the RxD pin, set the terminal to input mode respectively. Notice that P43 (RxD0) and P44 (TxD0) are also used as syncronized serial interface (SIO); the ch.0 of UART is not available when the syncronized serial interface is utilized. ## 2.8.1 Configuration Figure 2-39. UART #### 2.8.2 Control www.DataSheet4U.com UART is controlled by the UART control registers (UARTCRA, UARTCRB). The operating status can be monitored using the UART status register (UART0SR, UART1SR). | UART Control F | Register | • | | | | | | | | | |----------------------------------|---------------------------------------------------------------|-----|-------------|----------|----------|----|------------------------------------------------|----------------|---------------------------------------|-------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | UARTOCRA<br>(001A <sub>H</sub> ) | TXE | RXE | STBT | EVEN | PE | | BRG | 1 | (Initial value: 0000 0000) | | | UART1CRA<br>(001E <sub>H</sub> ) | O00: fc/13 [Hz] O01: fc/26 O10: fc/52 O11: fc/104 100: fc/208 | | 1<br>3<br>5 | | | | | | | | | | PE | | Parity a | ddition | | | 0: No parity<br>1: Parity | | · · · · · · · · · · · · · · · · · · · | /rite | | | EVE | N | Even-nu | ımbered | d parity | y | 0: Odd-numbered parity 1: Even-numbered parity | | mbered parity | | | | STB | Т | Transmi | t stop b | it leng | th | 1 ' | 1 bit<br>2 bit | | | | | RX | E | Receive | operati | ion | | 0: Disable<br>1: Enable | | | | | | TX | E | Transfe | r operat | tion | | 0: Disable<br>1: Enable | | | | Note 1: When operations are disabled by setting TXE and RXE bit to "0", the setting becomes valid when data transmit or receive complete. When the transmit data is stored in the transmit data buffer, the data are not transmitted. Even if data transmit is enabled, until new data are written to the transmit data buffer, the current data are not transmitted. Note 2: The transmit clock and the parity are common to transmit and receive. Note 3: UARTOCRA and UART1CRA are a write only register and must not be used with any of the read-modifywrite instructions. Note 4: Do not switch the transmit clock during transmit operation. | : | | RXDN | C STOPBR (Initial value: **** *000) | | |---|--------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | | STOPBR | Receive stop bit length | 0: 1 bit<br>1: 2 bit | | | | RxDNC | Selection of RxD input noise rejection time | 00: No noise rejection (hysteresis input) 01: Rejects pulses shorter than 31/fc [s] as noise 10: Rejects pulses shorter than 63/fc [s] as noise 11: Rejects pulses shorter than 127/fc [s] as noise | Write<br>only | **UART1CRB** $(001F_{H})$ UARTOCRB (001B<sub>H</sub>) Note 5: When RxDNC = 01, pulses longer than 96/fc [s] are always regarded as signals; when RxDNC = 10, longer than 192/fc [s]; and when RxDNC = 11, longer than 384/fc [s] Note 6: The following types of clocks are available for transmitting, while the clock gear is utilized. Note 7: UARTOCRB and UART1CRB are a write only register and must not be used with any of the read-modifywrite instructions. | D. | ec. | Clock Rate | fcgck [Hz] | | | | | | | | |----|----------------|------------|------------|---------|---------|---------|---------|---------|--|--| | ы | BRG Clock Rate | | fc | fc/2 | fc/4 | fc/8 | fc/16 | fc/32 | | | | 00 | 00 | fc/13 | Enable | Disable | Disable | Disable | Disable | Disable | | | | 00 | 01 | fc/26 | Enable | Enable | Disable | Disable | Disable | Disable | | | | 0 | 10 | fc/52 | Enable | Enable | Enable | Disable | Disable | Disable | | | | 0 | 11 | fc/104 | Enable | Enable | Enable | Enable | Disable | Disable | | | | 10 | 00 | fc/208 | Enable | Enable | Enable | Enable | Enable | Disable | | | | 10 | 01 | fc/416 | Enable | Enable | Enable | Enable | Enable | Enable | | | | 1 | 11 | fc/96 | Enable | Enable | Enable | Enable | Disable | Disable | | | Figure 2-40. UART control register 86CH06-103 Figure 2-41. UART status register and Data Buffer Registers ### 2.8.3 Transfer Data Format In UART, a one-bit start bit (low level), stop bit (bit length selectable at high level, by STBT), and parity (select parity in PE; even-or odd-numbered parity by EVEN) are added to the transfer data. The transfer data formats are shown as follow. Table 2-14. Transfer Data Format | PE | STBT | Frame length 1 | |----|------|----------------------------------------------------| | 0 | 0 | Start Bit 0 Bit 1 X Bit 6 Bit 7 Stop1 | | 0 | 1 | Start Bit 0 Bit 1 X Bit 6 Bit 7 Stop1 Stop2 | | 1 | 0 | Start Bit 0 Bit 1 X Bit 6 Bit 7 Parity Stop1 | | 1 | 1 | Start Bit 0 Bit 1 X Bit 6 Bit 7 Parity Stop1 Stop2 | ww.DataSheet4U.com #### 2.8.4 Transfer Rate The baud rate of UART is set of BRG (bit 0, 1, and 2 in UARTCR1) . The example of the baud rate shown as follows. | BRG | Sourse clock | | | | | | | | |-----|--------------|--------------|--------------|--|--|--|--|--| | ВКО | 16 MHz | 8 MHz | 4 MHz | | | | | | | 000 | 76800 [baud] | 38400 [baud] | 19200 [baud] | | | | | | | 001 | 38400 | 19200 | 9600 | | | | | | | 010 | 19200 | 9600 | 4800 | | | | | | | 011 | 9600 | 4800 | 2400 | | | | | | | 100 | 4800 | 2400 | 1200 | | | | | | | 101 | 2400 | 1200 | 600 | | | | | | Table 2-15. Transfer Rate (Example) W.Dataoncot-o.oom When INTTC0 is used as the UART transfer rate (when BRG=110), the transfer clock and transfer rate are detarmined as follows: $$Transfer clock = \frac{TC0 \text{ source clock}}{TTREG0 \text{ set value}}$$ Transfer rate $$=\frac{\text{Transfer clock}}{16}$$ ### 2.8.5 Data Sampling The UART receiver keeps sampling input using the clock selected by BRG (bit 0, 1, and 2 in UARTCRA) until a start bit is detected in RxD pin input. RT clock starts at the falling edge of the RxD pin. Once a start bit is detected, the start bit, data bits, stop bit(s), and parity bit are sampled at three times of RT7, RT8, and RT9 during one receiver clock interval (RT clock). (RT0 is the position where the bit supposedly starts). Bit is determined according to majority rule (the data are the same twice or more out of three samplings). Figure 2-42. Data Sampling ## 2.8.6 STOP Bit Length Select a transmit stop bit length (1 or 2 bits) by STBT (bit5 in UARTCR1) #### 2.8.7 Parity Set parity/no parity by PE; set parity type (odd-or even-numbered) by EVEN (bit 4 in UARTCRA). #### 2.8.8 Transmit/Receive #### (1) Data transmit Set TXE (bit 7 in UARTCRA) to 1. Read UARTSR to check TBEP=1, then write data in TDBUF (transmit data buffer). Writing data in TDBUF zero-clears TBEP, transfers the data to the transmit shift register and the data are sequentially output from the TxD pin. The data output include a one-bit start bit, stop bits whose number is specified in STBT (bit 5 in UARTCRA) and a parity bit if parity addition is specified. Select the data transfer baud rate using bits 0 to 2 in UARTCRA. When data transmit starts, transmit buffer empty flag TBEP is set to 1 and an INTTX interrupt is generated. When transmitting data, first read UARTSR, then write data in TDBUF. Otherwise, TBEP is not zero-cleared and transmit does not start. ### (2) Data receive Set RXE (bit 6 in UARTCRA) to 1. When data are received via the RxD pin, the receive data are transferred to RDBUF (receive data buffer). At this time, the data transmitted include a start bit and stop bit(s) and a parity bit if parity addition is specified. When stop bit(s) are received, data only are extracted and transferred to RDBUF (receive data buffer). Then the receive buffer full flag RBFL is set and an INTRX interrupt is generated. Select the data transfer baud rate using bits 0 to 2 in UARTCRA. If an overrun error (OERR) occurs when data are received, the data are not transferred to RDBUF (receive data buffer) but discarded; data in the RDBUF are not affected. Note: Setting RXE bit to "0" causes data receive to stop after the data transfer currently being received has completed. However, if a flaming error occurs in this last transfer, the data receive stop state may not be entered. Therefore, if a flaming error occurs, be sure to perform the receive operation again. ### 2.8.9 Status Flag/Interrupt Signal ## (1) Parity error When parity determined using the receive data bits differs from the received parity bit, the parity error flag PERR is set in UARTSR. Reading UARTSR then RDBUF clears PERR. Figure 2-43. Generation of Parity Error # (2) Framing error When 0 is sampled as the stop bit in the receive data, framing error flag FERR is set. Reading UARTSR then RDBUF clears FERR. Figure 2-44. Generation of Framing Error ### (3) Overrun error When all bits in the next data are received while unread data are still in RDBUF, overrun error flag OERR is set. In this case, the receive data is discarded; data in RDBUF are not affected. Reading UARTSR then RDBUF clears OERR. Figure 2-45. Generation of Overrun Error ### (4) Receive data buffer full Loading the received data in RDBUF sets receive data buffer full flag RBFL. Reading UARTSR then RDBUF clears the RBFL. Figure 2-46. Generation of Receive Buffer Full ## (5) Transmit data buffer empty When no data is in the transmit buffer TDBUF, TBEP is set, that is, when data in TDBUF are transferred to the transmit shift register and data transmit starts, transmit data buffer empty flag TBEP is set. Reading UARTSR then writing the data to TDBUF clears TBEP. Figure 2-47. Generation of Transmit Buffer Empty ### (6) Transmit end flag When data are transmitted and no data is in TDBUF (TBEP=1), transmit end flag TEND is set. Writing data to TDBUF then staring data transmit clears TEND. Figure 2-48. Generation of Transmit Buffer Empty ## 2.9 Serial Interface (SIO) The TMP86CH06 has one clocked-synchronous 8-bit serial interface. Serial interface have 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 P44 (SO), P43 (SI), P42 (SCK). The serial interface pins are also used as port P4. When used as input pins, the input pins should be set to the input mode. When used as output pins, beforehand the output pins should be set to the output mode, and output latch should be set to "1". In the transmit mode, pin P43 can be used as normal I/O port, and in the receive mode, the pin P44 can be used as normal I/O ports. ## 2.9.1 Configuration Figure 2-49. Serial 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 register (SIOSR). The transmit and receive data buffer is controlled by the BUF (bits 2 to 0 in SIOCR2). The data buffer is assigned to address 0028<sub>H</sub> to 002F<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). Figure 2-50. SIO Control Registers and Status Registers (1/2) 2002-10-08 Figure 2-50. SIO Control Registers and Status Registers (2/2) ### (1) Serial Clock #### a. Clock Source SCK (bits 2 to 0 in SIOCR) 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 $\overline{SCK}$ pin. The $\overline{SCK}$ pin goes high when transfer starts. In order to extract internal clock, set the output latch of P42 to "1" and set the terminal to output mode. 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. Table 2-16. Serial Clock Rate (DVCK = "01", fc = 16 MHz, fs = 32.768 kHz) | | | NORMAL1/2, I | DLE1/2 Mode | | 51.074.511 | | | |-----|--------------------|--------------|-------------------|-------------|-------------------|-----------|--| | | DV70 | CK = 0 | DV70 | CK = 1 | SLOW, SLI | EP Wode | | | SCK | Clock | Baud rate | Clock | Baud rate | Clock | Baud rate | | | 000 | fc/2 <sup>13</sup> | 1.91 Kbps | fs/2 <sup>5</sup> | 1024 bps | fs/2 <sup>5</sup> | 1024 bps | | | 001 | fc/2 <sup>8</sup> | 61.04 Kbps | fc/2 <sup>8</sup> | 61.04 Kbps | _ | _ | | | 010 | fc/2 <sup>7</sup> | 122.07 Kbps | fc/2 <sup>7</sup> | 122.07 Kbps | _ | _ | | | 011 | fc/2 <sup>6</sup> | 244.14 Kbps | fc/2 <sup>6</sup> | 244.14 Kbps | _ | _ | | | 100 | fc/2 <sup>5</sup> | 488.28 Kbps | fc/2 <sup>5</sup> | 488.28 Kbps | _ | _ | | | 101 | fc/2 <sup>5</sup> | 488.28 Kbps | fc/2 <sup>5</sup> | 488.28 Kbps | _ | _ | | | 110 | _ | _ | _ | _ | _ | _ | | | 111 | External | | External | | External | | | Note: 1 Kbps = 1024 bps Figure 2-51. 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 P42 ( $\overline{SCK}$ ) must be set to the input mode. To ensure shifting, a pulse width of at least 4 machine cycles is required. This pulse is needed for the shift operation to execute certainly. Actually, there is necessary processing time for interrupting, writing, and reading. The minimum pulse is determined by setting the mode and the program. ### b. Shift edge The leading edge is used to transmit, and the trailing edge is used to receive. ### 1 Leading Edge Transmitted data are shifted on the leading edge of the serial clock (falling edge of the $\overline{SCK}$ pin input/output). ### 2 Trailing Edge Received data are shifted on the trailing edge of the serial clock (rising edge of the $\overline{SCK}$ pin input/output). Figure 2-52. 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. An INTSIO interrupt is generated when the specified number of words has been transferred. If the number of words is to be changed during transfer, the serial interface must be stopped before making the change. The number of words can be changed during automatic-wait operation of an internal clock. In this case, the serial interface is not required to be stopped. Figure 2-53. Number of Bits to Transfer (Example: 4-bit serial transfer) nunu Data Chaat 41 L #### (4) Transfer Mode SIOM (bits 5 to 3 in SIOCR1) is used to select the transmit, receive, or transmit/receive mode. #### a) 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 MSB 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: An automatic-wait is also canceled by writing to a DBR not being used as a transmit data buffer register; therefore, during SIO do not use such DBR for other applications. For example, when 3 words are transmitted, do not use the DBR of the remained 5 words. When an external clock is used, the data must be written to the data buffer register before shifting next data. Thus, the transfer speed is determined by the maximum delay time from the generation of the interrupt request to writing of the data to the data buffer register by the interrupt service program. The transmission is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer empty interrupt service program. 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". 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". 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. ww.DataSheet4U.con Figure 2-54. Transfer Mode (Example: 8-bit, 1 Word Transfer) Figure 2-55. Transmitted Data Hold Time at End of Transmit #### b) 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: An automatic-wait is 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. After SIOS cleared, the transmissions is ended at the time that the final bit of the data being shifted has been output. That the transmission has ended can be determined from the status of SIOF (bit 7 in SIOSR). SIOF is cleared to "0" when the transmission is ended. 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 data receive, BUF must be rewritten before the received data is read out. 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. ww DataSheet4U com Figure 2-56. 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: An automatic-wait is also canceled by writing to a DBR not being used as a transmit data buffer registers; 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, 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. Clear SIOS to "0" to SIOINH to "1" in INTSIO interrupt service program to end transmit/receive mode. The transmit/receive is ended at the time that the final bit of the data being shifted has been output. The end of transmit/receive can be determined from the status of SIOF (bit 7 in SIOSR). SIOF is cleared to "0" when the transmit/receive is ended. When SIOINH is set, the transmit/receive is immediately ended and SIOF is cleared to "0". If the number of words is to be changed during transfer, SIOS must be cleared to "0" and BUF is rewritten after confirmed that SIOF clearing to "0". The number of words can be changed during automatic-wait operation of an internal clock. In this case, BUF must be rewritten before the final transmitted/received data is read out. 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. Figure 2-57. Transmit/Receive Mode (Example: 8-bit, 1word, internal clock) Figure 2-58. Transmitted Data Hold Time at End of Transmit/Receive # **Input/Output Circuitry** ## (1) Control Pins The input/output circuitries of the TMP86CH06 control pins are shown below. | Control Pin | I/O | Input/Output Circuitry | Remarks | |---------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | XIN<br>XOUT | Input<br>Output | XEN Fc VDD NDD Rf Ro XOUT | Resonator connecting pins (high-frequency) $R_f = 1.2 \ M\Omega \qquad \text{(typ.)} \\ R_O = 1 \ k\Omega \qquad \text{(typ.)}$ | | XTIN<br>XTOUT | Input<br>Output | XTEN | Resonator connecting pins (low-frequency) $R_f = 6 \text{M}\Omega \qquad \text{(typ.)} \\ R_O = 220 \text{k}\Omega \qquad \text{(typ.)}$ | | RESET | 1/0 | Address-trap-reset Watchdog-timer-reset System-clock-reset | Sink open drain output Hysteresis input Built in Pull-up resistor $R_{IN}=220~k\Omega$ (typ.) | | TEST | Input | R <sub>IN</sub> A | Built in Pull-down resistor $R_{IN} = 70 \text{ k}\Omega$ (typ.) | | ĒĀ | Input | OVDD TO THE PROPERTY OF PR | | Note: The TMP86PH06 does not have a pull-down resistor ( $R_{IN}$ ) and a diode ( $D_1$ ) for TEST pin. Be sure to fix the TEST pin to low level in MCU mode. # (2) Input/Output Ports The input/output circuitries of the TMP86CH06 input/output ports are shown below. | Port | I/O | Input/Output Circuitry | Remarks | |----------|-----|--------------------------------|------------------------------------------------------------------------| | PO<br>@m | 1/0 | Disable TTL | Tri-state I/O<br>Nch. High-currency output | | P1 | 1/0 | Initial "High-Z" Disable | Tri-state I/O<br>Hysteresis input | | P2 | 1/0 | Initial "High-Z" | Sink open drain output Hysteresis input | | P3 | I/O | Initial "High-Z" Disable | Tri-state I/O<br>Hysteresis input | | P4 | I/O | Initial "High-Z" ODE Disable | Tri-state I/O<br>Hysteresis input<br>Programmable Open Drain<br>output | ## **Electrical Characteristics** Absolute Maximum Rating $(V_{ss} = 0 V)$ | Parameter | Symbol | Pins | Rating | Unit | |---------------------------------|---------------------|------------|--------------------------------|------| | Supply Voltage | $V_{DD}$ | | – 0.3 to 6.5 | | | Input Voltage | $V_{IN}$ | | $-0.3$ to $V_{DD} + 0.3$ | V | | Output Voltage | V <sub>OUT</sub> | | – 0.3 to V <sub>DD</sub> + 0.3 | | | | I <sub>OUT1</sub> | P1 to P4 | 3.2 | | | Output Current | I <sub>OUT3</sub> | P0 | 30 | mA | | | Σ l <sub>OUT1</sub> | | 80 | | | Output Current | Σ I <sub>OUT3</sub> | | 120 | | | D | 20 | TMP86CH06N | 600 | | | Power Dissipation (Topr = 85°C) | PD | тмр86СН06U | 350 | mW | | Soldering Temperature (Time) | Tsld | | 260 (10 s) | | | Storage Temperature | Tstg | | – 55 to 125 | °C | | Operating Temperature | Topr | | – 40 to 85 | | Note: The absolute maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded. www.DataSheet4U.cor **Recommended Operating Conditions** $(V_{SS} = 0 \text{ V, Topr} = -40 \text{ to } 85^{\circ}\text{C})$ | Parameter | Symbol | Pins | | Conditions | Min | Max | Unit | |--------------------|-------------------|---------------------------------|----------------------------------|-------------------------|-----------------------|----------------------|------| | | | | fc = 16 | NORMAL1, 2 mode | | | | | | | | MHz | IDLE0, 1, 2 mode | 4.5 | | | | | | | fc = 8 | NORMAL1, 2 mode | | | | | | | | MHz | IDLE0, 1, 2 mode | 2.7 | | | | Supply Voltage | $V_{\mathrm{DD}}$ | | fc = 4.2 | NORMAL1, 2 mode | | 5.5 | l v | | om | 100 | | MHz<br>fs = 32.768 | IDLE0, 1, 2 mode | 1.8 | | | | | | | | SLOW1, 2 mode | ] | | | | | | | kHz | SLEEP0, 1, 2 mode | | | | | | | | | STOP mode | 1.8 | | | | | V <sub>IH1</sub> | Except hysteresis and TTL input | - V <sub>DD</sub> ≧ 4.5 V | | $V_{DD} \times 0.70$ | | | | | $V_{\text{IH2}}$ | Hysteresis input | | | $V_{DD} \times 0.75$ | | | | Input High Voltage | V <sub>IH3</sub> | Except TTL input | V <sub>DD</sub> <4.5 V | | $V_{DD} \times 0.90$ | $V_{DD}$ | V | | | V <sub>IH4</sub> | TTL input (Data bus) | $V_{DD} = 5 V$ $V_{DD} = 1.8 V$ | | 2.2 | | | | | V <sub>IH5</sub> | | | | V <sub>DD</sub> – 0.2 | | | | | V <sub>IL1</sub> | Except hysteresis and TTL input | | V >4 EV | | $V_{DD} \times 0.30$ | | | | V <sub>IL2</sub> | Hysteresis input | V <sub>DD</sub> ≧ 4.5 V | | $V_{DD} \times 0.25$ | | | | Input Low Voltage | V <sub>IL3</sub> | Except TLL input | | $V_{DD}$ < 4.5 V | 0 | $V_{DD} \times 0.10$ | ] v | | | V <sub>IL4</sub> | TTL input (Data bus) | | $V_{DD} = 5 V$ | | 0.8 | | | | $V_{IL5}$ | | | V <sub>DD</sub> = 1.8 V | | 0.2 | | | | | | V <sub>DD</sub> = 4.5 V to 5.5 V | | | 16 | | | Clask Fraguency | fc XIN, XOUT | | V <sub>DD</sub> = 2.7 V to 5.5 V | | 1.0 | 8 | MHz | | Clock Frequency | | | V <sub>DD</sub> = 1.8 V to 5.5 V | | <u> </u> | 4.2 | | | | fs | XTIN, XTOUT | | | 30.0 | 34.0 | kHz | Note 1: 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. Note 2: Clock Frequency fc; The condition of supply voltage range is the value under NORMAL1/2 and IDLE0/1/2 mode. Note 3: The minimum fc with clock gear is calculated as following formula with the ratio on divider n. $(Min\ fc) = (ratio\ on\ divider\ n) \times 1\ [MHz]$ DC Characteristics $(V_{SS} = 0 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$ | Parameter | Symbol | Pins | Conditions | Min | Тур. | Max | Unit | |-----------------------------------------|------------------|---------------------------------------------|--------------------------------------------------------------------|-----|------|-----|---------| | Hysteresis Voltage | V <sub>HS</sub> | Hysteresis input | | _ | 0.9 | - | ٧ | | lanut Cumant | I <sub>IN1</sub> | TEST, EA | V <sub>DD</sub> = 5.5 V | | | + 2 | _ | | Input Current | I <sub>IN2</sub> | Sink Open Drain, Tri-state Port RESET, STOP | V <sub>IN</sub> = 5.5 V/0 V | _ | _ | ± 2 | μΑ | | Innut Besistanse | R <sub>IN2</sub> | RESET | | 100 | 220 | 450 | kΩ | | Input Resistance | R <sub>IN3</sub> | TEST | | _ | 70 | _ | K77 | | OSC. Feedback | Rfx | XIN-XOUT | | _ | 1.2 | - | MO | | Resistance | Rfxt | XTIN-XTOUT | | _ | 6 | - | ΜΩ | | Output Leakage | I <sub>LO1</sub> | Sink Open Drain Port | $V_{DD} = 5.5 \text{ V}, V_{OUT} = 5.5 \text{ V}$ | _ | _ | 2 | | | Current | I <sub>LO2</sub> | Tri-state Port | $V_{DD} = 5.5 \text{ V}, \ V_{OUT} = 5.5 \text{ V}/0 \text{ V}$ | _ | _ | ± 2 | $\mu A$ | | "H" Output Voltage | V <sub>OH2</sub> | Tri-state Port | $V_{DD} = 4.5 \text{ V}, I_{OH} = -0.7 \text{ mA}$ | 4.1 | _ | - | V | | "L" Output Voltage | V <sub>OL3</sub> | Except P0 and XOUT | $V_{DD} = 4.5 \text{ V}, I_{OL} = 1.6 \text{ mA}$ | _ | _ | 0.4 | V | | "I " Output Compant | I <sub>OL1</sub> | Except P0 and XOUT | $V_{DD} = 4.5 \text{ V}, V_{OL} = 0.4 \text{ V}$ | 1.6 | _ | - | A | | "L" Output Current | I <sub>OL3</sub> | P0 | $V_{DD} = 4.5 \text{ V}, V_{OL} = 1.0 \text{ V}$ | _ | 20 | - | mA | | Supply Current under NORMAL1, 2 mode | | | $V_{DD} = 5.5 \text{ V}$<br>$V_{IN} = 5.3 \text{ V}/0.2 \text{ V}$ | - | 5.5 | 7.0 | | | Supply Current under IDLE1, 2 mode | | | fc = 16 MHz<br>fs = 32.768 kHz | _ | 2.8 | 3.5 | mA | | Supply Current under<br>NORMAL1, 2 mode | | | $V_{DD} = 5.5 \text{ V}$ $V_{IN} = 5.3 \text{ V}/0.2 \text{ V}$ | - | 4.0 | 5.0 | | | Supply Current under IDLE1, 2 mode | - | | fc = 8 MHz<br>fs = 32.768 kHz | _ | 2.0 | 2.5 | mA | | Supply Current under<br>SLOW1 mode | l <sub>DD</sub> | | | - | 14 | 25 | μΑ | | Supply Current under<br>SLEEP1 mode | | | $V_{DD} = 3.0 \text{ V}$ $V_{IN} = 2.8 \text{ V}/0.2 \text{ V}$ | _ | 7.0 | 15 | μΑ | | Supply Current under<br>SLEEP0 mode | | | fs = 32.768 kHz | - | 6.0 | 15 | μΑ | | Supply Current under STOP mode | | | $V_{DD} = 5.5 \text{ V}$<br>$V_{IN} = 5.3 \text{ V}/0.2 \text{ V}$ | - | 0.5 | 10 | μΑ | Note 1: Typical values are shown under $T_{opr} = 25^{\circ}\text{C}$ , $V_{DD} = 5 \text{ V}$ , while conditions are not stated. Note 2: Input current $I_{IN1}$ , $I_{IN3}$ : The current through pull-up or pull-down resistor is not included. AC Characteristics (1) $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$ ## ① CLOCK | Parameter | Symbol | Conditions | Min | Тур. | Max | Unit | |------------------------------|------------------|------------------------------------------|-------|------|-------|------| | | | NORMAL1, 2 mode | 0.25 | | 4 | | | Mashina Cysla Tima | +0.4 | IDLE0, 1, 2 mode | 0.25 | 1 | 4 | μ\$ | | Machine Cycle Time | tcy | SLOW1, 2 mode | 117.6 | | 422.2 | | | | | SLEEP0, 1, 2 mode | 117.0 | _ | 133.3 | | | High Level Clock Pulse Width | t <sub>WCH</sub> | External clock operation<br>(XIN input) | 25 | | | | | Low Level Clock Pulse Width | t <sub>WCL</sub> | fc = 16 MHz | 25 | ı | 1 | ns | | High Level Clock Pulse Width | t <sub>WSH</sub> | External clock operation<br>(XTIN input) | 14.7 | | | | | Low Level Clock Pulse Width | t <sub>WSL</sub> | fs = 32.768 kHz | 14.7 | - | _ | μ\$ | 86CH06-124 ## ② External Memory Interface (Multiplexed Bus) | at V <sub>DD</sub> | = 4 | 5 to | 5 5 | |--------------------|-------|------|------| | at v DD | ) — + | , ,, | ر. ر | | | Nia | C. mala al | Down mater | Vari | able | 16 N | ЛHz | Hait | |---------------------|-----|------------------|-----------------------------------------------------------------------|-----------|-----------|------|-----|------| | | No. | Symbol | Parameter | Min | Max | Min | Max | Unit | | | 1 | t <sub>AL</sub> | A7 to 0 effective → ALE | 0.5t – 15 | | 16 | | ns | | | 2 | t <sub>LA</sub> | ALE fall → A7 to 0 hold | 0.5t - 20 | | 11 | | ns | | | 3 | t <sub>LL</sub> | ALE pulse width | t – 40 | | 22 | | ns | | | 4 | t <sub>LC</sub> | ALE fall $\rightarrow \overline{RD}$ , $\overline{WR}$ fall | 0.5t - 25 | | 6 | | ns | | | 5 | t <sub>CL</sub> | RD, WR rise → ALE rise | 0.5t - 20 | | 11 | | ns | | | 6 | t <sub>ACL</sub> | A7 to 0 effective $\rightarrow \overline{RD}$ , $\overline{WR}$ fall | t – 25 | | 37 | | ns | | | 7 | t <sub>ACH</sub> | A15 to 8 effective $\rightarrow \overline{RD}$ , $\overline{WR}$ fall | 1.5t – 25 | | 68 | | ns | | | 8 | t <sub>CA</sub> | $\overline{RD}$ , $\overline{WR}$ rise $\rightarrow$ A15 to 8 hold | 0.5t - 20 | | 11 | | ns | | www.DataSheet4U.con | 9 | t <sub>ADL</sub> | A7 to 0 effective $\rightarrow$ D7 to 0 input | | 3t – 55 | | 132 | ns | | | 10 | t <sub>ADH</sub> | A15 to 8 effective $\rightarrow$ D7 to 0 input | | 3.5t – 65 | | 153 | ns | | | 11 | t <sub>RD</sub> | $\overline{RD}$ fall $\rightarrow$ D7 to 0 input | | 2t – 60 | | 65 | ns | | | 12 | t <sub>RR</sub> | RD pulse width | 2t – 40 | | 85 | | ns | | | 13 | t <sub>HR</sub> | $\overline{RD}$ rise $\rightarrow$ D7 to 0 hold | 0 | | 0 | | ns | | | 14 | t <sub>RAE</sub> | $\overline{RD}$ rise $\rightarrow$ A7 to 0 effective | t – 15 | | 47 | | ns | | | 15 | t <sub>WW</sub> | WR pulse width | 2t – 40 | | 85 | | ns | | | 16 | t <sub>DW</sub> | D7 to 0 effective $\rightarrow \overline{WR}$ rise | 2t – 40 | | 85 | | ns | | | 17 | t <sub>WD</sub> | $\overline{\text{WR}}$ rise $\rightarrow$ D7 to 0 hold | 0.5t – 15 | | 16 | | ns | Note: t = tcy/4 (t = 62.5 ns at fcgck = 16 MHz) ## A.C.Measurement Condition Output Level: High 2.2 V/Low 0.8 V, CL = 50 pFInput Level: High 2.4 V/Low 0.4 V (D7 to D0) High 0.8 VDD/Low 0.2 VDD (Except D7 to D0) # Read Cycle vw.DataSheet4U.com # Write Cycle **Recommended Oscillating Conditions - 1** $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$ | Parameter Octilists | | Oscillation | _ | | | Recommended Constant | | | |----------------------------|--------------------|-------------|--------|------------------------|------------------|----------------------|--|--| | Parameter | Oscillator | Frequency | Recom | Recommended Oscillator | | C <sub>2</sub> | | | | | | | MURATA | CSA16.00MXZ040 | 10 pF | 10 pF | | | | High francisco | | 8 MHz | MURATA | CSA8.00MTZ | 30 pF | 30 pF | | | | High-frequency Oscillation | Ceramic Resonator | 8 IVITIZ | | CST8.00MTW | 30 pF (built-in) | 30 pF (built-in) | | | | Oscillation | | 4.19 MHz | MURATA | CSA4.19MG | 30 pF | 30 pF | | | | | | | | CST4.19MGW | 30 pF (built-in) | 30 pF (built-in) | | | | Low-frequency | Crystal Oscillator | 32.768 kHz | SII | VT-200 | 6 pF | 6 pF | | | | Oscillation | Crystal Oscillator | 32.700 KHZ | ווכ | V 1-200 | O Pi | O Pi | | | www.DataShoot/III.com ## Recommended Oscillating Conditions - 2 $$(V_{SS} = 0 \text{ V}, V_{DD} = 2.7 \text{ to } 5.5 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$$ | Darameter | oromotor Ocillate | | D | Base was an dead Casillates | | Recommended Constant | | | |----------------|--------------------|------------|------------------------|-----------------------------|------------------|----------------------|--|--| | Parameter | Oscillator | Frequency | Recommended Oscillator | | C <sub>1</sub> | C <sub>2</sub> | | | | | | | MURATA | CSA8.00MTZ | 30 pF | 30 pF | | | | High-frequency | Camanaia Danamatan | 8 MHz | | CST8.00MTW | 30 pF (built-in) | 30 pF (built-in) | | | | Oscillation | Ceramic Resonator | 4 10 1411- | MURATA | CSA4.19MG | 30 pF | 30 pF | | | | | | 4.19 MHz | | CST4.19MGW | 30 pF (built-in) | 30 pF (built-in) | | | ## Recommended Oscillating Conditions - 3 $$(V_{SS} = 0 \text{ V}, V_{DD} = 1.8 \text{ to } 5.5 \text{ V}, Topr = -40 \text{ to } 85^{\circ}\text{C})$$ | Danamastan | 0 111 / | Oscillation | Recommended Oscillator | | Recommend | ed Constant | |----------------|---------------------|-------------|------------------------|------------|------------------|------------------| | Parameter | Oscillator | Frequency | | | C <sub>1</sub> | C <sub>2</sub> | | High-frequency | Cananai a Basanatan | 4 40 0411- | MURATA | CSA4.19MG | 30 pF | 30 pF | | Oscillation | Ceramic Resonator | 4.19 MHz | | CST4.19MGW | 30 pF (built-in) | 30 pF (built-in) | (1) High-frequency Oscillation (2) Low-frequency Oscillation - Note 1: An electrical shield by metal shield plate on the surface of IC package is recommended in order to protect the device from the high electric field stress applied from CRT (Cathodic Ray Tube) for continuous reliable operation. - Note 2: The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following URL; http://www.murata.co.jp/search/index.html ww.DataSheet4U.con