CMOS 8-Bit Microcontroller # TMP87CH75F, TMP87CM75F The 87CH75/87CM75 are the high speed and high performance 8-bit single chip microcomputers. These MCU contain 8-bit A/D conversion inputs and a VFT (Vacuum Fluorescent Tube) driver on a chip. | Part No. | ROM | RAM | Package | OTP MCU | |------------|--------------|-------------|---------------------|----------------| | TMP87CH75F | 16 K × 8-bit | 512 x 8-bit | D OFD100 1420 0 CFA | TM 4D07DM 47FF | | TMP87CM75F | 32 K × 8-bit | 1 K × 8-bit | P-QFP100-1420-0.65A | TMP87PM75F | #### **Features** - ◆8-bit single chip microcomputer TLCS-870 Series - Instruction execution time: 0.5 $\mu$ s (at 8 MHz), 122 $\mu$ s (at 32.768 kHz) - 412 basic instructions - Multiplication and Division (8 bits x 8 bits, 16 bits ÷ 8 bits) - Bit manipulations (Set/Clear/Complement/Load/Store/Test/Exclusive OR) - 16-bit data operations - 1-byte jump/subroutine-call (Short relative jump/ Vector call) - ◆15 interrupt sources (External: 6, Internal: 9) - All sources have independent latches each, and nested interrupt control is available. - 3 edge-selectable external interrupts with noise reject - High-speed task switching by register bank changeover - ◆ 13 Input/Output ports (89 pins) - Hight current output: 16 pins (typ. 20 mA) 030619EBP1 - The information contained herein is subject to change without notice. - The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No - assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of TOSHIBA or others. TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property. In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc.. - The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a 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, transport to instruments. transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. - The products described in this document are subject to the foreign exchange and foreign trade laws. - TOSHIBA products should not be embedded to the downstream products which are prohibited to be produced and sold, under any law and regulations - For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions. Purchase of TOSHIBA I<sup>2</sup> C components conveys a license under the Philips I<sup>2</sup> C Patent Rights to use these components in an I<sup>2</sup> C system, provided that the system conforms to the I<sup>2</sup> C Standard Specification as defined by - www. Two 16-bit Timer/Counters - Timer, Event counter, programmable pulse generator output, Pulse width measurement, External trigger timer, Window modes. - ◆Two 8-bit Timer/Counters - Timer, Event counter, Capture (Pulse width/duty measurement), PWM output, Programmable divider output modes - ◆Time Base Timer (Interrupt frequency: 1 Hz to 1634 kHz) - ◆Divider output function (frequency: 1 kHz to 8 kHz) - ◆Watchdog Timer - Interrupt source/reset output (programmable) - ◆8-bit Serial Interface - With 8 bytes transmit/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 A/D converter with sample and hold - 16 analog inputs - Conversion time: 23 $\mu$ s at 8 MHz - ◆ Vacuum Fluorescent Tube Driver (automatic display) - Programmable grid scan - High breakdown voltage ports (max. 40 V × 51 bits) - **♦** Dual clock operation - Single/Dual-clock mode (option) - ◆ 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 interrupts. - SLEEP mode: CPU stops, and Peripherals operate using low-frequency clock. Release by interrupts. - igoplus Wide operating voltage: 2.7 to 5.5 V at 32.768 kHz, 4.5 to 5.5 V at 8 MHz / 32.768 kHz - ◆Emulation Pod: BM87CM75F0A ## **TOSHIBA** ### Pin Assignments (Top View) Note: All VDDs should be connected externally for keeping the same voltage level. # **Block Diagram** # Pin Function | Pin Name | Input / Output | t Function | | | |--------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--| | P07 to P03 | 1/0 | Two 8-bit programmable input / output ports (tri-state). | | | | P02 (SO1) | I/O (Output) | Each bit of these ports can be individually | SIO1 serial data Output | | | P01 (SI1) | I/O (Input) | configured as an input or an output under sftware control. | SIO serial data Input | | | P00 (SCK1) | I/O (I/O) | When used as a SIO input / output, an | SIO serial clock input / output | | | P17 (INT4/TC3) | | External interrupt input, a timer / counter input, the latch must be set to "0". When | External interrupt input 4 or<br>Timer / Counter 3 input | | | P16 (INT2) | I/O (Input) | used as PPG output or divider output, the | External interrupt input 2 | | | P15 (INT3 / TC1) | ] | latch must be set to "1". | External interrupt input 3 or<br>Timer / Counter 1 input | | | P14 (TC4 / PDO / PWM) | I/O (I/O) | | Timer counter 4 input or 8-bit programmable divider output or 8-bit PWM output | | | P13 ( <del>DVO</del> ) | I/O (Output) | | Divider output | | | P12 (TC2 / PPG) | I/O (I/O) | | Timer counter 2 input or Programmable pulse generator output | | | P11 (INT1) | 1/0/(===+) | | External interrupt input 1 | | | P10 (ĪNTO) | I/O (Input) | | External interrupt input 0 | | | P22 (XOUT) | I/O (Output) | 3-bit input / output port with latch. | Resonator connectiong pins (32.768 kF For inputting external clock, XTIN is us | | | P21 (XTIN) | | When used as input port, or external interrupt input, STOP mode release signal | and XOUT is opened. | | | P20 (ĪNT5 / STOP) | I/O (Input) | input, the latch must be set to "1". | External interrupt input 5 or STOP mode release signal input | | | P32 ( <del>SCK0</del> ) | I/O (I/O) | 3-bit programmable input/output ports (Sink open drain). | SIO0 serial clock input / output | | | P31 (SDA / SO0) | I/O<br>(I/O/Output) | Each bit of these ports can be individually configured as an input or an output | I <sup>2</sup> C bus serial data input / output or SIO0 serial data output | | | DO0 (65) (610) | | under software control. When used as a I <sup>2</sup> C input/output, the | I <sup>2</sup> C bus serial clock input / output or SIO0 | | | P30 (SCL / SI0) | I/O (I/O/Input) | latch must be set to "1" | serial data input | | | P47 (AIN7) to P40 (AIN0) | I/O (Input) | Two 8-bit programmable input / output ports (tri-state). Each bit of these ports can be individuallay configured as an input or an | A/D converter analog inputs | | | P57 (AIN17) to | 1/0 // 1 | output under software control. When used as analog input, the P4CR and | | | | P50 (AIN10) | I/O (Input) | P5CR must be set to "0". | | | | P67 (V7) to P60 (V0) | | Six 8-bit high breakdown voltage output | | | | P77 (V15) to P70 (V8) | | ports with the latch. | | | | P87 (V23) to P80 (V16) | ] | When used as a VFT driver output, the | | | | P97 (V31) to P90 (V24) | l/O (Output) | latch must be cleared to "0". | VET driver output | | | PD7 (V39) to PD0 (V32) | | | VFT driver output | | | PE7 (V47) toPE0 (V40) | | | | | | PF2 (V50) to PE0 (V48) | | 3-bit high breakdown voltage output ports with the latch. When used as a VFT driver output, the latch must be cleared to "0". | | | **TOSHIBA** | Pin Name | Input / Output | Function | | | |------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|--| | XIN, XOUT | Resonator connecting pins for high-frequency clock. XIN, XOUT Input, output For inputting external clock, XIN is used and XOUT is opened. | | | | | RESET | I/O | Reset signal input or watchdog timer output / address-trap-reset output / system-clock-reset outputed. | | | | TEST | Input | Test pin for out-going test. Be tied to low. | | | | VDD, VSS (Note) | | + 5 V, 0 V (GND) | | | | VKK Power Supply VAREF, VASS | | VFT driver power supply | | | | | | Analog reference voltage inputs (High, Low) | | | $Note: \ \ All\ VDDs\ should\ be\ connected\ externally\ for\ keeping\ the\ same\ voltage\ level.$ 2004-10-01 ### OPERATIONAL DESCRIPTION ### 1. CPU CORE FUNCTIONS The CPU core consists of a CPU, a system clock controller, an interrupt controller, and a watchdog timer. This section provides a description of the CPU core, the program memory (ROM), the data memory (RAM), and the reset circuit. # 1.1 Memory Address Map The TLCS-870 Series is capable of addressing 64K bytes of memory. Figure 1-1 shows the memory address maps of the 87CH75/M75. In the TLCS-870 Series, the memory is organized 4 address spaces (ROM, RAM, SFR, and DBR). It uses a memory mapped I/O system, and all I/O registers are mapped in the SFR/DBR address spaces. There are 16 banks of general-purpose registers. The register banks are also assigned to the first 128 bytes of the RAM address space. Figure 1-1. Memory Address Maps ### 1.2 Program Memory (ROM) The 87CH75 has a $16K \times 8$ -bit (addresses $C000_H$ -FFFF<sub>H</sub>), the 87CM75 has a $32K \times 8$ -bit (address $8000_H$ -FFFF<sub>H</sub>) of program memory (mask programmed ROM). Addresses FF00<sub>H</sub>-FFFF<sub>H</sub> in the program memory can also be used for special purposes. ### (1) Interrupt / Reset vector table (addresses FFEO<sub>H</sub>-FFFF<sub>H</sub>) This table consists of a reset vector and 16 interrupt vectors (2 bytes/vector). These vectors store a reset start address and interrupt service routine entry addresses. ### (2) Vector table for **vector call** instructions (addresses FFC0<sub>H</sub>-FFDF<sub>H</sub>) This table stores call vectors (subroutine entry address, 2 bytes/vector) for the vector call instructions [CALLV n]. There are 16 vectors. The CALLV instruction increases memory efficiency when utilized for frequently used subroutine calls (called from 3 or more locations). ### (3) Entry area (addresses FF00<sub>H</sub>-FFFF<sub>H</sub>) for page call instructions This is the subroutine entry address area for the page call instructions [CALLP n]. Addresses FF00<sub>H</sub>-FFBF<sub>H</sub> are normally used because address FFC0<sub>H</sub>-FFFF<sub>H</sub> are used for the vector tables. Programs and fixed data are stored in the program memory. The instruction to be executed next is read from the address indicated by the current contents of the program counter (PC). There are relative jump and absolute jump instructions. The concepts of page or bank boundaries are not used in the program memory concerning any jump instruction. Example: The relationship between the jump instructions and the PC. - ① 5-bit PC-relative jump [JRS cc, \$ + 2 + d] E8C4H: JRS T, \$ + 2 + 08H When JF = 1, the jump is made to E8CE<sub>H</sub>, which is 08<sub>H</sub> added to the contents of the PC. (The PC contains the address of the instruction being executed + 2; therefore, in this case, the PC contents are E8C4<sub>H</sub> + 2 = E8C6<sub>H</sub>.) - ② 8-bit PC-relative jump [JR cc,\$+2+d] E8C4H: JR Z, \$+2+80HWhen ZF = 1, the jump is made to E846H, which is FF80H (-128) added to the current contents of the PC. - 3 16-bit absolute jump [JP a] E8C4H: JP 0C235H An unconditional jump is made to address C235H. The absolute jump instruction can jump anywhere within the entire 64K-byte space. Figure 1-2. Program Memory Map In the TLCS-870 Series, the same instruction used to access the data memory (e. g. [LD A, (HL) ] ) is also used to read out fixed data (ROM data) stored in the program memory. The register-offset-PC-relative addressing (PC + A) instructions can also be used, and the code conversion, table look-up and n-way multiple-direction jump processing can easily be programmed. ``` www.DataSheet4Example 1 : Loads the ROM contents at the address specified by the HL register pair contents into the accumulator (HL \ge A000_H): LD A, (HL) ; A←ROM (HL) Example 2: Converts BCD to 7-segment code (common anode LED). When A = 05H, 92H is output to port PO after executing the following program: LD (P0), (PC + A) A, TABLE - $ - 4 ADD ; P0 \leftarrow ROM (TABLE + A) IRS T, SNEXT TABLE: DB 0C0H, 0F9H, 0A4H, 0B0H, 99H, 92H, 82H, 0D8H, 80H, 98H SNEXT: Notes: "$" is a header address of ADD instruction. DB is a byte data difinition instruction. SHLC A JΡ (PC + A) N-way multiple jump in accordance with the contents of Example 3: accumulator (0 \le A \le 3): SHLC Α ; if A = 00_H then PC \leftarrow C234_H 78 JΡ (PC + A) if A = 01_H then PC \leftarrow C378_H 37 if A = 02_H then PC \leftarrow DA37_H DΑ if A = 03_H then PC \leftarrow E1B0_H B0 0C234H, 0C378H, 0DA37H, 0E1B0H E 1 ``` ### 1.3 Program Counter (PC) Note: DW is a word data definition instruction. The program counter (PC) is a 16-bit register which indicates the program memory address where the instruction to be executed next is stored. After reset, the user defined reset vector stored in the vector table (addresses FFFF<sub>H</sub> and FFFE<sub>H</sub>) is loaded into the PC; therefore, program execution is possible from any desired address. For example, when CO<sub>H</sub> and 3E<sub>H</sub> are stored at addresses FFFF<sub>H</sub> and FFFE<sub>H</sub>, respectively, the execution starts from address CO3E<sub>H</sub> after reset. The TLCS-870 Series utilizes pipelined processing (instruction pre-fetch); therefore, the PC always indicates 2 addresses in advance. For example, while a 1-byte instruction stored at address C123<sub>H</sub> is being executed, the PC contains C125<sub>H</sub>. Figure 1-3. Program Counter # 1.4 Data Memory (RAM) The 87CH75 have a $512 \times 8$ -bits (addresses $0040_H$ - $023F_H$ ), and the 87CM75 have a $1K \times 8$ bit (address $0040_H$ to $043F_H$ ) of data memory (static RAM). Figure 1-4 shows the data memory map. Addresses $0000_H$ - $00FF_H$ are used as a direct addressing area to enhance instructions which utilize this addressing mode; therefore, addresses $0040_H$ - $00FF_H$ in the data memory can also be used for user flags or user counters. General-purpose register banks (8 registers $\times$ 16 banks) are also assigned to the 128 bytes of addresses $0040_H$ - $00BF_H$ . Access as data memory is still possible even when being used for registers. For example, when the contents of the data memory at address $0040_H$ is read out, the contents of the accumulator in the bank 0 are also read out. The stack can be located anywhere within the data memory except the register bank area. The stack depth is limited only by the free data memory size. For more details on the stack, see section "1.7 Stack and Stack Pointer". The 87CH75/M75 cannot execute programs placed in the data memory. When the program counter indicates a data memory address, a bus error occurs and an address-trap-reset applies. The $\overline{\text{RESET}}$ pin goes low during the address-trap-reset. www.DataSheet4Example 1: If bit 2 at data memory address 00C0<sub>H</sub> is "1", 00<sub>H</sub> is written to data memory at address 00E3<sub>H</sub>; otherwise, FF<sub>H</sub> is written to the data memory at address 00E3<sub>H</sub>: TEST (00C0H).2 ; if $(00C0_H)_2 = 0$ then jump JRS T,SZERO CLR (00E3H) ; $(00E3_{H}) \leftarrow 00_{H}$ JRS T,SNEXT SZERO: LD (00E3H), 0FFH ; $(00E3_H) \leftarrow FF_H$ SNEXT: Example 2: Increments the contents of data memory at address 00F5<sub>H</sub>, and clears to 00<sub>H</sub> when 10<sub>H</sub> is exceeded: INC (00F5H) ; $(00F5_H) \leftarrow (00F5_H) + 1$ AND (00F5H), 0FH ; $(00F5_H) \leftarrow (00F5_H)_{\wedge} 0F_H$ The data memory contents become unstable when the power supply is turned on; therefore, the data memory should be initialized by an initialization routine. Note that the general-purpuse registers are mapped in the RAM; therefore, do not clear RAM at the current bank addresses. Example 1: Clears RAM to "00H" except the bank 0: (87CH75) 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, 01F7H ; 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: (87CM75/PM75) LD HL, 0048H ; Sets start address to HL register pair LD A, H ; Sets initial data $(00_H)$ to A register LD BC, 03F7H ; Sets number of byte to BC register pair SRAMCLR: LD (HL+), A DEC BC JRS F, SRAMCLR Figure 1-4. Data Memory Map ### 1.5 General-purpose Register Banks The general-purpose registers are mapped into addresses $0040_{H}$ - $00BF_{H}$ in the data memory as shown in Figure 1-4. There are 16 register banks, and each bank contains eight 8-bit registers W, A, B, C, D, E, H, and L. Figure 1-5 shows the general-purpose register bank configuration. Figure 1-5. General-purpose Register Banks In addition to access in 8-bit units, the registers can also be accessed in 16-bit units as the register pairs WA, BC, DE, and HL. Besides its function as a general-purpose register, the register also has the following functions: ### (1) A, WA The A register functions as an 8-bit accumulator and WA the register pair functions as a 16-bit accumulator (W is high byte and A is low byte). Registers other than A can also be used as accumulators for 8-bit operations. ``` Examples: ① ADD A, B ; Adds B contents to A contents and stores the result into A. © SUB WA, 1234H ; Subtracts 1234<sub>H</sub> from WA contents and stores the result into WA. © SUB E, A ; Subtracts A contents from E contents, and stores the result into E. ``` ### (2) HL, DE The HL and DE specify a memory address. The HL register pair functions as data pointer (HL) / index register (HL + d) / base register (HL + C), and the DE register pair function as a data pointer (DE). The HL also has an auto-post- increment and auto-pre-decrement functions. This function simplifies multiple digit data processing, software LIFO (last-in first-out) processing, etc. | Example 1 : | 1 | LD | A, (HL) | ; | Loads the memory contents at the address specified by HL into A. | |-------------|---|----|---------------|---|------------------------------------------------------------------------| | | 2 | LD | A, (HL + 52H) | ; | Loads the memory contents at the address specified by the value | | | | | | | obtained by adding 52 <sub>H</sub> to HL contents into A. | | | 3 | LD | A, (HL + C) | ; | Loads the memory contents at the address specified by the value | | | | | | | obtained by adding the register C contents to HL contents into A. | | | 4 | LD | A, (HL+) | ; | Loads the memory contents at the address specified by HL into A. $ \\$ | | | | | | | Then increments HL. | | | 5 | LD | A, ( – HL) | ; | Decrements HL. Then loads the memory contents at the address | | | | | | | specified by new HL into A. | The TLCS-870 Series can transfer data directly memory to memory, and operate directly between memory data and memory data. This facilitates the programming of block processing. 87CH75-12 2004-10-01 Example 2: Block transfer LD B, m ; m = n - 1 (n : Number of bytes to transfer) LD ; Sets destination address to HL HL, DSTA ; Sets source address to DE LD DE, SRCA SLOOP: LD (HL), (DE) ; (HL) ← (DE) INC HL INC DE DEC JRS F, SLOOP #### (3) B, C, BC Registers B and C can be used as 8-bit buffers or counters, and the BC register pair can be used as a 16-bit buffer or counter. The C register functions as an offset register for register-offset index addressing (refer to example 1 ③ above) and as a divisor register for the division instruction [DIV gg, C]. ``` Example 1: Repeat processing ``` SREPEAT: processing (n + 1 times processing) DEC B JRS F, SREPEAT Example 2 : Unsigned integer division (16-bit ÷ 8-bit) DIV WA, C ; Divides the WA contents by the C contents, places the quotient in A and the remainder in W. The general-purpose register banks are selected by the 4-bit register bank selector (RBS). During reset, the RBS is initialized to "0". The bank selected by the RBS is called the current bank. Together with the flag, the RBS is assigned to address 003F<sub>H</sub> in the SFR as the program status word (PSW). There are 3 instructions [LD RBS, n], [PUSH PSW] and [POP PSW] to access the PSW. The PSW can be also operated by the memory access instruction. ``` Example 1 : Incrementing the RBS INC (003FH) ; RBS \leftarrow RBS + 1 Example 2 : Reading the RBS LD A, (003FH) ; A \leftarrow PSW (A<sub>3-0</sub> \leftarrow RBS, A<sub>7-4</sub>\leftarrow Flags) ``` Highly efficient programming and high-speed task switching are possible by using bank changeover to save registers during interrupt and to transfer parameters during subroutine processing. During interrupt, the PSW is automatically saved onto the stack. The bank used before the interrupt was accepted is restored automatically by executing an interrupt return instruction [RETI]/[RETN]; therefore, there is no need for the RBS save/restore software processing. The TLCS-870 Series supports a maximum of 15 interrupt sources. One bank is assigned to the main program, and one bank can be assigned to each source. Also, to increase the efficiency of data memory usage, assign the same bank to interrupt sources which are not nested. Example: Saving /restoring registers during interrupt task using bank changeover. ``` PINT1: LD RBS, n ; RBS ← n (Bank changeover) Interrupt processing ; Maskable interrupt return (Bank restoring) ``` 87CH75-13 2004-10-01 ### 1.6 Program Status Word (PSW) The program status word (PSW) consists of a register bank selector (RBS) and four flags, and the PSW is assigned to address 003F<sub>H</sub> in the SFR. The RBS can be read and written using the memory access instruction (e. g. [LD A, (003FH)], [LD (003FH), A], however the flags can only be read. When writing to the PSW, the change specified by the instruction is made without writing data to the flags. For example, when the instruction [LD (003FH), 05H] is executed, "5" is written to the RBS and the JF is set to "1", but the other flags are not affected. [PUSH PSW] and [POP PSW] are the PSW access instructions. ### 1.6.1 Register Bank Selector (RBS) The register bank selector (RBS) is a 4-bit register used to select general-purpose register banks. For example, when RBS = 2, bank 2 is currently selected. During reset, the RBS is initialized to "0". Figure 1-6. PSW (Flags, RBS) Configuration ### 1.6.2 Flags The flags are configured with the upper 4 bits: a zero flag, a carry flag, a half carry flag and a jump status flag. The flags are set or cleared under conditions specified by the instruction. These flags except the half carry flag are used as jump condition "cc" for conditional jump instructions [JR cc, +2+d]/[JRS cc, +2+d]. After reset, the jump status flag is initialized to "1", other flags are not affected. # (1) Zero flag (ZF) The ZF is set to "1" if the operation result or the transfer data is $00_H$ (for 8-bit operations and data transfers)/ $0000_H$ (for 16-bit operations); otherwise the ZF is cleared to "0". During the bit manipulation instruction [SET, CLR, and CPL], the ZF is set to "1" if the contents of the specified bit is "0"; otherwise the ZF is cleared to "0". This flag is set to "1" when the upper 8 bits of the product are $00_H$ during the multiplication instruction [MUL], and when $00_H$ for the remainder during the division instruction [DIV]; otherwise it is cleared to "0". #### (2) Carry flag (CF) The CF is set to "1" when a carry out of the MSB (most significant bit) of the result occurred during addition or when a borrow into the MSB of the result occurred during subtraction; otherwise the CF is cleared to "0". During division, this flag is set to "1" when the divisor is $00_H$ (divided by zero error), or when the quotient is $100_H$ or higher (overflow error); otherwise it is cleared. The CF is also affected during the shift/rotate instructions [SHLC, SHRC, ROLC, and RORC]. The data shifted out from a register is set to the CF. This flag is also a 1-bit register (a boolean accumulator) for the bit manipulation instructions. Set/clear/complement are possible with the CF manipulation instructions. ### Example 1: Bit manipulation LD CF, (0007H).5 ; $(0001_H)_2 \leftarrow (0007_H)_5 \forall (009A_H)_0$ XOR CF, (009AH).0LD (0001H).2, CF Example 2: Arithmetic right shift LD CF, A.7 RORC A ### (3) Half carry flag (HF) The HF is set to "1" when a carry occurred between bits 3 and 4 of the operation result during an 8-bit addition, or when a borrow occurred from bit 4 into bit 3 of the result during an 8-bit subtraction; otherwise the HF is cleared to "0". This flag is useful in the decimal adjustment for BCD operations (adjustments using the [DAA r], or [DAS r] instructions). 87CH75-14 2004-10-01 www.DataSheet4Example: BCD operation (The A becomes $47_H$ after executing the following program when A = $19_H$ , B = $28_H$ ) ADD A, B ; $A \leftarrow 41_H$ , $HF \leftarrow 1$ DAA ; $A \leftarrow 41_H + 06_H = 47_H$ (decimal-adjust) ### (4) Jump status flag (JF) Zero or carry information is set to the JF after operation (e. g. INC, ADD, CMP, TEST). The JF provides the jump condition for conditional jump instructions [JRS T/F, \$+2+d], [JR T/F, \$+2+d] (T or F is a condition code). Jump is performed if the JF is "1" for a true condition (T), or the JF is "0" for a false condition (F). The JF is set to "1" after executing the load/exchange/swap/nibble rotate/jump instruction, so that [JRS T, \$ + 2 + d] and [JR T, \$ + 2 + d] can be regarded as an unconditional jump instruction. Example: Jump status flag and conditional jump instruction INC A JRS T, SLABLE1; Jump when a carry is caused by the immediately preceding operation instruction. LD A, (HL) JRS T, SLABLE2; JF is set to "1" by the immediately preceding instruction, making it an unconditional jump instruction. Example: The accumulator and flags will become as shown below after executing the following instructions when the WA register pair, the HL register pair, the data memory at address 00C5<sub>H</sub>, the carry flag and the half carry flag contents being "219AH", "00C5H", "D7H", "1" and "0", respectively. | Instruction | | Acc. after | Flag after execution | | | | | |-------------|----------|------------|----------------------|----|----|----|--| | | traction | execution | JF | ZF | CF | HF | | | ADDC | A, (HL) | 72 | 1 | 0 | 1 | 1 | | | SUBB | A, (HL) | C2 | 1 | 0 | 1 | 0 | | | СМР | A, (HL) | 9A | 0 | 0 | 1 | 0 | | | AND | A, (HL) | 92 | 0 | 0 | 1 | 0 | | | LD | A, (HL) | D7 | 1 | 0 | 1 | 0 | | | ADD | A, 66H | 00 | 1 | 1 | 1 | 1 | | | Instruction | Acc. after | Flag after execution | | | | |----------------|------------|----------------------|----|----|----| | mad detrom | execution | JF | ZF | CF | HF | | INC A | 9В | 0 | 0 | 1 | 0 | | ROLC A | 35 | 1 | 0 | 1 | 0 | | RORC A | CD | 0 | 0 | 0 | 0 | | ADD WA, 0F508H | 16A2 | 1 | 0 | 1 | 0 | | MUL W, A | 13DA | 0 | 0 | 1 | 0 | | SET A.5 | ВА | 1 | 1 | 1 | 0 | #### 1.7 Stack and Stack Pointer #### 1.7.1 Stack The stack provides the area in which the return address or status, etc. are saved before a jump is performed to the processing routine during the execution of a subroutine call instruction or the acceptance of an interrupt. On a subroutine call instruction, the contents of the PC (the return address) is saved; on an interrupt acceptance, the contents of the PC and the PSW are saved (the PSW is pushed first, followed by PC<sub>H</sub> and PC<sub>L</sub>). Therefore, a subroutine call occupies two bytes on the stack; an interrupt occupies three bytes. When returning from the processing routine, executing a subroutine return instruction [RET] restores the contents to the PC from the stack; executing an interrupt return instruction [RETI] / [RETN] restores the contents to the PC and the PSW (the PC<sub>L</sub> is popped first, followed by PC<sub>H</sub> and PSW). The stack can be located anywhere within the data memory space except the register bank area, therefore the stack depth is limited only by the free data memory size. ### 1.7.2 Stack Pointer (SP) The stack pointer (SP) is a 16-bit register containing the address of the next free locations on the stack. The SP is postdecremented when a subroutine call or a push instruction is executed, or when an interrupt is accepted; and the SP is preincremented when a return or a pop instruction is executed. Figure 1-8 shows the stacking order. Figure 1-7. Stack Pointer The SP is not initialized hardware-wise but requires initialization by an initialize routine (sets the highest stack address). [LD SP, mn], [LD SP, gg] and [LD gg, SP] are the SP access instructions (mn; 16-bit immediate data, gg; register pair). Example 1: To initialize the SP LD SP, 023FH ; $SP \leftarrow 023F_H$ Example 2: To read the SP LD HL, SP ; HL←SP Figure 1-8. Stack ### 1.8 System Clock Controller The system clock controller consists of a clock generator, a timing generator, and a stand-by controller. Figure 1-9. System Clock Controller #### 1.8.1 Clock Generator The clock generator generates the basic clock which provides the system clocks supplied to the CPU core and on-chip peripheral hardware. It contains two oscillation circuits: one for the high-frequency clock and one for the low-frequency clock. Power consumption can be reduced by switching of the system clock controller to low-power operation based on the low-frequency clock. The high-frequency (fc) and low-frequency (fs) clocks can be easily obtained by connecting a resonator between the XIN/XOUT and XTIN/XTOUT pins, respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to the XIN/XTIN pin with the XOUT/XTOUT pin not connected. Figure 1-10. Examples of Resonator Connection Note: Accurate Adjustment of the Oscillation Frequency: Although no hardware to externally and directly monitor the basic clock pulse is not provided, the oscillation frequency can be adjusted by providing a program to output fixed frequency pulses to the port while disabling all interrupts and monitoring this pulse. With a system requiring adjustment of the oscillation frequency, the adjusting program must be created beforehand. Example: To output the high-frequency oscillation frequency adjusting monitor pulse to P13 (DVO) pin. SFCCHK: (P1CR), 00001000B ; LD Configures port P13 as an output SET (P1).3 P13 output latch $\leftarrow$ 1 LD (TBTCR), 11100000B ; Enables divider output JRS T, \$ Loops endless fc/1024 ### 1.8.2 Timing Generator The timing generator generates from the basic clock the various system clocks supplied to the CPU core and peripheral hardware. The timing generator provides the following functions: - Generation of main system clock - ② Generation of divider output (DVO) pulses - 3 Generation of source clocks for time base timer - 4 Generation of source clocks for watchdog timer - ⑤ Generation of internal source clocks for timer/counters TC1 TC4 - © Generation of internal clocks for serial interfaces SIO and HSO - (7) 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 21-stage divider with a divided-by-4 prescaler, a main system clock generator, and machine cycle counters. An input clock to the 7th stage of the divider depends on 87CH75-17 2004-10-01 www.DataShethe operating mode and DV7CK (bit 4 in TBTCR) shown in Figure 1-11 as follows. During reset and upon releasing STOP mode, the divider is cleared to "0", however, the prescaler is not cleared. - In the single-clock mode A divided-by-256 of high-frequency clock (fc/28) is input to the 7th stage of the divider. - ② In the dual-clock mode During NORMAL2 or IDLE2 mode (SYSCK = 0), an input clock to the 7th stage of the divider can be selected either "fc/28" or "fs" with DV7CK. During SLOW or SLEEP mode (SYSCK = 1) "fs" is automatically input to the 7th stage. To During SLOW or SLEEP mode (SYSCK = 1), "fs" is automatically input to the 7th stage. To input clock to the 1st stage is stopped; output from the 1st to 6th stages is also stopped. Figure 1-11. Configuration of Timing Generator Figure 1-12. Timing Generator Control Register ### (2) Machine Cycle Instruction execution and on-chip peripheral hardware operation are synchronized with the main system clock. The minimum instruction execution unit is called an "machine cycle". There are a total of 10 different types of instructions for the TLCS-870 Series: ranging from 1-cycle instructions which require one machine cycle for execution to 10-cycle instructions which require 10 machine cycles forexecution. A machine cycle consists of 4 states (S0 - S3), and each state consists of one main system clock. 87CH75-18 Figure 1-13. Machine Cycle ### 1.8.3 Stand-by Controller The stand-by controller starts and stops the oscillation circuits for the high-frequency and low-frequency clocks, and switches the main system clock. There are two operating modes: single-clock and dual-clock. These modes are controlled by the system control registers (SYSCR1, SYSCR2). Figure 1-14 shows the operating mode transition diagram and Figure 1-15 shows the system control registers. Either the single-clock or the dual-clock mode can be selected by an option during reset. ### (1) Single-clock mode Only the oscillation circuit for the high-frequency clock is used, and P21 (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 at fc = 8 MHz). #### ① NORMAL1 mode In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock. In the case where the single-clock mode has been selected as an option, the 87CH75/M75 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 setting IDLE bit in 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 IMF (interrupt master enable flag) is "1" (interrupt enable), the execution will resume upon acceptance of the interrupt, and the operation will return to normal after the interrupt service is completed. When IMF is "0" (interrupt disable), the execution will resume with the instruction which follows IDLE mode start instruction. #### 3 STOP1 mode In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with the lowest power consumption during this mode. The output status of all output ports can be set to either output hold or high-impedance under software control. STOP1 mode is started by setting STOP bit in the system control register 1 (SYSCR1), and STOP1 mode is released by an input (either level-sensitive or edge-sensitive can be programmably selected) to the STOP pin. After the warming-up period is completed, the execution resumes with the next instruction which follows the STOP mode start instruction. # www.DataS(2)et4Dual-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] (0.5 $\mu$ s at fc = 8 MHz) in NORMAL2 and IDLE2 modes, and 4/fs [s] (122 $\mu$ s at fs = 32.768 kHz) in SLOW and SLEEP modes. Note that the 87PM75 is placed in the single-clock mode during reset. To use the dual-clock mode, the low-frequency oscillator should be turned on by executing [SET (SYSCR2).XTEN] instruction. #### ① NORMAL2 mode In this mode, the CPU core is operated using the high-frequency clock. The on-chip peripherals are operated on the high-frequency clock and/or low-frequency clock. In case that the dual-clock mode has been selected as an option, the 87CH75/M75 are placed in this mode after reset. #### ② SLOW mode This mode can be used to reduce power-consumption by turning off oscillation of the high-frequency clock. The CPU core and on-chip peripherals are operated using the low-frequency clock. Switching back and forth between NORMAL2 and SLOW modes is performed by the system control register 2. #### ③ IDLE2 mode In this mode, the internal oscillation circuits remain active. The CPU and the watchdog timer are halted; however, on-chip peripherals 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 operate using the low-frequency clock. Starting and releasing of SLEEP mode is the same as for IDLE1 mode, except that operation returns to SLOW mode. ### **⑤** STOP2 mode As in STOP1 mode, all system operations are halted in this mode. Figure 1-14. Operating Mode Transition Diagram #### System Control Register 1 SYSCR1 STOP RELM | RETM | OUTEN (Initial value: 0000 00\*\*) $(0038_{H})$ 0: CPU core and peripherals remain active **STOP** STOP mode start 1: CPU core and peripherals are halted (start STOP mode) Release method 0: Edge-sensitive release **RELM** for STOP mode 1: Level-sensitive release 0: Return to NORMAL mode Operating mode R/W RETM after STOP mode 1: Return to SLOW mode Port output control 0: High-impedance **OUTEN** during STOP mode 1: Remain unchanged $3 \times 2^{19}$ / fc or $3 \times 2^{13} / fs$ 00: [s] Warming-up time at WUT 219 / fc 01: 213 / fs releasing STOP mode 1\*: Reserved Note 1: Always set RETM to "0" when transiting from NORMAL1 mode to STOP1 mode and from Normal2 mode to STOP2 mode. Always set RETM to "1" when transiting from SLOW mode to STOP2 mode. Note 2: When STOP mode is released with RESET pin input, a return is made to NORMAL mode regardless of the RETM contents. Note 3: fc ; high-frequency clock [Hz] fs ; low-frequency clock [Hz] don't care Bits 1 and 0 in SYSCR1 are read in as undefined data when a read instruction is executed. Note 4: When the STOP mode is started by specifying OUTEN = "0", the internal input of port is fixed to Note 5: "0" and the interrupt of the falling edge may be set. **System Control Register 2** 3 2 1 0 SYSCR2 (Initial value: 10/100 \*\*\*\*) XEN XTEN SYSCK $(0039_{H})$ High-frequency oscillator 0: Turn off oscillation XEN 1: Turn on oscillation 0 : Turn off oscillation Low-frequency oscillator **XTEN** control 1: Turn on oscillation R/M Main system clock select 0 : High-frequency clock **SYSCK** (write)/main system clock 1: Low-frequency clock monitor (read) 0 : CPU and watchdog timer remain active IDLE IDLE mode start 1 : CPU and watchdog timer are stopped (start IDLE mode) A reset is applied (RESET pin output goes low) if both XEN and XTEN are cleared to "0". Note 1: Do not clear XEN to "0" when SYSCK = 0, and do not clear XTEN to "0" when SYSCK = 1. Note 2: WDT; watchdog timer, \*; don't care Note 3: Note 4: Bits 3 - 0 in SYSCR2 are always read in as "1" when a read instruction is executed. Note 5: An optional initial value can be selected for XTEN. Always specify when ordering ES (engineering sample). XTEN operating mode after reset 0 Single-clock mode (NORMAL1) Dual-clock mode (NORMAL2) Note 6: The instruction for specifying Masking Option (Operation Mode) in ES Order sheet is described in ADDITIONAL INFORMATION "Notice for Masking Option of TLCS-870 series" section 8. Figure 1-15. System Control Registers ### 1.8.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 (except for DBR), registers and port output latches are all held in the status in effect before STOP mode was entered. The port output can be select either output hold or high-impedance by setting OUTEN (bit 4 in SYSCR1). - 3 The divider of the timing generator is cleared to "0". - The program counter holds the address of the instruction following the instruction which started STOP mode. STOP mode includes a level-sensitive release mode and an edge-sensitive release mode, either of which can be selected with RELM (bit 6 in SYSCR1). ### a. Level-sensitive release mode (RELM = 1) In this mode, STOP mode is released by setting the STOP pin high. This mode is used for capacitor back-up when the main power supply is cut off and for long term battery back-up. When the STOP pin input is high, executing an instruction which starts the STOP mode will not place in the STOP mode but instead will immediately start the release sequence (warm-up). Thus, to start the STOP mode in the level-sensitive release mode, it is necessary for the program to first confirm that the STOP pin input is low. The following method can be used for confirmation: Using an external interrupt input INT5 (INT5 is a falling edge-sensitive input). Example: Starting STOP mode with an INT5 interrupt. PINT5: **TEST** (P2).0 ; To reject noise, STOP mode does not start if port P20 is at high JRS F, SINT5 LD (SYSCR1), 01000000B ; Sets up the level-sensitive release mode. SET (SYSCR1).7 ; Starts STOP mode (IL), 1111011101010111B ; IL11, 7, 5, $3 \leftarrow 0$ (Clears interrupt latehes) LDW SINT5: RETI Figure 1-16. Level-sensitive Release Mode Note: When changing to the level-sensitive release mode from the edge-sensitive release mode, the release mode is not switched until a rising edge of the STOP pin input is detected. 87CH75-23 2004-10-01 ### www.DataSheet4b.Edge-sensitive release mode (RELM = 0) In this mode, STOP mode is released by a rising edge of the STOP pin input. This is used in applications where a relatively short program is executed repeatedly at periodic intervals. This periodic signal (for example, a clock from a low-power consumption oscillator) is input to the STOP pin. In the edge-sensitive release mode, STOP mode is started even when the STOP pin input is high. ### Example: Starting STOP mode operation in the edge-sensitive release mode PINT5 : LD (SYSCR1), 00000000B ; OUTEN $\leftarrow$ 0 (specifies high-impedance) DI ; IMF $\leftarrow$ 0 (disables interrupt service) SET (SYSCR1). STOP ; STOP $\leftarrow$ (activates stop mode) LDW (IL), 111101110101111B ; IL11, 7, 5, 3 $\leftarrow$ 0 (Clears interrupt latehes) EI ; IMF $\leftarrow$ 1 (enables interrupt service) Figure 1-17. 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. When returning to Normal 1, only the high-frequency clock oscillator is turned on. - ② A warming-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Two different warming-up times can be selected with WUT (bits 2 and 3 in SYSCR1) as determined by the resonator characteristics. - When the warming-up time has elapsed, normal operation resumes with the instruction following the STOP mode start instruction (e.g. [SET (SYSCR1). 7]). The start is made after the divider of the timing generator is cleared to "0". | Table 1-1 | Warming-up | Time | evample | |------------|--------------|-----------|---------| | Table I-I. | vvariiiiu-ub | , i iiiie | examble | | Retu | n to NORMAL1 mode | Return to SLOW mode | | | |---------------------------------------------|----------------------|---------------------|------------------------------------------------------|--------------------| | WUT | At fc = 4.194304 MHz | At fc=8MHz | WUT | At fs = 32.768 kHz | | $3 \times 2^{19}$ / fc [s]<br>$2^{19}$ / fc | 375 [ms]<br>125 | 196.6 [ms]<br>65.5 | 3 × 2 <sup>13</sup> / fs [s]<br>2 <sup>13</sup> / fs | 750 [ms]<br>250 | Note: The warming-up time is obtained by dividing the basic clock by the divider: therefore, the warming-up time may include a certain amount of error if there is any fluctuation of the oscillation frequency when STOP mode is released. Thus, the warming-up time must be considered an approximate value. STOP mode can also be released by setting the RESET pin low, which immediately performs the normal reset operation. In this case, even if the setting is to return to the SLOW mode, it starts from the NORMAL mode. (if the initial XTEN of 87CH75/M75 are set to "1" by mask option, they start from the NORMAL2 mode. In case of 87PM75, starts from NORMAL1 mode. www.DataSheet4U.com www.DataSheet4U.c 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 the STOP mode. The RESET pin input must also be high, rising together with the power supply voltage. In this case, if an external time constant circuit has been connected, the RESET pin input voltage will increase at a slower rate than the power supply voltage. At this time, there is a danger that a reset may occur if input voltage level of the RESET pin drops below the non-inverting high-level input voltage (hysteresis input). ### (2) **IDLE** mode (IDLE1, IDLE2, SLEEP) IDLE mode is controlled by the system control register 2 and maskable interrupts. The following status is maintained during IDLE mode. - ① Operation of the CPU and watchdog timer is halted. The on-chip peripherals continue to operate. - ② The data memory, CPU registers and port output latches are all held in the status in effect before IDLE mode was entered. - ③ The program counter holds the address of the instruction following the instruction which started IDLE mode. IDLE mode includes a normal release mode and an interrupt release mode. Selection is made with the interrupt master enable flag (IMF). Releasing the IDLE mode returns from IDLE1 to NORMAL1, from IDLE2 to NORMAL2, and from SLEEP to SLOW mode. ### a. Normal release mode (IMF = "0") IDLE mode is released by any interrupt source enabled by the individual interrupt enable flag (EF) or an external interrupt 0 (INTO pin) request. Execution resumes with the instruction following the IDLE mode start instruction (e.g. [SET (SYSCR2).4]). Figure 1-19. IDLE Mode The interrupt latch (IL) of the interrupt source releasing the IDLE mode must be cleared to "0" by load instruction. ### b. Interrupt release mode (IMF = "1") IDLE mode is released and interrupt processing is started by any interrupt source enabled with the individual interrupt enable flag (EF) or an external interrupt 0 (INTO pin) request. After the interrupt is processed, the execution resumes from the instruction following the instruction which started IDLE mode. IDLE mode can also be released by setting the RESET pin low, which immediately performs the reset operation. After reset, the 87CH75/M75 are placed in NORMAL mode. The 87PM75 is placed in NORMAL1 mode after reset release. 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. 87CH75-26 2004-10-01 www.DataSheet4U.com #### www.DataS(3)et4SLOW mode SLOW mode is controlled by the system control register 2 and the timer/counter 2. ### a. Switching from NORMAL2 mode to SLOW mode First, set SYSCK (bit 5 in SYSCR2) to switch the main system clock to the low-frequency clock. Next, clear XEN (bit 7 in SYSCR2) to turn off high-frequency oscillation. 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 (Switches the main system clock to the ; SYSCK←1 low-frequency clock) (SYSCR2).7 ; XEN←0 (turns off high-frequency oscillation) Example 2: Switching to SLOW mode after low-frequency clock oscillation has stabilized. ; Sets TC2 mode (TC2CR), 14H (timer mode, source clock: fs) LDW (TREG2), 8000H ; Sets warming-up time (according to Xtal characteristics) ; Enable INTTC2 interrupt SFT (EIRH) . EF14 (TC2CR), 34H ; Starts TC2 LD PINTTC2: ΙD (TC2CR), 10H ; Stops TC2 SET (SYSCR2).5 ; SYSCK←1 (SYSCR2).7 CLR ; XEN←0 RETI CLR VINTTC2: DW 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. After the SYSCK is cleared to "0", the CPU core operate using low frequency clock when the main system clock is switching from low frequency clock to high frequency Note 2: SLOW mode can also be released by setting the RESET pin low, which immediately performs the reset operation. After reset, the 87CH75/M75 are placed in NORMAL2 mode (The PM75 is placed in NORMAL1 mode). Example: Switching from SLOW mode to NORMAL2 mode (fc = 8 MHz, warming-up time is about 7.9 ms). SET (SYSCR2).7 (turns on high-frequency oscillation) ; XEN←1 ΙD (TC2CR), 10H Sets TC2 mode (timer mode, source clock: fc) (TREG2 + 1), 0F8H Sets the warming-up time (according to frequency and resonator characteristics) Enable INTTC2 interrupt (EIRH) . EF14 SET PINTTC2: LD (TC2CR), 10H ; Stops TC2 (TC2CR), 30H (SYSCR2) . 5 (Switches the main system clock to the CLR ; SYSCK←0 ; Starts TC2 high-frequency clcok) **RFTI** LD VINTTC2: DW PINTTC2 ; INTTC2 vector table www.DataSheet4U.com Figure 1-21. Switching between the NORMAL2 and SLOW Modes ### 1.9 Sinterrupt Controller The 87CH75/M75 each have a total of 15 interrupt sources: 6 externals and 9 internals. Nested interrupt control with priorities is also possible. Two of the internal sources are pseudo non-maskable interrupts; the remainder are all maskable interrupts. Interrupt latches (IL) that hold the interrupt requests are provided for interrupt sources. Each interrupt vector is independent. The interrupt latch is set to "1" when an interrupt request is generated and requests the CPU to accept the interrupt. The acceptance of maskable interrupts can be selectively enabled and disabled by the program using the interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). When two or more interrupts are generated simultaneously, the interrupt is accepted in the highest priority order as determined by the hardware. Figure 1-22 shows the interrupt controller. | | I | nterrupt Source | Enable Condition | Interrupt<br>Latch | Vector Table<br>Address | Priority | |-----------------------|---------|----------------------------------|----------------------------|--------------------|-------------------------|----------| | Internal/<br>External | (Reset) | | Non-Maskable | _ | FFFE <sub>H</sub> | High 0 | | Internal | INTSW | (Software interrupt) | Pseudo | _ | FFFC <sub>H</sub> | 1 | | Internal | INTWDT | (Watchdog Timer interrupt) | non-maskable | IL <sub>2</sub> | FFFA <sub>H</sub> | 2 | | External | INT0 | (External interrupt 0) | IMF = 1, INT0EN = 1 | IL <sub>3</sub> | FFF8 <sub>H</sub> | 3 | | Internal | INTTC1 | (16-bit TC1 interrupt) | IMF • EF <sub>4</sub> = 1 | IL <sub>4</sub> | FFF6 <sub>H</sub> | 4 | | External | INT1 | (External interrupt 2) | IMF ⋅ EF <sub>5</sub> = 1 | IL <sub>5</sub> | FFF4 <sub>H</sub> | 5 | | Internal | INTTBT | (Time Base Timer interrupt) | IMF ⋅ EF <sub>6</sub> = 1 | IL <sub>6</sub> | FFF2 <sub>H</sub> | 6 | | External | INT2 | (External interrupt 2) | IMF • EF <sub>7</sub> = 1 | IL <sub>7</sub> | FFF0 <sub>H</sub> | 7 | | Internal | INTTC3 | (8-bit TC3 interrupt) | IMF ⋅ EF <sub>8</sub> = 1 | IL <sub>8</sub> | FFEE <sub>H</sub> | 8 | | Internal | INTSBI | (Serial Bus Interface interrupt) | IMF ⋅ EF <sub>9</sub> = 1 | IL <sub>9</sub> | FFEC <sub>H</sub> | 9 | | Internal | INTTC4 | (8-bit TC4 interrupt) | IMF ⋅ EF <sub>10</sub> = 1 | IL <sub>10</sub> | FFEA <sub>H</sub> | 10 | | External | INT3 | (External interrupt 3) | IMF • EF <sub>11</sub> = 1 | IL <sub>11</sub> | FFE8 <sub>H</sub> | 11 | | External | INT4 | (External interrupt 4) | $IMF \cdot EF_{12} = 1$ | IL <sub>12</sub> | FFE6 <sub>H</sub> | 12 | | Internal | INTSIO1 | (Serial interface1 interrupt) | IMF • EF <sub>13</sub> = 1 | IL <sub>13</sub> | FFE4 <sub>H</sub> | 13 | | Internal | INTTC2 | (16-bit TC2 interrupt) | IMF • EF <sub>14</sub> = 1 | IL <sub>14</sub> | FFE2 <sub>H</sub> | 14 | | External | INT5 | (External interrupt 5) | IMF • EF <sub>15</sub> = 1 | IL <sub>15</sub> | FFE0 <sub>H</sub> | Low 15 | Table 1-2. Interrupt Sources ### (1) Interrupt Latches (IL <sub>15-2</sub>) 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 003C<sub>H</sub> and 003D<sub>H</sub> in the SFR. Each latch can be cleared to "0" individually by an instruction; however, the read-modify-write instruction such as bit manipulation or operation instructions cannot be used (Do not clear the IL<sub>2</sub> for a watchdog timer intlerrupt to "0"). 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), 1110100000111111B ; $L_{12}$ , $L_{10} - L_{6} \leftarrow 0$ Example 2 : Reads interrupt latches $LD \hspace{1cm} WA, \hspace{1cm} (IL) \hspace{1cm} ; \hspace{1cm} W \leftarrow \hspace{-1.5cm} IL_H, \hspace{1cm} A \leftarrow \hspace{-1.5cm} IL_L$ www.DataSheet4U.com 87CH75-31 2004-10-01 www.DataSheet4Example 3: Tests an interrupt latch TEST (IL).7 ; if $IL_7 = 1$ then jump JR F, SSET #### (2) Interrupt Enable Register (EIR) The interrupt enable register (EIR) enables and disables the acceptance of interrupts, except for the 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 003A<sub>H</sub> and 003B<sub>H</sub> in the SFR, and can be read and written by an instruction (including read-modify-write instructions such as bit manipulation instructions). ### ① 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 in the interrupt service program. The IMF is assigned to bit 0 at address 003A<sub>H</sub> in the SFR, and can be read and written by an instruction. The IMF is normally set and cleared by the [EI] and [DI] instructions, and the IMF is initialized to "0" during reset. Note: Do not set IMF to "1" during non-maskable interrupt service programs. ### ② Individual interrupt Enable Flags (EF<sub>15</sub> – EF<sub>4</sub>) These flags enable and disable the acceptance of individual maskable interrupts, except for an external interrupt 0. Setting the corresponding bit of an individual interrupt enable flag to "1" enables acceptance of an interrupt, setting the bit to "0" disables acceptance. Example 1: Sets EF for individual interrupt enable, and sets IMF to "1". LDW (EIR), 1110100010100001B ; $EF_{15} - EF_{13}$ , $EF_{11}$ , $EF_{7}$ , $EF_{5}$ , $IMF \leftarrow 1$ Example 2: Sets an individual interrupt enable flag to "1". SET (EIRH).4 ; $EF_{12} \leftarrow 1$ Figure 1-23. Interrupt Latch (IL) and Interrupt Enable Register (EIR) 87CH75-32 2004-10-01 ### 1.9.1 Interrupt Sequence An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to "0" by a reset or an instruction. Interrupt acceptance sequence requires 8 machine cycles (4 $\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). ### (1) Interrupt acceptance processing - ① 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 are saved (pushed) on the stack. The contents of Stack Pointer is cleareased by 3. - The entry address of the interrupt service program is read from the vector table, and the entry address is loaded to the program counter. - © The instruction stored at the entry address of the interrupt service program is executed. Figure 1-24. Timing Chart of Interrupt Acceptance and Interrupt Return Instruction Example: Correspondence between vector table address for INTTBT and the entry address of the interrupt service program. A maskable interrupt is not accepted until the IMF is set to "1" even if a maskable interrupt of higher priority than that of the current interrupt being serviced. When nested interrupt service is necessary, the IMF is set to "1" in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags. However, an acceptance of external interrupt 0 cannot be disabled by the EF; therefore, if disablement is necessary, either the external interrupt function of the INTO pin must be disabled with the INTOEN in the external interrupt control register (EINTCR) or interrupt processing must be avoided by the program. www.Dat When INTOEN = 0, the interrupt latch IL3 is not set, therefore, the falling edge of the INTO pin input cannot be detected. Example 1: Disables an external interrupt 0 using INT0EN LD (EINTCR), 00000000B ; INT0EN←0 Example 2 : Disables the processing of external interrupt 0 under the software control (using bit 0 at address 00F0<sub>H</sub> as the interrupt processing disable switch) PINTO: TEST (00F0H).0 ; Return without interrupt processing if (00F0<sub>H</sub>)<sub>0</sub> = 1 JRS T, SINTO RETI SINTO: Interrupt processing RETI VINTO: DW PINTO ### (2) General-purpose registers save/restore processing During interrupt acceptance processing, the program counter and the program status word are automatically saved on the stack, but not the accumulator and other registers. These registers are saved by the program if necessary. Also, when nesting multiple interrupt services, it is necessary to avoid using the same data memory area for saving registers. The following method is used to save/restore the general-purpose registers: ① General-purpose register save/restore by register bank changeover: The general-purpose registers can be saved at high-speed by switching to a register bank that is not in use. Normally, bank 0 is used for the main task and banks 1 to 15 are assigned to interrupt service tasks. To increase the efficiency of data memory utilization, the same bank is assigned for interrupt sources which are not nested. The switched bank is automatically restored by executing an interrupt return instruction [RETI] or [RETN]. Therefore, it is not necessary for a program to save the RBS. Example: Register Bank Changeover PINTxx: LD RBS, n ; Switches to bank n (1 μs at 8 MHz) interrupt processing RETI ; Restores bank and Returns Figure 1-25. Saving/Restoring General-purpose Registers www.DataShee(4U,c@ General-purpose register save/restore using push and pop instructions: To save only a specific register, and when the same interrupt source occurs more than once, the general-purpose registers can be saved/restored using push/pop instructions. Example: Register save using push and pop instructions ③ General-purpose registers save/restore using data transfer instructions: Data transfer instructions can be used to save only a specific general-purpose register during processing of a single interrupt. Example: Saving/restoring a register using data transfer instructions PINTxx: LD (GSAVA), A interrupt processing ; Restore A register ; Save A register LD RETI A, (GSAVA) ; Return from interrupt service 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 3 times. | 2 | The stack pointer is incremented 3 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. | Interrupt requests are sampled during the final cycle of the instruction being executed. Thus, the next interrupt can be accepted immediately after the interrupt return instruction is executed. Note: When the interrupt processing time is longer than the interrupt request generation time, the interrupt service task is performed but not the main task. # 1.9.2 Software Interrupt (INTSW) Executing the [SWI] instruction generates a software interrupt and immediately starts interrupt processing (INTSW is highest prioritized interrupt). However, if processing of a non-maskable interrupt is already underway, executing the SWI instruction will not generate a software interrupt but will result in the same operation as the [NOP] instruction. Thus, the [SWI] instruction behaves like the [NOP] instruction. Use the [SWI] instruction only for detection of the address error or for debugging. #### ① Address Error Detection FF<sub>H</sub> is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address. Code FF<sub>H</sub> is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing FF<sub>H</sub> to unused areas of the program memory. the address trap reset is generated in case that an instruction is fetched from RAM or SFR areas. Note: The fetch data from addresses 7F80<sub>H</sub> to 7FFF<sub>H</sub> (test ROM area) for 87CH75/M75 is not "FF<sub>H</sub>". # 2 Debugging Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address. 87CH75-36 2004-10-01 # 1.9.3 External Interrupts The 87CH75/M75 each have six external interrupt inputs (INT0, INT1, INT2, INT3, INT4 and INT5). Four of these are equipped with digital noise rejection circuits (pulse inputs of less than a certain time are eliminated as noise). Edge selection is also possible with INT1, INT2, INT3 and INT4. The INTO/P10 pin can be configured as either an external interrupt input pin or an input/output port, and is configured as an input port during reset. Edge selection, noise rejection control and $\overline{\text{INT0}}/\text{P10}$ 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-3 (a). External Interrupts | Source | Pin | Secondary | Enable | | Edge | | Secondary function pin | |--------|------|--------------|---------------------------------------------|------------|------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Jource | FIII | function pin | conditions | rising | falling | both | , , , , , , , , , , , , , , , , , , , | | INT0 | ĪNT0 | P10 | IMF = 1<br>INT0EN = 1 | _ | 0 | _ | – (hysteresis input) | | INT1 | INT1 | P11 | $IMF \cdot EF_5 = 1$ | INT1ES = 0 | INT1ES = 1 | - | Pulses of less than 15/fc or 63/fc [s] are eliminated as noise. Pulses of equal to or more than 48/fc or 192/fc [s] are regarded as be signals. | | INT2 | INT2 | P16 | $IMF \cdot EF_7 = 1$ $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. | | | | | IMF · EF <sub>7</sub> = 1<br>INT2W = 1 | - | - | INT2W = 1<br>Note 2) | Noise cancellation conditions are as listed in Table 1.4. They are applied to the INT2 pin when it is used for both edge interrupts. | | INT3 | INT3 | INT3 P15/TC1 | $IMF \cdot EF_{11} = 1$ $INT3W = 0$ | INT3ES = 0 | INT3ES = 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. Same applies to pin TC1 (at one edge) | | | | | IMF · EF <sub>11</sub> = 1<br>INT3W = 1 | - | - | INT3W = 1<br>Note 2) | Noise cancellation conditions are as listed in Table 1.4. They are applied to the INT3 pin when it is used for both edge interrupts. | | INT4 | INT4 | P17/TC3 | IMF · EF <sub>11</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. Same applies to pin TC3 (at one edge) | | | | | $ \frac{IMF \cdot EF_{11} = 1}{INT4W = 1} $ | - | - | INT4W = 1<br>Note 2) | Noise cancellation conditions are as listed in Table 1.4. They are applied to the INT4 pin is used for both edge interrupts. To detect remote control signals using timer 3 in capture mode, the INT4 pin is used for both edge interrupts. | | INT5 | ĪNT5 | P20/STOP | $IMF \cdot EF_{15} = 1$ | _ | 0 | _ | – (hysteresis input) | ``` Note 1: The noise rejection function is turned off for INTO, INT1, INT2, INT3, INT4, INT5 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 (INT2EDT) in EINTCR2 (#0025<sub>H</sub>), bit 6 (INT3EDT) in EINTCR3 (#0026H), bit 6 (INT4EDT) in EINTCR4 (#0024H), that is, at the beginning of the interrupt processing routine. INT2EDT, INT3EDT, INT4EDT is valid only for both-edge interrupts (INT2W = 1, INT3W = 1, INT4W = 1). INT2EDT, INT3EDT, INT4EDT is set to 1 by an interrupt as the non- selected edge; cleared to 0 after read automatically. For both-edge interrupts, rising or falling edge is selected by setting/modifying bit 2 (INT2ES), bit 3 (INT3ES), bit 4 (INT4ES) in EINTCR (#0037H). When rising edge is selected (INT3ES = 0), bit 6 in INT3EDT (\#0026_H) 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; #0026H 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 and TC3 pins). Note 4: Noise cancellation/pulse receive conditions for timer/counter are as described below: ① TC1 pin: When the P15 pin is used for TC1 input, INT3W must be cleared to "0". Do not change INT3W to "1". ② TC3 pin: When INTSW = 0, less than 7/fc [s] (noise cancellation) and 24/fc [s] or more (pulse receive). For when INT3W = 1, see Table 1.4. 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 49/fc [s] (when INT1NC = 1) 193/fc [s] (when INT1NC = 0) 2. INT2 pin 25/fc [s] (when \#0025_H: INT2W = 0, falling or rising edge) 25/fc [s] (when \#0025_H: INT2W = 1, and NCS (0, 0, 0)) (26/fc) \times 8.5 + 19/fc [s] (when #0025<sub>H</sub>: INT2W = 1, and NCS (0, 0, 1)) (2^{7}/fc) \times 8.5 + 19/fc [s] (when #0025<sub>H</sub>: INT2W = 1, and NCS (0, 1, 0)) (2^{8}/fc) \times 8.5 + 19/fc [s] (when #0025<sub>H</sub>: INT2W = 1, and NCS (0, 1, 1)) (2^{9}/fc) \times 8.5 + 19/fc [s] (when #0025<sub>H</sub>: INT2W = 1, and NCS (1, 0, 0)) (2^{10}/fc) \times 8.5 + 19/fc [s] (when #0025<sub>H</sub>: INT2W = 1, and NCS (1, 0, 1)) (2^{11}/\text{fc}) \times 8.5 + 19/\text{fc} [s] (when \#0025_H: INT2W = 1, and NCS (1, 1, 0)) (2^{12}/\text{fc}) \times 8.5 + 19/\text{fc} [s] (when #0025<sub>H</sub>: INT2W = 1, and NCS (1, 1, 1)) 3. INT3 pin 25/fc [s] (when \#0026_H: INT3W = 0, falling or rising edge) 25/fc [s] (when \#0026_H: INT3W = 1, and NCS (0, 0, 0)) (2^{6}/fc) \times 8.5 + 19/fc [s] (when #0026<sub>H</sub>: INT3W = 1, and NCS (0, 0, 1)) (2^{7}/fc) \times 8.5 + 19/fc [s] (when #0026<sub>H</sub>: INT3W = 1, and NCS (0, 1, 0)) (2^{8}/fc) \times 8.5 + 19/fc [s] (when #0026<sub>H</sub>: INT3W = 1, and NCS (0, 1, 1)) (29/fc) \times 8.5 + 19/fc [s] (when \#0026_H: INT3W = 1, and NCS (1, 0, 0)) (2^{10}/\text{fc}) \times 8.5 + 19/\text{fc} [s] (when #0026<sub>H</sub>: INT3W = 1, and NCS (1, 0, 1)) (2^{11}/fc) \times 8.5 + 19/fc [s] (when #0026<sub>H</sub>: INT3W = 1, and NCS (1, 1, 0)) (2^{12}/\text{fc}) \times 8.5 + 19/\text{fc} [s] (when \#0026_{\text{H}}: INT3W = 1, and NCS (1, 1, 1)) 4. INT4 pin 25/fc [s] (when \#0024_H: INT4W = 0, falling or rising edge) 25/fc [s] (when \#0024_H: INT4W = 1, and NCS (0, 0, 0)) (26/fc) \times 8.5 + 19/fc [s] (when \#0024_H: INT4W = 1, and NCS (0, 0, 1)) (2^{7}/fc) \times 8.5 + 19/fc [s] (when #0024<sub>H</sub>: INT4W = 1, and NCS (0, 1, 0)) (28/fc) \times 8.5 + 19/fc [s] (when \#0024_H: INT4W = 1, and NCS (0, 1, 1)) (2^{9}/fc) \times 8.5 + 19/fc [s] (when #0024<sub>H</sub>: INT4W = 1, and NCS (1, 0, 0)) (2^{10}/\text{fc}) \times 8.5 + 19/\text{fc} [s] (when #0024<sub>H</sub>: INT4W = 1, and NCS (1, 0, 1)) (2^{11}/fc) \times 8.5 + 19/fc [s] (when #0024<sub>H</sub>: INT4W = 1, and NCS (1, 1, 0)) (2^{12}/fc) \times 8.5 + 19/fc [s] (when #0024<sub>H</sub>: INT4W = 1, and NCS (1, 1, 1)) ``` 87CH75-38 2004-10-01 www.DataSheet4U.com $\overline{INT0}/\overline{INT5} \text{ input} \qquad \qquad t_{INTL}, t_{INTH} > \text{tcyc} \quad \textit{(Note: tcyc = 4/fm [s])}$ Note 6: The pulse width (both "H" and "L" level) for input to the $\overline{\text{INTO}}$ and $\overline{\text{INT5}}$ pins must be over 1 machine cycle. Note 7: When INTOEN = 0, interrupt latch $IL_3$ is not set even if a falling edge is detected for $\overline{INTO}$ pin input. Note 8: When high-impedance is specified for port output in stop mode, port input is forcibly fixed to low level internally. Thus, interrupt latches of external interrupt inputs except INT5 (P20/STOP) which are also used as ports may be set to "1". To specify high-impedance for port output in stop mode, first disable interrupt service (IMF = 0), activate stop mode. After releasing stop mode, clear interrupt latches using load instruction, then, enable interrupt service. Example: Activating stop mode: LD (SYSCR1),01000000B ; OUTEN+O (specifies high-impedance) DI ; IMF+O (disables interrupt service) SET (SYSCR1).STOP ; STOP+1 (activates stop mode) LDW (IL),111001110101111B; IL12,11,7,5,3←0 (clears interrupt latches) EI ; IMF←1 (enables interrupt service) Table 1.3 (b) Noise reject condition for INT2, INT3, INT4 (both-edge interrupt) | #0024, #0025, #0026 | | <b></b> 0026 | max. pulse width | min. pulse width | | |---------------------|--------|--------------|--------------------------------------------|----------------------------------|--| | NCS2×2 | NCS1×1 | NCS0×0 | for noise reject | for immediate signal | | | 0 | 0 | 0 | – (histeresis 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}/\text{fc}) \times 7 - 6/\text{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 <sup>10</sup> /fc) × 7 – 6/fc | (2 <sup>10</sup> /fc) × 8 + 5/fc | | | 1 | 1 | 0 | $(2^{11}/fc) \times 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. 2004-10-01 Figure 1-26 (a). External Interrupt Control Register (1) External Interrupt Control Register 2 EINTCR2 (0025<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<br>1 : Both edge detection | R/W | |---------|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | INT2EDT | Flag indicating an interrupt at selected edge/non-selected edge, when INT2W = 1 (for 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 <sup>6</sup> /fc × 7 – 6/fc) as noise. 010: Cancels (2 <sup>7</sup> /fc × 7 – 6/fc) as noise. 011: Cancels (2 <sup>8</sup> /fc × 7 – 6/fc) as noise. 100: Cancels (2 <sup>9</sup> /fc × 7 – 6/fc) as noise. 101: Cancels (2 <sup>10</sup> /fc × 7 – 6/fc) as noise. 110: Cancels (2 <sup>11</sup> /fc × 7 – 6/fc) as noise. 111: Cancels (2 <sup>12</sup> /fc × 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 ( $\#0025_H$ ) 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 #0037<sub>H</sub>) 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-26 (a). **External Interrupt Control Register 3** EINTCR3 (0026<sub>H</sub>) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------|-------------|---|------|---|-------------|---|---|----------------|------------| | INT3W | INT3<br>EDT | | NCS3 | 1 | INT3<br>EDT | | | (initial value | 0000 00**) | | INT3W | INT3 both edge selection | 0 : Refer to INT3ES<br>1 : Both edge detection | R/W | |---------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | INT3EDT | Flag indicating an interrupt at selected edge/non-selected edge, when INT3W = 1 (for 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^{10}/fc \times 7 - 6/fc)$ as noise. 110 : 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 1 : Interrupt | R | Note 1: INT3EDT and NCS3 are valid only when the INT3W bit in EINTCR3 ( $\#0026_H$ ) 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 $\#0037_H$ ) when INT3W is set to 1 (both-edge detention). If changing the contents of INT3ES during INT2W is set to 1, according to Note 3/4/5 at Figure 1-26 (a). **TMP87CH/M75** Figure 1-26 (b). External Interrupt Control Register (2) Figure 1-26 (C) INT2 both edge detection / one-side edge detection Figure 1-26 (d) INT3/TC1 both edge detection / one-side edge detection Figure 1-26 (e) INT 4/TC3 both edge detection / one-side edge detection # www.DataNotes on the usage of INT2, INT3, INT4 pin (external interrupt) (The functions of only INT2 are described. INT3 and INT4 have the same functions as INT2) # When using the INT2 pin for one edge (either rising or falling) - Note 1: An interrupt generated from the INT2 pin can be detected by reading the interrupt latch (IL7). - Note 2: The greatest care must be taken in setting or rewriting the external interrupt control register (EINTCR: 0037H). - For details, see Figure 1-26. (a) note 2, 3, 4, 5 and 6 in accordance with the using instructions. #### When using the INT2 pin for both edges (rising and falling) - Note 1: When using the INT2 pin for both edges (rising or falling), set bit 7 (INT3W) in EINTCR2 (#0025<sub>H</sub>) to 1. - Note 2: To detect the edge at which an interrupt is generated, read bit 6 (INT2EDT) in EINTCR2 (#0025<sub>H</sub>), that is, at the beginning of the interrupt processing routine. - Note 3: INT2EDT is valid only for both-edge interrupts (INT2W = 1). INT2EDT is set to 1 by an interrupt as the non-selected edge; cleared to 0 after read automatically. For both-edge interrupts, rising or falling edge is selected by setting/modifying bit 2 (INT2ES) in EINTCR (#0037<sub>H</sub>). When rising edge is selected (INT2ES = 0), bit 6 in INT2EDT (#0025<sub>H</sub>) is set to 1 when a falling edge is detected at the INT2 pin. (That is, remains 0 if rising edge is detected.) When falling edge is selected (INT2ES = 1), bit 6 in INT2EDT: #0025<sub>H</sub> is set to 1 when a rising edge is detected at the INT2 pin. (That is, remains 0 at falling edge). - Note 4: The greatest care must be taken in setting or rewriting the external interrupt control register (EINTCR: 0037H). - For details, see Figure 1-26. (a) note 2, 3, 4, 5 and 6 in accordance with the using instructions. # www.Dat Operation description for INT2 (both-edge interrupt) in use: - 1. Operation without setting/modifying external interrupt control register (EINTCR) after reset: For both-edge interrupts, rising edge is selected (INT2ES = 0) and fixed. - 1) Case 1: When the initial state of the INT2 pin is high after reset: 2) Case2: When the initial state of the INT2 pin is low after reset: - 2 Operation with setting/modifying external interrupt control register (EINTCR) after reset: - 1) Case3: When the initial state of the INT2 pin is low after reset/low at edge switchover from rising to falling: 2) Case4: When the initial state of the INT2 pin is high after reset/high at edge switchover from rising to falling: Www.Data3) Case5 Case 5: When the initial state of the INT2 pin is high after reset/low at edge switchover from rising to falling: 4) Case6: When the initial state of the INT2 pin is low after reset/high at edge switchover from rising to falling: # 1.10 Watchdog Timer (WDT) The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or the like, and resumes the CPU to the normal state. The watchdog timer signal for detecting malfunction can be selected either as a reset output or a non-maskable interrupt request. However, selection is possible only once after reset. At first, the reset output is selected. When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals. # 1.10.1 Watchdog Timer Configuration Figure 1-27. Watchdog Timer Configuration # 1.10.2 Watchdog Timer Control Figure 1-28 shows the watchdog timer control registers (WDTCR1, WDTCR2). The watchdog timer is automatically enabled after reset. (1) Malfunction detection methods using the watchdog timer The CPU malfunction is detected as follows: - ① Setting the detection time, selecting output, and clearing the binary counter. - ② Repeatedly clearing the binary counter within the setting detection time. If a CPU malfunction occurs for any cause, the watchdog timer output will become active on the rise of an overflow from the binary counters unless the binary counters are cleared. At this time, when WDTOUT = 1 a reset is generated, which drives the $\overline{\text{RESET}}$ pin low to reset the internal hardware and the external circuits. When WDTOUT = 0, a watchdog timer interrupt (INTWDT) is generated. The watchdog timer temporarily stops counting in STOP mode (including warm-up) or IDLE mode, and automatically restarts (continues counting) when STOP/IDLE mode is released. 87CH75-50 2004-10-01 #### Watchdog Timer Control Register 1 WDTCR1 (Initial value: \*\*\*\* 1001) WDT OUT $(0034_{H})$ WDTT Watchdog timer 0: Disable (It is necessary to write the disable code to WDTCR2) WDTEN enable/disable 1: Enable 2<sup>17</sup> / fs 00: 2<sup>25</sup> / fc or [s] 01: 2<sup>23</sup> / fc or 215 / fs Watchdog timer write WDTT 2<sup>13</sup> / fs 10: 2<sup>21</sup> / fc or detection time only 11: 2<sup>19</sup> / fc or 211 / fs Watchdog timer 0: Interrupt request WDTOUT output select 1: Reset output WDTOUT cannot be set to "1" by program after clearing WDTOUT to "0". Note 1: Note 2: fc ; High-frequency clock [Hz] fs ; Low-frequency clock [Hz] \* ; don't care Note 3: WDTCR1 is a write-only register and must not be used with any of the read-modify-write instructions. Note 4: Disable the watchdog timer or clear the counter just before switching to STOP mode. When the counter is cleared just before switching to STOP mode, clear the counter again subsequently to releasing STOP mode. Watchdog Timer Control Register 2 WDTCR2 (Initial value: \*\*\*\* \*\*\*\*) $(0035_{H})$ Watchdog timer binary counter clear (clear code) Watchdog timer control write WDTCR2 $B1_H$ : Watchdog timer disable (disable code) code write register only others: Invalid Note 1: The disable code is invalid unless written when WDTEN = 0. Note 2: \*; don't care Note 3: Since WDTCR2 is a write-only register, read-modify-write instructions (e.g., bit manipulating instructions such as SET or CLR and arithmentic instructions such as AND or OR) cannot be used for read/write to this register. Note 4: To clear binary counter doesn't initialize the source clock, therefore, it is recommended to clear binary counter within 3/4 of the detection period. Figure 1-28. Watchdog Timer Control Registers Table 1-4. Watchdog Timer Detection Time | | Operating mode | Detection time | | | |--------------------------|--------------------------------------------|----------------------|---------------|--------------------| | NORMAL1 | NORMAL2 | SLOW | At fc = 8 MHz | At fs = 32.768 kHz | | 2 <sup>25</sup> / fc [s] | 2 <sup>25</sup> / fc, 2 <sup>17</sup> / fs | 2 <sup>17</sup> / fs | 4.194 s | 4 s | | 2 <sup>23</sup> / fc | 2 <sup>23</sup> / fc, 2 <sup>15</sup> / fs | 2 <sup>15</sup> / fs | 1.048 ms | 1 s | | 2 <sup>21</sup> / fc | 2 <sup>21</sup> / fc, 2 <sup>13</sup> / fs | | 262.1 ms | 250 ms | | 2 <sup>19</sup> / fc | 2 <sup>19</sup> / fc, 2 <sup>11</sup> / fs | | 65.5 ms | 62.5 ms | # (2) Watchdog Timer Enable The watchdog timer is enabled by setting WDTEN (bit 3 in WDTCR1) to "1". WDTEN is initialized to "1" during reset, so the watchdog timer operates immediately after reset is released. Example: Enables watchdog timer LD (WDTCR1), 00001000B ; WDTEN←1 # www.DataS(3)et4Watchdog 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". The watchdog timer is halted temporarily in STOP mode (including warm-up) and IDLE mode, and restarts automatically after STOP or IDLE mode is released. During disabling the watchdog timer, the binary counters are cleared. Example: Disables watchdog timer LDW (WDTCR1), 0B101H ; WDTEN←0, WDTCR2←disable code #### 1.10.3 Watchdog Timer Interrupt (INTWDT) This is a pseudo non-maskable interrupt which can be accepted regardless of the contents of the EIR. If a watchdog timer interrupt or a software interrupt is already accepted, however, the new watchdog timer interrupt waits until the previous interrupt processing is completed (the end of the [RETN] instruction execution). The stack pointer (SP) should be initialized before using the watchdog timer output as an interrupt source with WDTOUT. Example: Watchdog timer interrupt setting up. LD SP, 023FH ; Sets the stack pointer LD (WDTCR1), 00001000B ; WDTOUT←0 # 1.10.4 Watchdog Timer Reset If the watchdog timer output becomes active, a reset is generated, which drives the $\overline{\text{RESET}}$ pin (sink open drain output) low to reset the internal hardware and the external circuits. The reset output time is 12/fc [s] (1.5 $\mu$ s at fc = 8 MHz). The high-frequency clock oscillator also turns on when a watchdog timer reset is generated in SLOW mode. Note: The high-frequency clock oscillator turns on when a watchdog timer reset is generated in SLOW mode. Turns, the reset output time is 220 / fc. The reset output time include a certain amount of error if there is any fluctuation of the The reset output time include a certain amount of error if there is any fluctuation of the oscillation frequency when the high-frequency clock oscillator turns on. Thus, the reset, the reset output time must be considerd approximate value. Figure 1-29. Watchdog Timer Interrupt / Reset #### 1.11 Reset Circuit The 87CH75/M75 each have four types of reset generation procedures: an external reset input, an address trap reset, a watchdog timer reset and a system clock reset. Table 1-5 shows on-chip hardware initialization by reset action. The internal source reset circuit (watchdog timer reset, address trap reset, and system clock reset) is not initialized when power is turned on. Thus, output from the $\overline{\text{RESET}}$ pin may go low (12/fc [s.] (1.5 $\mu$ s at 8 MHz) when power is turned on. 87CH75-52 2004-10-01 | Table 1-5 | Initializing | Internal Status | by Reset Action | |-------------|--------------------|-------------------|-----------------| | I able 1-3. | IIIII III aliziilu | IIIICIIIai Status | DA IZSET WELIGH | | On-chip Hardware | | Initial Value | On-chip Hardware | Initial Value | |----------------------------------|---------|---------------------------------------------|-------------------------------|-----------------------------------| | Program counter | (PC) | (FFFF <sub>H</sub> ) · (FFFE <sub>H</sub> ) | Divider of Timing generator | 0 | | Register bank selector | (RBS) | 0 | | | | Jump status flag | (JF) | 1 | Watchdog timer | Enable | | Interrupt master enable flag | (IMF) | 0 | Output latches of I/O ports | Refer to I/O port | | Interrupt individual enable flac | ıs (EF) | 0 | Cutput fateries of 1/10 ports | circuitry | | Interrupt latches | (IL) | 0 | Control registers | Refer to each of control register | ### 1.11.1 External Reset Input When the RESET pin is held at low for at least 3 machine cycles (12/fc [s]) with the power supply voltage within the operating voltage range and oscillation stable, a reset is applied and the internal state is initialized. When the RESET pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFE<sub>H</sub> - FFFF<sub>H</sub>. The RESET pin contains a Schmitt trigger (hysteresis) with an internal pull-up resistor. A simple power-on-reset can be applied by connecting an external capacitor and a diode. Figure 1-30. Simple Power-on-Reset Circuitry # 1.11.2 Address Trap Reset If a CPU malfunction occurs and an attempt is made to fetch an instruction from the RAM or the SFR area (addresses 87CH75: $0040_H$ - $023F_H$ , 87CM75: $0040_H$ - $043F_H$ , an address-trap-reset will be generated. Then, the RESET pin output will go low. The reset time is 12/fc [s] (1.5 $\mu$ s at 8 MHz). Figure 1-31. Address-Trap-Reset # 1.11.3 Watchdog Timer Reset Refer to Section "1.10 Watchdog Timer". # 1.11.4 System-Clock-Reset Clearing both XEN and XTEN (bits 7 and 6 in SYSCR2) to "0" stops both high-frequency and low-frequency oscillation, and causes the MCU to deadlock. This can be prevented by automatically generating a reset signal whenever XEN = XTEN = 0 is detected to continue the oscillation. Then, the RESET pin output goes low from high-impedance. The reset time is 12/fc [s] (1.5 $\mu$ s at 8 MHz). # 2. ON-CHIP PERIPHERALS FUNCTIONS # 2.1 Special Function Registers (SFR) and Data Buffer Registers (DBR) The TLCS-870 Series uses the memory mapped I/O system, and all peripheral control and data transfers are performed through the special function registers (SFR) and data buffer registers (DBR). The SFR are mapped to addresses $0000_{\rm H} - 003F_{\rm H}$ , and the DBR to addresses $0F80_{\rm H} - 0FFF_{\rm H}$ . Figure 2-1 shows the 87CH75/M75 SFRs and DBRs. | ddress | Read | Write | Address | Read | Write | |-------------------|----------------------------|----------------------------------------|-------------------|---------------------------|---------------------------------------------------| | 0000 <sub>H</sub> | P0 port | | 0020 <sub>H</sub> | | SBICR1 (SBI control 1) | | 01 | P1 Port | | 21 | SBIDBR | (SBI Data Buffer) | | 02 | P2 Port | | 22 | | I <sup>2</sup> CAR (I <sup>2</sup> C bus address) | | 03 | P3 Port | | 23 | SBISR (SBI status) | SBICR2 (SBI control 2) | | 04 | P4 Port | | 24 | EINTCR4 (Exte | rnal interrupt control 4) | | 05 | P5 Port | | 25 | EINTCR2 (Exte | rnal interrupt control 2) | | 06 | P6 Port | | 26 | EINTCR3 (Exte | rnal interrupt control 3) | | 07 | P7 Port | | 27 | SIO1SR (SIO status) | SIO1CR1 (SIO1 control 1) | | 80 | P8 Port | | 28 | | SIO1CR2 (SIO1 control 2) | | 09 | P9 Port | | 29 | VFTSR (VFT status) | VFTCR1 (VFT control 1) | | 0A | _ F | OCR (P0 I/O control) | 2A | | VFTCR2 (VFT control 2) | | 0B | F | 1CR (P1 I/O control) | 2B | | P3CR (P3 I/O control) | | 0C | F | 4CR (P4 I/O control) | 2C | | reserved | | 0D | 1 | 5CR (P5 I/O control) | 2D | | reserved | | 0E | ADCCR (A/D conv | erter control) | 2E | | reserved | | 0F | ADCDR (A/D conv. register) | | 2F | | reserved | | 10 | | REG1AL<br>REG1AL | 30 | | reserved | | 11 | l | KEO IAH | 31 | | reserved | | 12 | TREG | IB <sub>L</sub><br>(Timer register 1B) | . 32 | | reserved | | 13 | | ьн | 33 | | reserved | | 14 | | C1CR (TC1 control) | 34 | | WDTCR1 (WDT control) ·· | | 15 | <u> </u> | C2CR (TC2 control) | 35 | _ | WDTCR2 | | 16 | <u> </u> | REG2 <sub>L</sub> (Timer register 2) | 36 | TBTCR | (TBT / TG / DVO control) | | 17 | [ | NEOZH | 37 | EINTCF | R (Interrupt control) | | 18 | TREG3A (Timer | register 3A) | 38 | SYSCR1 | (System control) ······ | | 19 | TREG3B (Timer register 3B) | | 39 | SYSCR2 | (System control) | | 1A | 1 | C3CR (TC3 control) | 3A | EIRL | (Interrupt enable register) | | 1B | | REG4 (Timer register 4) | ЗВ | EIR <sub>H</sub> | (interrupt chapte register) | | 1C | <sub>1</sub> | C4CR (TC4 control) | 3C | IL <sub>L</sub> | (Interrupt latch) ······ | | 1D | PD po | | 3D | IL <sub>H</sub> | (interrupt lateri) | | 1 E | PE po | ort | 3E | | reserved | | 1F | PF pc | rt | 3F | PSW (Program status word) | RBS (Register bank selector) | (a) Special Function Registers Note 1: Do not access reserved areas by the program. Note 2: -: Cannot be accessed. Note 3: When defining address $003F_H$ with assembler symbols, use GPSW and GRBS. Note 4: 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.) Figure 2-1. (a) SFR & DBR Figure 2-1. (b) SFR & DBR # 2.2 I/O Ports The 87CH75/M75 each have 13 parallel input/output ports (89pins) each as follows: | | Primary Function | Secondary Functions | |---------|--------------------|---------------------------------------------------------------------------------------------------| | Port P0 | 8-bit I/O port | Serial port input/output | | Port P1 | 8-bit I/O port | External interrupt input, timer/counter input, and divider output | | Port P2 | 3-bit I/O port | Low-frequency resonator connections, external interrupt input, and STOP mode release signal input | | Port P3 | 4-bit I/O port | Serial bus interface | | Port P4 | 8-bit I/O port | Analog input | | Port P5 | 8-bit I/O port | Analog input | | Port P6 | 8-bit I/O port | VFT output | | Port P7 | 8-bit Outoput port | VFT output | | Port P8 | 8-bit output port | VFT output | | Port P9 | 8-bit I/O port | VFT output | | Port PD | 8-bit I/O port | VFT output | | Port PE | 8-bit I/O port | VFT output | | Port PF | 3-bit I/O port | VFT output | www.Dat.Ports.P0, P1, P2, P3, P4, P5, P6, P7, P8, P9, PD, PE and PF can also use secondary function. Each output port contains a latch, which holds the output data. Input ports excluding P4 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 P0 and P1, whether the pin input data or the output latch contents are read depends on the instructions, as shown below: - (1) Instructions that read the output latch contents - ① XCH r, (src) - ⑤ LD - ② CLR/SET/CPL (src).b - 6 ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), n (pp) . b, CF - ③ CLR/SET/CPL (pp).g④ LD (src).b, CF - (src) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) - (2) Instructions that read the pin input data - ① Instructions other than the above (1) - ② (HL) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) # 2.2.1 Port P0 (P07 - P00) Port P0 is an 8-bit general-purpose input/output port which can be configured as either an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P0 input/output control register (P0CR). Port P0 is configured as an input if its corresponding P0CR bit is cleared to "0", and as an output if its corresponding P0CR bit is set to "1". During reset, POCR is initialized to "0", which configures port PO as input. The PO output latches are also initialized to "0". Data is written into the output latch regardless of POCR contents. Therefore initial output data should be written into the output latch before setting POCR. - Note 1: Ports set to the input mode read the pin states. When input pin and output in exist in port PO together, the contents of the output latch of ports set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch. - Note 2: The POCR is a write-only register. It can not be operated by the read-modify instruction (Bit manipulation instructions of SET, CLR, etc. and Arithmetic instructions of AND, OR, etc.) Figure 2-3. Port P0 and P0CR Example: Setting the upper 4 bits of port P0 as an input port and the lower 4 bits as an output port (Initial output data are $1010_B$ ). LD (P0), 00001010B ; Sets initial data to P0 output latches LD (P0CR), 00001111B ; Sets the port P0 input/output mode #### 2.2.2 Port P1 (P17 - P10) Port P1 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P1 input/output control register (P1CR). Port P1 is configured as an input if its corresponding P1CR bit is cleared to "0", and as an output if its corresponding P1CR bit is set to "1". During reset, P1CR is initialized to "0", which configures port P1 as an input. The P1 output latches are also initialized to "0". Data is written into the output latch regardless of P1CR contents. Therfore initial output data should be written into the output latch before setting P1CR. Port P1 is also used as an external interrupt input, a timer/counter input/output, 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". It is recommended that pins P11 and P15, P16, P17 should be used as external interrupt inputs, timer/counter input, or input ports. The interrupt latch is set on the rising or falling edge of the output when used as output ports. Pin P10 (INTO) can be configured as either an I/O port or an external interrupt input with INTOEN (bit 6 in EINTCR). During reset, the pin P10 (INTO) is configured as an input port P10. - Note 1: Ports set to the input mode read the pin states. When input pin and output in exist in port P1 together, the contents of the output latch of ports set to the input mode may be rewritten by executing the bit manipulation instructions. Pins set to the output mode read a value of the output latch. - Note 2: The P1CR is a write-only register. It can not be operated by the read-modify instruction (Bit manipulation instructions of SET, CLR, etc. and Arithmetic instructions of AND, OR, etc.) Figure 2-4. Port P1 and P1CR Example: Sets P17, P16 and P14 as output ports, P13 and P11 as input ports, and the others as function pins. Internal output data is "1" for the P17 and P14 pins, and "0" for the P16 pin. LD (EINTCR), 01000000B ; INT0EN←1 LD (P1), 101111111B ; P17←1, P14←1, P16←0 LD (P1CR), 11010000B 87CH75-58 2004-10-01 # 2.2.3 Port P2 (P22 - P20) Port P2 is a 3-bit input/output port. It is also used as an external interrupt input, and low-frequency crystal connection pins. When used as an input port, or 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 # 2.2.4 Port P3 (P32 - P30) Port P3 is an 3-bit input/output port, and is also used as serial bus interface (SBI) input/output. 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 input. The P3 output latches are also initialized to "0". Port P3 is also used as a serial bus interface input/output. When used as a secondary function pin, set P3 to the output mode using P3 port input/output control register (P3CR) to control input/output by the output data. (P3 is sink open drain with input/output control. At "1" of the output data, a pin is set to Hi-z and enabled to input.) When a read instruction for port P3 is executed bit 7 to 3 in P3 read in as undefined data. - Note 1: Ports set to the input mode read the pin states. 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. - Note 2: The P3CR is a write-only register. It can not be operated by the read-modify instruction (Bit manipulation instructions of SET, CLR, etc. and Arithmetic instructions of AND, OR, etc.) Figure 2-6. Port P3 # 2.2.5 Port P4 (P47 - 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). At reset, P4CR is set to 0 and AINDS is cleared to 0. Thus, P4 becomes an analog input port. At the same time, the output latch of port P4 is initialized to 0. P4CR is a write-only register. Pins not used for analog input can be used as I/O ports. But do not execute the output instruction to keep the accuracy in A/D conversion. Executing an input instruction on port P4 when the A/D converter is in use reads 0 at pins set for analog input: 1 or 0 at pins not set for analog input, depending on the pin input level. - Note 1: Ports set to the input mode read the pin states. 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. - Note 2: The P4CR is a write-only register. It can not be operated by the read-modify instruction (Bit manipulation instructions of SET, CLR, etc. and Arithmetic instructions of AND, OR, etc.) Figure 2-7. Port P4 # 2.2.6 Port P5 (P57 - 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). At reset, P5CR is set to 0 and AINDS is cleared to 0. Thus, P5 becomes an analog input port. At the same time, the output latch of port P5 is initialized to 0. P5CR is a write-only register. Pins not used for analog input can be used as I/O ports. But do not execute the output instruction to keep the accuracy in A/D conversion. Executing an input instruction on port P5 when the A/D converter is in use reads 0 at pins set for analog input: 1 or 0 at pins not set for analog input, depending on the pin input level. - Note 1: Ports set to the input mode read the pin states. 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. - Note 2: The P5CR is a write-only register. It can not be operated by the read-modify instruction (Bit manipulation instructions of SET, CLR, etc. and Arithmetic instructions of AND, OR, etc.) Figure 2-8. Port P5 # 2.2.7 Port P6 (P67 - P60) Port P6 are 8-bit high-breakdown voltage input/output ports, and are also used as VFT driver outputs, which can directly drive vacuum fluorescent tube (VFT). When used as an input port or a VFT driver output, the output latch should be cleared to "0". The output latches are initialized to "0" during reset. Pins which are not set for VFT driver output can be used as normal I/O port (refer to section "2.12.6 Port Function"). It is recommended that pins P67 to P60 should be used as VFT driver output. Figure 2-9. P6 Port # 2.2.8 Port P7 (P77 - P70) Port P7 are 8-bit high-breakdown voltage input/output ports, and are also used as VFT driver outputs, which can directly drive vacuum fluorescent tube (VFT). When used as an input port or a VFT driver output, the output latch should be cleared to "0". The output latches are initialized to "0" during reset. Pins which are not set for VFT driver output can be used as normal I/O port (refer to section "2.12.6 Port Function"). It is recommended that pins P77 to P70 should be used as VFT driver output. Figure 2-10. P7 Port # 2.2.9 Port P8 (P87 - P80) Port P8 are 8-bit high-breakdown voltage input/output ports, and are also used as VFT driver outputs, which can directly drive vacuum fluorescent tube (VFT). When used as an input port or a VFT driver output, the output latch should be cleared to "0". The output latches are initialized to "0" during reset. Pins which are not set for VFT driver output can be used as normal I/O port (refer to section "2.12.6 Port Function"). It is recommended that pins P87 to P80 should be used as VFT driver output. Figure 2-11. P8 Port # 2.2.10 Port P9 (P97 - P90) Port P9 is 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 input port or a VFT driver output, the output latch should be cleared to "0". The output latches are initialized to "0" during reset. Pins which are not set for VFT driver output can be used as normal I/O port (refer to section "2.12.6 Port Function"). It is recommended that pins P97 to P90 should be used as segment output. Figure 2-12. Port P9 # 2.2.11 PD (PD7 - PD0) , PE (PE7 - PE0) and PF (PF2 - PF0) Ports PD, PE and PF are high-breakdown voltage input/output ports, and are also used as VFT driver outputs, which can directly drive vacuum fluorescent tube (VFT). The segment and the input/output port are specified by VSEL (bit 5 to 0) of VFT driver control register (VFTCR1). At reset, VSEL is cleared to "0" and used as the input/output port. When used as an input port or a VFT driver output, the output latch should be cleared to "0". Pins which are not set for VFT driver output can be used as normal I/O port (refer to section "2.12.6 Port Function"). The output latches are initialized to "0" during reset. When a read instruction for port PF is executed bit 7 to 3 in PF read in as undefined data. Figure 2-13. PD, PE, PF Ports # 2.3 Time Base Timer (TBT) The time-base timer is used to generate the base time for key scan and dynamic display processing. For this purpose, it generates a time-base timer interrupt (INTTBT) at predetermined intervals. This interrupt is generated beginning with the first rising edge of the source clock (the timing generator's divider output selected by TBTCK) after the time-base timer is enabled. Note that since the divider cannot be cleared by a program, the first interrupt only may occur earlier than the set interrupt period (See Figure 2-14, (b).). When selecting the interrupt frequency, make sure the time-base timer is disabled (Do not change the selected interrupt frequency when disabling the active timer either). However, you can select the interrupt frequency simultaneously when enabling the timer. Example: Sets the time base timer frequency to fc/216 [Hz] and enables an INTTBT interrupt. LD (TBTCR), 00001010B SET (EIRL). 6 Figure 2-14. Time Base Timer Figure 2-15. Time Base Timer and Divider Output Control Register Table 2-1. Time Base Timer Interrupt Frequency | TDTCK | NORMAL1/2, | IDLE1/2 mode | SLOW, SLEEP mode | Interrupt Frequency | | | |-------|----------------------|----------------------|----------------------|---------------------|--------------------|--| | ТВТСК | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP Mode | At fc = 8 MHz | At fs = 32.768 kHz | | | 000 | fc / 2 <sup>23</sup> | fs / 2 <sup>15</sup> | fs / 2 <sup>15</sup> | 0.95 Hz | 1 Hz | | | 001 | fc / 2 <sup>21</sup> | fs / 2 <sup>13</sup> | fs / 2 <sup>13</sup> | 3.81 | 4 | | | 010 | fc/2 <sup>16</sup> | fs / 2 <sup>8</sup> | - | 122.07 | 128 | | | 011 | fc / 2 <sup>14</sup> | fs / 2 <sup>6</sup> | - | 488.28 | 512 | | | 100 | fc/2 <sup>13</sup> | fs / 2 <sup>5</sup> | - | 976.56 | 1024 | | | 101 | fc/2 <sup>12</sup> | fs / 2 <sup>4</sup> | - | 1953.12 | 2048 | | | 110 | fc / 2 <sup>11</sup> | fs / 2 <sup>3</sup> | - | 3906.25 | 4096 | | | 111 | fc / 2 <sup>9</sup> | fs / 2 | - | 15625 | 16384 | | # 2.4 Divider Output (DVO) A 50% duty pulse can be output using the divider output circuit, which is useful for piezo-electric buzzer drive. Divider output is from pin P13 (DVO). The P13 output latch should be set to "1" and then the P13 should be configured as an output mode. Divider output circuit is controlled by the control register (TBTCR) shown in Figure 2-12. Figure 2-16. Divider Output Control Register Example: 1 kHz pulse output (at fc = 8 MHz) SET (P1).3 ; P13 output latch $\leftarrow$ 1 LD (P1CR), 00001000B ; Configures P13 as an output mode LD (TBTCR), 10000000B ; DVOEN←1, DVOCK←00 Table 2-2. Frequency of Divider Output | DVOCK | Frequency of<br>Divider Output | At fc = 8 MHz | At fs = 32.768 kHz | |-------|---------------------------------------------|---------------|--------------------| | 00 | fc / 2 <sup>13</sup> or fs / 2 <sup>5</sup> | 0.976 [kHz] | 1.024 [kHz] | | 01 | fc / 2 <sup>12</sup> fs / 2 <sup>4</sup> | 1.953 | 2.048 | | 10 | fc / 2 <sup>11</sup> fs / 2 <sup>3</sup> | 3.906 | 4.096 | | 11 | fc / 2 <sup>10</sup> fs / 2 <sup>2</sup> | 7.812 | 8.192 | Figure 2-17. Divider Output # 2.5 16-bit Timer/Counter 1 (TC1) # 2.5.1 Configuration #### 2.5.2 Control The timer/counter 1 is controlled by a timer/counter 1 control register (TC1CR) and two 16-bit timer registers (TREG1A and TREG1B). Reset does not affect TREG1A and TREG1B. Figure 2-19. Timer Registers and TC1 Control Register #### 2.5.3 Function Timer/counter 1 has six operating modes: timer, external trigger timer, event counter, window, pulse width measurement, programmable pulse generator output mode. #### (1) Timer Mode In this mode, counting up is performed using the internal clock. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0". Counting up resumes after the counteriscleared. The current contents of up-counter can be transferred to TREG1B by setting SCAP1 (bit 6 in TC1CR) to "1" (software capture function). SCAP1 is automatically cleared to "0" after capaturing. Table 2-3. Timer/Counter 1 Source Clock (Internal Clock) | Source clock | | | Resolution | | Maximum time setting | | |--------------------------|--------------------------|--------------------------|------------------------------------------|--------------------|----------------------|--------------------| | NORMAL1/2, IDLE1/2 modes | | CLOVA CLEED | | | | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP modes | At $fc = 8 \text{ MHz}$ At $fs = 32.768$ | At fs = 32.768 kHz | At fc = 8 MHz | At fs = 32.768 kHz | | fc / 2 <sup>3</sup> [Hz] | fc / 2 <sup>3</sup> [Hz] | _ | 1 <i>μ</i> s | _ | 65.5 ms | _ | | fc / 2 <sup>7</sup> | fc / 2 <sup>7</sup> | <del>-</del> | 16 <i>μ</i> s | - | 1.0 s | - | | fc / 2 <sup>11</sup> | fs / 2 <sup>3</sup> | fs / 2 <sup>3</sup> [Hz] | 256 μs | 244.14 μs | 16.8 s | 16.0 s | Example 1 : Sets the timer mode with source clock $fs/2^3[Hz]$ and generates an interrupt 1 s later (at fs = 32.768 kHz). LDW (TREG1A), 1000H ; Sets the timer register (1 s $\div$ 23 / fs = 1000<sub>H</sub>) SET (EIRL). EF4 ; INTTC1 interrupt enable ΕI LD (TC1CR), 00010000B ; Starts TC1 Example 2 : Software capture LD (TC1CR), 01010000B ; SCAP1←1 (Captures) LD WA, (TREG1B) ; Reads captured value 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 INT3ES. Edge selection is the same as for the external interrupt input INT3 pin. Source clock is used an internal clock selected with TC1CK. The contents of TREG1A is compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0" and halted. The counter is restarted by the selected edge of the TC1 pin input. The TC1 pin input has the same noise rejection as the INT3 pin; therefore, pulses of 7/fc [s] or less are rejected as noise. A pulse width of 24/fc [s] or more is required for edge detection in NORMAL1/2 or IDLE1/2 mode. The noise rejection circuit is turned off in SLOW and SLEEP modes. But, a pulse width of 4/fs [s] or more is required. Figure 2-21. External Trigger Timer Mode Timing Chart #### (3) Event Counter Mode In this mode, events are counted on the edge of the TC1 pin input. Either the rising or falling edge can be selected with INT3ES in EINTCR. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. The maximum applied frequency is fc/24 [Hz] in NORMAL1/2 or IDLE1/2 mode and fs/24 [Hz] in SLOW or SLEEP mode. Setting SCAP1 to "1" transferres the current contents of up-counter to TREG1B (software capture function). SCAP is automatically cleared after capturing. Figure 2-22. Event Counter Mode Timing Chart (INT3ES = 1) ### www.Datas(4)et4Window mode Counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC1 pin input (window pulse) and an internal clock. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Positive or negative logic for the TC1 pin input can be selected with INT3ES. Setting SCAP1 to "1" transferes the current contents of up-counter to TREG1B. It is necessary that the maximum applied frequency (TC1 input) be such that the counter value can be analyzed by the program. That is, the frequency must be considerably slower than the selected internal clock. Figure 2-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 INT3ES, and single edge or double edge is selected with MCAP1 (bit 6 in TC1CR). Note: When fc/23 is selected for the source clock in pulse width measurement mode, the least significant bit of TREG1B which has been read out is always "0", but when other source clocks are selected, the least significant bit of TREG1B becomes "1" or "0" according to the value of counter. Figure 2-24. Pulse Width Measurement Mode Timing Chart | Example : | Duty meas | ureme | nt (Resolution fc/2 <sup>7</sup> [Hz] | ) | | |-----------|-----------|---------|---------------------------------------|---|---------------------------------------| | | | CLR | (INTTC1C). 0 | ; | INTTC1 service switch initial setting | | | | LD | (EINTCR), 00000000B | ; | Sets the rise edge at the INT3 edge | | | | LD | (TC1CR), 00000110B | ; | Sets the TC1 mode and source clock | | | | SET | (EIRL). 4 | ; | Enables INTTC1 | | | | El | | | | | | | LD<br>: | (TC1CR), 00110110B | ; | Starts TC1 with an external trigger | | | PINTTC1: | CPL | (INTTC1C). 0 | ; | Complements INTTC1 service switch | | | | JRS | F, SINTTC1 | | | | | | LD | (HPULSE), (TREG1BL) | ; | Reads TREG1B | | | | LD | (HPULSE + 1), (TREG1BH) | | | | | | RETI | | | | | | SINTTC1: | LD | (WIDTH), (TREG1BL) | ; | Reads TREG1B (Period) | | | | LD | (WIDTH + 1), (TREG1BH) | | | | | | | | | | | | | RETI | | | | | | | | | | | | | VINTTC1: | DW | PINTTC1 | | | | | | | | | | # www.DataS(6)et4Programmable Pulse Generate (PPG) output mode Counting is started by an edge of the TC1 pin input (either the rising or falling edge can be selected) or by a command. The source clock is used an internal clock. First, the contents of TREG1B are compared with the contents of the up-counter. If a match is found, timer F/F1 output is toggled. Next, timer F/F1 is again toggled and the counter is cleared by matching with TREG1A. An INTTC1 interrupt is generated at this time. Timer F/F output is connected to the P12 (PPG) pin. In the case of PPG output, set the P12 output latch to "1" and configure as an output with P1CR4. Timer F/F1 is cleared to "0" during reset. The timer F/F1 value can also be set by program and either a positive or negative logic pulse output is available. Also, writing to the TREG1B is not possible unless the timer / counter 1 is set to the PPG output mode with TC1M. Figure 2-25. PPG Output Mode Timing Chart Figure 2-26. PPG Output # 2.6 16-bit Timer/Counter 2 (TC2) # 2.6.1 Configuration Figure 2-27. Timer/Counter 2 (TC2) #### 2.6.2 Control The timer/counter 2 is controlled by a timer/counter 2 control register (TC2CR) and a 16-bit timer register 2 (TREG2). Reset does not affect TREG2. Figure 2-28. Timer Register 2 and TC2 Control Register #### 2.6.3 Function The timer/counter 2 has three operating modes: timer, event counter and window modes. Also timer/counter 2 is used for warm-up when switching from SLOW mode to NORMAL2 mode. ## (1) Timer Mode In this mode, the internal clock is used for counting up. The contents of TREG2 are compared with the contents of up-counter. If a match is found, a timer/ counter 2 interrupt (INTTC2) is generated, and the counter is cleared. Counting up is resumed after the counter is cleared. Also, when fc is selected as the source clock during SLOW mode, the lower 11 bits of TREG2 are ignored and an 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-4. Source Clock (Internal Clock) for Timer/Counter 2 | Source clock | | | | Resolution | | Maximum time setting | | | |---------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|-------------------|--------------------|----------------------|----------------------|--| | NORMAL1/2, IDLE1/2 mode | | CI (O)M/ | 51.014 | | Resolution | | Waximam time setting | | | DV7CK = 0 DV7CK = 1 | | SLOW mode SLEEP mode | | At fc = 8 MHz | At fs = 32.768 kHz | At fc = 8 MHz | At fs = 32.768 kHz | | | fc / 2 <sup>23</sup> [Hz]<br>fc / 2 <sup>13</sup> | fs / 2 <sup>15</sup> [Hz]<br>fs / 2 <sup>5</sup> | fs / 2 <sup>15</sup> [Hz]<br>fs / 2 <sup>5</sup> | fs / 2 <sup>15</sup> [Hz]<br>fs / 2 <sup>5</sup> | 1.05 s<br>1.02 ms | 1 s<br>0.98 ms | 19.1 h<br>1.1 min | 18.2 h<br>1.07 min | | | fc / 2 <sup>8</sup><br>fc / 2 <sup>3</sup> | fc / 2 <sup>8</sup><br>fc / 2 <sup>3</sup> | - | - | 32 μs<br>1 μs | | 2.1 s<br>65.5 ms | | | | - | - | fc (Note) | - | 125 ns | | 8.2 ms | | | | fs | fs | _ | _ | | 30.5 <i>μ</i> s | | 2 s | | Note: "fc" can be used only in the timer mode. Example: Sets the timer mode with source clock fc/23 [Hz] and generates an interrupt every 25 ms (at fc = 8 MHz). LDW (TREG2), 61A8H ; Sets TREG2 (25 ms $\div$ 23/fc = 61A8<sub>H</sub>) SET (EIRH). EF14 ; INTTC2 interrupt enable Ε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 fc/24 [Hz] in NORMAL1/2 or IDLE1/2 mode, and fs/24 [Hz] in SLOW or SLEEP mode. Example: Sets the event counter mode and generates an INTT2 interrupt 640 counts later. LDW (TREG2), 0280H ; Sets TREG2 SET (EIRH). EF14 ; INTTC2 interrupt enable ΕI LD (TC2CR), 00111100B : Starts TC2 #### (3) Window Mode In this mode, counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC2 pin input (window pulse) and an internal clock. The internal clock is selected with TC2CK. The contents of TREG2 are compared with the contents of up-counter. If a match is found, an INTTC2 interrupt is generated, and the up-counter is cleared to "0". It is necessary that the maximum applied frequency (TC2 input) be such that the counter value can be analyzed by the program. That is, the frequency must be considerably slower than the selected internal clock. Figure 2-29. Window Mode Timing Chart # 2.7 8-Bit Timer/Counter 3 (TC3) # 2.7.1 Configuration Figure 2-30. Timer/Counter 3 # 2.7.2 Control Figure 2-31. Timer Register 3A/3B and TC3 Control Register www.DataThe\_timer/counter 3 is controlled by a timer/counter 3 control register (TC3CR) and two 8-bit timer registers (TREG3A and TREG3B). Reset does not affect these timer registers. #### 2.7.3 Function The timer/counter 3 has three operating modes: timer, event counter, and capture mode. #### (1) Timer Mode In this mode, the internal clock is used for counting up. The contents of TREG3A are compared with the contents of up-counter. If a match is found, a timer/counter 3 interrupt (INTTC3) is generated, and the up-counter is cleared. Counting up resumes after the up-counter is cleared. The current contents of up-counter are loaded into TREG3B by setting SCAP (bit 6 in TC3CR) to "1". SCAP is automatically cleared after capturing. | | Source clo | k | Resolution | | Maximum setting time | | | |-----------------------------|--------------------------|--------------------------|----------------|-----------------|----------------------|-----------------|--| | NORMAL1 / 2, IDLE1 / 2 mode | | CLOVAL CLEED | | 1 | | | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP mode | fc = 8 MHz | fs = 32.768 kHz | fc = 8 MHz | fs = 32.768 kHz | | | fc / 2 <sup>12</sup> [Hz] | fs / 2 <sup>4</sup> [Hz] | fs / 2 <sup>4</sup> [Hz] | 512 μs | 488.28 μs | 131.1 ms | 124.5 ms | | | fc / 2 <sup>10</sup> | fs / 2 <sup>2</sup> | - | 128 <i>μ</i> s | 122.07 μs | 32.6 ms | 31.1 ms | | | fc / 2 <sup>7</sup> | _ | _ | 16 us | _ | 4.1 ms | _ | | Table 2-5. Source Clock (Internal Clock) for Timer Counter 3 #### (2) Event Counter Mode In this mode, the TC3 pin input pulses are used for counting up. Either the rising or falling edge can be selected with INT3ES (bit 3 in EINTCR). The contents of TREG3A are compared with the contents of the up-counter. If a match is found, an INTTC3 interrupt is generated and the counter is cleared. The maximum applied frequency is fc/2<sup>4</sup> [Hz] in the NORMAL1/2 or IDLE1/2 mode, and fs/2<sup>4</sup> [Hz] in SLOW or SLEEP mode. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width. The current contents of up-counter are loaded into TREG3B by setting SCAP (bit 6 in TC3CR) to "1". SCAP is automatically cleared after capturing. Example: Generates an interrupt every 0.5 s, inputing 50Hz pulses to the TC3 pin. LD (TC3CR), 00001100 ; Sets TC3 mode, source clock LD (TREG3A), 19H ; $0.5 \text{ s} \div 1/50 = 25 = 19_{\text{H}}$ LD (TC3CR), 00011100B ; Start TC3 #### (3) Capture Mode The pulse width, period and duty of the TC3 pin input are measured in this mode, which can be used in decoding the remote control signals, etc. The counter is free running by the internal clock. On the rising (falling) edge of the TC3 pin input, the current contents of counter is loaded into TREG3A, then the up-counter is cleared and an INTTC3 interrupt is generated. On the falling (rising) edge of the TC3 pin input, the current contents of the counter is loaded into the TREG3B. In this case, counting continues. At the next rising (falling) edge of the TC3 pin input, the current contents of counter are loaded into TREG3A, then the counter is cleared again and an interrupt is generated. If the counter overflows before the edge is detected, FF<sub>H</sub> is set to the TREG3A and an overflow interrupt (INTTC3) is generated. During interrupt processing, it can be determined whether or not there is an overflow by checking whether or not the TREG3A value is FF<sub>H</sub>. Also, after an interrupt (capture to TREG3A, or overflow detection) is generated, capture and overflow detection are halted until TREG3A has been read out; however, the counter continues. After TREG3A has been read out, capture and overflow detection are resumed, usually, TREG3B is read out first. Figure 2-32. Timing Chart for Capture Mode (INT3ES = 0) INT4/TC3 input pulse width measurement (for detecting remote control receive waveform) To detect and measure the low or high level width of waveforms input from INT4 or TC3, set timer 3 to capture mode and INT4/TC3 input edge detect to both edges. Figure 2-33. is a timing chart of when timer 3 is used in capture mode. Numbers ① to ⑱ in Figure 2-33. are described below: - Set INT4/TC3 edge detect to both edges. In Figure 2-33. INT4ES = 1 (falling edge is selected) and INT4W = 1 (both-edge detect enable). Change INT4ES and INT4W bits at #0024<sub>H</sub> only when IMF = 0. After changing EINTCR, interrupt latches of external interrupts must be cleared to "0" using load instruction. - Wake up timer 3 and enable timer 3 soft capture. Then the timer 3 counter starts free running. Also, enable timer 3 interrupts ( $EF_8 = 1$ ). - 3~6 At the selected (falling) edge of the INT4/TC3 input pin, the current counter value (K) is fetched to TREG3A and the counter is zero-cleared. At the same time, a timer 3 interrupt is generated. - © The interrupt processing routine for the timer 3 interrupt sets EF<sub>12</sub> in the interrupt enable register (EIR) to 1 and clears EF<sub>8</sub> to 0 so that INT4 can be detected at the non-selected (rising) edge of INT4/TC3 input. - TREG3B and TREG3A are read next, because after a timer 3 interrupt by capture to TREG3A is generated, capture/overflow detect is halted until the next TREG3A read. Reading TREG3A by the interrupt processing routine resumes capture/overflow detect. - $\otimes \sim \oplus$ Timer count continues. The counter value (m) is fetched to TREG3B at the next non-selected (rising) edge. - At this time, INT4 is generated. - ① Simultaneously, bit 6 in INT4EDT (#0024) is set to 1. - The interrupt processing routine for INT4 enables timer 3 interrupts and disables INT4 interrupts to detect the next edge (selected edge at (5)). - ⑤ ~ ⑥ Same as ⑦, resumes next capture/overflow detect. TREG3B value (m) read at ⑥ is necessary to determine T<sub>W</sub>L in Figure 2-33. At ⑥ #0024H is read: bit 6 (INT4EDT) and bit 2 (INT4EDT) are set to 1. After read, bits 6 and 2 - are both cleared. 15~6 Timer 3 count continues. The counter value (n) is fetched to TREG3A at the next selected (rising) edge. The counter is zero-cleared. - At the same time, INT4 is generated. - Interrupt processing for INT4 resumes at the next capture/overflow detect as at $\widehat{\mathcal{T}}$ . T<sub>W</sub>H is determined by TREG3A value (n) and TREG3B value (m) read at $\widehat{\mathcal{Y}}$ . Figure 2-33. Example of remote control waveform by timer 3 (in capture mode) # 2.8 8-bit Timer/Counter (TC4) # 2.8.1 Configuration Figure 2-34. Timer/Counter 4 #### 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-35. 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, a timer/counter 4 interrupt (INTTC4) is generated and the up-counter is cleared to "0". Counting up resumes after the up-counter is cleared. Table 2-6. Source Clock (Internal Clock) for Timer/Counter 4 | | Source cloc | :k | Resolution | | Maximum setting time | | |---------------------------|--------------------------|--------------------------|---------------|-----------------|----------------------|-----------------| | NORMAL1/2, IDLE1/2 mode | | CLOW SIEED was de | | Γ | | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP mode | fc = 8 MHz | fs = 32.768 kHz | fc = 8 MHz | fs = 32.768 kHz | | fc / 2 <sup>11</sup> [Hz] | fs / 2 <sup>3</sup> [Hz] | fs / 2 <sup>3</sup> [Hz] | 256 μs | 244.14 μs | 65.3 ms | 62.2 ms | | fc / 2 <sup>7</sup> | _ | _ | 16 <i>μ</i> s | - | 4.1 ms | _ | | fc / 2 <sup>3</sup> | ı | - | 1 μs | _ | 255 μs | _ | 87CH75-84 2004-10-01 # www.DataS(2)et4Programmable 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. Timer F/F 4 output is toggled and the counter is cleared each time a match is found. Timer F/F 4 output is inverted and output to the PDO (P44) pin. This mode can be used for 50 % duty pulse output. Timer F/F 4 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). 4 ; P14 output latch ← 1 LD (P1CR), 00010000BH ; Sets P14 (output mode) LD (TREG4), 10H ; $(1/2024 \div 2^{7}/\text{fc}) \div 2 = 10_\text{H}$ LD (TC4CR), 00010110B ; Starts TC4 Figure 2-36. Timing Chart for PDO Mode #### (3) Pulse Width Modulation (PWM) Output Mode PWM output with a resolution of 8 bits is possible. The internal clock is used for counting up. The contents of TREG4 are compared with the contents of up-counter. If a match is found, the timer F/F 4 output is toggled. The counter continues counting. And, when an overflow occurs, the timer F/F 4 output is again toggled and the counter is cleared. Timer F/F 4 output is inverted and output to the PWM (P44) pin. 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 1: Do not overwrite TREG4 only when an INTTC4 interrupt is generated. Usually, TREG4 is overwriten in the routine of INTTC4 interrupt service. Note 2: PWM output mode can be used only in the NORMAL1, 2 and IDLE1,2 mode. Figure 2-37. Timing Chart for PWM Mode Table 2-7. PWM Output Mode | | Source clock | | Resolution | | Maximum setting time | | |-------------------------------------------------------------------|------------------------------------------------------------------|------------------------------------|-------------------------|-----------------|-----------------------------|-----------------| | NORMAL1/2, IDLE1/2 mode | | CLOW CLEED was do | | | waxiinaiii setting time | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP mode | fc = 8 MHz | fs = 32.768 kHz | fc = 8 MHz | fs = 32.768 kHz | | fc/2 <sup>11</sup> [Hz]<br>fc/2 <sup>7</sup><br>fc/2 <sup>3</sup> | fs/2 <sup>3</sup> [Hz]<br>fc/2 <sup>7</sup><br>fc/2 <sup>3</sup> | fs / 2 <sup>3</sup> [Hz]<br>-<br>- | 256 μs<br>16 μs<br>1 μs | 244.14 μs | 65.5 ms<br>4.1 ms<br>256 μs | 62.5 ms | ## 2.9 Serial Bus Interface (SBI-ver.A) The 87CH75/M75 has a 1-channel serial bus interface which employs a clocked-synchronous 8-bit serial bus interface and an I<sup>2</sup>C bus. The serial bus interface is connected to an external device through P31 (SDA) and P30 (SCL) in the I<sup>2</sup>C bus mode; and through P32 (SCKO), P31 (SOO) and P30 (SIO) in the clocked-synchronous 8-bit SIO mode. The serial bus interface pins are also used as the port. When used as serial bus interface pins, set the P3 output latches of these pins to "1". When not used as serial bus interface pins, the P3 port is used as a normal I/O port. $I^2C$ bus has no an arbitration function which is necessary when two or more master devices scramble for the bus control. In master mode, other devices which are connected on the same bus need be slave devices. (single master) Note: When a multi master I<sup>2</sup>C bus system operates in I<sup>2</sup>C bus mode of this serial bus interface circuit, there is a possibility that the following problems raise. I<sup>2</sup>C bus mode of this serial bus interface circuit should be used by a single master I<sup>2</sup>C bus system. - 1. The SCL line is fixed to low level and transferring stops by the serial bus interface circuit. The other devices can not run on the SCL line. Thus the bus locks. - 2. The SCL pin is pulled down to low level regardless of the state of the SCL line by the serial bus interface circuit. A period of high-level SCL clock pulse which other devices output is shortened. The minimum value of which the SCL clock holds high level is not satisfied, which is specified with the I2C bus standard. ## 2.9.1 Configuration Figure 2-38. Serial Bus Interface (SBI-ver.A) # 2.9.2 Serial Bus Interface (SBI-ver.A) Control The following reginsters are used for control and operation status monitoring when using the serial bus interface (SBI-ver.A). - 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 (I2CAR) - Serial bus interface status register (SBISR) The above registers differ depending on a mode to be used. Refer to Section "2.9.4 I<sup>2</sup>C bus Mode Control" and "2.9.6 Clocked-synchronous 8-bit SIO Mode Control". # 2.9.3 The Data Formats in the I<sup>2</sup>C bus Mode The data formats when using the serial bus interface circuit in the I<sup>2</sup>C bus mode are shown below. Figure 2-39. Data Format # 2.9.4 J<sup>2</sup>C Bus Mode Control The following registers are used for control and operation status monitoring when using the serial bus interface (SBI-ver.A) in the I<sup>2</sup>C bus mode. Figure 2-40. Serial Bus Interface Control Register 1 / Serial Bus Interface Data Buffer Register/ I<sup>2</sup>C bus Address Register in the I<sup>2</sup>C bus Mode 87CH75-89 2004-10-01 Figure 2-41. Serial Bus Interface Control Register 2 / Serial Bus Interface Status Register in the I<sup>2</sup>Cbus Mode # www.Data(1) Acknowledgment mode specification Set the ACK (bit 4 in SBICR1) to "1" for operation in acknowledgment mode. When the serial bus interface circuit is the master mode, an additional clock pulse is generated for an acknowledge signal. In the transmitter mode during this additional clock pulse cycle, the SDA pin is released in order to receive the acknowledge signal from the receiver. In the receiver mode during this additional clock pulse cycle, the SDA pin is set to low level generating the acknowledge signal. Clear the ACK to "0" for operation in the non-acknowledgment mode. When the serial bus interface circuit is the master mode, a clock pulse for the acknowledge signal is not generated. In the acknowledgment mode, when the serial bus interface circuit is the slave mode, clocks are counted for the acknowledge signal. During the clock for the acknowledge signal, when a received slave address matches to a slave address set to the I2CAR or a "GENERAL CALL" is received, the SDA pin is set to low level generating an acknowledge signal. After a received slave address matches to a slave address set to the I2CAR and a "GENERAL CALL" is received, in the transmitter mode during the clock for the acknowledge signal, the SDA pin is released in order to receive the acknowledge signal from the receiver. In the receiver mode, the SDA pin is set to low level generating an acknowledge signal. In the non-acknowledgment mode, when the serial bus interface circuit is the slave mode, clocks for the acknowledge signal are not counted. #### (2) Number of transfer bits The BC (bits 7 to 5 in the SBICR1) is used to select a number of bits for next transmitting and receiving data. Since the BC is cleared to "000" by a start condition, a slave address and direction bit transmissions are 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 the SBICR1) is used to select a maximum transfer frequency outputed on the SCL pin in the master mode. Set a communication baud rate that meets the I<sup>2</sup>C bus specification, such as the shortest pulse width of t<sub>LOW</sub>, based on the equations shown below. Four or more machine cycles are required for both the high and low levels of the pulse width of a clock which is input externally in both the master and slave mode. Figure 2-42. Clock Source #### b. Clock synchronization The I<sup>2</sup>C bus has a clock synchronization function to meet the transfer speed to a slow processing device when a transfer is performed between devices which have different process speed. The clock synchronization functions when the SCL pin is high level and the SCL line of the bus is low level in the serial bus interface circuit. The serial bus interface circuit waits counting a clock pulse in high level until the SCL line of the bus is high level. When the SCL line of the bus is high level, the serial bus interface circuit starts counting during high level. The clock synchronization function holds clocks which are output from the serial interface circuit to be high level. The slave device can stop the clock output of the master device on one word or one bit basis. Additionally, the transfer speed by the master device matches to the process speed of the slave device. 87CH75-91 2004-10-01 Figure 2-43. Clock Synchronization ### (4) Slave address and address recognition mode specification To operate the serial bus interface circuit in the addressing format which recognizes the slave address, clear the ALS (bit 0 in I2CAR) to "0" and set the slave address to the SA (bits 7 to 1 in I2CAR). To operate the serial bus interface circuit in the free data format which does not recognize the slave address, set the ALS to "1". When the serial bus interface circuit is used in the free data format, the slave address and the direction bit are not recognized. They are handled as data just after generation of start conditions. #### (5) Master/slave selection Set the MST (bit 7 in the SBICR2) to "1" for operating the serial bus interface as a master device. Clear the MST to "0" for operation as a slave device. The MST is cleared to "0" by the hardware after a stop condition on a bus is detected or the noise is detected. #### (6) Transmitter / receiver selection Set the TRX (bit 6 in the SBICR2) to "1" for operating the serial bus interface circuit as a transmitter. Clear the TRX to "0" for operation as a receiver. When data with an addressing format is transferred in the slave mode, the TRX is set to "1" by the hardware if the direction bit (R/W) sent from the master device is "1", and is cleared to "0" by the hardware if the bit is "0". In the master mode, after an acknowledge signal is returned from the slave device, the TRX is cleared to "0" by the hardware if a transmitted direction bit is "1", and is set to "1" by the hardware if it is "0". When an acknowledge signal is not returned, the current condition is maintained. The TRX is cleared to "0" by the hardware after a stop condition on the bus is detected or the noise is detected. The following shows TRX change conditions in each mode and TRX after changing. | Mode | Direction bit | Change condition | TRX after<br>changing | |-------------|-------------------------------|-------------------------------|-----------------------| | Slave mode | 0 A received slave address is | | 0 | | Slave mode | 1 | same as a value set to I2CAR. | 1 | | Mastarmada | 0 | ACK signal is returned | 1 | | Master mode | 1 | ACK signal is returned. | 0 | When the serial bus interface circuit operates in the free data format, the slave address and the direction bit are not recognized. They are handled as data just after generating a start condition. The TRX was not changed by the hardware. ### www.Dat (7) Start/stop condition generation When the BB (bit 5 in the SBICR2) is "0", the slave address and the direction bit which are set to the SBIDBR are output on a bus after generating a start condition by writing "1" to the MST, TRX, BB, and PIN. It is necessary to set transmitted data to the data buffer register (SBIDBR) and set "1" to ACK beforehand. Figure 2-44. Start Condition Generation and Slave Address Generation When the BB is "1", a sequence of generating a stop condition is started by writing "1" to the MST, TRX, 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. When a stop condition is generated and the SCL line on the bus is set to low level by another device, a stop condition is generated after releasing the SCL line. Figure 2-45. Stop Condition Generation The bus condition can be indicated by reading the contents of the BB (bit 5 in the 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 on a bus. #### (8) Interrupt service request and cancel When the serial bus interface circuit is the master mode and transferring a number of clocks set by the BC and the ACK is complete, a serial bus interface interrupt request (INTSBI) is generated. In the slave mode, the INTSBI is generated when the received slave address is the same as the value set to the I2CAR and an acknowledge signal is output, when a "GENERAL CALL" is received and an acknowledge signal is output, or when transferring / receiving data is complete after the received slave address is the same as the value set to the I2CAR and a "GENERAL CALL" is received. When the serial bus interface interrupt request occurs, the PIN (bit 4 in the SBISR) is cleared to "0". During the time that the PIN is "0", the SCL pin is set to low level. Either writing or reading data to or from the SBIDBR sets the PIN to "1". The time from the PIN being set to "1" until the SCL pin is released takes $t_{LOW}$ . Although the PIN (bit 4 in the SBICR2) can be set to "1" by the program, the PIN is not cleared to "0" when it is written "0". #### (9) Serial bus interface operating mode selection The SBIM (bits 3 and 2 in the SBICR2) is used to specify the serial bus interface operation mode. Set the SBIM to "10" when used in the I<sup>2</sup>C bus mode after confirming that the serial bus interface pin is high level. Switch a mode to port after confirming that the bus is free. # www.Data(10) Noise detection monitor The I<sup>2</sup>C bus is easy to be affected by noise, because the bus is driven by the open drain and the pull-up resistor. With the serial bus interface circuit, the SDA pin output and the SDA line level are compared at a rise of the SCL line on the bus, and whether data are output correctly on the bus is detected only in the master transmitter mode. When the SDA pin output differs from the SDA line level, the AL (bit 3 in the SBISR) is set to "1". When the AL is set to "1", the SDA pin is released and the MST and the TRX are cleared to "0" by the hardware. The serial bus interface circuit changes to the slave receiver mode, and the serial bus interface circuit continues outputting clocks until transferring data when the AL was set to "1" is completed. Either writing or reading data to or from the SBIDBR, or writing data to the SBICR2 clears to the AL to "0". Figure 2-46. Noise Detection Monitor #### (11) Slave address match detection monitor The AAS (bit 2 in the SBISR) is set to "1" in the slave mode, in the address recognition mode (ALS = 0), when receiving "GENERAL CALL" or a slave address with the same value that is set to the 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 writing / reading data to / from a data buffer register. ## (12) GENERAL CALL detection monitor The AD0 (bit 1 in the SBISR) is set to "1" in the slave mode, when all 8-bit received data is "0", after a start condition (GENERAL CALL). The AD0 is cleared to "0" when a start or stop condition is detected on a bus. ### (13) Last received bit monitor The SDA value stored at the rising edge of the SCL is set to the LRB (bit 0 in the SBISR). In the acknowledge mode, immediately after an INTSBI interrupt request is generated, an acknowledge signal is read by reading the contents of the LSB. Figure 2-47. Last Received bit Monitor ### www.Data(14) Software reset function Software reset function is used to initialize SBI, when SBI is locked by external noise, etc. SWRST is set to "1", internal reset signal pulse is generated and inputted into SBI circuit. All command registers and status registers are initialized to an initial value. SWRST is automatically cleared to "0" after initialize SBI circuit. # 2.9.5 Data Transfer in I<sup>2</sup>C bus Mode Set the ACK in the SBICR1 to "1", and the BC to 000. Specify the data length to 8 bits to count clocks for acknowledge. Set a transfer frequency to the SCK. Subsequently, set a slave address to the SA in the I2CAR and clear the ALS to "0" to set an addressing format. After confirming that the serial bus interface pin is high-level, for specifying the default setting to a slave receiver mode, clear "0" to the MST, TRX, and BB in the SBICR2, set "1" to the PIN, "10" to the SBIM, and "0" to bits 1 and 0, Note: The initialization of the serial bus interface circuit must be complete within the time from all devices which are connected to the bus have initialized to any device does not generate a start condition. If not, there is a possibility that another device starts transferring before an end of the initialization of the serial bus interface circuit. Data can not be received correctly. ### (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: Do not write a slave address to be output to the SBIDBR while data are transferred. If data is written to the SBIDBR, data to been outputting may be destroyed. - Note 2: Do not start transferring due to another master from writing a slave address to be output to the SBIDBR to writing a start condition generation command to the SBICR2. The serial bus interface circuit malfunctions because it has not an arbitration function. Figure 2-48. Start Condition Generation and Slave Address Transfer # www.Data(3)ed-word Data Transfer Check the MST by the INTSBI interrupt process after an 1-word data transfer is completed, and determine whether the mode is a master or slave. ### a. When the MST is "1" (Master mode) Check the TRX and determine whether the mode is a transmitter or receiver. #### ① When the TRX is "1" (Master mode) Test the LRB. When the LRB is "1", a receiver does not request data. Implement the process to generate a stop condition (described later) and terminate data transfer. When the LRB is "0", the receiver requests new data. When the next transmitted data is other than 8 bits, set the BC, set the ACK to "1", and write the transmitted data to the SBIDBR. After writing the data, the PIN becomes "1", a serial clock pulse is generated for transferring a new 1-word of data from the SCL pin, and then the 1-word data is transmitted. After the data is transmitted, and an INTSBI interrupt request occurs. The PIN becomes "0" and the SCL pin is set to low level. If the data to be transferred is more than one word in length, repeat the procedure from the LRB test above. Figure 2-49. Example when BC = "000", ACK = "1" in Transmitter Mode #### ② 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 serial bus interface circuit 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". Then the serial bus interface circuit pulls down the SCL pin to the low level. The serial bus interface circuit outputs a clock pulse for 1-word of data transfer and the acknowledge signal each time that received data is read from the SBIDBR. Figure 2-50. Example when BC = "000", ACK = "1" in Receiver Mode www.DataSheet4U Innorder 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 serial bus interface circuit generates a clock pulse for a 1-bit data transfer. Since the master device is a receiver, the SDA line on a bus keeps the high level. The transmitter receives the high-level signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete. After 1-bit data is received and an interrupt request has occurred, the serial bus interface circuit generates a stop condition (Refer to 2.9.5. (4)) and terminates data transfer. Figure 2-51. Termination of Data Transfer in Master Receiver Mode # b. When the MST is "0" (Slave mode) In the slave mode, the serial bus interface circuit operates either in normal slave mode or in recovery process after a noise detection. In the slave mode, an INTSBI interrupt request occurs when the serial bus interface circuit 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 serial bus interface circuit operates in a slave mode if a noise is detected. An INTSBI interrupt request occurs when word data transfer terminates after a noise detection. When an INTSBI interrupt request occurs, the PIN (bit 4 in the SBICR2) is reset, and the SCL pin is set to low level. Either reading or writing from or to the SBIDBR or setting the PIN to "1" releases the SCL pin after taking t<sub>LOW</sub> time. The serial bus interface circuit tests 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. | _ | | | | rable 2-8. Operation in the sia | ve iviode | |-----|----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TRX | AL | AAS | AD0 | Conditions | Process | | 1 | 0 | 1 | 0 | In the slave receiver mode, the serial bus interface circuit receives a slave address of which the value of the direction bit sent from the master is "1". | Set the number of bits in 1-word to the BC and write transmitted data to the SBIDBR. | | | | 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 | 0 | 0 | The serial bus interface circuit detects the noise when transmitting a slave address or data and terminates transferring word data. | There is a possibility that a serial bus interface circuit does not receive data normally. The recovery process such as a data re-transfer, etc. is needed. | | | 0 | 1 | 1/0 | In the slave receiver mode, the serial bus interface circuit receives a slave address or GENERAL CALL of which the value of the direction bit sent from the master is "0". | Read the SBIDBR for setting the PIN to "1" (reading dummy data) or set the PIN to "1". | | | | 0 | 1/0 | In the slave receiver mode, the serial bus interface circuit 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-8. Operation in the Slave Mode ### www.Data(4) Stop Condition Generation When the BB is "1", a sequence of generating a stop condition is started by setting "1" to the MST, TRX and PIN, and "0" to the BB. Do not modify the contents of the MST, TRX, BB, PIN until a stop condition is generated on a bus. When a SCL line of bus is pulled down by other devices, the serial bus interface circuit generates a stop condition after they release a SCL line. Figure 2-52. 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 the serial bus interface circuit. Clear "0" to the MST, TRX, and BB and set "1" to the PIN. The SDA pin retains the high level and the SCL pin is released. Since a stop condition is not generated on the bus, the bus is assumed to be in a busy state from other devices. Test the BB until it becomes "0" to check that the SCL pin of the serial bus interface circuit is released. Test the LRB until it becomes "1" to check that the SCL line of the bus is not set to low level by other devices. After confirming that the 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-53. Timing Diagram when Restarting ## 2.9.6 Clocked-synchronous 8-bit SIO Mode Control The following registers are used for control and operation status monitoring when using the serial bus interface (SBI) in the clocked-synchronous 8-bit SIO mode. Figure 2-54. Control Register / Data Buffer Register / Status Register in SIO Mode # www.DataS(1) Serial clock ## a. Clock source The SCK(bits 2 to 0 in SBICR1) is used to select the following functions. #### ① Internal clock In an internal clock mode, any of seven frequencies can be selected. The serial clock is output to the outside on the $\overline{SCKO}$ pin. The $\overline{SCKO}$ 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-55. Automatic Wait Function #### ② External clock (SCK = "111") An external clock supplied to the $\overline{SCKO}$ 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-56. 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 SCKO pin input / output). # 2 Trailing edge Data is shifted on the trailing edge of the serial clock (at a rising edge of the $\overline{SCK0}$ pin input / output). Figure 2-57. Shift Edge ### (2) Transfer mode The SIOM (bits 5 and 4 in SBICR) 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 SOO 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, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the $\overline{SCK}$ . 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-58. Transfer Mode Example: SIO0 transfer end command (External clock) STEST1 : TEST (SBISR).SEF ; If SEF = 1 then loop JRS F, STEST1 STEST2 : TEST (P3).6 ; If SCK = 0 then loop JRS T, STEST2 LD (SBICR1), 00000111B ; SIOS $\leftarrow$ 0 Figure 2-59. Transmitted Data Hold Time at End of Transmit #### 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 SI 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. 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. 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-60. Receive Mode (Example: Internal clock) ### www.DataSheelc. | 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 SO 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 SI 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 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 external clock, 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, after the SIOF goes "1" output from the SO pin holds final bit of the last data until falling edge of the $\overline{SCK}$ . 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-61. Transmit / Receive Mode (Example: Internal clock) 2004-10-01 Figure 2-62. Transmitted Data Hold Time at End of Transmit / Receive ### 2.10 Serial Interface (SIO1) The 87CH75/M75 each have one clocked-synchronous 8-bit serial interface (SIO1). Each serial interface has an 8-byte transmit and receive data buffer that can automatically and continuously transfer up to 64 bits of data. The serial interfaces are connected to external devices via pins P02 (SO1), P01 (SI1), P00 (SCK1) for SIO1. The serial interface pins are also used as port P0. When used as serial interface pins, the output latches of these pins should be set to "1". In the transmit mode, pins P01 can be used as normal I/O ports, and in the receive mode, the pins P02 can be used as normal I/O ports. # 2.10.1 Configuration Figure 2-63. Serial Interfaces ### **2.10.2 Control** The serial interfaces are controlled by SIO1 control registers (SIO1CR1/SIO1CR2). The serial interface status can be determined by reading SIO status registers (SIO1SR). The transmit and receive data buffer is controlled by the BUF (bits 2-0 in SIO1CR2). The data buffer is assigned to addresses 0FF8<sub>H</sub> - 0FFF<sub>H</sub> for SIO1 in the DBR area, and can continuously transfer up to 8 words (bytes or nibbles) at one time. When the specified number of words has been transferred, a buffer empty (in the transmit mode) or a buffer full (in the receive mode or transmit/receive mode) interrupt (INTSIO1) is generated. When the internal clock is used as the serial clock in the 8-bit receive mode and the 8-bit transmit/receive mode, a fixed interval wait can be applied to the serial clock for each word transferred. Four different wait times can be selected with WAIT (bits 4 and 3 in SIO1CR2). ### **SIO Control Registers 1** SIO1CR1 (0027<sub>H</sub>) | 7 6 | 5 4 3 2 | 1 0_ | | |----------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | SIOS SIO | SIOM , | SCK (Initial value : 0000 0000) | | | SIOS | Indicate transfer start/stop | 0 : Stop<br>1 : Start | | | SIOINH | Continue/abort transfer | 0 : Continue transfer 1 : Abort transfer (automatically cleared after abort) | | | SIOM | Transfer mode select | 000 : 8-bit transmit mode 010 : 4-bit transmit mode 100 : 8-bit transmit/receive mode 101 : 8-bit receive mode 110 : 4-bit receive mode | write<br>only | | SCK | Serial clock select | 000 : Internal clock fc/2 <sup>13</sup> or fs/2 <sup>5</sup> [Hz] 001 : Internal clock fc/2 <sup>8</sup> 010 : Internal clock fc/2 <sup>6</sup> Output on SCK pin | | 011: Internal clock fc/25 Note 1: fc; High-frequency clock [Hz], fs; Low-frequency clock [Hz] Note 2: Set SIOS to "0" and SIOINH to "1" when setting the transfer mode or serial clock. Note 3: SIO1CR1 is write-only register, which cannot access any of in read-modify-write instruction such as bit operate, etc. 111 : External clock (input from SCK pin) #### SIO1 Control Registers 2 SIO1CR2 $(0028_{H})$ Note 1: \*; don't care Note 2: WAIT is valid only in the 8-bit transmit / receive and 8-bit receive modes. data transfer time Note 3: $T_f$ ; frame time, $T_D$ ; www.DataSheet4U.com Note 4: The lower 4 bits of each buffer are used during 4-bit transfers. Zeros (0) are stored to the upper 4bits when receiving. Note 5: Transmitting starts at the lowest address. Received data are also stored starting from the lowest address to the highest address. For example, in the case of SIO, the first buffer address transmitted is OFF8<sub>H</sub>. Note 6: The value to be loaded to BUF is held after transfer is completed. Note 7: SIO1CR2 are write-only registers, which cannot access any of in read-modify-write instruction such as bit operate, etc. SIO1, SIO2 Status Registers SIO1SR (0020<sub>H</sub>) SIOF SEF / After SIOS is cleared to "0", SIOF is cleared to "0" at the termination of transfer or \setting of SIOINH. Serial transfer operating 0: Transfer terminated SIOF status monitor 1: Transfer in process read only Shift operating status 0: Shift operation terminated SEF monitor 1: Shift operation in process Figure 2-64. SIO Control Registers and Status Registers #### (1) Serial Clock #### a. Clock Source SCK (bits 2 - 0 in SIO1CR1) is able to select the following: #### 1) Internal Clock Any of four frequencies can be selected. The serial clock is output to the outside on the SCK1 pin. The SCK pin goes high when transfer starts. When data writing (in the transmit mode) or reading (in the receive mode or the transmit/receive mode) cannot keep up with the serial clock rate, there is a wait function that automatically stops the serial clock and holds the next shift operation until the read/write processing is completed. Table 2-9. Serial Clock Rate | | Serial clock | Maximum transfer rate | | | | | | |------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------|---------------------|--|--|--| | NORMAL1/2, | IDLE1/2 mode | CLOW CLEED with | Waxiiiaii | Waximum danser rate | | | | | 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 | | | | Note: 1K bit = 1024 bit Figure 2-66. Clock Source (Internal Clock) #### 2 External Clock An external clock connected to the $\overline{SCK1}$ pin is used as the serial clock. In this case, the P00 ( $\overline{SCK1}$ ) output latch must be set to "1". To ensure shifting, a pulse width of at least 4 machine cycles is required. Thus, the maximum transfer speed is 244K-bit/s. (at fc = 8 MHz). ### b. Shift edge The leading edge is used to transmit, and the trailing edge is used to receive. ### ① Leading Edge Transmitted data are shifted on the leading edge of the serial clock (falling edge of the SCK1 pin input/output). #### ② Trailing Edge Received data are shifted on the trailing edge of the serial clock (rising edge of the SCK1 pin input/output). Figure 2-67. 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). ### www.Datas(3)et4Number of Words to Transfer Up to 8 words consisting of 4 bits of data (4-bit serial transfer) or 8 bits (8-bit serial transfer) of data can be transferred continuously. The number of words to be transferred is loaded to BUF in SIOBCR. An INTSIO interrupt is generated when the specified number of words has been transferred. If the number of words is to be changed during transfer, the serial interface must be stopped before making the change. Figure 2-68. Number of Bits to Transfer (Example : 4-bit serial transfer) #### (4) Transfer Mode SIOM (bits 5 - 3 in SIO1CR1) is used to select the transmit, receive, or transmit/receive mode. #### a. 4-bit and 8-bit Transmit Modes In these modes, the 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. 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. www.DataSheet4U.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 SCK1. 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 SIO1SR) because SIOF is cleared to "0" when a transfer is completed. When SIOINH is set, the transmission is immediately ended and SIOF is cleared to "0". If it is necessary to change the number of words, SIOS should be cleared to "0", then BUF must be rewritten after confirming that SIOF has been cleared to "0". When an external clock is used, it is also necessary to clear SIOS to "0" before shifting the next data; otherwise, dummy data will be transmitted and the operation will end. Figure 2-69. Transfer Mode (Example: 8-bit, 1 Word Transfer) Figure 2-70. Transmitted Data Hold Time at End of Transmit #### b. 4-bit and 8-bit Receive Modes After setting the control registers to the receive mode, set SIOS to "1" to enable receiving. The data are then transferred to the shift register via the SI1 pin in synchronous with the serial clock. When one word of data has been received, it is transferred from the shift register to the data buffer register (DBR). When the number of words specified with the BUF has been received, an INTSIO (buffer full) interrupt is generated to request that these data be read out. The data are then read from the data buffer registers by the interrupt service program. When the internal clock is used, and the previous data are not read from the data buffer register before the next data are received, the serial clock will stop and an automatic-wait will be initiated until the data are read. A wait will not be initiated if even one data word has been read. Note: Waits are also canceled by reading a DBR not being used as a received data buffer register is read; therefore, during SIO do not use such DBR for other applications. When an external clock is used, the shift operation is synchronized with the external clock; therefore, the previous data are read before the next data are transferred to the data buffer register. If the previous data have not been read, the next data will not be transferred to the data buffer register and the receiving of any more data will be canceled. When an external clock is used, the maximum transfer speed is determined by the delay between the time when the interrupt request is generated and when the data received have been read. The receiving is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer full interrupt service program. When SIOINH is set, the receiving is immediately ended and SIOF is cleared to "0". When SIOS is cleared, the current data are transferred to the buffer in 4-bit or 8-bit blocks. The receiving mode ends when the transfer is completed. SIOF is cleared to "0" when receiving is ended and thus can be sensed by program to confirm that receiving has ended. If it is necessary to change the number of words in external clock operation, SIOS should be cleared to "0" then BUF must be rewritten after confirming that SIOF has been cleared to "0". If it is necessary to change the number of words in internal clock, during automatic-wait operation which occurs after completion of data receive, BUF must be rewritten before the received data is read out. Note: The buffer contents are lost when the transfer mode is switched. If it should become necessary to switch the transfer mode, end receiving by clearing SIOS to "0", read the last data and then switch the transfer mode. Figure 2-71. Receive Mode (Example: 8-bit, 1 word, internal clock) #### c. 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 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 is read and the next data is written. A wait will not be initiated if even one data word 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. 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 $\overline{SCK}$ . The transmit/receive operation is ended by clearing SIOS to "0" or setting SIOINH 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". www.DataSheet4U.lf.it is necessary to change the number of words in external clock operation, SIOS should be cleared to "0" then BUF must be rewritten after confirming that Siof has been cleared to "0". If it is necessary to change the number of words in internal clock, during automatic-wait operation which occurs after completion of transmit/receive operation, BUF must be rewritten before reading and writing of the receive/transmit data. 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. Transmit/Receive Mode (Example: 8-bit, 1word, internal clock) Figure 2-73. Transmitted Data Hold Time at End of Transmit/receive ## 2.11 Shee 8-bit A/D Converter (ADC) The 87CH75/M75 each have an 8-channel multiplexed-input 8-bit successive approximate type A/D converter with sample and hold. # 2.11.1 Configuration Figure 2-74. A/D Converter ### **2.11.2 Control** The A/D converter is controlled by an A/D converter control register (ADCCR). Figure 2-76. A/D converter control register and A/D conversion result register ### 2.11.3 Operation Apply analog reference voltage to pins VAREF and VASS. #### (1) Start of A/D conversion First, set the corressponding P4CR and P5CR bit to "0" for analog input. Clear the AINDS (bit 4 in ADCCR) to "0" and select one of eight analog input AIN17-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. A/D conversion is started by setting the ADS (bit 6 in ADCCR) to "1". Conversion is accomplished in 46 machine cycles (184/fc [s]). When fc is 8 MHz, it needs 23 µs. The EOCF (bit 7 in ADCCR) is set to "1" at end of conversion. Setting ADS to "1" in A/D conversion starts converting over again. An analog input voltage is sampled at intervals of four cycles after starting A/D conversion. Note: The keep same level of an analog input during 4 Machine Cycle Time is necessary for charging the electron to the sample hold circuit which has a resistor (typ. 5k) and a capacitor (typ. 12pF). #### (2) Reading of A/D conversion result After the end of conversion, read the conversion result from the ADCDR. The EOCF is automatically cleared to "0" when reading the ADCDR. Undefined value is read in A/D conversion. # www.DataS (3) A/D conversion in STOP mode When the MCU places in the STOP mode during the A/D conversion, the conversion is terminated and the ADCDR contents become indefinite. After returning from STOP mode, EOCF is kept to be cleared to "0". However, if the STOP mode is started after the end of conversion (EOCF = 1), the ADCDR contents are held. Figure 2-77. A/D Conversion Timing Chart ### Example: SLOOP ; AIN SELECT LD (ADCCR), 00100100B; selects AIN4 ; A/D CONVERT START SET (ADCCR) . 6 ; ADS = 1 TEST (ADCCR) . 7 ; EOCF = 1? TEST (ADCCR). 7 JRS T, SLOOP ; RESULT DATA READ LD (9EH), (ADCDR) Figure 2-78. Analog Input Voltage vs A/D Conversion Result (typ.) ### 2.12 Vacuum Fluorescent Tube (VFT) Driver Circuit The 87CH75/M75 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. The segment and the digit, as it is the VFT drive circuit which included in the usual products, are not allocated. The segment and the digit can be freely allocated in the timing (T0 to T15) which is specified according to the display tube types and the layout. #### 2.12.1 Functions - (1) 51 high-breakdown voltage output buffers built-in. - Large current output pin (typ. 20mA) 16 (V0 to V15) - Middle current output pin (typ. 8mA) 35 (V16 to V50) 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 16 digits (T0 to T15) 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 register 1 bit by bit. - (4) Display data (112 bytes in DBR) are automatically transferred to the VFT output pin. - (5) Brightness level can be adjusted in 8 steps using the dimmer function. - (6) Four types (fc/212 to fc/29) of display time can be selected. # 2.12.2 Configuration Figure 2-51. #### 2.12.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" and EXEY is cleared to "0"; 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. Figure 2-80. VFT Control Register 1 Figure 2-81. VFT control Register 2, VFT status register #### (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 segments and the digits are not fixed, so that they can be freely allocated. However the number of states must be specified according to the number of digits of VFT which you use. Thought the layout of VFT display mode is freely allocated, the followings are recommended; usually, large current output (V0 to V15) is used for a digit, and middle current output (V16 to V50) is used for a segment. (See Display operation in section 2.12.4 for display timing and data setting procedures.) 87CH75-121 # www.DataS(2)et4Display data setting Data are converted into VFT display data by instructions. The converted data stored in the display data buffer (addresses 0F80 to 0FEF 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-82. (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 3 | Timing | |------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|--------| | | 0F80 <sub>H</sub> | 0F90 <sub>H</sub> | 0FA0 <sub>H</sub> | 0FB0 <sub>H</sub> | 0FC0 <sub>H</sub> | 0FD0 <sub>H</sub> | 0FE0 <sub>H</sub> | T0 | | | 0F81 <sub>H</sub> | 0F91 <sub>H</sub> | 0FA1 <sub>H</sub> | 0FB1 <sub>H</sub> | 0FC1 <sub>H</sub> | 0FD1 <sub>H</sub> | 0FE1 <sub>H</sub> | T1 | | | 0F82 <sub>H</sub> | 0F92 <sub>H</sub> | 0FA2 <sub>H</sub> | 0FB2 <sub>H</sub> | 0FC2 <sub>H</sub> | 0FD2 <sub>H</sub> | 0FE2 <sub>H</sub> | T2 | | | 0F83 <sub>H</sub> | 0F93 <sub>H</sub> | 0FA3 <sub>H</sub> | 0FB3 <sub>H</sub> | 0FC3 <sub>H</sub> | 0FD3 <sub>H</sub> | 0FE3 <sub>H</sub> | Т3 | | | 0F84 <sub>H</sub> | 0F94 <sub>H</sub> | 0FA4 <sub>H</sub> | 0FB4 <sub>H</sub> | 0FC4 <sub>H</sub> | 0FD4 <sub>H</sub> | 0FE4 <sub>H</sub> | T4 | | | 0F85 <sub>H</sub> | 0F95 <sub>H</sub> | 0FA5 <sub>H</sub> | 0FB5 <sub>H</sub> | 0FC5 <sub>H</sub> | 0FD5 <sub>H</sub> | 0FE5 <sub>H</sub> | T5 | | | 0F86 <sub>H</sub> | 0F96 <sub>H</sub> | 0FA6 <sub>H</sub> | 0FB6 <sub>H</sub> | 0FC6 <sub>H</sub> | 0FD6 <sub>H</sub> | 0FE6 <sub>H</sub> | Т6 | | | 0F87 <sub>H</sub> | 0F97 <sub>H</sub> | 0FA7 <sub>H</sub> | 0FB7 <sub>H</sub> | 0FC7 <sub>H</sub> | 0FD7 <sub>H</sub> | 0FE7 <sub>H</sub> | T7 | | | 0F88 <sub>H</sub> | 0F98 <sub>H</sub> | 0FA8 <sub>H</sub> | 0FB8 <sub>H</sub> | 0FC8 <sub>H</sub> | 0FD8 <sub>H</sub> | 0FE8 <sub>H</sub> | T8 | | | 0F89 <sub>H</sub> | 0F99 <sub>H</sub> | 0FA9 <sub>H</sub> | 0FB9 <sub>H</sub> | 0FC9 <sub>H</sub> | 0FD9 <sub>H</sub> | 0FE9 <sub>H</sub> | Т9 | | | 0F8A <sub>H</sub> | 0F9A <sub>H</sub> | 0FAA <sub>H</sub> | 0FBA <sub>H</sub> | 0FCA <sub>H</sub> | 0FDA <sub>H</sub> | 0FEA <sub>H</sub> | T10 | | | 0F8B <sub>H</sub> | 0F9B <sub>H</sub> | 0FAB <sub>H</sub> | 0FBB <sub>H</sub> | 0FCB <sub>H</sub> | 0FDB <sub>H</sub> | 0FEB <sub>H</sub> | T11 | | | 0F8C <sub>H</sub> | 0F9C <sub>H</sub> | 0FAC <sub>H</sub> | 0FBC <sub>H</sub> | 0FCC <sub>H</sub> | 0FDC <sub>H</sub> | 0FEC <sub>H</sub> | T12 | | | 0F8D <sub>H</sub> | 0F9D <sub>H</sub> | 0FAD <sub>H</sub> | 0FBD <sub>H</sub> | 0FCD <sub>H</sub> | 0FDD <sub>H</sub> | 0FED <sub>H</sub> | T13 | | | 0F8E <sub>H</sub> | 0F9E <sub>H</sub> | 0FAE <sub>H</sub> | 0FBE <sub>H</sub> | 0FCE <sub>H</sub> | 0FDE <sub>H</sub> | 0FEE <sub>H</sub> | T14 | | | 0F8F <sub>H</sub> | 0F9F <sub>H</sub> | 0FAF <sub>H</sub> | 0FBF <sub>H</sub> | 0FCF <sub>H</sub> | 0FDF <sub>H</sub> | 0FEF <sub>H</sub> | T15 | | output pin | V0 to V7 | V8 to V15 | V16 to V23 | V24 to V31 | V32 to V39 | V40 to V47 | V48 to V50 | l | Figure 2-82. VFT Display Data Buffer Memory (DBR) ## 2.12.4 Display Operation As the above-mentioned, the segment and the digit are not allocated. 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-83. shows the VFT drive pulse and Figure 2-84, 85 show the display operation. Figure 2-83. VFT Drive Waveform and Display timing # 2.12.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-84. Example of Conventional type VFT driver pulse # www.DataS(2)et4For 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-85. Grid Scan Type Display Vacuum Fluorescent Tube Ware # 2.12.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". #### ① 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-86. (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-86. External Circuit Interface ### INPUT/OUTPUT CIRCUITRY The instruction for specifying Masking Option (I/O code) in ES Order Sheet is described in ADDITIONAL INFORMATION "Notice for Masking Option of TLCS-870 series" section 8. # (1) Control pins The input/output circuitries of the 87CH75/M75 control pins are shown below. Please specify either the single-clock mode (oscillation only XIN/XOUT) or the dual-clock mode (oscillation both XIN/XOUT and XTIN/XTOUT) by a code (NM1 or NM2) as an option for an operating mode during reset. | CONTROL PIN | I/O | INPUT/OUTPUT CIRCUITRY and code | REMARKS | | |---------------|-----------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--| | XIN<br>XOUT | Input<br>Output | Osc. enable fc VDD O R <sub>f</sub> XIN XOUT | Resonator connecting pins (high-frequency) $R_f = 1.2 M\Omega \text{(typ.)} \\ R_O = 1.5 k\Omega \text{(typ.)}$ | | | XTIN<br>XTOUT | Input<br>Output | NM1 NM2 Osc. enable VDD o fs NTIN XTOUT | Resonator connecting pins (low-frequency) $R_f = 6 \text{M}\Omega \qquad \text{(typ.)} \\ R_O = 220 \text{k}\Omega \qquad \text{(typ.)}$ | | | RESET | 1/0 | Address-trap-reset Watchdog-timer-reset System-clock-reset | Sink open drain output Hysteresis input $Pull-up\ resistor$ $R_{IN}\ = 220\ k\Omega \qquad (typ.)$ $R\ = 1\ k\Omega \qquad (typ.)$ | | | STOP/INT5 | Input | P20 STOP/INT5 | Hysteresis input $R = 1 \text{ k}\Omega \qquad \text{(typ.)}$ | | | TEST | Input | R <sub>IN</sub> R <sub>IN</sub> | Pull-down resistor $R_{\text{IN}} = 70 \text{ k}\Omega \qquad \text{(typ.)}$ $R = 1 \text{ k}\Omega \qquad \text{(typ.)}$ | | Note1: The TEST pin of the 87PM75 does not have a pull-down resistor. Be sure to fix the TEST pin to low in MCU mode. Note2: The 87PM75 is placed in the single-clock mode during reset, and the input/output circuitries are the code NMI type. # www.D(2) 5 Det4Input/Output Ports The input/output circuitries of the 87CH75/M75 input / output ports are shown below, any one of the circuitries can be chosen by a code (A or D) as a mask option. | PORT | I/O | INPUT / OUTPUT CIRCUITRY | REMARKS | |----------|-----|--------------------------|-----------------------------------------------------------------------------------------------------| | P0<br>P1 | 1/0 | disable | Tri-state I/O Hysteresis input High current output (P0, P10 to P14) $R = 1 \ k\Omega \ (typ.)$ | | P2 | 1/0 | initial "Hi-Z" | Sink open drain output High current output $R=1\ k\Omega$ | | Р3 | 1/0 | initial "Hi-Z" disable | Sink open drain output $Hysteresis\ input \\ R=1\ k\Omega\ (typ.)$ | | P4<br>P5 | I/O | initial "Hi-Z" disable | Tri-state I/O $R=1\ k\Omega\ (typ.)$ | | P6 | 1/0 | initial "Hi-Z" | Source open drain output $High-breakdown\ voltage$ $R_K=80\ k\Omega\ (typ.)$ $R=1\ k\Omega\ (typ.)$ | | P8<br>P9 | 1/0 | R1 | R1 = 200 kΩ (typ.) | Note: The input/output circuitries of the 87PM75 I/O ports are the code A type. # www.D(2) = @et4Input/Output Ports | A D Source open drain output | |--------------------------------------------------------------------------------------------------------------------------------------------| | PE I/O $R_{K} = 80 \text{ k}\Omega \text{ (typ.)}$ $R_{K} = 1 \text{ k}\Omega \text{ (typ.)}$ $R_{R} = 200 \text{ k}\Omega \text{ (typ.)}$ | ### **Electrical Characteristics** **Absolute Maximum Ratings** $(V_{SS} = 0 V)$ | Parameter | Symbol | Pins | Ratings | Unit | | |---------------------------------|---------------------|-----------------------------|----------------------------------------|------|--| | Supply Voltage | $V_{DD}$ | | – 0.3 to 6.5 | V | | | Input Voltage | $V_{IN}$ | | – 0.3 to V <sub>DD</sub> + 0.3 | > | | | Output Valtage | V <sub>OUT1</sub> | P2, P3, P4, P5, XOUT, RESET | – 0.3 to V <sub>DD</sub> + 0.3 | \ \ | | | Output Voltage | V <sub>OUT3</sub> | Source open drain ports | $V_{DD} - 40 \text{ to } V_{DD} + 0.3$ | ] | | | | I <sub>OUT1</sub> | P15 to P17, P3, P4, P5 | 3.2 | | | | Output Current (Par 1 nin) | I <sub>OUT2</sub> | P0, P10 to P14, P2 | 30 | | | | Output Current (Per 1 pin) | I <sub>OUT3</sub> | P8, P9, PD, PE, PF | <b>–</b> 12 | mA | | | | I <sub>OUT4</sub> | P6, P7 | <b>– 2</b> 5 | | | | | $\Sigma I_{OUT1}$ | P15 to P17, P3, P4, P5 | 60 | | | | Output Current (Total) | $\Sigma I_{OUT2}$ | P0, P10 to P14, P2 | 160 | mA | | | | Σ I <sub>OUT3</sub> | P6, P7, P8, P9, PD, PE, PF | - 200 | | | | Power Dissipation [Topr = 25°C] | PD | Note 2 | 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: 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})$ | Parameter | Symbol | Pins | Conditions | | Min | Max | Unit | |----------------------|-------------------|-------------------------|---------------------------------------------------|-------------------------|----------------------|------------------------|-------| | | | | f- 0.0411- | NORMAL 1, 2 modes | 4.5 | | | | | | | fc = 8 MHz | IDLE1, 2 modes | 4.5 | | | | Supply Voltage | $V_{DD}$ | | fs = | SLOW mode | 2.7 | 5.5 | V | | | | | 32.768 kHz | SLEEP mode | 2.7 | | | | | | | | STOP mode | 2.0 | | | | Output Voltage | V <sub>OUT3</sub> | Source open drain ports | | | V <sub>DD</sub> – 38 | V <sub>DD</sub> | ٧ | | | V <sub>IH1</sub> | Except hysteresis input | V <sub>DD</sub> ≥ 4.5 V<br>V <sub>DD</sub> <4.5 V | | $V_{DD} \times 0.70$ | | V | | Input High Voltage | V <sub>IH2</sub> | Hysteresis input | | | $V_{DD} \times 0.75$ | V <sub>DD</sub> | | | Impacting it voltage | V <sub>IH3</sub> | | | | $V_{DD} \times 0.90$ | | | | | V <sub>IL1</sub> | Except hysteresis input | V >45V | | | $V_{DD} \times 0.30$ | | | Input Low Voltage | $V_{IL2}$ | Hysteresis input | \ | / <sub>DD</sub> ≥ 4.5 V | 0 | V <sub>DD</sub> × 0.25 | V | | | V <sub>IL3</sub> | | \ | / <sub>DD</sub> <4.5V | | V <sub>DD</sub> × 0.10 | | | | f- | VIN VOLIT | V <sub>DD</sub> = 4.5 V to 5.5 V | | 0.4 | 8.0 | N/11- | | Clock Frequency | fc X | XIN, XOUT | V <sub>DD</sub> = 2.7 V to 5.5 V | | 0.4 | 4.2 | MHz | | | fs | XTIN, XTOUT | | | 30.0 | 34.0 | kHz | Note 1: The recommended operating conditions for a device are operating conditions under which it can be guaranteed that the device will operate as specified. If the device is used under operating conditions other than the recommended operating conditions (supply voltage, operating temperature range, specified AC/DC values etc.), malfunction may occur. Thus, when designing products which include this device, ensure that the recommended operating conditions for the device are always adhered to. Note 2: Clock frequency fc: Supply voltage range is specified in NORMAL 1/2 mode and IDLE 1/2 mode. ### How to calculate power consumption. With the TMP87CH75/CM75F, a pull-down resistor (Rk = 80 k $\Omega$ typ.) can be built into a VFT driver using mask option. 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, $\begin{array}{lll} \text{operating power consumption: VDD x IDD} \\ \text{LED output loss} & : & I_{OL3} \, x \, V_{OL} \end{array}$ VFT driver loss : VFT driver output loss + pull-down resistor (Rk) loss #### Example: When Ta = 10 to $50^{\circ}$ C (When using a fluorescent display tube with a grid scan type which can use two or more grid outputs.) and a fluorescent display tube with segment output = 3 mA, digit output = 15 mA, Vxx = -25 V is used. Operating conditions: VDD = $5 \text{ V} \pm 10 \text{ %}$ , fc = 8 MHz, VFT dimmer time (DIM) = (14/16) x tseg, Digit outputs = two pins. Power consumption Pmax = (1) + (2) + (3) #### Where, (1) Operating power consumption: $V_{DD} \times I_{DD} = 5.5 \text{ V} \times 14 \text{ mA} = 77 \text{ mW}$ (2) LED output : $10 \text{ mA} \times 1.0 \text{ V} \times 4 = 40 \text{ mW}$ (when using four LED) (3) VFT driver loss : segment pin = 3 mA x 2 V x number of segments X = 6 mW x X digit pin = $15 \text{ mA} \times 2 \text{ V} \times 14/16$ (DIM) x number of digits Y = 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) = 18.605 mW x (X + 2) Therefore, Pmax = 77 mW + 40 mW + 6 mW $\times$ X + 52.5 mW + 18.605 mW x (X + 2) = 206.71 mW + 24.605X... Maximum power consumption Pd when $Ta = 50^{\circ}C$ is determined by the following equation: PD = 1200 mW - (14.3 x 25) = 842.5 mW The number of segments X which can be lit is: PD > Pmax $842.5 \,\mathrm{mW} > 206.71 + 24.605 \,\mathrm{X}$ 25.8 > X Thus, a fluorescent display tube with less than 25 segments can be used. If a fluorescent display tube with 25 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 25 by software. www.DataSheet4U.com #### 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 | - | ٧ | | | | I <sub>IN1</sub> | TEST | | | | | | | | In a set Command | I <sub>IN2</sub> | Open drain ports, Tri-state ports | V <sub>DD</sub> = 5.5 V | - | _ | ± 2 | | | | Input Current | I <sub>IN3</sub> | RESET, STOP | V <sub>IN</sub> = 5.5 V / 0 V | | | | μA | | | | I <sub>IN4</sub> | PD port (Note3) | ] | _ | _ | 80 | | | | Input Resistance | R <sub>IN2</sub> | RESET | | 100 | 220 | 450 | kΩ | | | Pull-down Resistance | $R_{K}$ | Source open drain ports | $V_{DD} = 5.5 \text{ V}, V_{KK} = -30 \text{ V}$ | 50 | 80 | 110 | kΩ | | | | I <sub>LO1</sub> | Sink open drain ports | $V_{DD} = 5.5 \text{ V}, V_{OUT} = 5.5 \text{ V}$ | _ | - | 2 | | | | Output Leakage<br>Current | I <sub>LO2</sub> | Source open drain ports and tristate ports | $V_{DD} = 5.5 \text{ V}, \ V_{OUT} = -32 \text{ V}$ | | - | - 2 | μΑ | | | | I <sub>LO3</sub> | Tri-state ports | $V_{DD} = 5.5 \text{ V}, V_{OUT} = 5.5 \text{ V}/0 \text{ V}$ | _ | _ | ± 2 | | | | Outro dell'ob Moltono | V <sub>OH2</sub> | Tri-state ports | $V_{DD} = 4.5 \text{ V}, I_{OH} = -0.7 \text{ mA}$ | 4.1 | _ | _ | - v | | | Output High Voltage | V <sub>OH3</sub> | P8, P9, PD | $V_{DD} = 4.5 \text{ V}, I_{OH} = -8 \text{ mA}$ | 2.4 | _ | _ | | | | Output Low Voltage | V <sub>OL</sub> | Except XOUT, P0, P10 to P14, P2 | $V_{DD} = 4.5 \text{ V}, I_{OL} = 1.6 \text{ mA}$ | _ | _ | 0.4 | V | | | Output Low Current | I <sub>OL3</sub> | P0, P10 to P14, P2 | $V_{DD} = 4.5 \text{ V}, V_{OL} = 1.0 \text{ V}$ | _ | 20 | _ | mA | | | Output High Current | I <sub>OH</sub> | P6, P7 | $V_{DD} = 4.5 \text{ V}, V_{OH} = 2.4 \text{ V}$ | _ | - 20 | _ | mA | | | Supply Current in NORMAL 1, 2 modes | | | V <sub>DD</sub> = 5.5 V<br>fc = 8 MHz | - | 10 | 14 | | | | Supply Current in IDLE 1, 2 modes | | | fs = 32.768 kHz<br>V <sub>IN</sub> = 5.3 V / 0.2 V | _ | 6 | 9 | mA | | | Supply Current in SLOW mode | I <sub>DD</sub> | | V <sub>DD</sub> = 3.0 V | - | 30 | 60 | | | | Supply Current in SLEEP mode | | | fs = 32.768 kHz<br>V <sub>IN</sub> = 2.8 V / 0.2 V | - | 15 | 30 | μA | | | Supply Current in 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,IIN3</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. ## A/D Conversion Characteristics $$(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 6.0 \text{ V}, Topr = -30 \text{ to } 70^{\circ}\text{C})$$ | Parameter | Symbol | Conditions | Min | Тур. | Max | Unit | | |--------------------------|-------------------|-----------------------------------------------------------|------------------|-----------------|-------------------|------|--| | Analan Dafananaa Valtana | V <sub>AREF</sub> | VAREF | | _ | V <sub>DD</sub> | V | | | Analog Reference Voltage | V <sub>ASS</sub> | $V_{AREF} - V_{ASS} \ge 2.5 V$ | | 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 | | | _ | _ | ± 1 | | | | Zero Point Error | | $V_{DD} = 5.0 \text{ V}, V_{SS} = 0.0 \text{ V}$ | _ | - | ± 1 | | | | Full Scale Error | | V <sub>AREF</sub> = 5.000 V<br>V <sub>ASS</sub> = 0.000 V | _ | - | ± 1 | LSB | | | Total Error | | | | _ | ± 2 | | | Note: Total errors includes all errors, except quantization error. www.DataSheet4U.com ### A.C. Characteristics $(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, Topr = -30 \text{ to } 70^{\circ}\text{C})$ | Parameter | Symbol | Conditions | Min | Тур. | Max | Unit | |------------------------------|------------------|-------------------------------|-------|------|-------|---------| | | | In NORMAL1, 2 modes | ٥٠ | | 10 | | | Marshing Coals Times | ١. | In IDLE 1, 2 modes | 0.5 | _ | 10 | | | Machine Cycle Time | t <sub>cy</sub> | In SLOW mode | 447.6 | | 122.2 | $\mu$ S | | | | In SLEEP mode | 117.6 | _ | 133.3 | | | High Level Clock Pulse Width | t <sub>WCH</sub> | For external clock operation | 50 | _ | _ | | | Low Level Clock Pulse Width | t <sub>WCL</sub> | (XIN input), fc = 8 MHz | | | | ns | | High Level Clock Pulse Width | t <sub>WSH</sub> | For external clock operation | 14.7 | - | _ | | | Low Level Clock Pulse Width | t <sub>WSL</sub> | (XTIN input), fs = 32.768 kHz | | | | μ\$ | # **Recommended Oscillating Conditions** $$(V_{SS} = 0 \text{ V}, V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, Topr = -30 \text{ to } 70^{\circ}\text{C})$$ | | <b>.</b> | Oscillation | Recommended Oscillator | | Recommended Constant | | | |-------------------------------|--------------------|-------------|------------------------|-------------|----------------------|----------------|--| | Parameter | Oscillator | Frequency | | | C <sub>1</sub> | C <sub>2</sub> | | | High-frequency<br>Oscillation | | 8 MHz | KYOCERA | KBR8.0M | | | | | | Ceramic Resonator | 4 MHz | KYOCERA | KBR4.0MS | 30pF | 30pF | | | | | | MURATA | CSA 4.00MG | | | | | | Crystal Oscillator | 8 MHz | тоуосом | 210B 8.0000 | | | | | | | 4 MHz | тоуосом | 204B 4.0000 | 20pF | 20pF | | | Low-frequency<br>Oscillation | Crystal Oscillator | 32.768 KHz | NDK | MX-38T | 15pF | 15pF | | (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.