#### CMOS 8-Bit Microcontroller ## TMP88CP77F, TMP88CS77F, TMP88CU77F The TMP88CP77/S77/U77 are the high speed and high performance 8-bit single chip microcomputers. These MCU contain VFT (Vacuum Fluorescent Tube) driver, serial interface, 8-bit AD converter and multi-function timer/counter on a chip. | PART No. | ROM | RAM | PACKAGE | OTP MCU | |------------|---------------------------|------------|---------------------|------------| | TMP88CP77F | 48K × 8 bit + 256 × 8 bit | 1K×8-bit | | | | TMP88CS77F | 64K × 8 bit + 256 × 8 bit | 2K×8-bit | P-QFP100-1420-0.65A | TMP88PU77F | | TMP88CU77F | 96K × 8 bit + 256 × 8 bit | 3K x 8-bit | | | #### **Features** - ◆8-bit single-chip microcomputer TLCS-870/X series microcomputer - ♦ interrupt sources: 20 (6 external, 14 internal) - ◆I/O ports: 88 pins - ◆Three 16-bit Timer/Counters - TC1: Timer, Event counter, Pulse width measurement, External trigger timer, Window modes - TC2: Timer, Event counter, Window modes - ETC1: Timer, Event counter, Window mode Minimum resolution: 500 \(\mu\s \text{ at 8 MHz}\) Two capture inputs (edge-selectable) Two compare outputs (High/Low/Toggle/Steady output modes) - 8-bit Timer/Counter - TC4: Timer, Event counter, PWM output, Programmable divider output modes - ◆Time Base Timer (Interrupt frequency: 1 Hz to 16384 Hz) - ◆Divider output function (frequency: 1 kHz to 8 kHz) 070122EBP - The information contained herein is subject to change without notice. 021023 D - TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property. - In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges—as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc. 021023\_A - The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunction or failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. 021023 B - The products described in this document shall not be used or embedded to any downstream products of which manufacture, use and/or sale are prohibited under any applicable laws and regulations. 060106 Q - The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patents or other rights of TOSHIBA or the third parties. 070122\_C - The products described in this document are subject to foreign exchange and foreign trade control laws. 060925\_E - For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions. 030619 **3-77-1** 2007-10-23 - ◆Watchdog Timer - Interrupt source/reset output (programmable) - ◆Two 8-bit Serial Interfaces - With 8 bytes and 32 bytes transmits/receive data buffer - Internal/external serial clock, and 4/8-bit mode - ◆Serial bus Interface - I2C-bus, 8-bit SIO modes - ◆8-bit successive approximate type AD converter with sample and hold - 12 analog inputs - Conversion time: 23 μs at 8 MHz - ◆ Vacuum Fluorescent Tube Driver (automatic display) - Programmable grid scan - High breakdown voltage ports (max.40 V x 53 bits) - ◆ Dual clock operation - Single/Dual-clock mode - ◆ Five Power saving operating modes - STOP mode: Oscillation stops. Battery/Capacitor back-up. Port output hold/High-impedance. - SLOW mode: Low power consumption operation using low-frequency clock (32.768 kHz) - IDLE1 mode: CPU stops, and Peripherals operate using high-frequency clock. Release by interrupts. - IDLE2 mode: CPU stops, and Peripherals operate using high-and low-frequency clock. Release by interruput. - SLEEP mode: CPU stops, and Peripherals operate using low-frequency clock. Release by interrupts. - ♦ Wide operating voltage: 4.5 to 5.5 V at 12.5 MHz / 32.768 kHz, 2.7 to 5.5 V at 32.768 kHz - ◆Emulation Pod: BM87CP77FOA **3-77-2** 2007-10-23 ## Pin Assignments (Top View) P-QFP100-1420-0.65A Note: All VDDs should be connected externally for keeping the same voltage level. **3-77-3** 2007-10-23 ## **Block Diagram** **3-77-4** 2007-10-23 # **Pin Function** | Pin Name | I/O | Funct | ion | | |-------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--| | P07 (INT4) | I/O (input) | 8-bit input/output port with latch. | External interrupt input 4 | | | P06 (INT3, OC1) | 1/0 (1/0) | When used as input port, multi function timer/counter, external interrupt input, | External interrupt input 3 or Expansion<br>Timer/Counter compare output 1 | | | P05 (TC1, INT2) | I/O (input) | serial bus interface, the latch must be set to | Timer/Counter 1 input or External interrupt input 2 | | | P04 (OC0, INT1) | 1/0 (1/0) | "1".<br> | Expansion Timer/Counter compare output<br>0 or External interrupt input 1 | | | P03 (IC0) | I/O (input) | | Expansion Timer/Counter capture input 0 | | | P02 (IC1, ETC1, <u>SCK3</u> ) | I/O (I/O) | | Expansion Timer/Counter capture input 1<br>or Expansion Timer/Counter 1 input or SIO3<br>serial clock input/output | | | P01 (SCL, SI3) | 1/0 (1/0) | | I <sup>2</sup> C bus serial clock input/output or SIO3 serial data input | | | P00 (SDA, SO3) | 1/0 (1/0) | | I <sup>2</sup> C bus serial data input/output or SIO3<br>serial data output | | | P17 | I/O | 8-bit programmable input/output ports (tristate). | | | | P16 (PWM, PDO, SO0) | I/O (output) | Each bit of this port can be individually | 8-bit PWM output or 8-bit programmable divider output or SIO0 serial data output | | | P15 (TC4, SI0) | I/O (input) | configured as an input or an output under software control. | Timer/Counter 4 input or SIO0 serial data input | | | P14 (DVO, SCK0) | 1/0 (1/0) | When used as serial data input, external | Divider output or SIO0 serial clock input/output | | | P13 | I/O | interrupt input, timer/counter input, the input mode is configured. | | | | P12 (SO1, TC2) | 1/0 (1/0) | When used as divider output, timer/counter output, serial data output, serial clock | SIO1 serial data output or Timer/Counter 2<br>input | | | P11 (SI1, ĪNTO) | I/O (input) | output, the latch must be set to "1" and the | SIO1 serial data input or External interrupt<br>0 input | | | P10 ( <del>SCK1</del> ) | 1/0 (1/0) | output mode is configured. | SIO1 serial clock input/output | | | P22 (XTOUT) | 1/0 (1/0) | 3-bit input/output port with latch. When used as input port, external interrupt | Resonator connectiong pins (32.768 kHz). For inputting external clock, XTIN is used | | | P21 (XTIN) | I/O (input) | input, STOP mode release signal input, the input mode is configured. | and XOUT is opened. | | | P20 (ĪNT5, STOP) | I/O (input) | input mode is configured. | External interrupt input 5 or STOP mode release signal input | | | P33 to P30 | 1/0 | 4-bit programmable input/output ports(tri-<br>state).<br>Each bit of this port can be individually<br>configured as an input or an output under<br>software control. | | | | P47 (AIN07) to<br>P40 (AIN00) | I/O (input) | 8-bit programmable input/output ports (tri-state). Each bit of this port can be individually configured as an input or an output under software control. When used as analog input, the input mode is configured. | AD converter analog inputs | | | P53 (AIN13) to<br>P50 (AIN10) | I/O (input) | 4-bit programmable input/output ports (tristate). Each bit of this port can be individually configured as an input or an output under software control. When used as analog input, the input mode is configured. | AD converter analog inputs | | **3-77-5** 2007-10-23 | Pin Name | 1/0 | Function | | | |---------------------------|---------------|----------------------------------------------------------------------------------------------|---------------------------------------------|--| | P67 (V7) to P60 (V0) | I/O (output) | Six 8-bit high breakdown voltage output ports with the latch. | | | | P77 (V15) to P70 (V8) | I/O (output) | When used as a VFT driver output, the latch must be cleared to "0". | | | | P87 (V23) to<br>P80 (V16) | I/O (output) | must be cleared to 0. | | | | P97 (V31) to<br>P90 (V24) | I/O (output) | | | | | PD7 (V39) to<br>PD0(V31) | I/O (output) | | VFT driver output | | | PE7 (V47) to<br>PE0 (V40) | I/O (output) | | | | | PF4 (V52) to<br>PF0 (V48) | I/O (output) | 6-bit high breakdown voltage output ports with the latch. | | | | | | When used as a VFT driver output, the latch must be cleared to "0". | | | | XIN, XOUT | Input, output | Resonator connecting pins for high-frequency For inputting external clock, XIN is used and X | clock.<br>OUT is opened. | | | RESET | 1/0 | Reset signal input or watchdog timer output/a<br>outputed. | ddress-trap-reset output/sistem-clock-reset | | | TEST | Input | Test pin for out-going test.Be tied to low. | | | | VDD, VSS (Note) | | +5V,0V(GND) | | | | VKK | Power Supply | VFT driver power supply | | | | VAREF, VASS | | Analog reference voltae inputs (High, Low) | | | $Note: \ \ All\ VDDs\ should\ be\ connected\ externally\ for\ keeping\ the\ same\ voltage\ level.$ **3-77-6** 2007-10-23 ## **Operational Description** ## 1. CPU Core FUnctions The CPU core consists of a CPU, a system clock controller, an interrupt controller, and a watchdog timer. This section provides a description of the CPU core, the program memory (ROM), the data memory (RAM), and the reset circuit. ## 1.1 Memory Address Map TLCS-870/X Series, the memory is organized 4 address spaces (ROM, RAM, SFR, and DBR). Figure 1-1 shows the memory address maps of the 88CP77/S77/U77. It uses a memory mapped I/O system, and all I/O registers are mapped in the SFR/DBR address spaces. There are 16 banks of general-purpose registers. Figure 1-1. Memory Address Maps **3-77-7** 2007-10-23 ### 1.2 Program Memory (ROM) The 88CP77 has a 48 Kbytes (addresses $04000_H$ to $0FFFF_H$ ) and 256 bytes (addresses $FFF00_H$ to $FFFFF_H$ ), the 88CS77 has a 64 Kbytes (address $04000_H$ to $13FFF_H$ ) and 256 bytes (addresses $FFF00_H$ to $FFFFF_H$ ), the 88CU77 has a 96 Kbytes (address $04000_H$ to $18FFF_H$ ) and 256 bytes (addresses $FFF00_H$ to $FFFFF_H$ ) of program memory (mask programmed ROM). Figure 1-1 shown in Memory address maps. Addresses $FFF00_H$ to $FFFFF_H$ in the program memory can also be used for special purposes. ## 1.3 Data Memory (RAM) The 88CP77 has 1 Kbytes (address $00040_H$ to $0043F_H$ ), the 88CS77 has 2 Kbytes (address $00040_H$ to $0083F_H$ ), the 88CU77 has a 3 Kbytes (address $00040_H$ to $00C3F_H$ ) of data memory (static RAM). The first 128 bytes ( $00040_H$ to $0008F_H$ ) of the internal RAM are also used as general-purpose register banks. The data memory contents become unstable when the power supply is turned on; therefore, the data memory should be initialized by an initialization routine. Example 1: Clears RAM to "00H" except the bank 0 (88CP77). LD HL, 00048H ; Sets start address to HL register pair LD A, H ; Sets initial data (00<sub>H</sub>) to A register LD BC, 03F7H ; Sets number of byte to BC register pair SRAMCLR: LD (HL+), A DEC BC JRS F, SRAMCLR Example2: Clears RAM to "00H" except the bank 0 (88CS77). LD HL, 0048H ; Sets start address to HL register pair LD A, H ; Sets initial data (00<sub>H</sub>) to A register LD BC, 07F7H ; Sets number of byte to BC register pair SRAMCLR: LD (HL+), A DEC BC JRS F, SRAMCLR Note: The general-purpose registers are mapped in the RAM; therefore, do not clear RAM at the current bank addresses. ## 1.4 System Clock Controller The system clock controller consists of a clock generator, a timing generator, and a stand-by controller. Figure 1-2. System Clock Controller ## 1.4.1 Clock generator The clock generator generates the basic clock which provides the system clocks supplied to the CPU core and peripheral hardware. It contains two oscillation circuits: one for the high-frequency clock and one for the low-frequency clock. Power consumption can be reduced by switching of the system clock controller to low-power operation based on the low-frequency clock. The high-frequency (fc) and low-frequency (fs) clocks can easily be obtained by connecting a resonator between the XIN / XOUT and XTIN / XTOUT pins, respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to XIN / XTIN pin with XOUT / XTOUT pin not connected. The 88CP77/S77/U77 are not provided an RC oscillation. Figure 1-3. Examples of Resonator Connection Note: Accurate Adjustment of the Oscillation Frequency Although no hardware to externally and directly monitor the basic clock pulse is not provided, the oscillation frequency can be adjusted by making the program to output fixed frequency pulse to the port with disabling all interrupts and watchdog timers, and monitoring this pulse. With a system requiring adjustment of the oscillation frequency, the adjusting program must be created beforehand. ## 1.4.2 Timing generator The timing generator generates the various system clocks supplied to the CPU core and peripheral hardware from the basic clock (fc or fs). The timing generator provides the following functions. - Generation of main system clock (fm) - ② Generation of divider output (DVO) pulses - ③ Generation of source clocks for time base timer - Generation of source clocks for watchdog timer - ⑤ Generation of internal source clocks for timer / counters - 6 Generation of internal clocks for serial interfaces SIO and HSO - ⑦ Generation of source clocks for VFT driver circuit - Generation of warm-up clocks for releasing STOP mode - Generation of a clock for releasing reset output ## (1) Configuration of timing generator The timing generator consists of a 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). The DV1CK should be set the peripheral circuit prior to starting the peripheral circuits. Do not change the set value after setting. 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-1. As reset and STOP mode started/canceled, The prescaler and the divider are cleared to "0". | Table1-1. | Input Cloc | k to 7th Stage | e of The Divider | |-----------|------------|----------------|------------------| |-----------|------------|----------------|------------------| | Single-clo | Single-clock mode Dual-c | | Dual-clock mode | | | | | |-------------------|--------------------------|------------------------|-------------------|------------------------|---------------------|------------|-------------| | NORMAL1, | IDLE1 mode | NORMAL2, IDLE2 mode (S | | NORMAL2, IDLE2 mode (S | | SYSCK = 0) | SLOW, SLEEP | | | | DV7CK = 0 | | DV7CK = 1 | mode<br>(SYSCK = 1) | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | | (313CK = 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 DV7CK to "1" in the single clock mode. 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. Figure 1-4. Configuration of Timing Generator Figure 1-5. Clock Gear Control Register Figure 1-6. Timing Generator Control Register #### (2) Machine cycle Instruction execution and peripheral hardware operation are synchronized with the main system clock. The minimum instruction execution unit is called an "machine cycle". There are a total of 15 different types of instructions for the TLCS-870/X Series: ranging from 1-cycle instructions which require one machine cycle for execution to 15-cycle instructions which require 15 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-7. Machine Cycle **3-77-11** 2007-10-23 #### 1.4.3 Stand-by controller The stand-by controller starts and stops the oscillation circuits for the high-frequency and low-frequency clocks, and switches the main system clock. There are two operating modes: single-clock and dual-clock. These modes are controlled by the system control registers (SYSCR1 and SYSCR2). Figure 1-8 shows the operating mode transition diagram and Figure 1-9 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. In the single-clock mode, the machine cycle time is 4/fc [s] (0.5 $\mu$ s @ fc = 8 MHz). #### ① NORMAL1 mode In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock. The 88CP77/S77/U77 are 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. ### 3 STOP1 mode In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with a lowest power consumption during STOP1 mode. STOP1 mode is started by the system control register 1 (SYSCR1), and STOP1 mode is released by an inputting (either level-sensitive or edge-sensitive can be programmably selected) to the STOP pin. After the warming-up period is completed, the execution resumes with the instruction which follows the STOP1 mode start instruction. ## (2) Dual-clock mode Both the high-frequency and low-frequency oscillation circuits are used in this mode. P21 (XTIN) and P22 (XTOUT) pins cannot be used as input / output ports. The main system clock is obtained from the high-frequency clock in NORMAL2 and IDLE2 modes, and is obtained from the low-frequency clock in SLOW and SLEEP modes. The machine cycle time is 4/fc [s] in the NORMAL2 and IDLE2 modes, and 4/fs [s] (122 $\mu$ s at fs = 32.768 kHz) in the SLOW and SLEEP modes. The TLCS-870/X is placed in the signal-clock mode during reset. To use the dual-clock mode, the low-frequency oscillator should be turned on by executing [SET (SYSCR2), XTEN] instruction. #### ① NORMAL2 mode In this mode, the CPU core operates using the high-frequency clock. On-chip peripherals operate using the high-frequency clock and/or low-frequency clock. #### ② SLOW mode This mode can be used to reduce power-consumption by turning off oscillation of the high-frequency clock. The CPU core and on-chip peripherals operate using the low-frequency clock. Switching back and forth between NORMAL2 and SLOW modes are performed by the system control register 2 (SYSCR2). ## 3 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. #### 4 SLEEP mode In this mode, the internal oscillation circuit of the low-frequency clock remains active. The CPU, the watchdog timer, and the internal oscillation circuit of the high-frequency clock are halted; however, on-chip peripherals remain active (operate using the low-frequency clock). Starting and releasing of SLEEP mode are the same as for IDLE1 mode, except that operation returns to SLOW mode. #### ⑤ STOP2 mode As in STOP1 mode, all system operations are halted in this mode. As in NORMAL2 mode at the start, the operating mode returns to NORMAL2 mode, and as in As in NORMAL2 mode at the start, the operating mode returns to NORMAL2 mode, and as SLOW mode at the start, it returns to SLOW mode after release. **3-77-13** 2007-10-23 Figure 1-8. Operating Mode Transition Diagram | System Co | ontrol Reg | 5 4 3 2 | 1 | | | | | |-----------------------|------------|---------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------|-----| | (00038 <sub>H</sub> ) | STOP RELI | VI RETM "1" WUT | | (Initial va | alue: 0001 00** | ) | | | | STOP | STOP mode start | 1: CPL | J core and periphe<br>J core and periphe<br>rt STOP mode) | | | | | | RELM | Release method<br>for STOP mode | 0: Edge-sensitive release<br>1: Level-sensitive release | | | | | | | RETM | Operating mode after STOP mode | 0: Return to NORMAL mode<br>1: Return to SLOW mode | | | | R/W | | | | Warming-up time at | | Return to NO<br>DV1CK = 0 | RMAL mode<br>DV1CK = 1 | Return to<br>SLOW mode | | | | WUT | releasing STOP mode | 00<br>01<br>10<br>11 | $3 \times 2^{16}$ / fc<br>$2^{16}$ / fc<br>$3 \times 2^{14}$ / fc<br>$2^{14}$ / fc | $3 \times 2^{17}$ / fc<br>$2^{17}$ / fc<br>$3 \times 2^{15}$ / fc<br>$2^{15}$ / fc | 3×2 <sup>13</sup> / fs<br>2 <sup>13</sup> / 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 $\overline{\text{RESET}}$ pin input, a return is made to NORMAL mode 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 in as undefined data when a read instruction is executed. Note 5: Always set bit 4 in SYSCR1 to "1" when STOP mode is started. ### System Control Register 2 SYSCR2 XEN XTEN SYSCK IDLE : : (00039<sub>H</sub>) (Initial value: 1000 \*\*\*\*) | XEN | High-frequency oscillator control | O: Turn off oscillation Turn on oscillation | | |-------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----| | XTEN | Low-frequency oscillator control | O: Turn off oscillation Turn on oscillation | R/W | | SYSCK | Main system clock select<br>(write)/main system clock<br>monitor (read) | 1 (). High-tredilency clock | | | IDLE | IDLE mode start | O: CPU and watchdog timer remain active 1: CPU and watchdog timer are stopped (start IDLE1 mode) | | Note 1: XEN and SYSCK are automatically overwritten in accordance with the contents of RETM (bit 5 in SYSCR1) when STOP mode is released. | RETM | operating mode after STOP mode | XEN | SYSCK | |------|--------------------------------|--------|-------| | | NORMAL 1/2 mode | 1<br>0 | 0 | | | | | | Note 2: Do not clear XEN to "0" when SYSCK = 0, and do not clear XTEN to "0" when SYSCK = 1. Note 3: A reset is applied (RESET pin output goes low) if both XEN and XTEN are cleared to "0". Note 4: \* ; don't care Note 5: Bits 3 to 0 in SYSCR2 are always read in as "1" when a read instruction is executed. Figure 1-9. System Control Registers 1, 2 ### 1.4.4 Operating mode control (1) **STOP** mode (STOP1, STOP2) 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. - 3 The prescaler and the divider of the timing generator are cleared to "0". - The program counter holds the address of the instruction but one to 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). ## 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 (P2).0 ; Wait until the STOP pin input goes low level JRS F, SSTOPH SET (SYSCR1). 7; Starts STOP mode Example 2: Starting STOP mode from NORMAL mode with an INT5 interrupt. PINT5: TEST (P2) . 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. SET (SYSCR1) . 7 ; Starts STOP mode SINT5: RETI Figure 1-10. Level-sensitive release Mode Note 1: Even if the STOP pin input is low after warming up start, the STOP mode is not restarted. Note 2: In this case of changing to the level-sensitive mode from the edge-sensitive mode, the release mode is not switched until a rising edge of the STOP pin input is detected. ## b. Edge-sensitive release mode (RELM = "0") In this mode, STOP mode is released by a rising edge of the 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 LD (SYSCR1), 10010000B; Starts after specified to the edge-sensitive release mode Figure 1-11. Edge-sensitive release Mode STOP mode is released by the following sequence. ① In the dual-clock mode, when returning to NORMAL2, both the high-frequency and low-frequency clock oscillators are turned on; when returning to SLOW mode, only the low-frequency clock oscillator is turned on. In the signal-clock mode, only the high-frequency clock oscillator is turned on. - ② A warming-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Four different warming-up times can be selected with the WUT (bits 2 and 3 in SYSCR1) in accordance with the resonator characteristics. - ③ When the warming-up time has elapsed, normal operation resumes with the instruction following the STOP mode start instruction (e.g. [SET (SYSCR1). 7]). The start is made after the prescaler and the divider of the timing generator are cleared to "0". | T | Гable 1-2. | Warming-up | Time Example | (at $fc = 8 MHz$ , | fs = 32.768 kHz | |---|------------|------------|--------------|--------------------|------------------| | | | | | | | | WUT | WUT Return to NORMAL mode | | Return to SLOW mode | |-----|---------------------------|-----------|---------------------| | | DV1CK = 0 | DV1CK = 0 | Return to SLOW mode | | 00 | 24.576 | 49.152 | 750 | | 01 | 8.192 | 16.384 | 250 | | 10 | 6.144 | 12.288 | _ | | 11 | 2.048 | 4.096 | _ | Note: The warming-up time is obtained by dividing the basic clock by the divider: therefore, the warming-up time may include a certain amount of error if there is any fluctuation of the oscillation frequency when STOP mode is released. Thus, the warming-up time must be considered an approximate value. STOP mode can also be released by inputting low level on the 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). **3-77-19** 2007-10-23 #### (2) **IDLE** mode (IDLE1, IDLE2, SLEEP) 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 of the instruction but one to the instruction which starts IDLE mode. Example: Starting IDLE mode. SET (SYSCR2).4 ; IDLE←1 Figure 1-13. IDLE Mode IDLE mode includes a normal release mode and an interrupt release mode. Selection is made with the interrupt master enable flag (IMF). Releasing IDLE mode returns from IDLE1 to NORMAL1, from IDLE2 to NORMAL2, and from SLEEP to SLOW mode. ## a. Normal release mode (IMF = "0") IDLE mode is released by any interrupt source enabled by the individual interrupt enable flag (EF) or an external interrupt 0 (INTO pin) request. Execution resumes with the instruction following the IDLE mode start instruction (e.g. [SET (SYSCR2), 4]. The interrupt latches (IL) of the interrupt source used for releasing must be cleared to "0" by load instructions. **3-77-20** 2007-10-23 ## b. Interrupt release mode (IMF = "1") IDLE mode is released and interrupt processing is started by any interrupt source enabled with the individual interrupt enable flag (EF) or an external interrupt 0 (INTO pin) request. After the interrupt is processed, the execution resumes from the instruction following the instruction which starts IDLE mode. IDLE mode can also be released by inputting low level on the RESET pin, which immediately performs the reset operation. After reset, the 88CP77/S77/U77 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. **3-77-21** 2007-10-23 **3-77-22** 2007-10-23 #### (3) SLOW mode SLOW mode is controlled by the system control register 2 (SYSCR2) and the timer/counter 2 (TC2). ### a. Switching from NORMAL2 mode to SLOW mode First, set SYSCK (bit 5 in SYSCR2) to switch the main system clock to the low-frequency clock. Next, clear XEN (bit 7 in SYSCR2) to turn off high-frequency oscillation. Note: The high frequency clock can be continued oscillation in order to return to NORMAL2 mode from SLOW mode quickly. Always turn off oscillation of high frequency clock when switching from SLOW mode to STOP mode. When the low-frequency clock oscillation is unstable, wait until oscillation stabilizes before performing the above operations. The timer/counter 2 (TC2) can conveniently be used to confirm that low-frequency clock oscillation has stabilized. Example 1: Switching from NORMAL2 mode to SLOW mode. SET (SYSCR2).5 ; SYSCK←1 (switches the main system clock to the low- frequency clock) CLR (SYSCR2).7 ; XEN←0 (turns off high-frequency oscillation) Example2: Switching to the SLOW mode after low-frequency clock oscillation has stabilized. LD (TC2CR), 14H; Sets TC2 mode (timer mode, source clock: fs) LDW (TREG2), 8000H; Sets warming-up time (according to Xtal characteristics) SET (EIRH). EF8 ; Enables INTTC2 LD (TC2CR), 34H ; Starts TC2 PINTTC2: LD (TC2CR), 10H ; Stops TC2 SET (SYSCR2) .5 ; SYSCK $\leftarrow$ 1 (switches the main system clock to the low- frequency clock) CLR (SYSCR2).7 ; XEN←0 (turns off high-frequency oscillation) RETI VINTTC2: DL PINTTC2 ; INTTC2 vector table #### b. Switching from SLOW 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 2 (TC2), clear SYSCK (bit 5 in SYSCR2) to switch the main system clock to the high-frequency clock. 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 88CP77/S77/U77 are placed in NORMAL1 mode. Example: Switching from SLOW mode to NORMAL2 mode (fc = 8 MHz, warming-up time is 7.94 ms). SET (SYSCR2).7; XEN←1 (turns on high-frequency oscillation) LD (TC2CR), 10H ; Sets TC2 mode (timer mode, source clock: fc) LD (TREG2 + 1), 0F8H; Sets the warming-up time (according to frequency and Xtal characteristics); Enables INTTC2 SET (EIRH). EF8 ; Enables INTTC: LD (TC2CR), 30H ; Starts TC2 PINTTC2: LD (TC2CR), 10H ; Stops TC2 CLR (SYSCR2) .5 ; SYSCK $\leftarrow$ 0 (switches the main system clock to the high- frequency clock) RETI VINTTC2: DL PINTTC2 ; INTTC2 vector table **3-77-25** 2007-10-23 ## 1.5 Interrupt Controller The 88CP77/S77/U77 each have a total of 20 interrupt sources: 6 externals and 14 internals. Nested interrupt control with priorities is also possible. Two of the internal sources are pseudo non-maskable interrupts; the remainder are all maskable interrupts. Interrupt latches (IL) that hold the interrupt requests are provided for interrupt sources. Each interrupt vector is independent. The interrupt latch is set to "1" when an interrupt request is generated and requests the CPU to accept the interrupt. The acceptance of maskable interrupts can be selectively enabled and disabled by the program using the interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). When two or more interrupts are generated simultaneously, the interrupt is accepted in the highest priority order as determined by the hardware. Figure 1-16 shows the interrupt controller. Table 1-3. Interrupt Sources | | I | nterrupt Source | Enable Condition | Interrupt<br>Latch | Vector<br>Address | Priority | |-----------------------|---------|----------------------------------|----------------------------|--------------------|--------------------|----------| | Internal/<br>External | (Reset) | | Non-Maskable | _ | FFFFC <sub>H</sub> | High 0 | | Internal | INTSW | (Software interrupt) | Pseudo | _ | FFFF8 <sub>H</sub> | 1 | | Internal | INTWDT | (Watchdog Timer interrupt) | non-maskable | IL <sub>2</sub> | FFFF4 <sub>H</sub> | 2 | | External | INT0 | (External interrupt 0) | IMF = 1, INT0EN = 1 | IL <sub>3</sub> | FFFF0 <sub>H</sub> | 3 | | Internal | INTTC1 | (16-bit TC1 interrupt) | $IMF \cdot EF_4 = 1$ | IL <sub>4</sub> | FFFEC <sub>H</sub> | 4 | | External | INT1 | (External interrupt 1) | IMF • EF <sub>5</sub> = 1 | IL <sub>5</sub> | FFFE8 <sub>H</sub> | 5 | | Internal | INTTBT | (Time Base Timer interrupt) | IMF ⋅ EF <sub>6</sub> = 1 | IL <sub>6</sub> | FFFE4 <sub>H</sub> | 6 | | External | INT2 | (External interrupt 2) | $IMF \cdot EF_7 = 1$ | IL <sub>7</sub> | FFFE0 <sub>H</sub> | 7 | | Internal | INTTC2 | (16-bit TC2 interrupt) | IMF • EF <sub>8</sub> = 1 | IL <sub>8</sub> | FFFDC <sub>H</sub> | 8 | | Internal | INTSBI | (Serial Bus Interface interrupt) | IMF • EF <sub>9</sub> = 1 | IL <sub>9</sub> | FFFD8 <sub>H</sub> | 9 | | Internal | INTTC4 | (8-bit TC4 interrupt) | IMF • EF <sub>10</sub> = 1 | IL <sub>10</sub> | FFFD4 <sub>H</sub> | 10 | | External | INT3 | (External interrupt 3) | IMF • EF <sub>11</sub> = 1 | IL <sub>11</sub> | FFFD0 <sub>H</sub> | 11 | | Internal | INTET1 | (16-bit ETC1 interrupt) | IMF • EF <sub>12</sub> = 1 | IL <sub>12</sub> | FFFCC <sub>H</sub> | 12 | | Internal | INTSIO0 | (Serial interface0 interrupt) | IMF ⋅ EF <sub>13</sub> = 1 | IL <sub>13</sub> | FFFC8 <sub>H</sub> | 13 | | Internal | INTSIO1 | (Serial interface1 interrupt) | IMF • EF <sub>14</sub> = 1 | IL <sub>14</sub> | FFFC4 <sub>H</sub> | 14 | | External | INT5 | (External interrupt 5) | IMF · EF <sub>15</sub> = 1 | IL <sub>15</sub> | FFFC0 <sub>H</sub> | 15 | | Internal | INTIC0 | (Input capture0 interrupt) | IMF • EF <sub>16</sub> = 1 | IL <sub>16</sub> | FFFBC | 16 | | Internal | INTIC1 | (Input capture1 interrupt) | IMF • EF <sub>17</sub> = 1 | IL <sub>17</sub> | FFFB8 | 17 | | Internal | INTOC0 | (Output compare0 interrupt) | IMF • EF <sub>18</sub> = 1 | IL <sub>18</sub> | FFFB4 | 18 | | Internal | INTOC1 | (Output compare1 interrupt) | IMF • EF <sub>19</sub> = 1 | IL <sub>19</sub> | FFFB0 | 19 | | External | INT4 | (External interrupt4) | IMF · EF <sub>20</sub> = 1 | IL <sub>20</sub> | FFFAC | Low 20 | ## (1) Interrupt Latches (IL 20 to 2) Interrupt latches are provided for each source, except for a software interrupt. The latch is set to "1" when an interrupt request is generated, and requests the CPU to accept the interrupt. The latch is cleared to "0" just after the interrupt is accepted. All interrupt latches are initialized to "0" during reset Interrupt latches are assigned to addresses $0003C_H$ and $0003D_H$ in the SFR. Each latch can be cleared to "0" individually by an instruction; however, the read-modify-write instruction such as bit manipulation or operation instructions cannot be used. Thus, interrupt requests can be canceled and initialized by the program. Note that interrupt latches cannot be set to "1" by any instruction. The contents of interrupt latches can be read out by an instruction. Therefore, testing interrupt requests by software is possible. **Example 1: Clears interrupt latches** LDW (IL), 11101000001111111B ; $IL_{10}$ to $IL_{6}\leftarrow 0$ Example 2: Reads interrupt latches LD WA, $(IL_L)$ ; W $\leftarrow$ ILH, A $\leftarrow$ ILL Example 3: Tests an interrupt latch TEST (IL).7 ; if $IL_7 = 1$ then jump JR F, SSET **3-77-27** 2007-10-23 ## (2) Interrupt Enable Register (EIR) The interrupt enable register (EIR) enables and disables the acceptance of interrupts, except for the pseudo non-maskable interrupts (software and watchdog timer interrupts). Pseudo non-maskable interrupts are accepted regardless of the contents of the EIR; however, the pseudo non-maskable interrupts cannot be nested more than once at the same time. For example, the watchdog timer interrupt is not accepted during the software interrupt service. The EIR consists of an interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). This register is assigned to addresses $0003A_H$ and $0003B_H$ in the SFR, and can be read and written by an instruction (including read-modify-write instructions such as bit manipulation instructions). ## 1 Interrupt Master enable Flag (IMF) The interrupt master enable flag (IMF) enables and disables the acceptance of all interrupts, except for pseudo non-maskable interrupts. Clearing this flag to "0" disables the acceptance of all maskable interrupts. Setting to "1" enables the acceptance of interrupts. When an interrupt is accepted, this flag is cleared to "0" to temporarily disable the acceptance of maskable interrupts. After execution of the interrupt service program, this flag is set to "1" by the maskable interrupt return instruction [RETI] to again enable the acceptance of interrupts. If an interrupt request has already been occurred, interrupt service starts immediately after execution of the [RETI] instruction. Pseudo non-maskable interrupts are returned by the [RETN] instruction. In this case, the IMF is set to "1" only when pseudo non-maskable interrupt service is started with interrupt acceptance enabled (IMF = 1). Note that the IMF remains "0" when cleared by the interrupt service program. The IMF is assigned to bit 0 at address $0003A_H$ in the SFR, and can be read and written by an instruction. The IMF is normally set and cleared by the [EI] and [DI] instructions, and the IMF is initialized to "0" during reset. ## ② Individual interrupt Enable Flags (EF<sub>20 to</sub> EF<sub>4</sub>) These flags enable and disable the acceptance of individual maskable interrupts, except for an external interrupt 0. Setting the corresponding bit of an individual interrupt enable flag to "1" enables acceptance of an interrupt, setting the bit to "0" disables acceptance. **3-77-29** 2007-10-23 Figure 1-17. Interrupt Latch (IL) and Interrupt Enable Register (EIR) ### 1.5.1 Interrupt sequence An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to "0" by a reset or an instruction. Interrupt acceptance sequence requires 12 machine cycles (6 $\mu$ s at fc = 8 MHz in the NORMAL mode) after the completion of the current instruction execution. The interrupt service task terminates upon execution of an interrupt return instruction [RETI] (for maskable interrupts) or [RETN] (for pseudo non-maskable interrupts). Figure 1-18 shows the timing chart of interrupt acceptance processing. ### (1) Interrupt acceptance Interrupt acceptance processing is as follows. - ① The interrupt master enable flag (IMF) is cleared to "0" to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled. - ② The interrupt latch (IL) for the interrupt source accepted is cleared to "0". - ③ The contents of the program counter (return address) and the program status word (PSW) are saved (pushed) on the stack in sequence of PSWH, PSWL, PCE, PCH, PCL. The stack pointer (SP) is decremented five times. - The entry address of the interrupt service program is read from the vector table, and set to the program counter. - (5) The RBS control code is read from the vector table. The lower 4-bit of this code is added to the RBS. - © The instruction stored at the entry address of the interrupt service program is executed. Figure 1-18. Timing Chart of Interrupt Acceptance and Interrupt Return Instruction **3-77-31** 2007-10-23 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 occurred. When nested interrupt service is necessary, the IMF is set to "1" in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags. However, an acceptance of external interrupt 0 cannot be disabled by the EF; therefore, if disable is necessary, either the external interrupt function of the $\overline{\text{INTO}}$ pin must be disabled with the INT0EN in the external interrupt control register (EINTCR) (the interrupt latch IL3 is not set at INT0EN = 0, therefore, the rising edge of $\overline{\text{INTO}}$ pin input can not be detected.) or an interrupt processing must be avoided by the program. Example 1: Disables an external interrupt 0 using the INT0EN LD (EINTCR), 00000000B; INT0EN←0 Example 2: Disables the processing of external interrupt 0 under the software control (using bit 0 at address 000F0<sub>H</sub> as the interrupt processing disable switch) PINTO: TEST (000F0H).0; Return without interrupt processing if $(000F0_H)_0 = 1$ JRS T, SINTO RETI SINTO: Interrupt processing **RETI** VINTO: DL PINTO **3-77-32** 2007-10-23 (2) Saving / Restoring general-purpose registers During interrupt acceptance processing, the program counter (PC) and the program status word (PSW) are automatically saved on the stack, but not the accumulator and other registers. These registers are saved by the program if necessary. Also, when nesting multiple interrupt services, it is necessary to avoid using the same data memory area for saving registers. The following method is used to save / restore the general-purpose registers. ① General-purpose register save/restore by automatic register bank changeover The general-purpose registers can be saved at high-speed by switching to a register bank that is not in use. Normally, the bank 0 is used for the main task and the banks 1 to 15 are assigned to interrupt service tasks. To increase the efficiency of data memory utilization, the same bank is assigned for interrupt sources which are not nested. The switched bank is automatically restored by executing an interrupt return instruction [RETI] or [RETN]. Therefore, it is not necessary for a program to save the RBS. Example: Register bank changeover ``` PINTxx: interrupt processing RETI : VINTxx: DP PINTxx DB 1 ; RBS ← RBS + 1 ``` ② General-purpose register save/restore by register bank changeover The general-purpose registers can be saved at high-speed by switching to a register bank that is not in use. Normally, the bank 0 is used for the main task and the banks 1 to 15 are assigned to interrupt service tasks. Example: Register bank changeover ``` PINTxx: LD RBS, n interrupt processing RETI ; Restores bank and Returns : VINTxx: DP PINTxx ; Interrupt sevice routine entry address DB 0 ``` ③ General-purpose registers save / restore using push and pop instructions To save only a specific register, and when the same interrupt source occurs more than once, the general-purpose registers can be saved / restored using the push / pop instructions. Example: Register save / restore using push and pop instructions PINTxx: PUSH WA ; Save WA register pair interrupt processing POP WA ; Restore WA register pair RETI ; Return General-purpose registers save / restore using data transfer instructions Data transfer instruction can be used to save only a specific general-purpose register during processing of single interrupt. Example: Saving / restoring a register using data transfer instructions PINTxx: LD (GSAVA), A ; Save A register interrupt processing | LD A, (GSAVA) ; Restore A register RETI ; Return Figure 1-19. Saving / Restoring General-purpose Registers #### (3) Interrupt return The interrupt return instructions [RETI] / [RETN] perform the following operations. | | [RETI] Maskable interrupt return | [RETN] Non-maskable interrupt return | | | |---|----------------------------------------------------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 1 | The contents of the program counter and the program status word are restored from the stack. | 1 | The contents of the program counter and program status word are restored from the stack. | | | 2 | The stack pointer is incremented 5 times. | 2 | The stack pointer is incremented 5 times. | | | 3 | The interrupt master enable flag is set to "1". | 3 | The interrupt master enable flag is set to "1" only when a non-maskable interrupt is accepted in interrupt enable status. However, the interrupt master enable flag remains at "0" when so clear by an interrupt service program. | | | 4 | The interrupt nesting counter is decremented, and the interrupt nesting flag is changed. | 4 | The interrupt nesting counter is decremented, and the interrupt nesting flag is changed. | | Interrupt requests are sampled during the final cycle of the instruction being executed. Thus, the next interrupt can be accepted immediately after the interrupt return instruction is executed. Note: When the interrupt processing time is longer than the interrupt request generation time, the interrupt service task is performed but not the main task. ## 1.5.2 Software interrupt (INTSW) Executing the [SWI] instruction generates a software interrupt and immediately starts interrupt processing (INTSW is highest prioritized interrupt). However, if processing of a non-maskable interrupt is already underway, executing the SWI instruction will not generate a software interrupt but will result in the same operation as the [NOP] instruction. Use the [SWI] instruction only for detection of the address error or for debugging. Note: To use the SWI instruction for software break in the development tool, software interrupt always generates even if the non-maskable interrupt is in progress. #### Address error detection FF<sub>H</sub> is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address. Code FF<sub>H</sub> is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing FF<sub>H</sub> to unused areas of the program memory. Address-trap reset is generated in case that an instruction is fetched from RAM or SFR areas. ## 2 Debugging Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address. ## 1.5.3 External interrupts The 88CP77/S77/U77 each have six external interrupt inputs (INTO, INT1, INT2, INT3, INT4 and INT5). Four of these are equipped with digital noise rejection circuits (pulse inputs of less than a certain time are eliminated as noise). Edge selection is also possible with INT1, INT2, INT3 and INT4. The INTO/P11 pin can be configured as either an external interrupt input pin or an input/output port, and is configured as an input port during reset. Edge selection, noise rejection control and $\overline{\text{INT0}}/\text{P11}$ pin function selection are performed by the external interrupt control register (EINTCR). When INT0EN = 0, the IL<sub>3</sub> will not be set even if the falling edge of $\overline{\text{INT0}}$ pin input is detected. Table 1-4. External Interrupts | C | Pin | Secondary<br>function pin | Enable<br>conditions | Edge | | | Secondary function pin | |--------|------|---------------------------|-----------------------------------------|------------|------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Source | | | | rising | falling | both | secondary function pill | | INT0 | ĪNT0 | P11/SI1 | IMF = 1<br>INT0EN = 1 | _ | 0 | _ | – (hysteresis input) | | INT1 | INT1 | P04 / OC0 | IMF · EF <sub>5</sub> = 1<br>INT1W = 0 | INT1ES = 0 | INT1ES = 1 | - | For falling or rising edge, pulses of less than 7/fc [s] are eliminated as noise. Pulses of equal to or more than 24/fc [s] are regarded as signals. | | | | | IMF · EF5 = 1<br>INT1W = 1 | - | ı | INT1W = 1<br>(Note 2) | Noise cancellation conditions are as listed in Table 1-5. They are applied to the INT1 pin when it is used for both edge interrupts. | | INT2 | INT2 | P05/TC1 | IMF · EF <sub>7</sub> = 1<br>INT2W = 0 | INT2ES = 0 | INT2ES = 1 | - | For falling or rising edge, pulses of less than 7/fc [s] are eliminated as noise. Pulses of equal to or more than 24/fc [s] are regarded as signals. Same applies to pin TC1 (at one edge) | | | | | IMF · EF <sub>7</sub> = 1<br>INT2W = 1 | - | - | INT2W = 1<br>(Note 2) | Noise cancellation conditions are as listed in Table 1-5. They are applied to the INT2 pin when it is used for both edge interrupts. | | INT3 | INT3 | P06 / OC1 | $IMF \cdot EF_{11} = 1$ $INT3W = 0$ | INT3ES = 0 | INT3ES = 1 | - | For falling or rising edge, pulses<br>less than 7/fc [s] are cancelled as<br>noise. Pulses equal to or more<br>than 24/fc [s] are regarded as<br>signals. | | | | | IMF · EF <sub>11</sub> = 1<br>INT3W = 1 | - | ı | INT3W = 1<br>(Note 2) | Noise cancellation conditions are as listed in Table 1-5. They are applied to the INT3 pin when it is used for both edge interrupts. | | INT4 | INT4 | P07 | IMF · EF <sub>20</sub> = 1<br>INT4W = 0 | INT4ES = 0 | INT4ES = 1 | - | For falling or rising edge, pulses less than 7/fc [s] are cancelled as noise. Pulses equal to or more than 24/fc [s] are regarded as signals. | | | | | IMF · EF <sub>20</sub> = 1<br>INT4W = 1 | - | _ | INT4W = 1<br>(Note 2) | Noise cancellation conditions are as listed in Table 1-5. They are applied to the INT4 pin is used for both edge interrupts. | | INT5 | ĪNT5 | P20/STOP | IMF • EF <sub>15</sub> = 1 | _ | 0 | - | – (hysteresis input) | ``` Note 1: The noise rejection function is turned off for INT1, INT2, INT3 and INT4, used in SLOW and SLEEP modes. Also, the noise reject times are not constant for pulses input while transiting between operating modes (NORMAL2↔SLOW) Note 2: To detect the edge at which an interrupt is generated, read bit 6 (INT1EDT) in EINTCR1, bit 6 (INT2EDT) in EINTCR2, bit 6 (INT3EDT) in EINTCR3 and bit 6 (INT4EDT) in EINTCR4, that is, at the beginning of the interrupt processing routine. INT1EDT, INT2EDT and INT3EDT and INT4EDT are valid only for both-edge interrupts (INT1W = 1, INT2W = 1, INT3W = 1 and INT4W = 1). INT1EDT, INT2EDT, INT3EDT and INT4EDT are set to 1 by an interrupt as the non-selected edge; cleared to 0 after read automatically. When rising edge is selected (INT3ES = 0), bit 6 in INT3EDT is set to 1 when a falling edge is detected at the INT3 pin. (That is, remains 0 if rising edge is detected.) When falling edge is selected (INT3ES = 1), bit 6 in INT3EDT is set to 1 when a rising edge is detected at the INT3 pin. (That is, remains 0 at falling edge.) Note 3: The noise rejection function is also affected for timer/counter input (TC1 pin). Note 4: Noise cancellation/pulse receive conditions for timer/counter are as described below: ① TC1 pin: When the P05 pin is used for TC1 input, INT2W must be cleared to "0". Do not change INT2W to "1". Note 5: If a noiseless signal is input to the external interrupt pin in the NORMAL 1/2 or IDLE 1/2 mode, the maximum time from the edge of input signal until the IL is set is as follows: 1. INT1 pin 25/fc [s] (when INT1W = 0, falling or rising edge) 25/fc [s] (when INT1W = 1, and NCS (0, 0, 0)) (2^{6}/fc) \times 8.5 + 19/fc [s] (when INT1W = 1, and NCS (0, 0, 1)) (2^{7}/fc) \times 8.5 + 19/fc [s] (when INT1W = 1, and NCS (0, 1, 0)) (2^{8}/fc) \times 8.5 + 19/fc [s] (when INT1W = 1, and NCS (0, 1, 1)) (2^{9}/fc) \times 8.5 + 19/fc [s] (when INT1W = 1, and NCS (1, 0, 0)) (2^{10}/fc) \times 8.5 + 19/fc [s] (when INT1W = 1, and NCS (1, 0, 1)) (2^{11}/fc) \times 8.5 + 19/fc [s] (when INT1W = 1, and NCS (1, 1, 0)) (2^{12}/fc) \times 8.5 + 19/fc [s] (when INT1W = 1, and NCS (1, 1, 1)) 2. INT2 pin 25/fc [s] (when INT2W = 0, falling or rising edge) 25/fc [s] (when INT2W = 1, and NCS (0, 0, 0)) (2^{6}/fc) \times 8.5 + 19/fc [s] (when INT2W = 1, and NCS (0, 0, 1)) (2^{7}/fc) \times 8.5 + 19/fc [s] (when INT2W = 1, and NCS (0, 1, 0)) (2^{8}/fc) \times 8.5 + 19/fc [s] (when INT2W = 1, and NCS (0, 1, 1)) (2^{9}/fc) \times 8.5 + 19/fc [s] (when INT2W = 1, and NCS (1, 0, 0)) (2^{10}/fc) \times 8.5 + 19/fc [s] (when INT2W = 1, and NCS (1, 0, 1)) (2^{11}/fc) \times 8.5 + 19/fc [s] (when INT2W = 1, and NCS (1, 1, 0)) (2^{12}/fc) \times 8.5 + 19/fc [s] (when INT2W = 1, and NCS (1, 1, 1)) 3. INT3 pin 25/fc [s] (when INT3W = 0, falling or rising edge) 25/fc [s] (when INT3W = 1, and NCS (0, 0, 0)) (26/fc) \times 8.5 + 19/fc [s] (when INT3W = 1, and NCS (0, 0, 1)) (2^{7}/fc) \times 8.5 + 19/fc [s] (when INT3W = 1, and NCS (0, 1, 0)) (28/fc) \times 8.5 + 19/fc [s] (when INT3W = 1, and NCS (0, 1, 1)) (2^{9}/fc) \times 8.5 + 19/fc [s] (when INT3W = 1, and NCS (1, 0, 0)) (2^{10}/\text{fc}) \times 8.5 + 19/\text{fc} [s] (when INT3W = 1, and NCS (1, 0, 1)) (2^{11}/fc) \times 8.5 + 19/fc [s] (when INT3W = 1, and NCS (1, 1, 0)) (2^{12}/fc) \times 8.5 + 19/fc [s] (when INT3W = 1, and NCS (1, 1, 1)) ``` **3-77-37** 2007-10-23 Table 1-5. Noise reject condition for INT1, INT2, INT3, INT4 (both-edge interrupt) | EINTCR1, EIN | ITCR2, EINTCI | R3, EINTCR4 | max. pulse width | min. pulse width | | |--------------|---------------|-------------|----------------------------------|----------------------------------|--| | NCS2×2 | NCS1 x 1 | NCS0×0 | for noise reject | for immediate signal | | | 0 | 0 | 0 | – (histere | sis input) | | | 0 | 0 | 1 | (2 <sup>6</sup> /fc) ×7 – 6/fc | (2 <sup>6</sup> /fc) ×8 + 5/fc | | | 0 | 1 | 0 | $(2^7/fc) \times 7 - 6/fc$ | (2 <sup>7</sup> /fc) ×8 + 5/fc | | | 0 | 1 | 1 | (28/fc) ×7 – 6/fc | (28/fc) ×8 + 5/fc | | | 1 | 0 | 0 | (2 <sup>9</sup> /fc) ×7 – 6/fc | (2 <sup>9</sup> /fc) ×8 + 5/fc | | | 1 | 0 | 1 | $(2^{10}/fc) \times 7 - 6/fc$ | (2 <sup>10</sup> /fc) × 8 + 5/fc | | | 1 | 1 | 0 | (2 <sup>11</sup> /fc) × 7 – 6/fc | (2 <sup>11</sup> /fc) × 8 + 5/fc | | | 1 | 1 | 1 | $(2^{12}/fc) \times 7 - 6/fc$ | (2 <sup>12</sup> /fc) × 8 + 5/fc | | Note: In SLOW mode, set (NCS $\times$ 2, 1, 0) = (0, 0, 0). In SLOW mode, the digital noise filter in the above table is disabled. **3-77-38** 2007-10-23 Figure 1-20. External Interrupt Control Register (1) ## External Interrupt Control Register 1 EINTCR1 (00024<sub>H</sub>) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------|-------------|---|------|---|-------------|---|---|-----------------|------------| | INT1W | INT1<br>EDT | | NCS1 | | INT1<br>EDT | | | (initial value: | 0000 00**) | | INT1W | INT1 both edge selection | 0: Refer to INT1ES 1: Both edge detection | R/W | |---------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | INT1EDT | Flag indicating an interrupt at<br>selected edge/non-selected<br>edge, when INT1W = 1 (for<br>both-edge interrupts) | 0: Interrupt at selected edge or no interrupt<br>1: Interrupt at non-selected edge | R | | NCS1 | Noise cancellation time select<br>for INT1 digital noise filter<br>(valid only when INT1W = 1) | 000: No noise cancellation 001: Cancels $(2^6/fc \times 7 - 6/fc)$ as noise. 010: Cancels $(2^7/fc \times 7 - 6/fc)$ as noise. 011: Cancels $(2^8/fc \times 7 - 6/fc)$ as noise. 100: Cancels $(2^9/fc \times 7 - 6/fc)$ as noise. 101: Cancels $(2^9/fc \times 7 - 6/fc)$ as noise. 110: Cancels $(2^{10}/fc \times 7 - 6/fc)$ as noise. 111: Cancels $(2^{11}/fc \times 7 - 6/fc)$ as noise. 111: Cancels $(2^{12}/fc \times 7 - 6/fc)$ as noise. | R/W | | INT1DET | INT1 interrupt detection flag | 0: No interrupt<br>1: Interrupt | R | Note 1: INT1EDT and NCS1 are valid only when the INT1W bit in EINTCR1 is set to 1. Therefore, when INT1W = 0, the digital noise filter set by the NCS1 bit is disabled. Note 2: Do not changing the contents of INT1ES (bit 1 in EINTCR) when INT1W is set to 1 (both-edge detention). If changing the contents of INT1ES during INT1W is set to 1, according to Note 3/4/5 at Figure 1-20 (1). External Interrupt Control Register 2 EINTCR2 (00025<sub>H</sub>) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------|-------------|---|------|---|-------------|---|---|-----------------|------------| | INT2W | INT2<br>EDT | | NCS2 | | INT2<br>FDT | | | (initial value: | 0000 00**) | | INT2W | INT2 both edge selection | 0: Refer to INT2ES 1: Both edge detection | R/W | |---------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | INT2EDT | Flag indicating an interrupt at<br>selected edge/non-selected<br>edge, when INT2W = 1 (for<br>both-edge interrupts) | 0: Interrupt at selected edge or no interrupt 1: Interrupt at non-selected edge | R | | NCS2 | Noise cancellation time select<br>for INT2 digital noise filter<br>(valid only when INT2W = 1) | 000: No noise cancellation 001: Cancels $(2^6/fc \times 7 - 6/fc)$ as noise. 010: Cancels $(2^7/fc \times 7 - 6/fc)$ as noise. 011: Cancels $(2^8/fc \times 7 - 6/fc)$ as noise. 100: Cancels $(2^9/fc \times 7 - 6/fc)$ as noise. 101: Cancels $(2^9/fc \times 7 - 6/fc)$ as noise. 110: Cancels $(2^{10}/fc \times 7 - 6/fc)$ as noise. 111: Cancels $(2^{11}/fc \times 7 - 6/fc)$ as noise. 111: Cancels $(2^{12}/fc \times 7 - 6/fc)$ as noise. | R/W | | INT2DET | INT2 interrupt detection flag | 0: No interrupt<br>1: Interrupt | R | Note 1: INT2EDT and NCS2 are valid only when the INT2W bit in EINTCR2 is set to 1. Therefore, when INT2W = 0, the digital noise filter set by the NCS2 bit is disabled. Note 2: Do not changing the contents of INT2ES (bit 2 in EINTCR) when INT2W is set to 1 (both-edge detention). If changing the contents of INT2ES during INT2W is set to 1, according to Note 3/4/5 at Figure 1-20 (1). External Interrupt Control Register 3 EINTCR3 (00026<sub>H</sub>) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------|-------------|---|------|---|-------------|---|---|-----------------|------------| | INT3W | INT3<br>EDT | | NCS3 | | INT3<br>EDT | | | (initial value: | 0000 00**) | | INT3W | INT3 both edge selection | 0: Refer to INT3ES 1: Both edge detection | R/W | |---------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | INT3EDT | Flag indicating an interrupt at<br>selected edge/non-selected<br>edge, when INT3W = 1 (for<br>both-edge interrupts) | 0: Interrupt at selected edge or no interrupt 1: Interrupt at non-selected edge | R | | NCS3 | Noise cancellation time select<br>for INT3 digital noise filter<br>(valid only when INT3W = 1) | 000: No noise cancellation 001: Cancels $(2^6/fc \times 7 - 6/fc)$ as noise. 010: Cancels $(2^7/fc \times 7 - 6/fc)$ as noise. 011: Cancels $(2^8/fc \times 7 - 6/fc)$ as noise. 100: Cancels $(2^9/fc \times 7 - 6/fc)$ as noise. 101: Cancels $(2^9/fc \times 7 - 6/fc)$ as noise. 110: Cancels $(2^{10}/fc \times 7 - 6/fc)$ as noise. 111: Cancels $(2^{11}/fc \times 7 - 6/fc)$ as noise. 111: Cancels $(2^{12}/fc \times 7 - 6/fc)$ as noise. | R/W | | INT3DET | INT3 interrupt detection flag | 0: No interrupt<br>1: Interrupt | R | Note 1: INT3EDT and NCS3 are valid only when the INT3W bit in EINTCR3 is set to 1. Therefore, when INT3W = 0, the digital noise filter set by the NCS3 bit is disabled. Note 2: Do not changing the contents of INT3ES (bit 3 in EINTCR) when INT3W is set to 1 (both-edge detention). If changing the contents of INT3ES during INT3W is set to 1, according to Note 3/4/5 at Figure 1-20 (1). External Interrupt Control Register 4 EINTCR4 (00027<sub>H</sub>) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------|-------------|---|------|---|-------------|---|---|-----------------|------------| | INT4W | INT4<br>EDT | | NCS4 | 1 | INT4<br>EDT | | | (initial value: | 0000 00**) | | INT4W | INT4 both edge selection | 0: Refer to INT4ES 1: Both edge detection | R/W | |---------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | INT4EDT | Flag indicating an interrupt at<br>selected edge/non-selected<br>edge, when INT4W = 1 (for<br>both-edge interrupts) | 0: Interrupt at selected edge or no interrupt<br>1: Interrupt at non-selected edge | R | | NCS4 | Noise cancellation time select<br>for INT4 digital noise filter<br>(valid only when INT4W = 1) | 000: No noise cancellation 001: Cancels (26/fc × 7 – 6/fc) as noise. 010: Cancels (27/fc × 7 – 6/fc) as noise. 011: Cancels (28/fc × 7 – 6/fc) as noise. 100: Cancels (29/fc × 7 – 6/fc) as noise. 101: Cancels (210/fc × 7 – 6/fc) as noise. 110: Cancels (211/fc × 7 – 6/fc) as noise. 111: Cancels (212/fc × 7 – 6/fc) as noise. | R/W | | INT4DET | INT4 interrupt detection flag | 0: No interrupt<br>1: Interrupt | R | Note 1: INT4EDT and NCS4 are valid only when the INT4W bit in EINTCR4 is set to 1. Therefore, when INT4W = 0, the digital noise filter set by the NCS4 bit is disabled. Note 2: Do not changing the contents of INT4ES (bit 4 in EINTCR) when INT4W is set to 1 (both-edge detention). If changing the contents of INT4ES during INT4W is set to 1, according to Note 3/4/5 at Figure 1-20 (1). Figure 1-21. External Interrupt Control Register (2) #### 1.6 Reset Circuit The 88CP77/S77/U77 have 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-6 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/fc [s] (3 $\mu$ s at 8 MHz) when power is turned on. | On-chip hardware | | Initial value | On-chip hardwear | Initial value | | |---------------------------------|--------|---------------------------------------------|---------------------------------|-------------------|--| | Program counter | (PC) | (FFFFE <sub>H</sub> to FFFFC <sub>H</sub> ) | | | | | Stack pointer | (SP) | not initialized | Prescaler and Divider of timing | 0 | | | General-purpose registers | | not initialized | generator | " | | | (WABC | CDEHL) | | | | | | Register bank selector | (RBS) | 0 | \M/atshdag timer | Enable | | | Jump status flag | (JF) | 1 | Watchdog timer | Enable | | | Zero flag | (ZF) | not initialized | | | | | Carry flag | (CF) | not initialized | | | | | Half carry flag | (HF) | not initialized | Output latabas of I/O same | Refer to I/O port | | | Sign flag | (SF) | not initialized | Output latches of I/O ports | circuitry | | | Overflow flag | (VF) | not initialized | | | | | Interrupt master enable flag | (IMF) | 0 | | | | | Interrupt individinal enable fl | ags | 0 | | Refer to each of | | | | (EF) | | Control registers | | | | Interrut latchs | (IL) | 0 | | control register | | Table 1-6. Initializing Internal Status by Reset Action ## 1.6.1 External reset input The RESET pin contains a Schmitt trigger (hysteresis) with an internal pull-up resistor. When the RESET pin is held at "L" level for at least 3 machine cycles (12/fc [s]) with the power supply voltage within the operating voltage range and oscillation stable, a reset is applied and the internal state is initialized. When the RESET pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFFC to FFFFE<sub>H</sub>. Figure 1-22. Reset Circuit 3-77-42 ### 1.6.2 Address-trap-reset If the CPU should start looping for some cause such as noise and an attempt be made to fetch an instruction from the on-chip RAM or the SFR area, an address-trap-reset will be generated. Then, the $\overline{\text{RESET}}$ pin output will go low. The reset time is about 8/fc to 24/fc [s] (1 to 3 $\mu$ s at 8 MHz). Figure 1-23. Address-Trap-Reset ## 1.6.3 Watchdog timer reset Refer to Section "2.4 Watchdog Timer". ## 1.6.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 XEN 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 is detected to continue the oscillation. Then, the RESET pin output goes low from high-impedance. The reset time is about 8/fc to 24/fc [s] (1 to 3 $\mu$ s at 8 MHz). **3-77-43** 2007-10-23 ## 2. On-Chip Peripheral Functions ## 2.1 Special Function Registers (SFR) The 88CP77/S77/U77 use the memory mapped I/O system, and all peripheral control and data transfers are performed through the special function registers (SFR). The SFR are mapped to addresses $00000_H$ to $0003F_H$ , and DBR are mapped to address $00F00_H$ to $00FFF_H$ . Figure 2-1. shows the 88CP77/S77/U77 SFR, DBR. | ddress | Read | Write | Address | Read | Write | | |--------------------|-------------------------------------------------------|-------------------------------------------------------|--------------------|---------------------------------------------|---------------------------------------------------|--| | 00000 <sub>H</sub> | P0 port | (write) | 00020 <sub>H</sub> | - SBICR1 (SBI control 1) | | | | 01 | P1 ; | oort | 21 | SBIDBR ( | SBI data buffer) | | | 02 | P2 <sub>I</sub> | oort | 22 | _ | I <sup>2</sup> CAR (I <sup>2</sup> C bus address) | | | 03 | P3 ; | oort | 23 | SBRSR (SBI status register) | SBICR2 (SBI control 2) | | | 04 | P4 p | oort | 24 | | nal interrupt control 1) | | | 05 | P5 p | oort | 25 | ENTCR2 (Extern | nal interrupt control 2) | | | 06 | P6 r | oort | 26 | ENTCR3 (Extern | nal interrupt control 3) | | | 07 | P7 p | oort | 27 | ENTCR4 (Extern | nal interrupt control 4) | | | 08 | P8 ; | oort | 28 | SIO1SR (SIO1 status register) | SIO1CR1 (SIO1 control 1) | | | 09 | P9 p | oort | 29 | _ | SIO1CR2 (SIO1 control 2) | | | 0A | P3CR (P3 port I/C | output control) | 2A | VFTSR (VFT status register) | VFTCR1 (VFT control 1) | | | 0B | P1CR (P1 port I/C | output control) | 2B | - | VFTCR2 (VFT control 2) | | | 0C | P4CR (P4 port I/C | output control) | 2C | EIR <sub>E</sub> (Internal enable regoster) | | | | 0D | P5CR (P5 port I/C | output control) | 2D | r | eserved | | | 0E | ADCCR (AD cor | verter control) | 2E | IL <sub>E</sub> (in | terrupt latch) | | | 0F | ADCDR (AD conv.result) | - | 2F | r | eserved | | | 10 | P0 port (read) | _ | 30 | DVCR (DV1 control) | | | | 11 | rese | rved | 31 | r | eserved | | | 12 | TREG1B <sub>L</sub> (Timer register 1B <sub>L</sub> ) | <del>-</del> | 32 | r | eserved | | | 13 | TREG1B <sub>H</sub> (Timer register 1B <sub>H</sub> ) | - | 33 | r | eserved | | | 14 | - | TC1CR (TC1 control) | 34 | - | WDTCR1 (Watch dog timer control 1) | | | 15 | - | TC2CR (TC2 control) | 35 | - | WDTCR2 (Watch dog timer control 2) | | | 16 | - | TREG1A <sub>L</sub> (Timer register 1A <sub>L</sub> ) | 36 | TBTCR (TBT | /TG/DVO control) | | | 17 | - | TREG1A <sub>H</sub> (Timer register 1A <sub>H</sub> ) | 37 | EINTCR (Exter | nal interrupt control) | | | 18 | - | TREG2 <sub>L</sub> (Timer register 2 <sub>L</sub> ) | 38 | SYSCR1 (S | System control 1) | | | 19 | - | TREG2 <sub>H</sub> (Timer register 2 <sub>H</sub> ) | 39 | SYSCR2 (S | System control 2) | | | 1A | rese | rved | 3A | EIR, (Interrupt enable register) | | | | 1B | | TREG4 ( Timer register 4) | 3B | EIR <sub>H</sub> (Interru | upt enable register) | | | 1C | | TC4CR (TC4 control) | 3C | IL <sub>L</sub> (In | ternal latch) | | | 1D | PDı | port | 3D | IL <sub>H</sub> (Ir | nternal latch) | | | 1E | PE | oort | 3E | PSW <sub>1</sub> (Pro | gram status word) | | | 1F | PF | oort | 3E | PSW <sub>□</sub> (Pro | gram status word) | | ## (a) Special function registers Note 1: Do not access reserved areas by the program. Note 2: -; Cannot be accessed. Note 3: Write-only registers and interrupt latches cannot use the read-modify-write instructions (bit manipulation instructions such as SET, CLR, etc. and logical operation instructions such as AND, OR, etc.). Note 4: When defining address $0003F_H$ with assembler symbols, use GRBS. Address $0003E_H$ must be GPSW/GFLAG. Figure 2-1. (a) SFR & DBR | 00Fxy | | | | | | | | | |-------|--------|--------|----------|-------------|---------------------------------------|---------------------------------------------------------|----------------------------------|----------| | X | 0 to 1 | 2 to 3 | 4 to 5 | 6 to 7 | 8 to 9 | A to B | C to D | E to F | | 0 | 00F00 | 00F20 | 00F40 | 00F60 | 00F80 | 00FA0 | 00FC0 | 00FE0 | | 1 | 00F01 | | | • | | • | • | | | 2 | 00F02 | | | | | | | | | 3 | 00F03 | | | | | | | | | 4 | 00F04 | | | | | | | | | 5 | 00F05 | | | | | | | | | 6 | 00F06 | | | | | | | | | 7 | 00F07 | | | | VFT | | | | | 8 | 00F08 | | | | display data b | ouffer | | SIO0 | | 9 | 00F09 | | | | (126 byte | e) | | transmit | | Α | 00F0A | | | | | | | data | | В | 00F0B | | | | | | | buffer | | С | 00F0C | | | | | | | (32 byte | | D | 00F0D | | | | | | | | | Е | 00F0E | | | | | | | | | F | 00F0F | | | | | | | | | 0 | 00F10 | | | | | | | | | 1 | 00F11 | | : | !<br>!<br>! | | <br> | | | | 2 | 00F12 | 00F32 | 00F52 | 00F72 | 00F92 | 00FB2 | 00FD2 | | | 3 | 00F13 | | | | | Read Write | • | | | 4 | 00F14 | | | | | OCRO <sub>L</sub> | | | | 5 | 00F15 | | | | | (Compare regoster 0 <sub>L</sub> ) OCR0 <sub>H</sub> | " | | | 6 | 00F16 | | | | | (Compare regoster 0 <sub>H</sub> )<br>OCR1 <sub>1</sub> | Read Write SIO0SR SIO0CR1 | | | | | | | | | (Compare regoster 1 <sub>L</sub> ) | (SIO0 status) (SIO0 control1) | | | 7 | 00F17 | | | | | OCR1 <sub>H</sub><br>(Compare regoster 1 <sub>H</sub> ) | reserved SIO0CR2 (SIO0 control2) | | | 8 | 00F18 | | | | | ICROA <sub>L</sub> – (Capter register) – | (SIOU control2) | | | 9 | 00F19 | | reserved | | | ICROA <sub>H</sub> – | | | | Α | 00F1A | | | | | ICR0B <sub>L</sub> | ···] | | | В | 00F1B | | | | Read Write | ICR0B <sub>H</sub> | <br>SIO1 | | | С | 00F1C | | | | (ETC1 control)<br>TMEN | (Capter register) —<br>ICR1A <sub>L</sub> | transmit data buffer | | | | | | | | (Timer channel | (Capter register) _ | (8 byte) | | | D | 00F1D | | | | enable register)<br>TMD | ICR1A <sub>H</sub> | | | | | 00115 | | | | (Capture mode register) | (Capter register) _ | | | | Е | 00F1E | | | | ETREG1 <sub>L</sub> – (Extended timer | ICR1B <sub>L</sub> (Capter register) _ | ·· <b> </b> | | | | | | | | register 1 <sub>L</sub> ) | | | | | F | 00F1F | | | | ETREG1 <sub>H</sub> | ICR1B <sub>H</sub> | ·· | | | | l i | | ! | ! | – (Extended timer | (Capter register) _ | | | Note 1: Do not access reserved areas by the program. Note 2: -; Cannot be accessed. Figure 2-1. (b) SFR & DBR #### 2.2 **I/O Ports** The 88CP77/S77/U77 each have 13 parallel input/output ports (88 pins) each as follows: | 1 | Port P0 | 8-bit I/O port | Serial bus interface input/output, Extended timer/counter input/output, timer/counter input and External interrupt input | |-----|---------|----------------|--------------------------------------------------------------------------------------------------------------------------| | 2 | Port P1 | 8-bit I/O port | External interrupt input, serial interface input/output, timer/counter input/output, and divider output | | 3 | Port P2 | 3-bit I/O port | Low-frequency resonator connections, external interrupt input, and STOP mode release signal input | | 4 | Port P3 | 3-bit I/O port | | | 5 | Port P4 | 8-bit I/O port | Anarog input | | 6 | Port P5 | 4-bit I/O port | Anarog input | | 7 | Port P6 | 8-bit I/O port | VFT output | | 8 | Port P7 | 8-bit I/O port | VFT output | | 9 | Port P8 | 8-bit I/O port | VFT output | | 10 | Port P9 | 8-bit I/O port | VFT output | | 11) | Port PD | 8-bit I/O port | VFT output | | 12 | Port PE | 8-bit I/O port | VFT output | | 13 | Port PF | 5-bit I/O port | VFT output | Each output port contains a latch, which holds the output data. Input ports excluding do not have latches, so the external input data should either be held externally until read or reading should be performed several times before processing. Figure 2-2 shows input/output timing examples. External data is read from an I/O port in the S1 state of the read cycle during execution of the read instruction. This timing can not be recognized from outside, so that transient input such as chattering must be processed by the program. Output data changes in the S2 state of the write cycle during execution of the instruction which writes to an I/O port. Figure 2-2. Input/Output Timing (Example) When reading an I/O port except programmable I/O ports P1, P3, P4 and P5, whether the pin input data or the output latch contents are read depends on the instructions, as shown below: - (a) Instructions that read the output latch contents - ① XCH r, (src) - 6 XCH CF, (src), b - ② CLR/SET/CPL (src).b - ⑦ ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), n - ③ CLR/SET/CPL (pp).g - (src) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) - 4 LD (src).b, CF - 9 MXOR (src), n - ⑤ LD (pp).b,CF - (b) Instructions that read the pin input data - ① (HL) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) Port P0 has P0 read register and P0 write register. Port P0 can select the pin input data or the output latch contents by reading each registers. ## 2.2.1 Port P0 (P07 to P00) Port P0 is an 8-bit input/output port, and is also used as external interrupt input, a serial bus interface input/output, a timer/counter input and extended timer/counter. When used as an input port or a secondary function pin, the output latch should be set to "1". The output latches are initialized to "1" during reset. Port P0 has P0 read register and P0 write register. Port P0 can select the pin input data or the output latch contents by reading each registers. Figure 2-3. Port P0 and P0CR The terminal of Sink open drain port needs to set it as follows. Note1: Set output latch to "0" when an unused port is open. Note2: An input level of an input which is assigned as input should be kept high or low level in all operation mode. Note3: Output level is kept during STOP mode. Set output latch to "0" before changing to the STOP mode in case cutting off power supply which is connected as pulls up a voltage level of the port through register. **3-77-47** 2007-10-23 ## 2.2.2 Port P1 (P17 to P10) Port P1 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P1 input/output control register (P1CR). Port P1 is configured as an input if its corresponding P1CR bit is cleared to "0", and as an output if its corresponding P1CR bit is set to "1". During reset, P1CR is initialized to "0", which configures port P1 as an input. The P1 output latches are also initialized to "0". Data is written into the output latch regardless of P1CR contents. Therfore initial output data should be written into the output latch before setting P1CR. Port P1 is also used as a serial interface input/output, an external interrupt input, a timer/counter input, and a divider output. When used as a secondary function pin, the input pins should be set to the input mode, and the output pins should be set to the output mode and beforehand the output latch should be set to "1". Note: Port set to the input mode read the pin status. When input pin and output in exist in port P1 together, the contents of the output latch of ports set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch. Figure 2-4. Port P1 and P1 I/O control register The terminal of Tri-state port needs to set it as follows. Note1: When an unused port is open, change the port mode to "output" after setting the output latch high or low. Note2: An input level of an input which is assigned as input should be kept high or low level in all operation mode. **3-77-48** 2007-10-23 ## 2.2.3 Port P2 (P22 to P20) Port P2 is a 3-bit input/output port. It is also used as an external interrupt input, and low-frequency crystal connection pins. When used as an input port, or the secondary function pin, the output latch should be set to "1". During reset, the output latches are initialized to "1". A low-frequency crystal (32.768 kHz) is connected to pins P21 (XTIN) and P22 (XTOUT) in the dual-clock mode. In the single-clock mode, pins P21 and P22 can be used as normal input/output ports. It is recommended that the P20 pin should be used as an external interrupt input, a STOP mode release signal input, or an input port. If used as an output port, the interrupt latch is set on the falling edge of the output pulse. When a read instruction for port P2 is executed, bits 7 to 3 in P2 read in as undefined data. Figure 2-5. Port P2 The terminal of Sink open drain port needs to set it as follows. Note1: Set output latch to "0" when an unused port is open. Note2: An input level of an input which is assigned as input should be kept high or low level in all operation mode. Note3: Output level is kept during STOP mode. Set output latch to "0" before changing to the STOP mode in case cutting off power supply which is connected as pulls up a voltage level of the port through register. **3-77-49** 2007-10-23 ### 2.2.4 Port P3 (P33 to P30) Port P3 is an 4-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P3 input/output control register (P3CR). Port P3 is configured as an input if its corresponding P3CR bit is cleared to "0", and as an output if its corresponding P3CR bit is set to "1". During reset, P3CR is initialized to "0", which configures port P3 as an input. The P3 output latches are also initialized to "0". Data is written into the output latch regardless of P3CR contents. Therefore initial output data should be written into the output latch before setting P3CR. When a read instruction for port P3 is executed, bit7 to 4 in P3 read in as undefined data. Note: Port set to the input mode read the pin status. When input pin and output in exist in port P3 together, the contents of the output latch of ports set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch. Figure 2-6. P3 and Port P3 I/O control register The terminal of Tri-state port needs to set it as follows. Note1: When an unused port is open, change the port mode to "output" after setting the output latch high or low. Note2: An input level of an input which is assigned as input should be kept high or low level in all operation mode. **3-77-50** 2007-10-23 ## 2.2.5 Port P4 (P47 to P40) Ports P4 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P4 input/output control register (P4CR). Port P4 is also used as an analog input for the AD converter. When used as an analog input, AINDS (bit 4 in the ADCCR) must be cleared to "0" and its corresponding P4CR bit must be set to "1". In this case, unuse pin as analog input is configured as only input port. During reset, AINDS is initialized to "0" and all bits of P4CR are initialized to "1", which configures port P4 as analog input. The P4 output latches are initialized to "0". Data is written into the output latch regardless of the P4CR contents. Therefore initial output data should be written into the output latch before setting P4CR. Note: Port set to the input mode read the pin status. When input pin and output in exist in port P4 together, the contents of the output latch of ports set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch. Figure 2-7. P4 and Port P4 control register The terminal of Tri-state port needs to set it as follows. Note1: When an unused port is open, change the port mode to "output" after setting the output latch high or low. Note2: An input level of an input which is assigned as input should be kept high or low level in all operation mode. **3-77-51** 2007-10-23 ### 2.2.6 Port P5 (P53 to P50) Ports P5 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P5 input/output control register (P5CR). Port P5 is also used as an analog input for the AD converter. When used as an analog input, AINDS (bit 4 in the ADCCR) must be cleared to "0" and its corresponding P5CR bit must be set to "1". In this case, unuse pin as analog input is configured as only input port. During reset, AINDS is initialized to "0" and all bits of P5CR are initialized to "1", which configures port P5 as analog input. The P5 output latches are initialized to "0". Data is written into the output latch regardless of the P5CR contents. Therefore initial output data should be written into the output latch before setting P5CR. When a read instruction for port P5 is executed, bit7 to 4 in P5 read in as undefined data. Note: Port set to the input mode read the pin status. When input pin and output in exist in port P5 together, the contents of the output latch of ports set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch. Figure 2-8. P5 and Port P5 I/O control register The terminal of Tri-state port needs to set it as follows. Note1: When an unused port is open, change the port mode to "output" after setting the output latch high or low. Note2: An input level of an input which is assigned as input should be kept high or low level in all operation mode. **3-77-52** 2007-10-23 ## 2.2.7 Port 6 (P67 to P60), P7 (P77 to P70), P8 (P87 to P80), P9 (P97 to P90) Port P6, P7, P8 and P9 are an 8-bit high-breakdown voltage input / output port, and also used as a VFT driver output, which can directly drive vacuum fluorescent tube (VFT). When used as an VFT driver output, the output latch should be cleared to "0". Pins not used for VFT driver output can be used as I/O ports. When use an VFT driver and normal input / output at the same time, VET driver output data buffer memory (DBR) need to cleared to "0". The output latches are initialized to "0" during reset. It recommends that port P6, P7, P8 and P9 shoud be used to drive directly drive vacuum fluorescent tube (VFT), since this port has a pull down resistance. Figure 2-9. P6, P7, P8, P9 ports The terminal of Source open drain port needs to set it as follows. Note: When an unused port is open, clear corresponding DBR data for the port to "0" and set the output latch to "0". Vkk needs to be tied to power supply in this case. **3-77-53** 2007-10-23 ## 2.2.8 PD (PD7 to PD0), PE (PE7 to PE0), PF (PF4 to PF0) Port PD, PE and PF are high-breakdown voltage input / output port, and also used as a VFT driver output, which can directly drive vacuum fluorescent tube (VFT). General-purpose or segment can be selected for each bit by VSEL (bit 4 to 0) in VFT driver control register 1 (VFTCR1). The VSEL is cleared to "0" during reset, which used as an input mode. When used as an input port or VFT driver output, the output latch set to "0". The output latches are initialized to "0" during reset. When a read instruction for port PF is executed bit 7 to 5 in PF read in as undefined data. Figure 2-10. PD, PE, PF Ports The terminal of Source open drain port needs to set it as follows. Note: When an unused port is open, clear corresponding DBR data for the port to "0" and set the output latch to "0". Vkk needs to be tied to power supply in this case. When the port without built-in Rk pull-down register is not used, clear corresponding DBR data for the port to "0", set the output latch to "0" and apply the GND level to the port. **3-77-54** 2007-10-23 ## 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 rising 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-11.(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-11. Time Base Timer Example: Sets the time base timer frequency to fc/216 [Hz] and enables an INTTBT interrupt. LD (TBTCR), 00000010B LD (TBTCR), 00001010B SET (EIRL). 6 | <b>TBTCR</b> (00036 <sub>H</sub> ) | 7<br>(DVOEN) | 6 5 4 3<br>(DVOCK) (DV7CK) TBTEN | 2 1<br>, <sup>TBTCK</sup> , | 0 (1 | nitial value: | 0**0 0***) | | | | |------------------------------------|--------------|----------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----| | | TBTEN | Time base timer enable / disable | 0: Dis<br>1: Ena | | | | | | | | | | | | | ORMAL1/2,<br>CK = 0 | IDLE1/2 mod<br>DV7C | | SLOW,<br>SLEEP | | | | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | mode | | | | ТВТСК | Time base timer interrupt<br>frequency select [Hz] | 000<br>001<br>010<br>011<br>100<br>101 | fc/2 <sup>23</sup><br>fc/2 <sup>21</sup><br>fc/2 <sup>16</sup><br>fc/2 <sup>14</sup><br>fc/2 <sup>13</sup><br>fc/2 <sup>12</sup><br>fc/2 <sup>11</sup> | fc/2 <sup>24</sup><br>fc/2 <sup>22</sup><br>fc/2 <sup>17</sup><br>fc/2 <sup>15</sup><br>fc/2 <sup>14</sup><br>fc/2 <sup>13</sup><br>fc/2 <sup>12</sup> | fs/2 <sup>15</sup><br>fs/2 <sup>13</sup><br>fs/2 <sup>8</sup><br>fs/2 <sup>6</sup><br>fs/2 <sup>5</sup><br>fs/2 <sup>4</sup><br>fs/2 <sup>3</sup> | fs/2 <sup>15</sup><br>fs/2 <sup>13</sup><br>fs/2 <sup>8</sup><br>fs/2 <sup>6</sup><br>fs/2 <sup>5</sup><br>fs/2 <sup>4</sup><br>fs/2 <sup>3</sup> | fs / 2 <sup>15</sup><br>fs / 2 <sup>13</sup><br>-<br>-<br>-<br>-<br>- | R/W | | | | | 111 | fc / 2 <sup>9</sup> | fc / 2 <sup>10</sup> | fs / 2 | fs/2 | - | | | • | Note ; fc; F | High-frequency clock [Hz], fs ; | Low-frequ | ency clock [l | Hz], * ; do | n't care | | | | Figure 2-12. Time Base Timer Control Register Table 2-1. Time Base Timer Interrupt Frequency (Example; fc = 8 MHz, fs = 32.768 kHz) | | Time base timer interrupt frequency [Hz] | | | | | | | |---------|------------------------------------------|------------|--------------|-----------|-------------|--|--| | твтск [ | | NORMAL1/2, | IDLE1/2 mode | | SLOW, SLEEP | | | | I TOTAL | DV70 | CK = 0 | DV70 | CK = 1 | mode | | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | mode | | | | 000 | 0.95 | 0.48 | 1 | 1 | 1 | | | | 001 | 3.81 | 1.91 | 4 | 4 | 4 | | | | 010 | 122.07 | 61.04 | 128 | 128 | _ | | | | 011 | 488.28 | 244.14 | 512 | 512 | _ | | | | 100 | 976.56 | 488.28 | 1024 | 1024 | _ | | | | 101 | 1953.13 | 976.56 | 2048 | 2048 | _ | | | | 110 | 3906.25 | 1953.13 | 4096 | 4096 | _ | | | | 111 | 15625.00 | 7812.50 | 16384 | 16384 | _ | | | **3-77-56** 2007-10-23 ## 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 pseudo 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. ## 2.4.1 Watchdog timer configuration Figure 2-13. Watchdog Timer Configuration #### 2.4.2 Watchdog timer control Figure 2-14 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 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 drives the $\overline{\text{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. Figure 2-14. 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. Example: Enables watchdog timer ## (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". Example: Disables watchdog timer LDW (WDTCR1), 0B101H ; WDTEN←0, WDTCR2←Disable code Table 2-2. Watchdog Timer Detection Time (Example: fc = 8 MHz, fs = 32.768 kHz) | | Watchdog timer detection time [s] | | | | | | | |-------|-----------------------------------|-----------|-----------|-----------|--------|--|--| | WDTT | | | | | | | | | I *** | DV7C | DV7CK = 0 | | DV7CK = 1 | | | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | | | | | 00 | 4.194 | 8.389 | 4 | 4 | 4 | | | | 01 | 1.048 | 2.097 | 1 | 1 | 1 | | | | 10 | 262.144 m | 524.288 m | 250 m | 250 m | 250 m | | | | 11 | 65.536 m | 131.072 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 drives the $\overline{\text{RESET}}$ pin (sink open drain input / output with pull-up) low to reset the internal hardware and external circuits. The reset output time is about 8/fc to 24/fc [s] (1 to 3 $\mu$ s at fc = 8 MHz, fcgck = fc). 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/fc to 24/fc [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-15. Watchdog Timer Interrupt / Reset ## 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 (DVO). The P13 output latch should be set to "1" and then the P13 should be configured as an output mode. Figure 2-16. Divider Output Control Register Example: 976 Hz pulse output (at fc = 8 MHz, DV1CK = 0, DV7CK = 0, ) SET (P1).4 ; P14 output latch←1 LD (P1CR), 00010000B ; Configures P14 as an output mode LD (TBTCR), 10000000B ; DVOEN $\leftarrow$ 1, DVOCK $\leftarrow$ 00 Table 2-3. Divider Output Frequency (Example: at fc = 8 MHz, fs = 32.768 kHz) | | Divider output frequency [kHz] | | | | | | | |-------|--------------------------------|-------------|-----------|-----------|-------|--|--| | DVOCK | | SLOW, SLEEP | | | | | | | | DV7CK = 0 | | DV7C | · · | | | | | | DV1CK = 0 | DV1CK = 1 | DV1CK = 0 | DV1CK = 1 | mode | | | | 00 | 0.976 | 0.488 | 1.024 | 1.024 | 1.024 | | | | 01 | 1.953 | 0.976 | 2.048 | 2.048 | 2.048 | | | | 10 | 3.906 | 1.953 | 4.096 | 4.096 | 4.096 | | | | 11 | 7.812 | 3.906 | 8.192 | 8.192 | 8.192 | | | Figure 2-17. Divider Output # 2.6 16-bit Timer / Counter 1 (TC1) # 2.6.1 Configuration **3-77-61** 2007-10-23 #### 2.6.2 Control The timer / counter 1 is controlled by a timer / counter 1 control register (TC1CR) and two 16-bit timer registers (TREG1A and TREG1B). Reset does not affect TREG1A and TREG1B. Figure 2-19. Timer Registers and TC1 Control Register 3-77-62 2007-10-23 #### 2.6.3 Function Timer / counter 1 has five operating modes: timer, external trigger timer, event counter, window, pulse width measurement. #### (1) Timer mode In this mode, counting up is performed using the internal clock. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0". Counting up resumes after the counter is cleared. The current contents of up-counter can be transferred to TREG1B by setting SCAP1 (bit 6 in TC1CR) to "1" (software capture function). SCAP1 is automatically cleared after capturing. Table 2-4. Source Clock (internal clock) for Timer / Counter 1 (Example: at fc = 8 MHz, fs = 32.768 kHz) | | NORMAL1/2, IDLE1/2 mode | | | | | | | | | |-------|-------------------------|--------------|------------|--------------|------------|--------------|---------------|--------------|--| | | | DV70 | K = 0 | | | DV7CK = 1 | | | | | TC1CK | CK DV1CK = 0 DV1CK = 1 | | CK = 1 | DV1CK = 0 | | DV1CK = 1 | | | | | 1 | Resolution | Maximum | Resolution | Maximum | Resolution | Maximum | Resolution | Maximum | | | | [μs] | time setting | [μs] | time setting | [µs] | time setting | [ <i>μ</i> s] | time setting | | | 00 | 256.00 | 16.77 | 512.00 | 33.55 | 244.14 | 16.0 | 244.14 | 16.0 | | | 01 | 16.00 | 1.04 | 32.00 | 2.09 | 16.00 | 1.04 | 32.00 | 2.09 | | | 10 | 1.00 | 65.53 m | 2.00 | 131.07 m | 1.00 | 65.53 m | 2.00 | 131.07 m | | | | SLOW, SLEEP mode | | | | |-------|------------------|------------------|--|--| | TC1CK | Resolution | Maximum | | | | | [ <i>µ</i> s] | time setting [s] | | | | 00 | 244.14 | 16.0 | | | | 01 | _ | - | | | | 10 | _ | - | | | Example 1: Sets the timer mode with source clock $fs/2^3$ [Hz] and generates an interrupt 1 later (at fs = 32.768 kHz). LDW (TREG1A), 1000H ; Sets the timer register (1 s $\div$ 2<sup>3</sup> / fs = 1000<sub>H</sub>) SET (EIRL). EF4 ; Enable INTTC1 ΕI LD (TC1CR), 00010000B; Starts TC1 Note: TC1CR is a wire-only register and must not be used with [SET(TC1CR).4] instruction. **Example 2: Software capture** LD (TC1CR), 01010000B; SCAP1←1 (Captures) LD WA, (TREG1B); Reads the capture value **3-77-63** 2007-10-23 Figure 2-20. Timer Mode Timing Chart #### (2) External trigger timer mode In this mode, counting up is started by an external trigger. This trigger is the edge of the TC1 pin input. Either the rising or falling edge can be selected with INT2ES in EINTCR. Edge selection is the same as for INT2 pin. Source clock is an internal clock selected with TC1CK. The contents of TREG1A is compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0" and halted. The counter is restarted by the selected edge of the TC1 pin input. When METT1 (bit 6 in TC1CR) is "1", inputting the edge to the reverse direction of the trigger edge to start counting clears the counter, and the counter is stopped. Inputting a constant pulse width can generate interrupts. When METT1 is "0", the reverse directive edge input is ignored. The TC1 pin input edge before a match detection is also ignored. The TC1 pin input has the same noise rejection as the INT2 pin; therefore, pulses of 7/fc [s] or less are rejected as noise. A pulse width of 24/fc [s] or more is required for edge detection in NORMAL1, 2 or IDLE1, 2 mode. The noise rejection circuit is turned off in SLOW and SLEEP modes. But, a pulse width of one machine cycle or more is required. ``` Example 1: Detects rising edge in TC1 pin input and generates an interrupt 100 \mus later. (at fc = 8 MHz, DV1CK = 1) ``` LD (EINTCR), 00000000B ; INT2ES $\leftarrow$ 0 (rising edge) LDW (TREG1A), 0032H ; 100 $\mu$ s ÷ 2<sup>4</sup>/fc = 32<sub>H</sub> SET (EIRL).EF4 ; INTTC1 interrupt enable ΕI LD (TC1CR), 00111000B; TC1 external trigger start, METT1 = 0 Example 2: Generates an interrupt, inputting "L" level pulse (pulse width: 4 ms or more) to the TC1 pin. (at fc = 8 MHz, DV1CK = 1) LD (EINTCR), 00000100B ; INT2ES $\leftarrow$ 1 ("L" level) LDW (TREG1A), 007DH ; 4 ms $\div$ 2 $^8$ / fc = 7D<sub>H</sub> SET (EIRL).EF4 ; INTTC1 interrupt enable ΕI LD (TC1CR), 01110100B; TC1 external trigger start, METT1 = 1 **3-77-64** 2007-10-23 Figure 2-21. External Trigger Timer Mode Timing Chart ### (3) Event counter mode In this mode, events are counted at the edge of the TC1 pin input. Either the rising or falling edge can be selected with INT2ES in EINTCR. Edge selection is the same as for INT2 pin. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. This maximum applied frequency is shown in table 2-5. Setting SCAP1 to "1" transfers the current contents of up-counter to TREG1B (software capture Setting SCAP1 to "1" transfers the current contents of up-counter to TREG1B (software capture function). SCAP1 is automatically cleared after capturing. Figure 2-22. Event Counter Mode Timing Chart Table 2-5. Timer / Counter 1 External Clock Source | Maximum applied frequency [Hz] | | | | | |--------------------------------|---------------------|--|--|--| | NORMAL1/2, IDLE1/2 mode | SLOW, SLEEP mode | | | | | fc / <b>2</b> <sup>4</sup> | fs / 2 <sup>4</sup> | | | | **3-77-65** 2007-10-23 #### (4) Window mode Counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC1 pin input (window pulse) and an internal clock. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Positive or negative logic for the TC1 pin input can be selected. Edge selection is the same as for INT2 pin. Setting SCAP1 to "1" transfers the current contents of up-counter to TREG1B. It is necessary that the maximum applied frequency be such that the counter value can be analyzed by the program. That is; the frequency must be considerably slower than the selected internal clock. Figure 2-23. Window Mode Timing Chart ### (5) Pulse width measurement mode Counting is started by the external trigger (set to external trigger start by TC1S). The trigger can be selected either the rising or falling edge of the TC1 pin input. The source clock is used an internal clock. On the next falling (rising) edge, the counter contents are transferred to TREG1B and an INTTC1 interrupt is generated. The counter is cleared when the single edge capture mode is set. When double edge capture is set, the counter continues and, at the next rising (falling) edge, the counter contents are again transferred to TREG1B. If a falling (rising) edge capture value is required, it is necessary to read out TREG1B contents until a rising (falling) edge is detected. Falling or rising edge is selected with INT2ES, and single edge or double edge is selected with MCAP1 (bit 6 in TC1CR). Note: The first captured value after the timer starts may be read incorrectively, therefore, ignore the first captured value. ``` Example: Duty measurement (resolution fc/27 [Hz] DV1CK = 0) ; INTTC1 service switch initial setting CLR (INTTC1SW). 0 LD (EINTCR), 00000000B Sets the rise edge at the INT2 edge Sets the TC1 mode and source clock LD (TC1CR), 00000110B SET (EIRL). EF4 Enables INTTC1 ΕI LD (TC1CR), 00110110B ; Starts TC1 with an external trigger at MCAP1 = 0 PINTTC1: ; Complements INTTC1 service switch CPL (INTTC1SW). 0 JRS F, SINTTC1 LD (HPULSE), (TREG1BL) Reads TREG1B ("H" level pulse width) LD (HPULSE + 1), (TREG1BH) RETI SINTTC1: (WIDTH), (TREG1BL) ; Reads TREG1B (Period) LD (WIDTH + 1), (TREG1BH) LD ; Duty calculation RETI PINTTC1 VINTTC1: DW WIDTH HPULSE TC1 pin INTTC1SW ``` **3-77-67** 2007-10-23 Figure 2-24. Pulse Width Measurement Mode Timing Chart **3-77-68** 2007-10-23 # 2.7 16-bit Timer / Counter 2 (TC2) # 2.7.1 Configuration Figure 2-25. Timer / Counter 2 (TC2) #### 2.7.2 Control The timer / counter 2 is controlled by a timer/counter 2 control register (TC2CR) and a 16-bit timer register 2 (TREG2). Reset does not affect TREG2. Figure 2-26. Timer Register 2 and TC2 Control Register instructions such as SET, CLR, etc. Note 5: "fc" and "fc/2" can be selected as the source clock only in the timer mode during the SLOW mode. Note 6: TC2CR and TREG2 are write-only registers and must not be used with any of the read-modify-write #### 2.7.3 Function The timer / counter 2 has three operating modes: timer, event counter and window modes. Also timer / counter 2 is used for warm-up when switching from SLOW mode to NORMAL2 mode. #### (1) Timer mode In this mode, the internal clock is used for counting up. The contents of TREG2 are compared with the contents of up-counter. If a match is found, a timer / counter 2 interrupt (INTTC2) is generated, and the counter is cleared. Counting up is resumed after the counter is cleared. Also, when "fc" is selected as the source clock during SLOW mode, the lower 11 bits of TREG2 are ignored and an INTTC2 interrupt is generated by matching the upper 5 bits. Thus, in this case, only the TREG2<sub>H</sub> setting is necessary. | Table 2-6. | Source Clock | (internal clock | ) for Timer / Counter 2 ( | (at fc = 8 MHz, fs = 32.768 kHz) | |------------|--------------|-----------------|---------------------------|----------------------------------| |------------|--------------|-----------------|---------------------------|----------------------------------| | | | NORMAL1/2, IDLE1/2 mode | | | | | | | | | |-------|--------------|-------------------------|---------------|--------------|-----------------|--------------|---------------|--------------|--|--| | | | DV7C | K = 0 | | | DV7C | K = 1 | | | | | TC2CK | DV1CK = 0 | | DV1CK = 1 | | DV1CK = 0 | | DV1CK = 1 | | | | | | Resolution | Maximum | Resolution | Maximum | Resolution | Maximum | Resolution | Maximum | | | | | Resolution | time setting | Resolution | time setting | Resolution | time setting | Resolution | time setting | | | | 000 | 1.04 s | 19.08 h | 2.90 s | 38.17 h | 1 s | 18.2 h | 1 s | 18.2 h | | | | 001 | 1.02 ms | 67.10 s | 2.04 ms | 2.23 min | 0.98 ms | 1.07 min | 0.98 ms | 1.07 min | | | | 010 | 32 μs | 2.09 s | 64.00 $\mu$ s | 4.19 s | $32 \mu$ s | 2.09 s | 64 <i>μ</i> s | 4.19 s | | | | 011 | 1 <i>μ</i> s | 65.53 ms | 2.00 μs | 131.07 ms | 1 <i>μ</i> s | 65.53 ms | 2 <i>μ</i> s | 131.07 ms | | | | 100 | _ ` | _ | _ | _ | | _ | _ ` | - | | | | 101 | 30.5 μs | 2 s | 30.5 μs | 2 s | 30.5 <i>μ</i> s | 2 s | 30.5 μs | 2 s | | | | 110 | _ ` | - | | _ | ′ | _ | _ ` | _ | | | | | SLOV | / mode | SLEEP mode | | | |-------|----------------|----------------------|----------------|----------------------|--| | TC2CK | Resolution [s] | Maximum time setting | Resolution [s] | Maximum time setting | | | 000 | 1 s | 18.2 h | 1 s | 18.2 h | | | 001 | 0.98 ms | 1.07 min | 0.98 ms | 1.07 min | | | 01* | _ | _ | _ | _ | | | 100 | 125 ns (Note) | _ | _ | _ | | | 101 | | _ | _ | _ | | | 110 | 250 ns (Note) | - | _ | _ | | Note: fc and fc/2 can be used only in the timer mode. It is used for warm-up when switching from SLOW mode to NORMAL2 mode. Example: Sets the timer mode with source clock fc/24 [Hz] and generates an interrupt every 25 ms (at fc = 8 MHz, DV1CK = 1). LDW (TREG2), 30D4H ; Sets TREG2 (25 ms $\div$ 24 / fc = , 30D4<sub>H</sub>) SET (EIRH).EF8 ; Enables INTTC2 interrupt ΕI LD (TC2CR), 00101100B ; Starts TC2 #### (2) Event counter mode In this mode, events are counted on the rising edge of the TC2 pin input. The contents of TREG2 are compared with the contents of the up-counter. If a match is found, an INTTC2 interrupt is generated, and the counter is cleared. The maximum frequency applied to the TC2 pin is shown in table 2-7. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width. Example: Sets the event counter mode and generates an INTTC2 interrupt 640 counts later. LDW (TREG2), 640 ; Sets TREG2 SET (EIRH).EF8 ; Enables INTTC2 interrupt ΕI LD (TC2CR), 00111100B; Starts TC2 Table 2-7. Timer / Counter 2 External Clock Source | Maximum applied frequency [Hz] | | | | | | |--------------------------------|---------------------|--|--|--|--| | NORMAL1/2, IDLE1/2 mode | SLOW, SLEEP mode | | | | | | fc / 2 <sup>4</sup> | fs / 2 <sup>4</sup> | | | | | #### (3) Window mode In this mode, counting up is performed on the rising edge of an internal clock during TC2 external pin input(window pulse) is "H" level. The contents of TREG2 are compared with the contents of upcounter. If a match is found, an INTTC2 interrupt is generated, and the up-counter is cleared. The maximum applied frequency (TC2 input) must be considerably slower than the selected internal clock. Example: Generates an interrupt, inputting "H" level pulse width of 120 ms or more. (at fc = 8 MHz, DV1CK = 1) LDW (TREG2), 003AH ; Sets TREG2 (120 ms $\div$ 2<sup>14</sup>/fc = 003A<sub>H</sub>) SET (EIRH).EF8 ; Enables INTTC2 interrupt ΕI LD (TC2CR), 00100101B ; Starts TC2 Figure 2-27. Window Mode Timing Chart # 2.8 8-bit Timer / Counter 4 (TC4) # 2.8.1 Configuration Figure 2-28. Timer / Counter 4 (TC4) #### 2.8.2 Control The timer / counter 4 is controlled by a timer / counter 4 control register (TC4CR) and an 8-bit timer register 4 (TREG4). Reset does not affect TREG4. Figure 2-29. Timer Register 4 and TC4 Control Register #### 2.8.3 Function The timer / counter 4 has four operating modes: timer, event counter, programmable divider output, and PWM output mode. #### (1) Timer mode In this mode, the internal clock is used for counting up. The contents of TREG4 are compared with the contents of up-counter. If a match is found, an INTTC4 interrupt is generated and the up-counter is cleared to "0". Counting up resumes after the up-counter is cleared. Table 2-8. Source Clock (internal clock) for Timer / Counter 4 (Example: at fc = 8 MHz, fs = 32.768 kHz) | | | | | NORMAL1/2, I | DLE1/2 mode | | | | |-------|--------------------|--------------------------|--------------------|--------------------------|----------------------|--------------------------|--------------------|--------------------------| | | | DV70 | K = 0 | | DV7CK = 1 | | | | | TC4CK | DV1CK = 0 | | DV10 | CK = 1 | DV1CK = 0 | | DV1CK = 1 | | | TC4CK | Resolution<br>[μs] | Maximum setting time [s] | Resolution<br>[µs] | Maximum setting time [s] | Resolution $[\mu s]$ | Maximum setting time [s] | Resolution<br>[µs] | Maximum setting time [s] | | 000 | 256 | 65.28 m | 512 | 130.56 m | 244.14 | 62.2 m | 244.14 | 62.2 m | | 001 | 16 | 4.08 m | 32 | 8.16 m | 10.24 | 2.6 m | 20.48 | 5.2 m | | 010 | 1 | $255 \mu$ | 2 | 510 $\mu$ | 0.64 | 163.2 $\mu$ | 1.28 | 326 $\mu$ | | 100 | 4 | 1.02 m | 8 | 2.04 μ | 2.56 | 653 μ | 5.12 | 1306 μ | | | SLOW, SLEEP mode | | | | |-------|----------------------|--------------------------------|--|--| | TC4CK | Resolution $[\mu s]$ | Maximum<br>setting time<br>[s] | | | | 000 | 244.14 | 62.2 m | | | | 001 | _ | _ | | | | 010 | _ | _ | | | | 100 | | _ | | | # (2) Event counter mode In this mode, the TC4 pin input (external clock) pulse is used for counting up. The contents of the TREG4 are compared with the contents of the up-counter. If a match is found, an INTTC4 interrupt is generated and the counter is cleared. Counting up resumes after the up-counter is cleared. The maximum applied frequency is shown in Table 2-12. Two or more machine cycles are required for both the high and low levels of the pulse width. Table 2-9. Timer / Counter 4 External Clock Source | Maximum applied frequency [Hz] | | | | | |------------------------------------------|-------------------|--|--|--| | NORMAL1/2, IDEL1/2 mode SLOW, SLEEP mode | | | | | | fc/2 <sup>4</sup> | fs/2 <sup>4</sup> | | | | # (3) Programmable Divider Output (PDO) mode The internal clock is used for counting up. The contents of TREG4 are compared with the contents of the up-counter. If a match is found, the timer F/F4 output is toggled and the counter is cleared. Timer F/F4 output is inverted and output to the P16 (PDO) pin. When programmable divider output is executed, P16 output latch is set to "1" and the output mode is configured. This mode can be used for approximate 50% duty pulse output. Timer F/F4 can be initialized by program, and it is initialized to "0" during reset. An INTTC4 interrupt is generated each time the PDO output is toggled. Example: Output a 1024 Hz pulse (at fc = 4.194304 MHz) SET (P1).6 ; P16 output latch←1 LD (P1CR), 01000000B ; P16 output mode LD (TREG4), 10H ; $(1/1024 \div 2^{7}/fc) \div 2 = 10_{H}$ LD (TC4CR), 00010110B ; Stats TC4 Figure 2-30. PDO Mode Timing Chart # (4) Pulse Width Modulation (PWM) output mode PWM output with a resolution of 8 bits is possible. The internal clock is used for counting up. The contents of TREG4 are compared with the contents of up-counter. If a match is found, the timer F/F4 output is toggled. Counting up resumes. And, when an overflow occurs, the timer F/F4 output is again toggled and the counter is cleared. Timer F/F4 output is inverted and output to the P16 (PWM) pin. When pulse width modulation output is executed, P16 output latch is set to "1". An INTTC4 interrupt is generated when an overflow occurs. TREG4 is configured a 2-stage shift register and, during output, will not switch until one output cycle is completed even if TREG4 is overwritten; therefore, output can be altered continuously. Also, the first time, TREG4 is shifted by setting TC4S (bit 4 in TC4CR) to "1" after data are loaded to TREG4. Note: Do not rewrite the contents of TREG4 at only an INTTC4 interrupt generation cycle. The contents of TREG4 is rewritten by the INTTC4 interrupt service routine. Figure 2-31. PWM Output Mode Timing Chart Table 2-10. PWM Output Mode (Example: fc = 8 MHz, fs = 32.768 kHz) | | NORMAL1/2, IDLE1/2 mode | | | | | | | | | |-------|-------------------------|-----------------|----------------|--------------|---------------|-----------------|---------------|-----------------|--| | | DV7CK = 0 | | | DV7CK = 1 | | | | | | | TC4CK | DV1CK = 0 | | DV1CK = 1 DV | | DV10 | CK = 0 | DV10 | DV1CK = 1 | | | | Resolution | Repeat cycle | Resolution | Repeat cycle | Resolution | Repeat cycle | Resolution | Repeat cycle | | | | [ns] | [μs] | [ns] | [μs] | [ns] | [μs] | [ns] | [μs] | | | 000 | 256 μs | 65.5 ms | 512 <i>μ</i> s | 131.0 ms | 244.1 $\mu$ s | 62.5 ms | 244.1 $\mu$ s | 62.5 ms | | | 001 | 16 <i>μ</i> s | 4.09 ms | 32 <i>μ</i> s | 8.19 ms | 16 <i>μ</i> s | 4.09 ms | 32 μs | 8.19 ms | | | 010 | 1 <i>μ</i> s | 256 | 2 $\mu$ s | 512 | 1 <i>μ</i> s | 256 | 2 μs | 512 | | | 100 | 4 μs | 1.02 <i>μ</i> s | 8 <i>μ</i> s | 2.04 ms | 4 μs | 1.02 <i>μ</i> s | 4 μs | 1.02 <i>μ</i> s | | | 101 | 500 | 128 | 500 | 128 | 500 | 128 | 500 | 128 | | | 110 | 250 | 64 | 250 | 64 | 250 | 34 | 250 | 64 | | | 111 | 125 | 32 | 125 | 32 | 125 | 32 | 125 | 32 | | **3-77-77** 2007-10-23 # 2.9 Extended Timer-Counter (ETC1) Figure 2-32. Extended Timer-Counter (ETC1) **3-77-78** 2007-10-23 #### 2.9.2 Control Extended timer-counter 1 is controlled by the following registers. The following shows the structure of the registers. Pay special attention to Notes 1 to 4. Figure 2-33. Extended Timer-Counter 1 Register (1/3) Figure 2-33. Extended Timer-Counter 1 Register (2/3) Figure 2-33. Extended Timer-Counter 1 Register (3/3) **3-77-81** 2007-10-23 #### 2.9.3 Outline TMP88CP77/S77/U77 each have three internal 16-bit timer-counter channels (TC1, TC2, ETC1). The following is an outline of the extended timer (ETC1). # (1) Free-running timer mode and event counter mode The ETC1 timer-counter has two operating modes: free-running timer mode and event counter mode. Free-running timer mode counts up on an internal clock generated by a dedicated prescaler. Event counter mode counts up on input from the ETC1 (P02) pin. Table 2-11. Free-Running Mode and Event Counter Mode (When fc = 8 MHz, fs = 32.768 kHz) | | Count aloak | Edwa | Resolution | | | |--------------------|----------------|-------------------|---------------------|---------------------------|--| | | Count clock | Edge | (fc) | (fs) | | | Free-running timer | Internal clock | Rising edge | 500ns to 16 $\mu$ s | 122 <i>μ</i> s to 3.906ms | | | Event counter mode | ETC1 pin | Rising or falling | 1 $\mu$ s or more | 244 $\mu$ s or more | | ### (2) Input capture function and output compare function ETC1 has two input capture pin channels (P03 (IC0) and P02 (IC1)) and two output compare pin channels (P04 (OC0) and P06 (OC1)). Each channel can be used as a standard input / output port when not being used by ETC1. Table 2-12. Input Capture Function and Output Compare Function | | Pin | Function | Resolution | Data register | |---------------------|------------|-------------------------------------------------------|----------------------------|---------------------| | Input capture mode | P03<br>P02 | Rising edge<br>Falling edge<br>Either edge | Depends on specified timer | Two for P03 and P02 | | Output compare mode | P04<br>P06 | Outputs 1<br>Outputs 0<br>Inverts output<br>No change | | One per channel | #### 2.9.4 Outline of timer modes ETC1 has two operating modes: free-running timer mode and event counter mode. ## (1) Free-running timer mode **SET** (ET1CR).7 This mode counts up on an internal clock. When the counter value reaches FFFFH, an INTET1 / INTET2 interrupt is generated. This does not halt the count. The ET1CK bit of the extended timer-counter 1 control register (ET1CR) selects the source clock. Setting ET1CK to 111B sets event counter mode. To generate an interrupt after a specific number of counts, subtract the desired count from FFFFH and set in extended timer register 1 (ETREG1). To clear the counter, write 0000H. When writing to the ETREG1, write the lower byte first, followed by the upper byte. As the trigger for the counter to load the data value is the completion of the write to the upper byte, writing the lower byte only does not load the data value. After a write to the upper byte, a one-machine cycle wait is generated before the count starts. ETREG1 is write-only register and must not be used with any of the read-modify-write instructions such as SET, CLR, etc. ``` Example 1: Generate an ETC1 interrupt after 4s using the fs / 2<sup>2</sup> source clock. (fs = 32.768 kHz) (ET1CR), 00000000B LD ; stops the counter, sets the source clock to fs / 2^2 LDW (ETREG1), 07FFFH ; sets the timer register (4 s \div 122 \mus = 07FFFH) SET (EIRH).EF12 ; enables interrupt INTET1 ΕI SET (ET1CR).7 ; starts ETC1 Example 2: Generate an ETC1 interrupt after 256 \mus using the fc/2<sup>3</sup> source clock. (fc = 8 MHz, DV1CK = 0) LD (ET1CR), 00000001B ; stops the counter, sets the source clock to fc / 2<sup>3</sup> LDW (ETREG1), 0FEFFH ; sets the timer register (0FFFFH to 100H) SET (EIRH) .EF12 ; enables interrupt INTET1 ΕI ``` ; starts ETC1 Figure 2-34. Example of Free-Running Mode Operation Table 2-13. ETC1 Internal Clock Source (Example: When fc = 8 MHz, fs = 32.768 kHz) | ET1CK | NORMAL1/2 or | IDLE1/2 modes | SLOW mode or SLEEP modes | | | |-------|--------------|-------------------|--------------------------|-------------------|--| | ETICK | Resolution | Max. setting time | Resolution | Max. setting time | | | 000 | 500 ns | 32.77 ms | 122.0 $\mu$ s | 8 s | | | 001 | 1 ns | 65.54 ms | 244.1 $\mu$ s | 16 s | | | 010 | 2 μs | 131.07 ms | 488.3 $\mu$ s | 32 s | | | 011 | 4 μs | 262.14 ms | 976.6 μs | 64 s | | | 100 | 8 μs | 524.29 ms | 1.953 ms | 128 s | | | 101 | 16 μs | 1.05 s | 3.906 ms | 256 s | | | 110 | _ | _ | _ | _ | | Note: ET1CK is the ETC1 source clock setting bit. #### (2) Event counter mode Event counter mode counts up on an edge input to the ETC1 pin. ET1CK = 111B sets event counter mode. When used as ETC1 (P02), the P02 latch must be set to "1". This mode functions the same as free-running mode, except that the source clock changes from an internal clock to a pin input. The maximum applied frequency is fc/23 [Hz] in NORMAL 1/2 or IDLE 1/2 mode and fs/23 [Hz] in SLOW or SLEEP mode. Therefore, the external clock of two machine cycle or less is not guaranteed. Example 1: Generate an interrupt after counting 100 (64H) rising edges on the ETC1 pin. SET (P0 write). 2 ; sets P02 (ETC1) output latch to "1" LD (ET1CR), 00000111B ; stops the count, sets rising edge, sets ungated event counter mode LDW (ETREG1), 0FF9BH ; sets the timer register (0FFFFH to 0064H) SET (EIRH).EF12 ; enables INTET1 interrupt ΕI SET (ET1CR).7 ; starts ETC1 Figure 2-35. Example of Event Counter Mode Operation (ETC1 Rising Edge Detection) **3-77-85** 2007-10-23 #### 2.9.5 Pin Functions #### (1) Channel pin ETC1 has two input capture (IC) pin channels (P03 (IC0) and P02 (IC1)), and two output compare (OC) pin channels (P04 (OC0) and P06 (OC1)). Use the timer channel enable register (TMEN) to select whether to use a pin as an ETC channel pin or as a standard I/O port. When using a pin as an ETC channel pin, be sure to set the output data latch in P0 write. For example, when using P04 as OC0, set P0 write (P0 write, bit 4) to 1. #### (2) Input capture function This function can be used to measure such parameters as pulse width, period, and duty. The function loads the timer value into the capture register at the capture input change timing. The capture input circuit has an internal digital noise canceller circuit. Inputs shorter than a maximum of fc / 6 may be interpreted as noise and not be accepted as an input signal. Therefore, the width of the capture input must always be longer than fc / 6. Since this mode loads the timer value to the capture register after the capture input is sampled by the fc/4 sampling clock, a detection delay of between fc/2 (min.) and fc/6 (max.) occurs. The timer value is loaded into capture register iA (ICRiA) when the first edge is detected and an interrupt generated. Further capture operations are disabled until ICRiA is read. Always read the lower byte of the ICRiA register first, followed by the upper byte. ICO, IC1 shift the ICRiA value (at previous edge detection) to ICRiB when the next edge is detected, load the timer value (at current edge detection) to ICRiA, and generate an interrupt. Since the timer continues to count up if an overflow occurs before edge detection, the capture operation proceeds as normal. Note: i = 0, 1 Figure 2-36. Example of Capture Function Sampling (Capture 0 Rising Edge Detection, ETREG1 Source Clock = $fc/2^2$ ) **3-77-86** 2007-10-23 Figure 2-37. Example of Capture Mode Operation (Channel 0 Either-Edge Detection) ``` Example 1: Detect rising or falling edges on ICO. ; sets P03 output data latch to "1" (P0 write). 3 SET ; sets ICO to either-edge detection LD (TMD), 20H (TMEN). 4 SET ; sets P03 to capture mode (IC0) Example 2: Measure the width of positive pulses on IC1. SET (P0 write). 2 ; sets P02 to input LD (TMD), 00H ; sets IC1 to rising edge detection LP: TEST ; waits for IC1 rising edge detection (sets IL17) ILE.1 JR T, LP LD (ILE), FDH ; clears IL17 LD L, (ICR1AL) ; reads ICR1A LD H, (ICR1AH) LD (TMD), 40H ; sets IC1 to falling edge detection LP2: ; waits for IC1 falling edge detection (sets IL17) ILE.1 TEST JR T, LP2 LD A, (ICR1AL) W, (ICR1AH) LD SUB WA, HL ; calculates pulse width, stores in WA register LD (ILE), OFDH ; clears IL17 ``` **3-77-87** 2007-10-23 #### (3) Output compare mode This mode can set the output to any desired level at any desired timing. Bit OMi of the compare mode register (TMD) selects the output mode. The modes are 1 output, 0 output, toggle output, and NOP. The compare register (OCRi) is used to set the output change timing. Always write to the lower byte of OCRi first, followed by the upper byte. Since the trigger for OCRi to load the data value is the completion of the write to the upper byte, writing the lower byte only does not load the data value. A match between the values of the selected timer and OCRi outputs the mode set in OMi to P0k. The timer generates an interrupt request (INTOCi) after performing the output change operation. Further output compare operations are disabled until writing to the upper byte of OCRi completes. However, writing 0 to ET1S enables another compare operation. If the output mode is NOP, an interrupt only is generated when the set time is reached and the output value does not change. This can be used as a time-set interrupt with no change in the output. When OMi = 11, the output value inverts. Note: i = 0, 1k = 6, 4 Figure 2-38. Example of Compare Mode Operation ``` Example 1: Change the output of OC0 from 0 to 1 when ETREG1 = 0C80H (1 output mode). SET (P0 write). 4 ; sets P04 output data latch to "1" LD (TMD), 01H ; sets OC0 to 1 output LD (OCR0), 0C80H ; sets output change time LD (TMEN), 40H ; sets P04 to compare mode (OC0) Example 2: Change OC0 output from 0 to 1 when ETREG1 = 0C80H (toggle output mode). ; sets P04 output data latch to "1" (P0 write). 4 SET (TMD), 03H ; sets OC0 to toggle output LD LD (OCR0), 0C80H ; sets output change timing (TMEN), 40H LD ; sets P04 to compare mode (OC0) Example 3: Output pulses from OC0 with a 0 width of 100\mus and a 1 width of 200\mus. (fc = 8 MHz, DV1CK = 0) LD (ET1CR), 02H ; sets source clock to fc / 2^3 (1 \mus) LDW (ETREG1), 0000H LDW BC, 064H ; sets 0 width setting time (100 \mus) LDW DE, 0C8H ; sets 1 width setting time (200 \mus) LD WA, 064H SET (P0 write). 4 ; sets P04 output data latch to "1" (TMD), 03H ; sets OC0 to toggle output LD ; sets 0-to-1 output change time LD (OCR0), BC LD (TMEN), 40H ; sets P04 to compare mode (OC0) (ET1CR). 7 ; starts ETC1 SFT OOUT: ADD WA, DE ; sets 1-to-0 output change time ILE.2 ; waits for OC0 1-to-0 change (sets IL18) LP: TEST JR T, LP LD (ILE), OFBH ; clears IL18 LD (OCR0L), A ; sets 1-to-0 output change time LD (OCR0H), W 10UT: ADD WA, BC ; sets 0-to-1 output change time LP2: TEST ILE.2 ; waits for OC0 0-to-1 change (sets IL18) JR T, LP LD ; clears IL18 (ILE), OFBH ; sets 0-to-1 output change time LD (OCR0L), A LD (OCR0H), W JP 0OUT ``` **3-77-89** 2007-10-23 # 2.9.6 Interrupts The timer block has a total of five interrupt requests: one extended timer interrupts (INTET1), two input capture pin interrupts (INTIC0 and INTIC1), and two output compare pin interrupts (INTOC0 and INTOC1). (1) INTET1 Generated on counter overflow. The counter continues counting up after the overflow. (2) INTIC0 and INTIC1 Input capture pin interrupts The interrupt is generated when the timer value is loaded to the capture register at edge detection. (3) INTOC0 and INTOC1 Output compare pin interrupts The interrupt is generated at a match between the compare register and timer value. **3-77-90** 2007-10-23 ## 2.10 Serial Bus Interface (SBI-ver.C) The 88CP77/S77/U77 each have a 1-channel serial bus interface which employs a clocked-synchronous 8-bit serial bus interface and an I<sup>2</sup>C bus (a bus system by Philips). The serial bus interface is connected to an external device through P00 (SDA) and P01 (SCL) in the I<sup>2</sup>C bus mode; and through P02 (SCK3), P00 (SO3) and P01 (SI3) in the clocked-synchronous 8-bit SIO mode. The serial bus interface pins are also used for the P0 port. When used for serial bus interface pins, set the P0 output latches of these pins to "1", and control inputs and outputs of these pins by the I/O control register. When not used for serial bus interface pins, the pin is used as a normal I/O port. # 2.10.1 Configuration Figure 2-39. Serial Bus Interface (SBI-ver.C) # **2.10.2 Control** The following registers are used to control the serial bus interface and monitor the operation status. - Serial bus interface control register 1 (SBICR1) - Serial bus interface control register 2 (SBICR2) - Serial bus interface data buffer register (SBIDBR) - I<sup>2</sup>C bus address register (I<sup>2</sup>CAR) - Serial bus interface status register (SBISR) The above registers differ depending on an mode to be used. Refer to Section "2.10.4 I<sup>2</sup>C bus mode control" and "2.10.6 Clocked-synchronous 8-bit SIO mode control". # 2.10.3 The data format in the I<sup>2</sup>C bus mode The data format in the I<sup>2</sup>C bus mode are shown in Figure 2-40. Figure 2-40. Data Format in I<sup>2</sup>C Bus Mode **3-77-92** 2007-10-23 # 2.10.4 I<sup>2</sup>C bus mode control The following registers are used to control the serial bus interface (SBI-ver.C) and monitor the operation status in the I<sup>2</sup>C bus mode. Figure 2-41.Serial Bus Interface Control Register 1, Serial Bus Interface Data Buffer Register and I<sup>2</sup>C Bus Address Register In The I<sup>2</sup>C Bus Mode 3-77-93 2007-10-23 Figure 2-42. Serial Bus Interface Control Register 2 and Serial Bus Interface Status Register In The I<sup>2</sup>C Bus Mode ### (1) Acknowledge mode specification Set the ACK (bit 4 in SBICR1) to "1" for operation in the acknowledge mode. The 88CP77/S77/U77 generates an additional clock pulse for an acknowledge signal when operating in the master mode. In the transmitter mode during the clock pulse cycle, the SDA pin is released in order to receive the acknowledge signal from the receiver. In the receiver mode during the clock pulse cycle, the SDA pin is set to the low level in order to generate the acknowledge signal. Reset the ACK for operation in the non-acknowledge mode. The 88CP77/S77/U77 do not generate a clock pulse for the acknowledge signal when operating in the master mode. In the acknowledge mode, the 88CP77/S77/U77 counts a clock pulse for the acknowledge signal when operating in the slave mode. During the clock pulse, when the received slave address is the same as the value set at the I2CAR or when a GENERAL CALL is received, the SDA pin is set to the low level in order to generate the acknowledge signal. In the transmitter mode during the clock pulse cycle after matching the slave addresses or receiving a GENERAL CALL, the SDA pin is released in order to receive the acknowledge signal from the receiver. In the receiver mode during the clock pulse cycle, the SDA pin is set to the low level in order to generate the acknowledge signal. In non-acknowledge mode, the 88CP77/S77/U77 does not count a clock pulse for the acknowledge signal when operating in the slave mode. #### (2) Number of transfer bits The BC (bits 7 to 5 in SBICR1) is used to select a number of bits for transmitting and receiving data. Since the BC is cleared to "000" as a start condition, a slave address and direction bit transmissions are always executed in 8 bits. Other than these, the BC retains a specified value. # (3) Serial clock # a. Clock source The SCK (bits 2 to 0 in SBICR1) is used to select a maximum transfer frequency output from the SCL pin in the master mode. Set a communication baud rate that meets the I<sup>2</sup>C bus specification, such as the shortest pulse width of tLOW, based on the equations shown below.In both master mode and slave mode, a pulse width of at least 4 machine cycles is required for both high and low levels. Figure 2-43. Clock Source #### b. Clock synchronization In the I<sup>2</sup>C bus mode, in order to drive a bus with a wired AND, a master device which pulls down a clock pulse to low will, in the first place, invalidate a clock pulse of another master device which generates a high-level clock pulse. The master device with a high-level clock pulse needs to detect the situation and implement the following procedure. The 88CP77/S77/U77 have a clock synchronization function for normal data transfer even when more than one master exists on a bus. The example explains clock synchronization procedures when two masters simultaneously exist on a bus. Figure 2-44. Clock Synchronization As Master 1 pulls down the SCL pin to the low level at point "a", the SCL line of the bus becomes the low level. After detecting this situation, Master 2 resets counting a clock pulse in the high level and sets the SCL pin to the low level. Master 1 finishes counting a clock pulse in the low level at point "b" and sets the SCL pin to the high level. Since Master 2 holds the SCL line of the bus at the low level, Master 1 waits for counting a clock pulse in the high level. After Master 2 sets a clock pulse to the high level at point "c" and detects the SCL line of the bus at the high level, Master 1 starts counting a clock pulse in the high level. The clock pulse on the bus is determined by the master device with the shortest high-level period and the master device with the longest low-level period from among those master devices connected to the bus. ### (4) Slave address and address recognition mode specification When the serial bus interface circuit is used with an addressing format to recognize the slave address, clear the ALS (bit 0 in I2CAR) to "0", and set the SA (bits 7 to 1 in I2CAR) to the slave address. When the serial bus interface circuit is used with a free data format not to recognize the slave address, set the ALS to "1". With a free data format, the slave address and the direction bit are not recognized, and they are processed as data from immediately after start condition. ## (5) Master / slave selection Set the MST (bit 7 in SBICR2) to "1" for operating the 88CP77/S77/U77 as a master device. Reset the MST for operation as a slave device. The MST is cleared to "0" by the hardware after a stop condition on the bus is detected or arbitration is lost. #### (6) Transmitter / receiver selection Set the TRX (bit 6 in SBICR2) to "1" for operating the 88CP77/S77/U77 as a transmitter. Reset the TRX for operation as a receiver. When data with an addressing format is transferred in the slave mode, the TRX is set to "1" if the direction bit $(R/\overline{W})$ sent from the master device is "1", and is cleared to "0" if the bit is "0". In the master mode, after an acknowledge signal is returned from the slave device with the hardware, the TRX is set to "0" if a transmitted direction bit is "1", and set to "1" if it is "0". When an acknowledge signal is not returned, the current condition is maintained. The TRX is cleared to "0" by the hardware after a stop condition on the bus is detected or arbitration is lost. The following table shows TRX changing conditions and TRX value after changing. | Mode | Direction bit | Conditions | TRX after changing | |---------------|---------------|----------------------------------------|--------------------| | Slave mode | 0 | When the received slave address is the | 0 | | | 1 | same as I2CAR | 1 | | Master mode 0 | | When the ACK signal is returned | 1 | | | 1 | | 0 | When the serial bus interface circuit is used with a free data format, the TRX is not changed by hardware since the slave address and the direction bit are not recognized, and they are processed as data from immediately after start condition. #### (7) Start / stop condition generation A start condition and 8-bit data are output on the bus by writing "1" to the MST, TRX and BB when the BB (bit 5 in SBICR2) is "0". It is necessary to set the transmitting data to the data buffer register and "1" to ACK beforehand. Figure 2-45. Start Condition Generation and Slave Address Generation When the BB is "1", sequence of generating a stop condition is started by writing "1" to the MST, TRX, and PIN, and "0" to the BB. Do not modify the contents of MST, TRX, BB and PIN until a stop condition is generated on a bus. Figure 2-46. Stop Condition Generation The bus condition can be indicated by reading the contetns of the BB (bit 5 in SBISR). The BB is set to "1" when a start condition on a bus is detected and is cleared to "0" when a stop condition is detected. #### (8) Interrupt service request cancel In the master mode, a serial bus interface interrupt request (INTSBI) occurs after the number of clocks which is specified by the BC and ACK has been transmitted. In the slave mode, when the received slave address is the same as the value set at the I2CAR, after outputting the acknowledge signal when a GENERAL CALL is received, or when data transfer is complete after matching the slave addresses or receiving a GENERAL CALL, an INTSBI interrupt request occurs. When a serial bus interface interrupt request occurs, the PIN (bit 4 in SBISR) is cleared to "0". During the time that the PIN is "0", the SCL pin is pulled down to the low level. Either writing / reading data to / from the SBIDBR sets the PIN to "1". The time from the PIN being set to "1" until the SCL pin is released takes t<sub>LOW</sub>. Although the PIN (bit 4 in SBICR2) can be set to "1" by the program, the PIN is not set to "0" when "0" is written. #### (9) Serial bus interface operating mode The SBIM (bits 3, 2 in SBICR2) is used to specify the serial bus interface operation mode. Set the SBIM to "10" after confirming that the serial bus interface pin is set to high level when used in the I2C bus mode. Switch a mode to port after making sure that a bus is free. #### (10) Arbitration lost detection monitor Since more than one master device can exist simultaneously on a bus in the I<sup>2</sup>C bus mode, a bus arbitration procedure is implemented in order to guarantee the contents of transferred data. Data on the SDA line is used for bus arbitration of the I<sup>2</sup>C bus. The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on the bus. Master 1 and Master 2 output the same data until point "a". After Master 1 outputs "1" and Master 2, "0", the SDA line of the bus is wired AND and the SDA line is pulled down to the low level by Master 2. When the SCL line of the bus is pulled up at point "b", the slave device reads data on the SDA line, that is, data in Master 2. Data transmitted from Master 1 becomes invalid. The state in Master 1 is called "arbitration lost". A master device which loses arbitration releases the SDA pin and the SCL pin in order not to effect data transmitted from other masters with arbitration. When more than one master sends the same data at the first word, arbitration occurs continuously after the second word. Figure 2-47. Arbitration Lost The 88CP77/S77/U77 compares levels of the SDA line of the bus with those of the 88CP77/S77/U77 SDA pin at the rising edge of the SCL line. If the levels are unmatched, arbitration is lost and the AL (bit 3 in SBISR) is set to "1". When the AL is set to "1", the MST and TRX are reset to "0" and the mode is switched to a slave receiver mode. The AL is reset to "0" by writing/reading data to / from the SBIDBR or writing data to the SBICR2. Figure 2-48. Example of when 88CP77/S77/U77 are Master B # (11) Slave address match detection monitor The AAS (bit 2 in SBISR) is set to "1" in the slave mode, in the address recognition mode (ALS = 0), or when receiving a slave address with the same value that sets a GENERAL CALL or I2CAR. When the ALS is "1", the AAS is set to "1" after receiving the first 1-word of data. The AAS is cleared to "0" by after writing / reading data to / from a data buffer register. ## (12) GENERAL CALL detection monitor The AD0 (bit 1 in SBISR) is set to "1" in the slave mode, when all 8-bit data received immediately after a start condition are "0". The AD0 is cleared to "0" when a start or stop condition is detected on the bus. ## (13) Last received bit monitor The SDA value stored at the rising edge of the SCL line is set to the LRB (bit 0 in SBISR). When the contents of the LRB are read immediately after an INTSBI interrupt request is generated in the acknowledge mode, and ACK signal is read. # (14) Software Reset Function Software reset function is used to initialize SBI, when SBI is rocked by external noise, etc. SWRST (bit 0 in SBICR) is set to "1", internal reset signal pulse is generated and inputted into SBI ... All command registers and status registers are initialized to an initial value. SWRST is automatically cleared to "0" after initializing SBI circuit. # 2.10.5 Data transfer in I<sup>2</sup>C bus mode #### (1) Device initialization First, set the ACK in the SBICR1 to "1", the BC to "000", and the data length to 8-bit to count a clock pulse for the acknowledge signal. In addition, set the transmit frequency to the SCK. Next, set the slave address to the SA in the I2CAR. Clear the ALS to "0" to set the addressing format. After confirming that the serial bus interface pin is high level, for specifying the default setting to a slave receiver mode, clear "0" to the MST, TRX, and BB in the SBICR2; "1" to the PIN; "10" to the SBIM; and "0" to bits 1 and 0. Note: To initialize the serial bus interface circuit, a constant period that the start conditions are not generated for any device is required after all devices which are connected to the bus are initialized. Then, the initialization must be completed during the period. If not, other devices may start transmitting data before the serial bus interface circuit has been initialized. Thus, data can not be normally received. # (2) Start condition and slave address generation Confirm a bus free status (when BB = 0). Set the ACK to "1" and specify a slave address and a direction bit to be transmitted to the SBIDBR. When the BB is "0", the start condition are generated and the slave address and the direction bit which are set to the SBIDBR are output on a bus by writing "1" to the MST, TRX, BB, and PIN. An INTSBI interrupt request occurs at the 9th falling edge of the SCL clock cycle, and the PIN is cleared to "0". The SCL pin is pulled down to the low level while the PIN is "0". When an interrupt request occurs, the TRX changes by the hardware according to the direction bit only when an acknowledge signal is returned from the slave device. - Note 1: The slave address to be output to the SBIDBR must be set after the bus free is detected by software. If setting of the slave address is executed before detection bus free, the current output data may be corrupted. - Note 2: The bus free must be confirmed by software within 98.0 µs (the shortest transmitting time according to the I2C bus standard) after setting of the slave address to be output. Only when the bus free is confirmed, set "1" to the MST, TRX, BB, and PIN to generate the start conditions. If the start conditions are generated without writing "1" to them, transferring may be executed by other masters between the time when the slave address to be output to the SBIDBR is written and the time when "1" is written to the MST, TRX, BB, and PIN in the SBICR2. Thus, the slave address may be corrupted. Figure 2-49. Start Condition Generation and Slave Address Transfer #### (3) 1-word data transfer Check the MST by the INTSBI interrupt process after a 1-word data transfer is completed, and determine whether the mode is a master or slave. a. When the MST is "1" (Master mode) Check the TRX and determine whether the mode is a transmitter or receiver. ## ① When the TRX is "1" (Transmitter mode) Check the LRB. When the LRB is "1", a receiver does not request data. Implement the process to generate a stop condition and terminate data transfer. When the LRB is "0", the receiver requests new data. When the next transmitted data is other than 8 bits, set the BC and write the transmitted data to the SBIDBR after setting ACK to "1". After writing the data, the PIN becomes "1", a serial clock pulse is generated for transferring a new 1-word of data from the SCL pin, and then the 1-word data is transmitted. After the data is transmitted, an INTSBI interrupt request occurs. The PIN becomes "0" and the SCL pin is pulled down to the low level. If the data to be transferred is more than one word in length, repeat the procedure from the LRB checking above. Figure 2-50. Example when BC = "000", ACK = "1" #### ② When the TRX is "0" (Receiver mode) When the next transmitted data is other than 8 bits, set the BC again. Set the ACK to "1" and read the received data from the SBIDBR (data which is read immediately after a slave address is sent is undefined). After the data is read, the PIN becomes "1". The 88CP77/S77/U77 outputs a serial clock pulse to the SCL to transfer new 1-word of data and sets the SDA pin to "0" at the acknowledge signal timing. An INTSBI interrupt request occurs and the PIN becomes "0". The 88CP77/S77/U77 outputs a clock pulse for 1-word of data transfer and the acknowledge signal each time that received data is read from the SBIDBR. Figure 2-51. Example when BC = "000", ACK = "1" In order to terminate transmitting data to a transmitter, clear the ACK to "0" before reading data which is 1 word before the last data to be received. The last data does not generate a clock pulse for the acknowledge signal. After the data is transmitted and an interrupt request has occurred, set the BC to "001" and read the data. The 88CP77/S77/U77 generates a clock pulse for a 1-bit data transfer. Since the master device is a receiver, the SDA line of the bus keeps the high level. The transmitter receives the high-level signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete. After 1-bit data is received and an interrupt request has occurred, the 88CP77/S77/U77 generates a stop condition and terminates data transfer. Figure 2-52. Termination of Data Transfer in Master Receiver Mode # b. When the MST is "0" (Slave mode) In the slave mode, the 88CP77/S77/U77 operates either in normal slave mode or in slave mode after losing arbitration. In the slave mode, an INTSBI interrupt request occurs when the 88CP77/S77/U77 receives a slave address or a GENERAL CALL from the master device, or when a GENERAL CALL is received and data transfer is complete after matching a received slave address. In the master mode, the 88CP77/S77/U77 operates in a slave mode if it is losing arbitration. An INTSBI interrupt request occurs when word data transfer terminates after losing arbitration. When an INTSBI interrupt request occurs, the PIN (bit 4 in the SBICR2) is reset, and the SCL pin is pulled down to the low level. Either reading/writing from/to the SBIDBR or setting the PIN to "1" releases the SCL pin after taking $t_{LOW}$ time. Check the AL (bit 3 in the SBISR), the TRX (bit 6 in the SBISR), the AAS (bit 2 in the SBISR), and the ADO (bit 1 in the SBISR) and implements processes according to conditions listed in the next table. | TRX | AL | AAS | AD0 | Conditions Process | | |-----|----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | 1 | 1 | 0 | The 88CP77/S77/U77 loses arbitration when transmitting a slave address and receives a slave address of which the value of the direction bit sent from another master is "1". | Set the number of bits in 1 word to the BC and write transmitted data to the SBIDBR. | | | 0 | 1 | 0 | In the slave receiver mode, the 88CP77/S77/U77 receives a slave address of which the value of the direction bit sent from the master is "1". | | | | | 0 | 0 | In the slave transmitter mode, 1-word data is transmitted. | Check the LRB. If the LRB is set to "1", set the PIN to "1" since the receiver does not request next data. Then, clear the TRX to "0" release the bus. If the LRB is cleared to "0", set the number of bits in a word to the BC and write transmitted data to the SBIDBR since the receiver requests next data. | | 0 | 1 | 1 | 1/0 | The 88CP77/S77/U77 loses arbitration when transmitting a slave address and receives a slave address or GENERAL CALL of which the value of the direction bit sent from another master is "0". | Read the SBIDBR for setting the PIN to "1" (reading dummy data) or write "1" to the PIN. | | | | 0 | 0 | The 88CP77/S77/U77 loses arbitration when transmitting a slave address or data and terminates transferring word data. | | | | 0 | 1 | | In the slave receiver mode, the 88CP77/S77/U77 receives a slave address or GENERAL CALL of which the value of the direction bit sent from the master is "0". | | | | | 0 | 1/0 | In the slave receiver mode, the 88CP77/S77/U77 terminates receiving of 1-word data. | Set the number of bits in a word to the BC and read received data from the SBIDBR. | Table 2-14. Operation in the Slave Mode # (4) Stop condition generation When the BB is "1", a sequence of generating a stop condition is started by writing "1" to the MST, TRX, and PIN, and "0" to the BB. Do not modify the contents of the MST, TRX, BB, PIN until a stop condition is generated on a bus. Figure 2-53. Stop Condition Generation #### (5) Restart Restart is used to change the direction of data transfer between a master device and a slave device during transferring data. The following explains how to restart when the 88CP77/S77/U77 are in the master mode. Specify "0" to the MST, TRX, and BB and "1" to the PIN and release the bus. The SDA pin retains the high level and the SCL pin is released. Since a stop condition is not generated on a bus, a bus is assumed to be in a busy state from other devices. Check the BB until it becomes "0" to check that the SCL pin of the 88CP77/S77/U77 are released. Check the LRB until it becomes "1" to check that the SCL line of a bus is not pulled down to the low level by other devices. After confirming that a bus stays in a free state, generate a start condition with procedure (2). In order to meet setup time when restarting, take at least 4.7 [ $\mu$ s] of waiting time by software from the time of restarting to confirm that the bus is free until the time to generate the start condition. Figure 2-54. Timing Diagram when Restarting the 88CP77/S77/U77 # 2.10.6 Clocked-synchronous 8-bit SIO Mode Control The following registers are used to control the serial bus interface (SBI-ver. C) and monitor the operation status in the clocked-synchronous 8-bit SIO mode. Figure 2-55. Control Register / Data Buffer Register / Status Register in SIO Mode #### (1) Serial clock #### a. Clock source The SCK(bits 2 to 0 in SBICR1) is used to select the following functions. #### 1) Internal clock In an internal clock mode, any of seven frequencies can be selected. The serial clock is output to the outside on the SCK3 pin. The SCK3 pin becomes a high level when data transfer starts. When writing (in the transmit mode) or reading (in the receive mode) data cannot follow the serial clock rate, an automatic-wait function is executed to stop the serial clock automatically and hold the next shift operation until reading or writing is complete. Figure 2-56. Automatic Wait Function # ② External clock (SCK = "111") An external clock supplied to the $\overline{SCK3}$ pin is used as the serial clock. In order to ensure shift operation, a pulse width of at least 4 machine cycles is required for both high and low levels in the serial clock. The maximum data transfer frequency is 250 kHz (fc = 8 MHz). Figure 2-57. The Maximum Data Transfer Frequency in The External Clock Input # b. Shift edge The leading edge is used to transmit data, and the trailing edge is used to receive data. # ① Leading edge Data is shifted on the leading edge of the serial clock (at a falling edge of the SCK3 pin input / output). #### 2 Trailing edge Data is shifted on the trailing edge of the serial clock (at a rising edge of the SCK3 pin input / output). Figure 2-58. Shift Edge #### (2) Transfer mode The SIOM (bits 5 and 4 in SIO1CR) is used to select a transmit, receive, or transmit/receive mode. # a. 8-bit transmit mode Set a control register to a transmit mode and write data to the SBIDBR. After the data is written, set the SIOS to "1" to start data transfer. The transmitted data is transferred from the SBIDBR to the shift register and output to the SO3 pin in synchronous with the serial clock, starting from the least significant bit (LSB). When the data is transferred to the shift register, the SBIDBR becomes empty. The INTSBI (buffer empty) interrupt request is generated to request new data. When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated if new data is not loaded to the data buffer register after the specified 8-bit data is transmitted. When new data is written, automatic-wait function is canceled. When the external clock is used, data should be written to the SBIDBR before new data is shifted. The transfer speed is determined by the maximum delay time between the time when an interrupt request is generated and the time when data is written to the SBIDBR by the interrupt service program. When the transmit is started, the same value as the final bit of the last data is output until the falling edge of the SCK3 after the SIOF goes "1". Transmitting data is ended by cleaning the SIOS to "0" by the buffer empty interrupt service program or setting the SIOINH to "1". When the SIOS is cleared, the transmitted mode ends when all data is output. In order to confirm if data is surely transmitted by the program, set the SIOF (bit 3 in the SBISR) to be sensed. The SIOF is cleared to "0" when transmitting is complete. When the SIOINH is set, transmitting data stops. The SIOF turns "0". When the external clock is used, it is also necessary to clear the SIOS to "0" before new data is shifted; otherwise, dummy data is transmitted and operation ends. Figure 2-59. Transfer Mode Example: SIO0 transfer end command (External clock) STEST1: TEST (SBISR). SEF ; If SEF = 1 then loop JRS F, STEST1 STEST2: TEST (P0 read) . 2 ; If $\overline{SCK3} = 0$ then loop JRS T, STEST2 LD (SBICR1), 00000111B ; $SIOS \leftarrow 0$ Figure 2-60. Transmitted Data Hold Time at End of Transmit **3-77-107** 2007-10-23 #### b. 8-bit receive mode Set a control register to a receive mode and the SIOS to "1" for switching to a receive mode. Data is received from the SIO pin to the shift register in synchronous with the serial clock, starting from the least significant bit (LSB). When the 8-bit data is received, the data is transferred from the shift register to the SBIDBR. The INTSBI (buffer full) interrupt request is generated to request of reading the received data. The data is then read from the SBIDBR by the interrupt service program. When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated until the received data is read from the SBIDBR. When the external clock is used, since shift operation is synchronized with the clock pulse provided externally, the received data should be read before new data is transferred to the SBIDBR. If the received data is not read, further data to be received is canceled. The maximum transfer speed when the external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when received data is read. Receiving data is ended by clearing the SIOS to "0" by the buffer full interrupt service program or setting the SIOINH to "1". When the SIOS is cleared, received data is transferred to the SBIDBR in complete blocks. The received mode ends when the transfer is complete. In order to confirm if data is surely received by the program, set the SIOF (bit 3 in SBIDBR) to be sensed. The SIOF is cleared to "0" when receiving is complete. After confirming that receiving has ended, the last data is read. When the SIOINH is set, receiving data stops. The SIOF turns "0" (the received data becomes invalid, therefore no need to read it). Note: When the transfer mode is switched, the SBIDBR contents are lost. In case that the mode needs to be switched, conclude receiving data by clearing the SIOS to "0", read the last data, and then switch the mode. Figure 2-61. Receive Mode (Example: Internal clock) #### c. 8-bit transmit / receive mode Set a control register to a transmit / receive mode and write data to the SBIDBR. After the data is written, set the SIOS to "1" to start transmitting / receiving. When transmitting, the data is output from the SO3 pin on the leading edges in synchronous with the serial clock, starting from the least significant bit (LSB). When receiving, the data is input to the SI3 pin on the trailing edges of the serial clock. 8-bit data is transferred from the shift register to the SBIDBR, and the INTSBI interrupt request occurs. The interrupt service program reads the received data from the data buffer register and writes data to be transmitted. The SBIDBR is used for both transmitting and receiving. Transmitted data should always be written after received data is read. When the internal clock is used, automatic-wait function is initiated until received data is read and next data is written. When the external clock is used, since the shift operation is synchronized with the serial clock provided externally, received data is read and transmitted data is written before new shift operation is executed. The maximum transfer speed when the external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when received data is read and transmitted data is written. When the transmit is started, the same value as the final bit of the last data is output until the falling edge of the SCK3 after the SIOF goes "1". Transmitting / receiving data is ended by cleaning the SIOS to "0" by the INTSBI interrupt service program or setting the SIOINH to "1". When the SIOS is cleared, received data is transferred to the SBIDBR in complete blocks. The transmit / receive mode ends when the transfer is complete. In order to confirm if data is surely transmitted / received by the program, set the SIOF (bit 3 in SBISR) to be sensed. The SIOF becomes "0" after transmitting / receiving is complete. When the SIOINH is set, transmitting / receiving data stops. The SIOF turns "0". Note: When the transfer mode is switched, the SBIDBR contents are lost. In case that the mode needs to be switched, conclude transmitting/receiving data by clearing the SIOS to '0", read the last data, and then switch the transfer mode. Figure 2-62. Transmit / Receive Mode (Example: Internal clock) Figure 2-63. Transmitted Data Hold Time at End of Transmit / Receive **3-77-110** 2007-10-23 #### 2.11 Serial Interface (SIO0, SIO1) The 88CP77/S77/U77 each have two built-in 8-bit serial interface channels that operate in sync with the clock: SIO0 and SIO1. SIO0 has a 32-byte send/receive data buffer. SIO1 has an 8-byte send/receive data buffer. SIO0 can consecutively transfer up to 256 bits of data automatically; SIO1 up to 64 bits. Serial interface is connected to external devices via the following pins: - (1) P16 (SO0), P15 (SI0), P14 (SCK0) - (2) P12 (SO1), P11 (SI1), P10 (SCK1) Serial interface pins are also used as port P1. When used as serial interface pins, set the output latches of port P1 to 1. In send mode, SIx pins: P15 and P11 can be used as general-purpose I/O ports; in receive mode, SOx pins P16 and P12. ## 2.11.1 Configuration The SIO0 and SIO1 have the same configuration, except for the addresses/bit positions of the control/status registers and buffer registers. Figure 2-64. Serial Interfaces #### **2.11.2 Control** SIO0 and SIO1 are controlled by SIO0CR1/SIO0CR2 and SIO1CR1/SIO1CR2. SIO states can be determined by reading SIO0SR and SIO1SR. The send/receive data buffer is controlled by BUF (bits 4 to 0 in SIO0CR2) or (bits 2 to 0 in SIO1CR2). The send/receive data buffer for SIO0 is assigned to addresses 0FE0 to 0FFF<sub>H</sub> in DBR; for SIO1, addresses 0FD8 to 0FDF<sub>H</sub>. The buffer for SIO0 can consecutively transfer up to 32 words at a time; the buffers for SIO1, up to 8 words. When transfer of the set number of words is complete, a buffer empty (in send mode) or buffer full (in receive or send/receive mode) interrupt (INTSIO0 or INTSIO1) is generated. When using the internal clock as the serial clock in 8-bit send/receive or 8-bit receive mode, a fixed-time wait can be inserted to the serial clock every time one word is transferred. One of the four wait times can be selected by WAIT (bits 6 and 5 in SIOOCR2) or (bits 4 and 3 in SIO1CR2). Figure 2-65. SIO Control Registers and Status Registers Figure 2-66. SIO Control Register 3-77-113 #### (1) Serial clock ### a. Clock Source SCK (bits 2 to 0 in SIO0CR1/SIO1CR1) is able to select the following: #### ① Internal clock Any of four frequencies can be selected. The serial clock is output to the outside on the $\overline{SCK0}$ / $\overline{SCK1}$ pin. The $\overline{SCK0}$ and $\overline{SCK1}$ pins goes high when transfer starts. When data writing (in the transmit mode) or reading (in the receive mode or the transmit/receive mode) cannot keep up with the serial clock rate, there is a wait function that automatically stops the serial clock and holds the next shift operation until the read/write processing is completed. | | Serial clock | | Maximum t | ransfer rate | | | | |----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------|--------------------|--|--|--| | NORMAL1/2, | IDLE1/2 mode | SLOW SLEED | | | | | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP mode | At fc = 8 MHz | At fs = 32.768 kHz | | | | | fc/2 <sup>13</sup> [Hz]<br>fc/2 <sup>8</sup><br>fc/2 <sup>6</sup><br>fc/2 <sup>5</sup> | fs / 2 <sup>5</sup> [Hz]<br>fc / 2 <sup>8</sup><br>fc / 2 <sup>6</sup><br>fc / 2 <sup>5</sup> | fs / 2 <sup>5</sup> [Hz]<br>-<br>-<br>- | 0.95 Kbit/s<br>30.5<br>122<br>244 | 1 Kbit/s | | | | Table 2-15. Serial Clock Rate Note: 1 Kbit = 1024 bit Figure 2-67. Clock Source (Internal Clock) ## 2 External clock An external clock connected to the $\overline{SCK0}$ / $\overline{SCK1}$ pins are used as the serial clock. In this case, the P14 ( $\overline{SCK0}$ ) / P10 ( $\overline{SCK1}$ )output latch must be set to "1". To ensure shifting, a pulse width of at least 4 machine cycles is required. Thus, the maximum transfer speed is 244K-bit/s. (at fc = 8MHz). #### b. Shift edge The leading edge is used to transmit, and the trailing edge is used to receive. ① Leading edge Transmitted data are shifted on the leading edge of the serial clock (falling edge of the SCK pin input/output). ② Trailing edge Received data are shifted on the trailing edge of the serial clock (rising edge of the SCK pin input/output). Figure 2-68. Shift Edge #### (2) Number of bits to transfer Either 4-bit or 8-bit serial transfer can be selected. When 4-bit serial transfer is selected, only the lower 4 bits of the transmit/receive data buffer register are used. The upper 4 bits are cleared to "0" when receiving. The data is transferred in sequence starting at the least significant bit (LSB). #### (3) Number of words to transfer Up to 8 words consisting of 4 bits of data (4-bit serial transfer) or 8 bits (8-bit serial transfer) of data can be transferred continuously. The number of words to be transferred is loaded to BUF in SIOOCR2 and SIO1CR2. 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-69. Number of Bits to Transfer (Example: 4-bit serial transfer) **3-77-116** 2007-10-23 #### 2.11.3 Transfer mode SIOM (bits 5 - 3 in SIOOCR1/SIO1CR1) is used to select the transmit, receive, or transmit/receive mode. #### (1) 4-bit and 8-bit transmit modes In these modes, the SIOOCR1/SIO1CR1 is set to the transmit mode and then the data to be transmitted first are written to the data buffer registers (DBR). After the data are written, the transmission is started by setting SIOS to "1". The data are then output sequentially to the SO pin in synchronous with the serial clock, starting with the least significant bit (LSB). As soon as the LSB has been output, the data are transferred from the data buffer register to the shift register. When the final data bit has been transferred and the data buffer register is empty, an INTSIO (buffer empty) interrupt is generated to request the next transmitted data. When the internal clock is used, the serial clock will stop and an automatic-wait will be initiated if the next transmitted data are not loaded to the data buffer register by the time the number of data words specified with the BUF has been transmitted. Writing even one word of data cancels the automatic-wait; therefore, when transmitting two or more words, always write the next word before transmission of the previous word is completed. Note: Waits are also canceled by writing to a DBR not being used as a transmit data buffer register; therefore, during SIO do not use such DBR for other applications. For example (SIO1), when 3words are transmitted, do not use the DBR of the remained When an external clock is used, the data must be written to the data buffer register before shifting next data. Thus, the transfer speed is determined by the maximum delay time from the generation of the interrupt request to writing of the data to the data buffer register by the interrupt service program. When the transmit is started, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the SCK. The transmission is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer empty interrupt service program. That the transmission has ended can be determined from the status of SIOF (bit 7 in SIOOSR/SIO1SR) because SIOF is cleared to "0" when a transfer is completed. 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. 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". **3-77-117** 2007-10-23 Figure 2-70. Transfer Mode (Example: 8-bit, 1 Word Transfer) Figure 2-71. Transmitted Data Hold Time at End of Transmit **3-77-118** 2007-10-23 #### (2) 4-bit and 8-bit receive modes After setting the control registers to the receive mode, set SIOS to "1" to enable receiving. The data are then transferred to the shift register via the SI pin in synchronous with the serial clock. When one word of data has been received, it is transferred from the shift register to the data buffer register (DBR). When the number of words specified with the BUF has been received, an INTSIO (buffer full) interrupt is generated to request that these data be read out. The data are then read from the data buffer registers by the interrupt service program. When the internal clock is used, and the previous data are not read from the data buffer register before the next data are received, the serial clock will stop and an automatic-wait will be initiated until the data are read. A wait will not be initiated if even one data word has been read. Note: Waits are also canceled by reading a DBR not being used as a received data buffer register is read; therefore, during SIO do not use such DBR for other applications. When an external clock is used, the shift operation is synchronized with the external clock; therefore, the previous data are read before the next data are transferred to the data buffer register. If the previous data have not been read, the next data will not be transferred to the data buffer register and the receiving of any more data will be canceled. When an external clock is used, the maximum transfer speed is determined by the delay between the time when the interrupt request is generated and when the data received have been read. When the transmit is started, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the SCK. The 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 SIOF is cleared to "0" receiving. When SIOS is cleared, the current data are transferred to the buffer in 4-bit or 8-bit blocks. The receiving mode ends when the transfer is completed. SIOF is cleared to "0" when receiving is ended and thus can be sensed by program to confirm that receiving has ended. If it is necessary to change the number of words in external clock operation, SIOS should be cleared to "0" then BUF must be rewritten after confirming that SIOF has been cleared to "0". If it is necessary to change the number of words in internal clock operation, during automatic-wait which occurs after completion of data receiving, BUF must be rewritten before the received data is read out. 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-72. 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 initialed if even one data ward has been written. Note: The 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. The transmit/receive operation is ended by clearing SIOS to "0" or setting SIO1NH to "1" in interrupt service program. When SIOS is cleared, the current data are transferred to the data buffer register in 8-bit blocks. The transmit mode ends when the transfer is completed. SIOF is cleared to "0" when receiving is ended and thus can be sensed by program to confirm that receiving has ended. When SIOINH is set, the transmit/receive operation is immediately ended and SIOF is cleared to "0". If it is necessary to change the number of words in external clock operation, SIOS should be cleared to "0", then BUF must be rewritten after confirming that SIOF has been cleared to "0". If it is necessary to change the number of words in internal clock, during automatic-wait which operation which occurs after completion of transmit/receive operation, BUF must be rewritten before reading and writing of the receive/transmit data. Note: The buffer contents are lost when the transfer mode is switched. If it should become necessary to switch the transfer mode, end receiving by clearing SIOS to "0", read the last data and then switch the transfer mode. **3-77-120** 2007-10-23 Figure 2-73. Transmit/Receive Mode (Example: 8-bit, 1word, internal clock) Figure 2-74. Transmitted Data Hold Time at End of Transmit/Receive **3-77-121** 2007-10-23 #### 2.12 8-bit AD Converter (ADC) The 88CP77/S77/U77 each have an 8-channel multiplexed-input 8-bit successive approximate type AD converter with sample and hold. # 2.12.1 Configuration Figure 2-75. AD Converter # 2.12.2 Control The AD converter is controlled by the AD converter control register (ADCCR). The operating state of the AD converter is confirmed by reading EOCF in ADCCR. The AD conversion value is confirmed by reading the contents of AD conversion value registers. Figure 2-76. AD Conversion Result Register | DCCR | 7<br>EOCF | 6<br>ADS | 5<br>ACK | 4<br>AINDS | 3 | 2<br>S/ | 1<br>AIN | . 0 | $\neg$ | | (Initial | value: | 00000 | 000) | | | |---------------------|---------------------------------------------|------------------|--------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|-------------------|--------|--------------------|--------------------------|----------|----------|------|--|-----| | 000E <sub>H</sub> ) | SAIN Analog input selection 001 011 011 011 | | | | 0000: AIN0 select 1000: AIN10 select 0001: AIN1 select 1001: AIN11 select 0010: AIN2 select 1010: AIN12 select 0011: AIN3 select 1011: AIN13 select 0100: AIN4 select 1100: reserved 0101: AIN5 select 1101: reserved 0110: AIN6 select 1110: reserved 0111: AIN7 select 1111: reserved | | | | | | | | | | | | | | AINI | os | Analog | input c | ontrol | | - 1 ' | ): Ena<br> : Disa | | | | | | | | R/W | | | ACI | к | Conver | sion tim | e select | tion | | | | | 2 μs (fc =<br>8 μs (fc = | | | | | | | | AD | s | AD con | version | start | | 1 7 | ): –<br> : AD ( | conve | ersion s | start | | | | | | | | EOC | CF | End of | AD con | ersion | flag | - 1 - | | | nversio<br>nversio | on or Be | fore cor | nversion | | | R | | | Note 2<br>Note 3 | ?: The<br>?: The | ADS is a<br>EOCF is<br>EOCF is | utoma:<br>cleared | tically cl<br>l to "0" | leared | to ″0 | ″ aftei | rstari | _ | nversion | ı. | | | | • | Figure 2-77. AD converter control register and AD conversion result register ### 2.12.3 Operation Analog reference voltage on high side is applied to the VAREF pin; on the low side, to the VASS pin. The reference voltage between VAREF and VASS is divided a ladder resistor and compared with the analog voltage input for AD conversion. #### (1) Start of AD conversion First, set the corressponding P4CR and P5CR bit to "0" for analog input. Clear the AINDS (bit 4 in ADCCR) to "0" and select one of twelve analog input AIN13-AIN0 with the SAIN (bits 3-0 in ADCCR). Note: The pin that is not used as an analog input can be used as regular input/output pins. During conversion, do not perform output instruction to maintain a precision for all of the pins. AD conversion is started by setting the ADS (bit 6 in ADCCR) to "1". Conversion is accomplished in 46 machine cycles (184/fc [s]). The EOCF (bit 7 in ADCCR) is set to "1" at end of conversion. When setting the ADS to "1" under AD conversion, the AD converter circuit is initialized and the AD conversion try again from start. The sampling of the analog input voltage is excuted at 4 machine cycles after setting the ADS to "1". Note: The circuit of sample and hold is included in a capacitor of (12 pF (try.)) through a register (5 $k\Omega$ (try)). Therefore, until 4 machine cycles is over, this capacitor must be charged. #### (2) Reading of AD conversion result After the end of conversion, read the conversion result from the ADCDR. The EOCF is automatically cleared to "0" when reading the ADCDR. #### (3) AD conversion in STOP mode When the MCU places in the STOP mode during the AD conversion, the conversion is terminated and the ADCDR contents become indefinite. However, if the STOP mode is started after the end of conversion (EOCF = 1), the ADCDR contents are held. Figure 2-78. AD Conversion Timing Chart (ACK = 1) Example: SLOOP: ; AIN SELECT LD (ADCCR), 00100100B; Selects AIN4, ACK = 1 ; AD CONVERT START SET (ADCCR) . 6 ; ADS = 1 TEST (ADCCR) . 7 ; EOCF = 1? JRS T, SLOOP ; RESULT DATA READ LD (9EH), (ADCDR) Figure 2-79. Analog Input Voltage vs AD Conversion Result (typ.) ### 2.13 Vacuum Fluorescent Tube (VFT) Driver Circuit The 88CP77/S77/U77/U77 features built-in high-breakdown voltage output buffers for directly driving fluorescent tubes, and a display control circuit used to automatically transfer display data to the output port. ### 2.13.1 Functions - (1) 53 high-breakdown voltage output buffers built-in. - Large current output pin (V0 to V17) - Middle current output pin (V18 to V52) There is also the VKK pin used for the VFT drive power supply. - (2) The dynamic lighting system makes it possible to select 1 to 18 digits (T0 to T17) by program. - (3) Pins not used for VFT driver can be used as general-purpose ports. - Pins can be selected using the VSEL (bits 4 to 0) in VFT control register1 bit by bit. - (4) Display data (126 bytes in DBR) are automatically transferred to the VFT output pin. - (5) Brightness level can be adjusted in 7 steps using the dimmer function. - (6) Table 2-16. shown in setting of display time. Table 2-16. Setting of display time | DV1CK = 0 [s] | DV1CK = 1 [s] | |---------------------|---------------------| | 2 <sup>10</sup> /fc | 2 <sup>10</sup> /fc | | 2 <sup>11</sup> /fc | 2 <sup>11</sup> /fc | | 2 <sup>12</sup> /fc | 2 <sup>12</sup> /fc | | 213/fc | 2 <sup>13</sup> /fc | # 2.13.2 Configuration Figure 2-80. Vacuum Fluorescent Tube (VFT) Driver Circuit #### 2.13.3 **Control** The VFT driver circuit is controlled by the VFT control registers (VFTCR1, VFTCR2). Reading VFTSR determines the VFT operating status. Switching the mode from NORMAL1/2 to SLOW or STOP puts the VFT driver circuit into blanking state (BLK is set to "1"; values set in the VFT control registers except BLK and EKEY are maintained), and sets segment outputs and digit outputs are cleared to "0". Thus, ports P6 to P9, and PD to PF function as general-purpose output ports with pull-down.010000 Figure 2-81. VFT Control Register 1, VFT status register Figure 2-82. VFT control Register 2 #### (1) Setting of display mode VFT display mode is set by VFT control register 1 (VFTCR1) and VFT control register 2 (VFTCR2). VFT control register 1 (VFTCR1) sets 1 display time (tdisp) and the number of display lines (VSEL), and VFT control register 2 (VFTCR2) sets dimmer timer (DIM) and state (STA). (BLK of VFTCR1 must be set to "1".) The pin which DIM is valid, it is assigned from P60 to P81 by setting of STA. For example, when STA is 8 display mode, the DIM output pins are assigned from P60 to P67. Therefore, one display time of other pins are tdisp (s). (See Display operation in section 2.13.4 for display timing and data setting procedures.) #### (2) Display data setting Data are converted into VFT display data by instructions. The converted data stored in the display data buffer (addresses 00F00 to 00FD1 in DBR) are automatically transferred to the VFT driver circuit, then transferred to the high-breakdown voltage output buffer. Thus, to change the display pattern, just change the data in the display data buffer. Bits in the VFT segment (dot) and display data area correspond one to one. When data are set to 1, the segments corresponding to the bits light. The display data buffer is assigned to the DBR area shown in Figure 2-83. (The display data buffer can not be used as data memory) | bit | 0 to 7 | 0 to 7 | 0 to 7 | 0 to 7 | 0 to 7 | 0 to 7 | 0 to 4 | Timing | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|--------|--|--|--| | | 00F00 | 00F20 | 00F40 | 00F60 | 00F80 | 00FA0 | 00FC0 | T0 | | | | | | 00F01 | 00F21 | 00F41 | 00F61 | 00F81 | 00FA1 | 00FC1 | T1 | | | | | | 00F02 | 00F22 | 00F42 | 00F62 | 00F82 | 00FA2 | 00FC2 | T2 | | | | | | 00F03 | 00F23 | 00F43 | 00F63 | 00F83 | 00FA3 | 00FC3 | T3 | | | | | | 00F04 | 00F24 | 00F44 | 00F64 | 00F84 | 00FA4 | 00FC4 | T4 | | | | | | 00F05 | 00F25 | 00F45 | 00F65 | 00F85 | 00FA5 | 00FC5 | T5 | | | | | | 00F06 | 00F26 | 00F46 | 00F66 | 00F86 | 00FA6 | 00FC6 | Т6 | | | | | | 00F07 | 00F27 | 00F47 | 00F67 | 00F87 | 00FA7 | 00FC7 | T7 | | | | | | 00F08 | 00F28 | 00F48 | 00F68 | 00F88 | 00FA8 | 00FC8 | T8 | | | | | | 00F09 | 00F29 | 00F49 | 00F69 | 00F89 | 00FA9 | 00FC9 | Т9 | | | | | | 00F0A | 00F2A | 00F4A | 00F6A | 00F8A | 00FAA | 00FCA | T10 | | | | | | 00F0B | 00F2B | 00F4B | 00F6B | 00F8B | 00FAB | 00FCB | T11 | | | | | | 00F0C | 00F2C | 00F4C | 00F6C | 00F8C | 00FAC | 00FCC | T12 | | | | | | 00F0D | 00F2D | 00F4D | 00F6D | 00F8D | 00FAD | 00FCD | T13 | | | | | | 00F0E | 00F2E | 00F4E | 00F6E | 00F8E | 00FAE | 00FCE | T14 | | | | | | 00F0F | 00F2F | 00F4F | 00F6F | 00F8F | 00FAF | 00FCF | T15 | | | | | | 00F10 | 00F30 | 00F50 | 00F70 | 00F90 | 00FB0 | 00FD0 | T16 | | | | | | 00F11 | 00F31 | 00F51 | 00F71 | 00F91 | 00FB1 | 00FD1 | T17 | | | | | output | output V0 to V7 V8 to V15 V16 to V23 V24 to V31 V32 to V39 V40 to V47 V48 to V52 Note: Writing "0" in 7 to 5 bit of address 00FCO <sub>H</sub> to 00FDI <sub>H</sub> in DBR. | | | | | | | | | | | Figure 2-83. VFT Display Data Buffer Memory (DBR) Note: The data memory contents become unstable when the power supply is turned on; therefore, the data memory should be initialized. **3-77-128** 2007-10-23 # 2.13.4 Display operation After setting of the display timing for the number of digits according to the using VFT and storing the segment and digit data according to the respective timings, clearing BLK in VFTCR1 to 0 starts VFT display. Figure 2-84. shows the VFT drive pulse and Figure 2-85, 86 show the display operation. Figure 2-84. VFT Drive Waveform and Display timing **3-77-129** 2007-10-23 # 2.13.5 Example of display operation ## (1) For Conventional type VFT When using the conventional type VFT, the output timing of the digits is specified to output 1 digit for 1 timing. Data must be set to output the pins which are specified to the digit in sequence. The following figure shows a data allocation of the display data buffer (DBR) and the output timing when VFT of 10 digits is used and V0 to V9 pins are allocated as the digit outputs. (When data is first written by the data buffer which corresponds to the digit pin, it is unnecessary to rewrite the data later.) Figure 2-85. Example of Conventional type VFT driver pulse #### (2) For Grid scan type VFT When using the grid scan type VFT, two or more grids must be simultaneously selected to turn the display pattern which contains two or more grids on. Additionally, the timing and the data must be determined to set the grid scan mode as follows. - When the display pattern which is fully set in the respective grids is turned on, only the grids which correspond as ever must be scanned in sequence to turn on the display pattern. (timing of T8 to T3 in the following figure) - When the display pattern which contains two or more grids is turned on, two or more corresponding grids are simultaneously selected to turn on the display pattern. (timing of T2 to T0 in the following figure) Figure 2-86. Grid Scan Type Display Vacuum Fluorescent Tube Ware **3-77-131** 2007-10-23 #### 2.13.6 Port function #### (1) High-breakdown voltage buffer To drive fluorescent display tube, clears the port output latch to "0". The port output latch is initialized to 0 at reset. It is recommended that ports P6, P7, P8 and P9 should be used as VFT driver output. Precaution for using as general-purpose I/O pins are follows. Note: When not using a pin which is pulled down to pin $V_{KK}$ (RK = typ. 80 k $\Omega$ ), it must be set to open. It is necessary to clear the port output latch and the data buffer memory (DBR) to "0". #### 1) Ports P6 to P9 When a part of P6 to P9 is used as the input/output pin (VFT driver in operation), the data buffer memory (DBR) of the segment which is also used as the input/output pin must be cleared to "0". #### 2 Port PD to PF VFT output and usual input/output are controlled by VSEL of VFT control register in bits. When a pin which is pulled down to pin $V_{KK}$ is used as usual output or input, the following cautions are required. #### (a) When outputting When level "L" is output, a port which is pulled down to pin $V_{KK}$ is pin $V_{KK}$ voltage. Such processes as clamping with the diode as shown in figure 2-87. (a) are necessary to prevent pin $V_{KK}$ voltage applying to the external circuit. #### (b) When inputting When the external data is input, the port output latch is cleared to "0". The input threshold is the same as that of the other usual input/output port. However it is necessary to drive RK (typ. 80 k $\Omega$ ) sufficiently because of pulled down to pin VKK. Figure 2-87. External Circuit Interface # Input / Output Circuitry # (1) Control pins The input/output circuitries of the 88CP77/S77/U77/U77 control pins are shown below. | Control Pin | I/O | Circuitry | Remarks | |---------------|-----------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | XIN<br>XOUT | Input<br>Output | Osc. enable fc VDD o Rf SRo 88CU77 | Resonator connecting pins (high-frequency) $R_f = 1.2 M\Omega \text{(typ.)} \\ R_O = 0.5 \text{k}\Omega \text{(typ.)}$ | | XTIN<br>XTOUT | Input<br>Output | Osc. enable fs VDD VDD Rf RO XTIN XTOUT | Resonator connecting pins (low-frequency) $R_f = 6 \ M\Omega \qquad \text{(typ.)} \\ R_O = 220 \ k\Omega \qquad \text{(typ.)}$ | | RESET | I/O | Address-trap-reset Watchdog-timer-reset System-clock-reset | Hysteresis input $R_{IN}=220~k\Omega~~(typ.)$ $R=1~k\Omega~~(typ.)$ | | STOP/INT5 | Input | P20 STOP/INT5 | Hysteresis input $R=1~k\Omega~~(typ.)$ | | TEST | Input | R<br>W<br>R <sub>IN</sub> | Pull-down resistor $R_{IN} = 70 \text{ k}\Omega$ (typ.) $R = 1 \text{ k}\Omega$ (typ.) | Note 1: The TEST pin of the 88PU77 does not have a pull-down resistor. Fix the test pin at low-level. Note 2: The XOUT pin of the 88CU77 has a $R_O$ resistor unlike the 88PU77/CS77/CP77. # (2) - ① Input/Output Ports | Port | I/O | Input/Output Circuitry | Remarks | |----------------------|-----|----------------------------------|----------------------------------------------------------------------------------------------------------------------------| | PO | 1/0 | initial "Hi-Z" VDD only 88CU77 | Sink open drain output Hysteresis input $R=1\ k\Omega\ (typ.)$ | | P1<br>P3 | 1/0 | disable disable | Tri-state I/O Hysteresis input $R=1~k\Omega~(typ.)$ | | P2 | 1/0 | initial "Hi-Z" | Sink open drain output Hysteresis input $R=1\ k\Omega$ | | P4<br>P5 | I/O | disable > R | Tri-state I/O $R=1~k\Omega~(typ.)$ | | P6<br>P7<br>P8<br>P9 | I/O | initial "Hi-Z" | Source open drain I/O $High-breakdown\ voltage$ $R_K=80\ k\Omega\ (typ.)$ $R=1\ k\Omega\ (typ.)$ $R1=200\ k\Omega\ (typ.)$ | Note: The PO port of 88CU77 is different from 88PU77/CS77/CP77 and has guard diodes built-in VDD side. Therefore, absolute maximum rating of input voltage is " – 0.3 to VDD + 0.3" volts. # (2) - ② Input / output Ports **3-77-135** 2007-10-23 ## **Electrical Characteristics** | Absolute Maximum Rat | ings | (V <sub>SS</sub> = 0 V) | | | | | | | |---------------------------------|---------------------|----------------------------------|----------------------------------------|------|--|--|--|--| | PARAMETER | SYMBOL | PINS | RATINGS | UNIT | | | | | | Supply Voltage (* Note4) | $V_{DD}$ | | - 0.3 to 6.5 | V | | | | | | | V <sub>IN1</sub> | P1, P2, P3, P4, P5, XOUT, RESET | - 0.3 to V <sub>DD</sub> + 0.3 | ., | | | | | | Input Voltage | V <sub>IN2</sub> | P0 port (* Note 3) | – 0.3 to 5.5 V | V | | | | | | | V <sub>OUT1</sub> | P1, P2, P3, P4, P5, XOUT, RESET | - 0.3 to V <sub>DD</sub> + 0.3 | | | | | | | Output Voltage | V <sub>OUT2</sub> | P0 port (* Note 3) | – 0.3 to 5.5 V | V | | | | | | | V <sub>OUT3</sub> | Source open drain ports | $V_{DD} - 40 \text{ to } V_{DD} + 0.3$ | | | | | | | | I <sub>OUT1</sub> | P0, P1, P2, P3, P4, P5 ports | 3.2 | | | | | | | Output Current (Per 1 pin) | I <sub>OUT2</sub> | P6, P7, P80, 81 Ports | - 25 | mA | | | | | | | I <sub>OUT3</sub> | P82 to P87, P9, PD, PE, PF ports | - 12 | | | | | | | | Σ I <sub>OUT1</sub> | P1, P3, P4, P5 ports | - 40 | | | | | | | Output Current (Total) | Σ I <sub>OUT2</sub> | P0, P1, P2, P3, P4, P5 ports | 60 | mA | | | | | | | Σ ΙΟυτ3 | P6, P7, P8, P9, PD, PE, PF ports | - 120 | | | | | | | Power Dissipation [Topr = 25°C] | PD Note | | 1200 | mW | | | | | | Soldering Temperature (time) | Tsld | | 260 (10 s) | °C | | | | | | Storage Temperature | Tstg | | - 55 to + 125 | °C | | | | | | Operating Temperature | Topr | | - 30 to + 70 | °C | | | | | Note 1: 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. Note 2: Power Dissipation (PD); For PD, it is necessary to decrease -14.3 mw/°C. Note 3: The P0 port of TMP88CU77 is different from TMP88PU77/CS77/CP77 and has guard diodes built-in VDD side. Therefore, absolute maximum rating of input voltage is " – 0.3 to VDD + 0.3" volts. Note 4: All VDDs should be connected externally for keeping the same voltage level. | | Recommended | Operating | Conditions | $V_{SS} = 0 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C}$ | |---|-------------|-----------|------------|---------------------------------------------------------------------------| | ı | Recommended | Operating | Conditions | $ (v_{SS} = 0 \text{ v}, \text{ ropr} = -30 \text{ to } 70 \text{ c})$ | | PARAMETER | SYMBOL | PINS | С | ONDITIONS | Min | Max | UNIT | |--------------------|------------------|-------------------------|-----------------------------------------------------|-------------------------|------------------------|------------------------|------| | | | | fc = | NORMAL 1, 2 modes | | | | | | | | 12.5 MHz | IDLE1, 2 modes | | 5.5 | | | Supply Voltage | V <sub>DD</sub> | | fs = | SLOW mode | 4.5 | | l v | | | | | 32.768 kHz | SLEEP mode | | | | | | | | | STOP mode | 2.0 | | | | | V <sub>IH1</sub> | Except hysteresis input | $V_{DD} \ge 4.5 \text{ V}$ $V_{DD} < 4.5 \text{ V}$ | | $V_{DD} \times 0.70$ | | | | Input High Voltage | V <sub>IH2</sub> | Hysteresis input | | | V <sub>DD</sub> × 0.75 | V <sub>DD</sub> | V | | | V <sub>IH3</sub> | | | | V <sub>DD</sub> × 0.90 | | | | | V <sub>IL1</sub> | Except hysteresis input | | V >45V | | V <sub>DD</sub> × 0.30 | | | Input Low Voltage | V <sub>IL2</sub> | Hysteresis input | | V <sub>DD</sub> ≧ 4.5 V | 0 | V <sub>DD</sub> × 0.25 | V | | | V <sub>IL3</sub> | | V <sub>DD</sub> <4.5 V | | | $V_{DD} \times 0.10$ | | | | fc | XIN, XOUT | V <sub>DD</sub> | = 4.5 V to 5.5 V | 1.0 | 12.5 | MHz | | Clock Frequency | fs | XTIN, XTOUT | V <sub>DD</sub> | = 2.7 V to 5.5 V | 30.0 | 34.0 | kHz | Note: The recommended operating conditions for a device are operating conditions under which it can be guaranteed that the device will operate as specified. If the device is used under operating conditions other than the recommended operating conditions (supply voltage, operating temperature range, specified AC/DC values etc.), malfunction may occur. Thus, when designing products which include this device, ensure that the recommended operating conditions for the device are always adhered to. **3-77-136** 2007-10-23 #### How to calculate power consumption. With the TMP88CP77/S77/U77, a pull-down resistor (Rk = 80 k $\Omega$ typ.) can be built into a VFT driver using mask option (port by port). The share of VFT driver loss (VFT driver output loss + pull-down resistor (Rk) loss) in power consumption Pmax is high. When using a fluorescent display tube with a large number of segments, the maximum power consumption Pd must not be exceeded. power consumption Pmax = operating power consumption + normal output port loss + VFT driver loss #### Where, operating power consumption: VDD x IDD normal power consumption: $\Sigma$ lout2 x 0.4 VFT driver loss: VFT driver output loss + pull-down resistor (Rk) loss #### Example: When Ta = 10 to $50^{\circ}$ c and a fluorescent display tube with segment output = 3 mA, digit output = 15 mA, Vxx = -25 V is used. Operating conditions: $VDD = 5 V \pm 10\%$ , fc = 8 MHz, VFT dimmer time (DIM) = (14/16) x tseg: Power consumption Pmax = (1) + (2) + (3) Where, segments pin = X grid pin = Y, Y = 2 - (1) Operating power consumption: $V_{DD} \times I_{DD} = 5.5 \text{ V} \times 22 \text{ mA} = 121 \text{ mW}$ - (2) Normal output port loss: $\Sigma$ lout2 x 0.4 V = 60 mA x 0.4 V = 24 mW 18.605 mW x (X + 2) (3) VFT driver loss: segment pin = 3 mA x 2 V x number of segments X = 6 mW x X digit pin = 15 mA x 2 V x 14/16 (DIM) x number of gridsY = 52.5 mW Rk loss = $(5.5 + 25 \text{ V})^2 / 50 \text{ k}\Omega \text{ x}$ (number of segments X + number of digits Y) = Therefore, $Pmax = 121 \text{ mW} + 24 \text{ mW} + 6 \text{ mW} \times X + 52.5 \text{ mW} + 18.605 \text{ mWx} (X + 2) = 234.71 + 24.605X$ Maximum power consumption Pd when $Ta = 50^{\circ}C$ is determined by the following equation: ``` PD = 1200 \text{ mW} - (14.3 \text{ x } 25) = 842.5 \text{ mW} ``` The number of segments X which can be lit is: ``` PD > Pmax 842.5 mW > 234.71 mW + 24.605 X 24.7 > X ``` Thus, a fluorescent display tube with less than 24 segments can be used. If a fluorescent display tube with 24 segments or more is used, either a pull-down resistor must be attached externally, or the number of segments to be lit must be kept to less than 24 by software. **3-77-137** 2007-10-23 # D.C. Characteristics $(V_{SS} = 0 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C})$ | PARAMETER | SYMBOL | PINS | CONDITIONS | Min | Тур. | Max | UNIT | |----------------------------------------|------------------|--------------------------------------|--------------------------------------------------------------------|-----|------|------------|------------| | Hysteresis Voltage | V <sub>HS</sub> | Hysteresis input | | _ | 0.9 | - | V | | | I <sub>IN1</sub> | TEST | | | | | | | Input Current | I <sub>IN2</sub> | Open drain ports,<br>Tri-state ports | $V_{DD} = 5.5 \text{ V}$<br>$V_{IN} = 5.5 \text{ V} / 0 \text{ V}$ | - | _ | ± 2 | μA | | | I <sub>IN3</sub> | RESET, STOP | VIN = 3.3 V / 0 V | | | | | | | I <sub>IN4</sub> | PD, PE, PF ports (Note3) | | - | _ | 80 | | | Input Resistance | R <sub>IN2</sub> | RESET | | 100 | 220 | 450 | kΩ | | Pull-down Resistance | R <sub>K</sub> | Source open drain ports | $V_{DD} = 5.5 \text{ V}, V_{KK} = -30 \text{ V}$ | 50 | 80 | 110 | K77 | | | I <sub>LO1</sub> | Sink open drain ports | V <sub>DD</sub> = 5.5 V, V <sub>OUT</sub> = 5.5 V | _ | _ | 2 | | | Output Leakage<br>Current | I <sub>LO2</sub> | Source open drain ports | V <sub>DD</sub> = 5.5 V, V <sub>OUT</sub> = -32 V | _ | _ | <b>–</b> 2 | $\mu$ A | | | I <sub>LO3</sub> | Tri-state ports | V <sub>DD</sub> = 5.5 V, V <sub>OUT</sub> = 5.5 V / 0 V | - | - | 2 | 1 | | | V <sub>OH2</sub> | Tri-state ports | $V_{DD} = 4.5 \text{ V}, I_{OH} = -0.7 \text{ mA}$ | 4.1 | - | - | | | Output High Voltage | V <sub>OH3</sub> | P82 to P87, P9, PD, PE, PF<br>ports | $V_{DD} = 4.5 \text{ V}, I_{OH} = -8 \text{ mA}$ | 2.4 | - | - | V | | Output Low Voltage | V <sub>OL</sub> | Except XOUT | $V_{DD} = 4.5 \text{ V, } I_{OL} = 1.6 \text{ mA}$ | _ | _ | 0.4 | V | | | I <sub>OH1</sub> | P6, P7, P80, P81 ports | | _ | - 30 | - | | | Output High current | I <sub>OH2</sub> | P82 to P87, P9, PD, PE, PF<br>ports | $V_{DD} = 4.5 \text{ V}, V_{OH} = 2.4 \text{ V}$ | - | - 15 | - | mA | | Supply Current in NORMAL 1, 2 modes | | | V <sub>DD</sub> = 5.5 V<br>V <sub>IN</sub> = 5.3 V / 0.2 V | _ | 15 | 22 | mA | | modesSupply Current in IDLE 1, 2 modes | | | fc = 12.5 MHz<br>fs = 32.768 kHz | - | 6 | 12 | mA | | Supply Current in<br>SLOW mode | I <sub>DD</sub> | | V <sub>DD</sub> = 3.0 V<br>V <sub>IN</sub> = 2.8 V / 0.2 V | - | 30 | 60 | | | Supply Current in<br>SLEEP mode | | | fs = 32.768 kHz | - | 15 | 30 | μ <b>Α</b> | | Supply Current in<br>STOP mode | ] | | V <sub>DD</sub> = 5.5 V<br>V <sub>IN</sub> = 5.3 V / 0.2 V | - | 0.5 | 10 | | Note 1: Typical values show those at Topr = $25^{\circ}$ C, $V_{DD} = 5 V$ . Note 2: Input Current I<sub>IN1,</sub>I<sub>IN3</sub>; The current through resistor is not included, when the input resistor (pull-up/pull-down) is contained. Note 3: Input Current $I_{IN4}$ ; The current when the pull-down register (Rk) is not connected by the mask option. # **AD Conversion Characteristics** $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C})$ | PARAMETER | SYMBOL | CONDITIONS | Min | Тур. | Max | UNIT | |--------------------------|-------------------|-------------------------------------------------------|------------------|------|-------------------|------| | | V <sub>AREF</sub> | | 4.5 | _ | V <sub>DD</sub> | | | Analog Reference Voltage | V <sub>ASS</sub> | | V <sub>SS</sub> | | | \ \ | | Analog Input Voltage | V <sub>AIN</sub> | | V <sub>ASS</sub> | _ | V <sub>AREF</sub> | V | | Analog Supply Current | I <sub>REF</sub> | $V_{AREF} = 5.5 \text{ V}, \ V_{ASS} = 0.0 \text{ V}$ | _ | 0.5 | 1.0 | mA | | Nonlinearity Error | | $V_{DD} = 5.0 \text{ V}, V_{SS} = 0.0 \text{ V}$ | _ | _ | ± 1 | | | Zero Point Error | | V <sub>AREF</sub> = 5.000 V | - | - | ± 1 | | | Full Scale Error | | V <sub>ASS</sub> = 0.000 V | - | - | ± 1 | LSB | | Total Error | | 1 433 | - | _ | ± 2 | | Note: Total errors includes all errors, except quantization error. **3-77-138** 2007-10-23 ### A.C. Characteristics $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C})$ | PARAMETER | SYMBOL | CONDITIONS | Min | Тур. | Max | UNIT | |------------------------------|------------------|-------------------------------|-------|------|-------|------| | | | In NORMAL1, 2 modes | 0.22 | _ | 10 | | | Machine Cycle Time | tcy | In IDLE 1, 2 modes | 0.32 | | 10 | μS | | | | In SLOW mode | 447.6 | _ | 133.3 | | | | | In SLEEP mode | 117.6 | | | | | High Level Clock Pulse Width | t <sub>WCH</sub> | For external clock operation | 32 | | | | | Low Level Clock Pulse Width | t <sub>WCL</sub> | (XIN input), fc = 12.5 MHz | 32 | _ | _ | ns | | High Level Clock Pulse Width | t <sub>WSH</sub> | For external clock operation | 15.2 | | | μS | | Low Level Clock Pulse Width | t <sub>WSL</sub> | (XTIN input), fs = 32.768 kHz | 13.2 | _ | _ | μ3 | # Recommended Oscillating Conditions $$(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Topr} = -30 \text{ to } 70^{\circ}\text{C})$$ | ſ | PARAMETER | Oscillator | Oscillation<br>Frequency | Recommended Oscillator | | Recommended Constant | | |---|-------------------------------|--------------------|--------------------------|------------------------|------------|----------------------|----------------| | l | | | | | | C <sub>1</sub> | C <sub>2</sub> | | ſ | High-frequency<br>Oscillation | Ceramic Resonator | 12.5 MHz | Murata | CSA12.5MTZ | 30 pF | 30 pF | | l | | | 8 MHz | Murata | CSA8.00MTZ | 30 pF | 30 pF | | | | Crystal Oscillator | 12.5 MHz | NDK | AT-51 | 10 pF | 10 pF | | | Low-frequency<br>Oscillation | Crystal Oscillator | 32.768 kHz | NDK | MX-38T | 15 pF | 15 pF | (1) High-frequency Oscillation (2) Low-frequency Oscillation Note: An electrical shield by metal shield plate on the surface of IC package should be recommendable in order to prevent the device from the high electric fieldstress applied from CRT (Cathode Ray Tube) for continuous reliable operation. 0.2 0.4 0.6 0.8 P0, P1, P2, P3, P4, P5 ports 1 1.2 (V) **3-77-140** 2007-10-23