#### CMOS 8-Bit Microcontroller ## TMP87CM53F The 87CM53 is the high speed and high performance 8-bit single chip microcomputers. These MCU contain CPU core, ROM, RAM, input/output ports, an A/D converter, DTMF generator, multi-function timer/counters, two serial interfaces, and two clock generators on a chip. The 87CM53 provides high current output capability for LED direct drive. | Part No. | ROM | RAM | Package | OTP MCU | | |------------|--------------|--------------|--------------------|------------|--| | TMP87CM53F | 32 K × 8-bit | 1024 × 8-bit | P-QFP80-1420-0.80B | TMP87PM53F | | #### **Features** - ▶8-bit single chip microcomputer TLCS-870 Series - Instruction execution time: 0.5 $\mu$ s (at 8 MHz, gear ratio 1/1), 122 $\mu$ s (at 32.768 kHz) - 412 basic instructions - Multiplication and Division (8 bits × 8 bits, 16 bits ÷ 8 bits) - Bit manipulations (Set/Clear/Complement/Move/Test/Exclusive or) - 16-bit data operations - 1-byte jump/subroutine-call (Short relative jump / Vector call) - 15 interrupt sources (External: 5, Internal: 10) - All sources have independent latches each, and nested interrupt control is available. - edge-selectable external interrupts with noise reject - High-speed task switching by register bank changeover - 10 Input/Output ports (72 pins) - High current output: 7 pins (typ. 20 mA) - 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 frequenc: 0.95 Hz to 16384 Hz) - Divider output function (frequency: 0.976 kHz to 8.192 kHz) - Tone generator - Single tone / Dual tone (DTMF) output function - Melody (sine wave / square wave) output function - Watchdog Timer - 8-bit Serial Interface - 8 bytes transmit/receive data buffer - Internal/external serial clock, and 4/8-bit mode - **UART** - 8-bit successive approximate type A/D converter with sample and hold - 8 analog inputs - Conversion time: 23 $\mu$ s or 92 $\mu$ s (at 8 MHz, gear ratio 1/1) 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. TOSHIBA is continually working to improve the quality and the 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 observe standards of safety, and to avoid situations in which a malfunction or failure of a TOSHIBA product 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 products specifications. Also, please keep in mind the precautions and conditions set forth in the TOSHIBA Semiconductor Reliability Handbook. The products described in this document are subject to the foreign exchange and foreign trade laws. The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA CORPORATION for any infringements of intellectual property or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any intellectual property or other rights of TOSHIBA CORPORATION or others. The information contained herein is subject to change without notice. 3-53-1 1999-08-23 - ◆Key on Wake-Up - ◆ Dual clock operation - ◆Internal clock select mode (fc, fc/2, fc/4, fc/8) Initial fc/8 operation - ◆ Five Power saving operating modes - STOP mode: Oscillation stops. Battery/Capacitor back-up. Port output hold/high-impedance. - SLOW mode: Low power consumption operation using low-frequency clock (32.768kHz). - 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. - ♦ Wide operating voltage: 2.2 to 5.5 V at [3.58 MHz] [3.84 MHz] [4.0 MHz] [4.19 MHz] / 32.768 kHz, 4.5 to 5.5 V at 8 MHz / 32.768 kHz - ◆Emulation Pod: BM87CM53F0A 3-53-2 1999-08-23 # Pin Assignments (Top View) ## **Pin Function** | Pin Name | Input / Output | Function | | | | | |------------------|----------------|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------|--|--|--| | P07 to P00 | I/O | Two 8-bit programmable input/output | | | | | | P17, P16 | I/O | ports (tri-state). | | | | | | P15 (TC2) | I/O (Input) | Each bit of these ports can be individually configured as an input or an output | Timer/Counter 2 input | | | | | P14 (PPG) | | under software control. | Programmable pulse generator output | | | | | P13 (DVO) | I/O (Output) | During reset, all bits are configured as | Divider output | | | | | P12 (INT2 / TC1) | | input. | External interrupt input 2 or Timer/Counter 1 input | | | | | P11 (INT1) | I/O (Input) | When used as a divider output or a PPG | External interrupt input 1 | | | | | P10 (ĪNTO) | | output, the latch must be set to "1". | External interrupt input 0 | | | | | P23 | 1/0 | | l l | | | | | P22 (XTOUT) | I/O (Output) | 4-bit input/output port with latch. | Resonator connecting pins (32.768kHz). | | | | | P21 (XTIN) | ",o (output) | When used as an input port, the latch | For inputting external clock, XTIN is used and XTOUT is opened. | | | | | P20 (INT5/STOP) | I/O (Input) | must be set to "1". | External interrupt input 5 or STOP mode | | | | | P36 to P30 | 1/0 | 7-bit input/output port (high current outpu | release signal input<br>t) with latch. | | | | | | | When used as an input port, the latch must 8-bit programmable input/output port | | | | | | P47 (Tone) | I/O (Output) | (tri-state). Each bit of the port can be | Tone output | | | | | P46 (Melody1) | I/O (Output) | individually configured as an input or an | Melody1 output (sine wave) | | | | | P45 (SO) | I/O (Output) | output or a port option under software | SIO serial data output | | | | | P44 (SI) | I/O (Input) | control. During reset, all bits are | SIO serial data input | | | | | P43 (SCK) | 1/0 (1/0) | configured as input. | SIO serial clock input/output | | | | | P42 | 1/0 | When used as an input port or a SIO | SIO serial data output | | | | | P41 (TxD) | I/O (Output) | input/output, the latch must be set to "1". | (asynchronous only)<br> SIO serial data input | | | | | P40 (RxD) | I/O (Input) | | (asynchronous only) | | | | | P54 | 1/0 | 5-bit programmable input/output port<br>(tri-state) Each bit of the port can be | | | | | | P53 (Melody2) | I/O (Output) | individually configured as an input or an output or a port option under software | Melody2 output (square wave) | | | | | P52 (PWM/PDO) | I/O (Output) | control. During reset, all bits are configured as input. | 8-bit PWM output or<br>8-bit programmable divider output | | | | | P51 | I/O | When used as an inp <u>ut port, an</u> external | | | | | | P50 (INT3/TC3) | I/O (Input) | interrupt input, or a PWM/PDO output,<br>the latch must be set to "1". | External interrupt input 3 or Timer/Counter 3 input | | | | | P67 (AIN7) | | 8-bit programmable input/output port (tri-state). Each bit of the port can be | | | | | | to P60 (AIN0) | I/O (Input) | individually configured as an input or an output under software control. | A/D converter analog inputs | | | | | P77 to P70 | 1/0 | 8-bit programmable input/output port (tri-s | state). Each bit of the port can be | | | | | P97 to P90 | 1/0 | individually configured as an input or an ou<br>control. During reset, all bits are configure | ιτρατ or a port option under soπware<br>d as input. | | | | | P87 (STPR7) | | 8-bit programmable input/output port (tri-s | | | | | | to P80 (STPR0) | I/O (Input) | Reset signal input or watchdog timer output/address-trap-reset output/system-clock- | | | | | | XIN, XOUT | Input, Output | | | | | | | RESET | 1/0 | | | | | | | TEST | Input | reset output. Test pin for out-going test. Be tied to low. | | | | | | VDD, VSS | прис | | | | | | | | Power Supply | | | | | | | VAREF, VASS | | Analog reference voltage inputs (High, Low) | | | | | ## **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 87CM53. 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 3-53-5 ## 1.2 Program Memory (ROM) The 87CM53 has a 32K $\times$ 8-bit (address 8000<sub>H</sub>-FFFF<sub>H</sub>) of program memory (mask programmed ROM). Addresses FF00<sub>H</sub>-FFFF<sub>H</sub> in the program memory can also be used for special purposes. - (1) Interrupt / Reset vector table (addresses FFE0<sub>H</sub>-FFFF<sub>H</sub>) This table consists of a reset vector and 15 interrupt vectors (2 bytes/vector). These vectors store a reset start address and interrupt service routine entry addresses. - (2) Vector table for **vector call** instructions (addresses FFC0<sub>H</sub>-FFDF<sub>H</sub>) This table stores call vectors (subroutine entry address, 2 bytes/vector) for the vector call instructions [CALLV n]. There are 16 vectors. The CALLV instruction increases memory efficiency when utilized for frequently used subroutine calls (called from 3 or more locations). - (3) Entry area (addresses FF00<sub>H</sub>-FFFF<sub>H</sub>) for **page call** instructions This is the subroutine entry address area for the page call instructions [CALLP n]. Addresses FF00<sub>H</sub>-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+80H When ZF = 1, the jump is made to E846<sub>H</sub>, which is FF80<sub>H</sub> (-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 C235<sub>H</sub>. The absolute jump instruction can jump anywhere within the entire 64K-bytes space. Figure 1-2. Program Memory Map In the TLCS-870 Series, the same instruction used to access the data memory (e.g. [LD A, (HL)]) is also used to read out fixed data (ROM data) stored in the program memory. The register-offset PC-relative addressing (PC + A) instructions can also be used, and the code conversion, table look-up and n-way multiple jump processing can easily be programmed. ``` Loads the ROM contents at the address specified by the HL register pair contents into the accumulator (HL \ge 8000_H): LD A, (HL) ; A←ROM (HL) Converts BCD to 7-segment code (common anode LED). When A = 05H, 92H is Example 2: output to port P6 after executing the following program: ; P6 ←ROM (TABLE + A) ADD A, TABLE - $ - 4 LD (P6), (PC + A) JRS T, SNEXT TABLE: DB 0C0H, 0F9H, 0A4H, 0B0H, 99H, 92H, 82H, 0D8H, 80H, 98H SNEXT: Notes: "$" is a header address of ADD instruction. DB is a byte data difinition instruction. (PC + A) Example 3: N-way multiple jump in accordance with the contents of 34 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 C3 if A = 02_H then PC \leftarrow DA37_H DΔ if A = 03_H then PC \leftarrow E1B0_H B0 0C234H, 0C378H, 0DA37H, 0E1B0H E1 Note: DW is a word data definition instruction. ``` ## 1.3 Program Counter (PC) The program counter (PC) is a 16-bit register which indicates the program memory address where the instruction to be executed next is stored. After reset, the user defined reset vector stored in the vector table (addresses FFFF<sub>H</sub> and FFFE<sub>H</sub>) is loaded into the PC; therefore, program execution is possible from any desired address. For example, when C0<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 C03E<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 3-53-7 ## 1.4 Data Memory (RAM) The 87CM53 has a 1K $\times$ 8-bit (addresses 0040<sub>H</sub>-043F<sub>H</sub>) of data memory (static RAM). Figure 1-4 shows the data memory map. Addresses 0000<sub>H</sub>-00FF<sub>H</sub> are used as a direct addressing area to enhance instructions which utilize this addressing mode; therefore, addresses 0040<sub>H</sub>-00FF<sub>H</sub> in the data memory can also be used for user flags or user counters. Example 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_{H,}$ and clears to $00_H$ when $10_H$ is exceeded. INC (00F5H) ; $(00F5_{H}) \leftarrow (00F5_{H}) + 1$ AND (00F5H), 0FH ; $(00F5_{H}) \leftarrow (00F5_{H}) \wedge 0F_{H}$ 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". With the 87CM53, programs in data memory cannot be executed. If the program counter indicates a data memory address, an address-trap-reset is generated due to due to bus error. (Output from the RESET pin goes low.) ``` Example 1: Clears RAM to "00H" except the bank 0 ``` 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. 03F7H ; Sets number of byte to BC register pair SRAMCLR: LD (HL+), ADEC BC JRS F, SRAMCLR Note 1: The data memory contents become unstable when the power supply is turned on; therefore, the data memory should be initialized by an initialization routine. 3-53-8 Note 2: The general-purpuse registers are mapped in the RAM; therefore, do not clear RAM at the current bank addresses. 1999-08-23 Figure 1-4. Data Memory Map ## 1.5 General-purpose Register Banks General-purpose registers are mapped into addresses 0040<sub>H</sub>-00BF<sub>H</sub> in the data memory as shown in Figure 1-4. There are 16 register banks, and each bank contains eight 8-bit registers W, A, B, C, D, E, H, and L. Figure 1-5 shows the general-purpose register bank configuration. Figure 1-5. General-purpose Register Banks In addition to access in 8-bit units, the registers can also be accessed in 16-bit units as the register pairs WA, BC, DE, and HL. Besides its function as a general-purpose register, the register also has the following functions: ## (1) A, WA The A register functions as an 8-bit accumulator and WA the register pair functions as a 16-bit accumulator (W is high byte and A is low byte). Registers other than A can also be used as accumulators for 8-bit operations. ``` Examples: ① ADD A, B ; Adds B contents to A contents and stores the result into A. © SUB WA, 1234H ; Subtracts 1234<sub>H</sub> from WA contents and stores the result into WA. © SUB E, A ; Subtracts A contents from E contents, and stores the result into E. ``` ## (2) HL, DE The HL and DE specify a memory address. The HL register pair functions as data pointer (HL) /index register (HL + d) /base register (HL + C), and the DE register pair function as a data pointer (DE). The HL also has an auto-post- increment and auto-pre-decrement functions. This function simplifies multiple digit data processing, software LIFO (last-in first-out) processing, etc. ``` Example 1: ① LD ; Loads the memory contents at the address specified by HL into A. A, (HL) 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 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. A, (HL +) ; Loads the memory contents at the address specified by HL into A. Then increments HL. 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. #### Example 2: Block transfer ``` ; m = n - 1 (n : number of bytes to transfer) B. m LD HL, DSTA ; Sets destination address to HL ; Sets source address to DE LD DE, SRCA SLOOP: LD (HL), (DE) : HL←DE INC HL ; HL ← HL + 1 INC DE ; DE ← DE + 1 DEC R ; B \leftarrow B - 1 JRS F, SLOOP ; if B \ge 0 then loop ``` ## (3) **B, C, BC** Registers B and C can be used as 8-bit buffers or counters, and the BC register pair can be used as a 16-bit buffer or counter. The C register functions as an offset register for register-offset index addressing (refer to example 1 ③ above) and as a divisor register for the division instruction [DIV gg, C]. ``` Example 1: Repeat processing ``` 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], [POP PSW] to access the PSW. The PSW can be also operated by the memory access instruction. ``` Example 1 : Incrementing the RBS |NC| \quad (003FH) \qquad ; \quad RBS \leftarrow RBS + 1 Example 2 : Reading the RBS |D| \quad A, (003FH) \qquad ; \quad A \leftarrow PSW \, (A_{3-0} \leftarrow RBS, A_{7-4} \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 $\leftarrow$ n (Bank changeover) Interrupt processing RETI ; Maskable interrupt return (Bank restoring) ## 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 instructions [SET, CLR, and CPL], the ZF is set to "1" if the contents of the specified bit is "0"; otherwise the ZF is cleared to "0". This flag is set to "1" when the upper 8 bits of the product are $00_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 (The result of exclusive-OR between bit 5 content of address 07<sub>H</sub> and bit 0 content of address 9A<sub>H</sub> is written to bit 2 of address 01<sub>H</sub>.) LD CF, (0007H) . 5 ; $(0001_H)_2 \leftarrow (0007_H)_5 \forall (009A_H)_0$ XOR CF, (009AH) . 0LD (0001H) . 2, CF ## (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). Example: 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$ , $CF \leftarrow 0$ DAA A ; $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 [JR T/F, \$+2+d], [JRS 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 [JRST, \$+2+d] and [JRT, \$+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 T, SLABLE2; JF is set to "1" by the immediately preceding instruction, making it an unconditional jump instruction. Example: The accumulator and flags become as shown below after executing the following instructions when the WA register pair, the HL register pair, the data memory at address 00C5<sub>H</sub>, the carry flag and the half carry flag contents being "219A<sub>H</sub>", "00C5<sub>H</sub>", "D7<sub>H</sub>", "1" and "0", respectively. | Instruction | | Acc. after | Flag after execution | | | | |-------------|-----------|------------|----------------------|----|----|----| | 1113 | ou action | 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 | | | | |----------------|------------|----------------------|----|----|----| | madadam | 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 [CALL a] / [CALLP n] / [CALLV n], the contents of the PC (the return address) is saved; on an interrupt acceptance, the contents of the PC and the PSW are saved (the PSW is pushed first, followed by 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. 3-53-13 ## 1.7.2 Stack Pointer (SP) The stack pointer (SP) is a 16-bit register containing the address of the next free locations on the stack. The SP is post-decremented when a subroutine call or a push instruction is executed, or when an interrupt is accepted; and the SP is pre-incremented when a return or a pop instruction is executed. Figure 1-8 shows the stacking order. Figure 1-7. Stack Pointer The SP is not initialized hardware-wise but requires initialization by an initialize routine (sets the highest stack address). [LD SP, mn], [LD SP, gg] and [LD gg, SP] are the SP access instructions (mn; 16-bit immediate data, gg; register pair). Example 1: To initialize the SP LD SP, 043FH ; SP←043F<sub>H</sub> 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 peripheral hardware. It contains two oscillation circuits: one for the high-frequency clock and one for the low-frequency clock. Power consumption can be reduced by switching of the system clock controller to low-power operation based on the low-frequency clock. The high-frequency (fc) and low-frequency (fs) clocks can be easily obtained by connecting a resonator between the XIN/XOUT and XTIN/XTOUT pins, respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to the XIN/XTIN pin with the XOUT/XTOUT pin not connected. The 87CM53 is not provided an RC oscillation. Figure 1-10. Examples of Resonator Connection Note: Accurate Adjustment of the Oscillation Frequency: Although no hardware to externally and directly monitor the basic clock pulse is not provided, the oscillation frequency can be adjusted by making the program to output fixed frequency pulses to the port while disabling all interrupts and the watchdog timer and monitoring this pulse. With a system requiring adjustment of the oscillation frequency, the adjusting program must be created beforehand. ## 1.8.2 Clock Gear The clock gear is a circuit to select a gear clock fcgck, that is the basis of the main system clock supplied to the timing generator, from high-frequency clock fc, or the divided clock fc/2, fc/4, or fc/8. Power consumption can be reduced by switching of the gear clock from fc to fc/2, fc/4, and fc/8 with the clock gear using. The clock gear consists of a 3-stage prescaler with a multiplexer. Note: The gear clock fcgck is specified to be fc/8 after reset release. Figure 1-11. Configuration of Clock Gear Figure 1-12. Clock Gear Control Register Figure 1-13. Example of Clock Exchangeable Timing by Clock Gear ## 1.8.3 Timing Generator The timing generator generates the various system clocks supplied to the CPU core and peripheral hardware from the gear clock (fcgck) or the basic clock (fc or fs). The timing generator provides the following functions. - ① Generation of main system clock (fm) - ② Generation of divider output (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-TC3, TC5 - 6 Generation of warm-up clocks for releasing STOP mode ## (1) Configuration of timing generator The timing generator consists of a 2-stage prescaler, a 21-stage divider, a main system clock generator, and machine cycle counters. The clock fc/4, that is output from the 2nd stage of the prescaler. Even if the main system clock is changed by the clock gear, the output from the divider is not changed. The peripheral circuit using high-speed divider output (1st to 4th output) can not be used when the main system clock slows down. In this case, setting DVCK (bits 7, 6 and 5 in CGCR) can change high-speed divider output to low-speed divider output. The DVCK should be set according to the lowest speed of the clock gear and divider output used for the peripheral circuit prior to starting the peripheral circuits. Do not change the set value after setting. An input clock to the 7th stage of the divider depends on the operating mode, DV7CK(bit 4 in TBTCR), that is shown in Table 1-2. As reset and STOP mode started/canceled, The prescaler and the divider are cleared to "0". Divider output capability DVCK Gear clock frequency DV2G DV3G DV1G DV4 fcgck = fcD Ε Ε fcgck = fc/2D D F F 000 fcgck = fc/4D D D Ε D fcgck = fc/8D D D fcgck = fcЕ Ε fcgck = fc/2D D Ε Ε 010 fcgck = fc/4D D D Ε fcgck = fc/8D D D D fcgck = fc F F F F fcqck = fc/2Ε Ε 100 fcgck = fc/4D D D Е fcgck = fc/8D ח ח D fcgck = fc E E E E fcgck = fc/2F Ε Ε Ε 110 fcgck = fc/4Ε Ε D fcack - fc/8 Table 1-1. Divider Output Capability Note : D = disable, E = enable Table 1-2. Input Clock to 7th Stage of the Divider | Single-clock mode | Dual-clock mode | | | | |----------------------|---------------------------------|-----------|------------------|--| | NORMAL1, IDLE1 mode | NORMAL2, IDLE2 mode (SYSCK = 0) | | SLOW, SLEEP mode | | | NORWALI, IBELI MIGGE | DV7CK = 0 | DV7CK = 1 | (SYSCK = 1) | | | fc/2 <sup>8</sup> | fc/2 <sup>8</sup> | fs | fs | | Note 1 : Do not set DV7CK to "1" in the single clock mode. Note 2 : In SLOW and SLEEP mode, the input clock to the 1st stage of the divider is stopped; output from the 1st to 6th stages is also stopped. Note 3 : D = disable, E = enable Note 4 : TC1CK 10 : DV1G TC5CK 011 : DV1G TC2CK 011 : DV1G SCK 010 : DV3G (SIO) 011 : DV2G 1) In the single-clock mode A divided-by-256 of high-frequency clock (fc/28) is input to the 7th stage of the divider. Do not set DVCK to "1" in the single-clock mode. ② In the dual-clock mode During NORMAL2 or IDLE2 mode (SYSCK = 0), an input clock to the 7th stage of the divider can be selected either "fc/28" or "fs" with DV7CK. During SLOW or SLEEP mode (SYSCK = 1), fs is automatically input to the 7th stage. To input clock to the 1st stage is stopped; output from the 1st to 6th stages is also stopped. Figure 1-14. Configuration of Timing Generator Figure 1-15. Clock Gear Control Register Figure 1-16. Timing Generator Control Register ## (2) Machine Cycle Instruction execution and peripheral hardware operation are synchronized with the main system clock. The minimum instruction execution unit is called an "machine cycle". There are a total of 10 different types of instructions for the TLCS-870 Series: ranging from 1-cycle instructions which require one machine cycle for execution to 10-cycle instructions which require 10 machine cycles for execution. A machine cycle consists of 4 states (S0 - S3), and each state consists of one main system clock. Figure 1-17. Machine Cycle ## 1.8.4 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-18 shows the operating mode transition diagram and Figure 1-19 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/fcgck [s]. #### ① NORMAL1 mode In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock. In the case when the single-clock mode has been selected as an option, the 87CM53 is placed in this mode after reset. ## ② IDLE1 mode In this mode, the internal oscillation circuit remains active, and the CPU and the watchdog timer are halted; however, on-chip peripherals remain active (operate using the high-frequency clock). IDLE1 mode is started by setting IDLE bit in the system control register 2 (SYSCR2), and IDLE1 mode is released to NORMAL1 mode by an interrupt request from on-chip peripherals or external interrupt inputs. When IMF (interrupt master enable flag) is "1" (interrupt enable), the execution will resume upon acceptance of the interrupt, and the operation will return to normal after the interrupt service is completed. When IMF is "0" (interrupt disable), the execution will resume with the instruction which follows IDLE mode start instruction. #### 3 STOP1 mode In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with the lowest power consumption during this mode. The output status of all output ports can be set to either output hold or high-impedance under software control. STOP1 mode is started by setting STOP bit in the system control register 1 (SYSCR1), and STOP1 mode is released by an input (either level-sensitive or edge-sensitive can be programmably selected) to the STOP pin. After the warming-up period is completed, the execution resumes with the next instruction which follows the STOP mode start instruction. 3-53-20 1999-08-23 #### (2) Dual-clock mode Both high-frequency and low-frequency oscillation circuits are used in this mode. Pins P21 (XTIN) and P22 (XTOUT) cannot be used as input/output ports. The main system clock is obtained from the high-frequency clock in NORMAL2 and IDLE2 modes, and is obtained from the low-frequency clock in SLOW and SLEEP modes. The machine cycle time is 4/fcgck [s] (0.5 $\mu$ s at fcgck = 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: The 87PM53 is placed in the single-clock mode during reset. To use the dual-clock mode, the low-frequency oscillator should be turned on by executing [SET (SYSCR2).XTEN] instruction. #### ① NORMAL2 mode In this mode, the CPU core operates using the high-frequency clock. On-chip peripherals operate using the high-frequency clock and/or low-frequency clock. In case that the dual-clock mode has been selected by an option, the 87CM53 is placed in this mode after reset. #### ② SLOW mode This mode can be used to reduce power-consumption by turning off oscillation of the high-frequency clock. The CPU core and on-chip peripherals operate using the low-frequency clock. Switching back and forth between NORMAL2 and SLOW modes is performed by the system control register 2. ## ③ IDLE2 mode In this mode, the internal oscillation circuits remain active. The CPU and the watchdog timer are halted; however, on-chip peripherals remain active (operate using the high-frequency clock and/or the low-frequency clock). Starting and releasing of IDLE2 mode are the same as for IDLE1 mode, except that operation returns to NORMAL2 mode. ## 4 SLEEP mode In this mode, the internal oscillation circuit of the low-frequency clock remains active. The CPU, the watchdog timer, and the internal oscillation circuit of the high-frequency clock are halted; however, on-chip peripherals remain active (operate using the low-frequency clock). Starting and releasing of SLEEP mode is the same as for IDLE1 mode, except that operation returns to SLOW mode. #### ⑤ STOP2 mode As in STOP1 mode, all system operations are halted in this mode. 3-53-21 Figure 1-18. Operating Mode Transition Diagram #### System Control Register 1 SYSCR1 (Initial value: 0000 00\*\*) STOP RELM RETM OUTEN $(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 RETM after STOP mode 1: Return to SLOW mode R/W Port output control 0: High-impedance OUTEN during STOP mode 1: Remain unchanged Return to Return to NORMAL made SLOW made Warming-up time at 00 01 10 WUT releasing STOP mode Note 1: Always set RETM to "0" when transitting from NORMAL1 mode to STOP1 mode and from NOMAL2 mode to STOP2 mode. Always set RETM to "1" when transitting 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 Note 4: Bits 1 and 0 in SYSCR1 are read in "1" data when a read instruction is executed. Note 5: When the stop operation is set by OUTEN = "0", the internal input is fired to "0". Interrupts may be set at the falling edge. Note 6: When the Key on wake-up is used, the edge release can not function according to some conditions. It is recommended to set the level release (RELM = "0"). System Control Register 2 SYSCR2 (Initial value: 10/100 \*\*\*\*) XEN XTEN SYSCK IDLE (0039<sub>H</sub>) High-frequency oscillator 0: Turn off oscillation XFN 1: Turn on oscillation control Low-frequency oscillator 0: Turn off oscillation **XTEN** 1 : Turn on oscillation control R/W 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) Note 1: A reset is applied (RESET pin output goes low) if both XEN and XTEN are cleared to "0". Note 2: Do not clear XEN to "0" when SYSCK = 0, and do not clear XTEN to "0" when SYSCK = 1. Note 3: WDT; watchdog timer, \*; don't care 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 (Operating Mode) is ES Order Sheet is described in ADDITIONAL INFORMATION "Notice for Masking Option of TLCS-870 series" section 8. Figure 1-19. System Control Registers 3-53-23 1999-08-23 ## 1.8.5 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 (except for DBR) and port output latches are all held in the status in effect before STOP mode was entered. The port output can be select either output hold or high-impedance by setting OUTEN (bit 4 in SYSCR1). - 3 The divider of the timing generator is cleared to "0". - The program counter holds the address of the instruction following the instruction which started the STOP mode. STOP mode includes a level-sensitive release mode and an edge-sensitive release mode, either of which can be selected with RELM (bit 6 in SYSCR1). ## a. Level-sensitive release mode (RELM = 1) In this mode, STOP mode is released by setting the STOP pin high. This mode is used for capacitor back-up when the main power supply is cut off and long term battery back-up. When the STOP pin input is high, executing an instruction which starts the STOP mode will not place in STOP mode but instead will immediately start the release sequence (warm-up). Thus, to start STOP mode in the level-sensitive release mode, it is necessary for the program to first confirm that the STOP pin input is low. The following method can be used for confirmation: Using an external interrupt input INT5 (INT5 is a falling edge-sensitive input). Example: Starting STOP mode with an INT5 interrupt. PINT5: **TEST** (P2).0 ; To reject noise, the STOP mode does not start if JRS F, SINT5 port P20 is at high LD (SYSCR1), 01000000B ; Sets up the level-sensitive release mode. ; Starts STOP mode SFT (SYSCR1).7 LDW (IL),1110011101010111B ; IL12, 11, 7, 5, $3 \leftarrow 0$ SINT5: RETI Figure 1-20. Level-sensitive Release Mode Note 1: After warm-up start, even if STOP pin input is low again, STOP mode does not restart. Note 2: 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. ## b. Edge-sensitive release mode (RELM = 0) In this mode, STOP mode is released by a rising edge of the STOP pin input. This is used in applications where a relatively short program is executed repeatedly at periodic intervals. This periodic signal (for example, a clock from a low-power consumption oscillator) is input to the STOP pin. In the edge-sensitive release mode, STOP mode is started even when the STOP pin input is high. Example: Starting STOP mode operation in the edge-sensitive release mode LD (SYSCR1), 10000000B Figure 1-21. Edge-sensitive Release Mode #### STOP mode is released by the following sequence: - When returning to NORMAL2, both the high-frequency and low-frequency clock oscillators are turned on; when returning to SLOW mode, only the low-frequency clock oscillator is turned on. When returning to NORMAL 1, only the high-frequency clock oscillator is turned on. - ② A warming-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Four (two in SLOW mode) 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-3. | Warming-up Time | (example at fcqck | c = 8 MHz = 1 | fs = 32 768 kHz) | |------------|------------------|---------------------|-------------------------|--------------------| | Tubic I J. | Training up inne | (CAUITIPIC OF ICACI | <b>\ —</b> O IVII IZ, I | 13 - 32.7 00 K112/ | | WUT | Warming-up Time [ms] | | | |-----|-----------------------|---------------------|--| | | Return to NORMAL mode | Return to SLOW mode | | | 00 | 24.576 | 750 | | | 01 | 8.192 | 250 | | | 10 | 6.144 | - | | | 11 | 2.048 | _ | | 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 87CM53 is set to "1" by mask option, they start from the NORMAL2 mode. In case of 87PM53, starts from NORMAL1 mode.) 3-53-25 Figure 1-22. STOP Mode Start / Release Note: When STOP mode is released with a low hold voltage, the following cautions must be observed. The power supply voltage must be at the operating voltage level before releasing STOP mode. The RESET pin input must also be high, rising together with the power supply voltage. In this case, if an external time constant circuit has been connected, the RESET pin input voltage will increase at a slower rate than the power supply voltage. At this time, there is a danger that a reset may occur if input voltage level of the RESET pin drops below the non-inverting high-level input voltage (hysteresis input). ## (2) **IDLE** mode (IDLE1, IDLE2, SLEEP) IDLE mode is controlled by the system control register 2 and maskable interrupts. The following status is maintained during IDLE mode. - ① Operation of the CPU and watchdog timer is halted. On-chip peripherals continue to operate. - ② The data memory, CPU registers and port output latches are all held in the status in effect before IDLE mode was entered. - ③ The program counter holds the address of the instruction following the instruction which started IDLE mode. Example: Starting IDLE mode. SET (SYSCR2).4 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-23. IDLE Mode The interrupt latch (IL) of the interrupt source for releasing the IDLE mode must be cleared to "0" by load instruction. #### b. Interrupt release mode (IMF = "1") IDLE mode is released and interrupt processing is started by any interrupt source enabled with the individual interrupt enable flag (EF) or an external interrupt 0 (INTO pin) request. After the interrupt is processed, the execution resumes from the instruction following the instruction which started IDLE mode. IDLE mode can also be released by setting the RESET pin low, which immediately performs the reset operation. After reset, the 87CM53 are placed in NORMAL mode (the 87PM53 is placed in NORMAL1 mode). Note: When a watchdog timer interrupt is generated immediately before the IDLE mode is started, the watchdog timer interrupt will be processed but IDLE mode will not be started. 3-53-28 1999-08-23 #### (3) SLOW mode SLOW mode is controlled by the system control register 2 (SYSCR2) and the timer/counter 2 (TC2). ## a. Switching from NORMAL2 mode to SLOW mode First, set SYSCK (bit 5 in SYSCR2) to switch the main system clock to the low-frequency clock. Next, clear XEN (bit 7 in SYSCR2) to turn off high-frequency oscillation. When the low-frequency clock oscillation is unstable, wait until oscillation stabilizes before performing the above operations. The timer/counter 2 (TC2) can conveniently be used to confirm that low-frequency clock oscillation has stabilized. Note: The high frequency clock can be continued oscillation in order to return to NORMAL2 mode from SLOW mode quickly. Always turn off oscillation of high frequency clock when switching from SLOW mode to STOP mode. Example 1: Switching from NORMAL2 mode to SLOW mode. SET (SYSCR2).5; SYSCK←1 (Switches the main system clock to the low-frequency clock) CLR (SYSCR2).7 ; XEN←0 (turns off high-frequency oscillation) Example 2: Switching to SLOW mode after low-frequency clock oscillation has stabilized. LD (TC2CR), 14H ; Sets TC2 mode (timer mode, source clock : fs) LDW (TREG2), 8000H ; Sets warming-up time (according to Xtal characteristics) SET (EIRH). EF14 ; Enable INTTC2 LD (TC2CR), 34H ; Starts TC2 : PINTTC2 : LD (TC2CR), 10H ; Stops TC2 SET (SYSCR2) . 5 ; SYSCK←1 CLR (SYSCR2).7 ; XEN←0 RETI : VINTTC2: DW PINTTC2 ; INTTC2 vector table 1999-08-23 ## 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. Note1: After the SYSCK is cleared to "0", the CPU core operate using low frequency clock when the main system clock is switching from low frequency clock to high frequency clock. Note2: SLOW mode can also be released by setting the RESET pin low, which immediately performs the reset operation. After reset, the 87CM53 is placed in NORMAL mode. (The PM53 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 ; XEN←1 (turns on high-frequency oscillation) LD (TC2CR), 10H ; Sets TC2 mode (timer mode, source clock: fc) LD (TREG2 + 1), 0F8H ; Sets the warming-up time (according to frequency and resonator characteristics) SET (EIRH). EF14 ; enable INTTC2 LD (TC2CR), 30H ; Starts TC2 ED (TC2CR), 10H; Stops TC2 CLR (SYSCR2).5; SYSCK←0 (Switches the main system clock to the high-frequency clcok) RETI PINTTC2: 1 VINTTC2: DW PINTTC2 ; INTTC2 vector table Figure 1-25. Switching between the NORMAL2 and SLOW Modes 3-53-31 1999-08-23 ## 1.9 Interrupt Controller The 87CM53 has a total of 15 interrupt sources: 5 externals and 10 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-26 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 \cdot EF_4 = 1$ | IL <sub>4</sub> | FFF6 <sub>H</sub> | 4 | | External | INT1 | (External interrupt 1) | $IMF \cdot EF_5 = 1$ | IL <sub>5</sub> | FFF4 <sub>H</sub> | 5 | | Internal | INTTBT | (Time Base Timer interrupt) | $IMF \cdot EF_6 = 1$ | IL <sub>6</sub> | FFF2 <sub>H</sub> | 6 | | External | INT2 | (External interrupt 2) | $IMF \cdot EF_7 = 1$ | IL <sub>7</sub> | FFF0 <sub>H</sub> | 7 | | Internal | INTTC3 | (8-bit TC3 interrupt) | IMF · EF <sub>8</sub> = 1 | IL <sub>8</sub> | FFEE <sub>H</sub> | 8 | | Internal | INTSIO | (Serial Interface interrupt) | IMF · EF <sub>9</sub> = 1 | IL <sub>9</sub> | FFEC <sub>H</sub> | 9 | | Internal | INTTC5 | (8-bit TC5 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 | | Internal | INTRX | (UART receive interrupt) | IMF ⋅ EF <sub>12</sub> = 1 | IL <sub>12</sub> | FFE6 <sub>H</sub> | 12 | | Internal | INTTX | (UART transmit 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> | FFEO <sub>H</sub> | Low 15 | Table 1-4. Interrupt Sources #### (1) Interrupt Latches (IL <sub>15 to 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. The interrupt latches are assigned to addresses $003C_H$ and $003D_H$ in the SFR. Each latch can be cleared to "0" individually by an instruction; however, the read-modify-write instruction such as bit manipulation or operation instructions cannot be used (Do not clear the IL2 for a watchdog timer interrupt to "0"). Thus, interrupt requests can be cancelled and initialized by the program. Note that interrupt latches cannot be set to "1" by any instruction. The contents of interrupt latches can be read out by an instruction. Therefore, testing interrupt requests by software is possible. Example 1: Clears interrupt latches LDW (IL), 1110100000111111B ; $IL_{12}$ , $IL_{10}$ to $IL_{6} \leftarrow 0$ Example 2 : Reads interrupt latches LD WA, (IL) ; W $\leftarrow$ IL<sub>H</sub>, A $\leftarrow$ IL<sub>L</sub> Example 3: Tests an interrupt latch TEST (IL).7 ; if IL<sub>7</sub> = 1 then jump JR F, SSET ### (2) Interrupt Enable Register (EIR) The interrupt enable registers (EIR) enable and disable the acceptance of interrupts except for the pseudo non-maskable interrupts (software and watchdog timer interrupts). Pseudo non-maskable interrupts are accepted regardless of the contents of the EIR; however, the pseudo non-maskable interrupts cannot be nested more than once at the same time. The EIR consists of an interrupt master enable flag (IMF) and individual interrupt enable flags (EF). These registers are assigned to addresses 003A<sub>H</sub> and 003B<sub>H</sub> in the SFR, and can be read and written by an instruction (including read-modify-write instructions such as bit manipulation instructions). ## ① 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 Pseudo non-maskable interrupts are returned by the [RETN] instruction. In this case, the IMF is set to "1" only when pseudo non-maskable interrupt service is started with interrupt acceptance enabled (IMF = 1). Note that IMF remains "0" when cleared in the interrupt service program. The IMF is assigned to bit 0 at address $003A_H$ in the SFR, and can be read and written by an instruction. IMF is normally set and cleared by the [EI] and [DI] instructions, and the IMF is initialized to "0" during reset. #### 2 Individual interrupt Enable Flags (EF<sub>15</sub> to EF<sub>4</sub>) SET 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. EF<sub>12</sub>←1 ``` Example 1 : Sets EF for individual interrupt enable, and sets IMF to "1". LDW (EIR), 1110100010100001B ; EF<sub>15</sub> to EF<sub>13</sub>, EF<sub>11</sub>, EF<sub>7</sub>, EF<sub>5</sub>, IMF←1 Example 2 : Sets an individual interrupt enable flag to "1". ``` (EIRH).4 service starts immediately after execution of the [RETI] instruction. 15 14 13 12 11 10 8 6 IL (003C, 003D<sub>H</sub>) IL<sub>15</sub> : IL<sub>14</sub> : IL<sub>13</sub> : IL<sub>12</sub> : IL<sub>11</sub> : IL<sub>10</sub> : IL<sub>9</sub> : IL<sub>8</sub> IL<sub>7</sub> : IL<sub>6</sub> . IL₅ $IL_4$ : IL<sub>3</sub> . IL₂ IL<sub>L</sub> (003C<sub>H</sub>) ILH (003DH) (Initial Value: 00000000 000000\*\*) EF<sub>15</sub> : EF<sub>14</sub> : EF<sub>13</sub> : EF<sub>12</sub> : EF<sub>11</sub> : EF<sub>10</sub> : EF<sub>6</sub> . EF₄ (003A, 003B<sub>H</sub>) EIR<sub>I</sub> (003A<sub>H</sub>) EIRH (003BH) (Initial Value: 00000000 0000\*\*\*0) Do not use any read-modify-write instruction such as bit manipulation for clearing IL. Do not clear $IL_2$ to "0" by an instruction. Do not set IMF to "1" during non-maskable interrupt service program. Note3: Figure 1-27. Interrupt Latch (IL) and Interrupt Enable Register (EIR) 3-53-34 1999-08-23 ## 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 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 Interrupt acceptance processing is as follows: - ① The interrupt master enable flag (IMF) is cleared to "0" to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled. - ② The interrupt latch (IL) for the interrupt source accepted is cleared to "0". - ③ The contents of the program counter (PC) and the program status word (PSW) are saved (pushed) onto the stack. (pushed down in order of PSW, PC<sub>H</sub>, PC<sub>L</sub>). The stack pointer (SP) is three decrements. The contents of Stack Pointer is decreased by 3. - The entry address of the interrupt service program is read from the vector table address corresponding to the interrupt source, 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-28. 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 must be disabled in the external interrupt control register (INT0EN) or interrupt processing must be avoided by the program. (When INT0EN = 0, the interrupt latch IL3 is not set, therefore, the falling edge of the INT0 pin input cannot be detected.) Example 1: Disables an external interrupt 0 using INT0EN: ``` CLR (EINTCR), INTOEN ; INTOEN←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 ; Returns 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 register save/restore processing During interrupt acceptance processing, the program counter and the program status word are automatically saved on the stack, but not the accumulator and other registers. These registers are saved by the program if necessary. Also, when nesting multiple interrupt services, it is necessary to avoid using the same data memory area for saving registers. The following method is used to save/restore the general-purpose registers: ① General-purpose register save/restore by register bank changeove: General-purpose registers can be saved at high-speed by switching to a register bank that is not in use. Normally, bank 0 is used for the main task and banks 1 to 15 are assigned to interrupt service tasks. To increase the efficiency of data memory utilization, the same bank is assigned for interrupt sources which are not nested. The switched bank is automatically restored by executing an interrupt return instruction [RETI] or [RETN]. Therefore, it is not necessary for a program to save the RBS. Example: Register Bank Changeover PINTxx: LD RBS, n ; Switches to bank n (1 \( \mu \)s at 8 MHz) interrupt processing RETI ; Restores bank and Returns ② General-purpose register save/restore using push and pop instructions: To save only a specific register, and when the same interrupt source occurs more than once, the general-purpose registers can be saved/restored using push/pop instructions. ③ General-purpose registers save/restore using data transfer instruction: Data transfer instructions can be used to save only a specific general-purpose register during processing of a single interrupt. Example: Saving/restoring a register using data transfer instructions PINTxx : LD (GSAVA), A ; Save A register interrupt processing LD A, (GSAVA) ; Restore A register RETI ; Return Figure 1-29. Saving/Restoring General-purpose Registers #### (3) Interrupt return The interrupt return instructions [RETI] / [RETN] perform the following operations. | | [RETI] Maskable interrupt return | [RETN] Non-maskable interrupt return | | | |---|----------------------------------------------------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 1 | The contents of the program counter and the program status word are restored from the stack. | 1 | The contents of the program counter and program status word are restored from the stack. | | | 2 | The stack pointer is incremented 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. Note: Software interrupt generates during non-maskable interrupt processing to use SWI instruction for software break in a development tool. Use the [SWI] instruction only for detection of the address error or for debugging. #### 1 Address Error Detection $FF_H$ is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address. Code $FF_H$ is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing $FF_H$ to unused areas of the program memory. Address trap reset is generated for instruction fetch from a part of RAM area (address $0040_H$ - $043F_H$ ) or SFR area ( $0000_H$ - $003F_H$ ). Note: The fetch data from addresses (test ROM area), 7H80H to 7FFFH for 87PM/CM53 is not FFH. # ② Debugging Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address. # 1.9.3 External Interrupts The 87CM53 has five external interrupts (INT0 to INT5 : INT0, INT1, INT2, INT3, INT5). Three of these (INT1, INT2, INT3) have digital noise cancellation circuits (pulse inputs of less than a fixed time are cancelled as noise). Edge selection is possible with pins INT1, INT2, and INT3. The INTO/P10 pin can be selected either as an external interrupt input pin or as an I/O port. At reset, it is initialized as an input port. Edge selection, noise cancellation control, and INTO/P10 pin function selection are performed by the external interrupt control register (#0037H : EINTCR). Table 1-5 lists enable conditions, edge select, noise cancellation conditions. The following are notes on the usage of external interrupts: # Notes on usage of external interrupts: Note 1: When INT1 to INT3 (INT1, INT2, INT3) are used in SLOW or SLEEP mode, the noise cancellation function is disabled. Noise cancellation time for a pulse input during operating mode transition is indeterminate. Input pulse must be 2 machine cycle or more at both "H" and "L" levels. Note 2 : Input pulse width for INTO and INT5 must be 2 machine cycle or more at both "H" and "L" levels. t<sub>INTL</sub>, t<sub>INTH</sub> > 2t<sub>cyc</sub> t<sub>cyc</sub> = 4/fcgck [s] (at NORMAL 1/2 and IDLE 1/2 modes) 4/fs [s] (at SLOW and SLEEP modes) Note 3: If a signal without noise is input to the external interrupt pin in NORMAL 1/2 or IDLE 1/2 mode, the maximum times from input signal edge to input latch set are as described below: ① INT1 pin 49/fc [s] (when INT1NC = 1) 193/fc [s] (when INT1NC = 0) ② INT2 and INT3 pin 25/fc [s] Note 4: Noise cancellation/pulse receive conditions for timer/counter are as described below: TC1, 3 pin : Less than 7/fc [s] (noise cancellation) and 24/fc [s] or more (pulse receive) Note 5: When INTOEN = 0, interrupt latch IL3 is not set even if a falling edge is detected for INTO pin input. 3-53-39 Note 6: Change EINTCR only when IMF = 0. After changing EINTCR, interrupt latches of external interrupt inputs must be cleared to "0" using load instruction. - Note 7: If changing the contents of INT1ES during NORMAL1/2 mode, interrupt latch of external interrupt input INT1 must be cleared after 14 machine cycles (when INT1NC = 1) or 50 machine cycles (when INT1NC = 0) from the time of changing. During SLOW mode, 3 machine cycles are required. - Note 8: In order to change an edge of timer counter input by rewriting the contents of INT2ES and INT3ES during NORMAL1/2 mode, rewrite the contents after timer counter is stopped (TC\*S=0), that is, interrupt disable state. Then, clear interrupt laches of external interrupt inputs (INT2 and INT3) after 8 machine cycles from the time of rewriting to change to interrupt enable state. Finally, start timer counter. During SLOW mode, 3 machine cycles are required. Example: When changing TC1 pin inputs edge in external trigger timer mode from rising edge to falling edge. ``` LD (TC1CR),01001000B ; TC1S \leftarrow 00 (stop TC1) DI ; IMF \leftarrow 0 (disable interrupt service) LD (EINTCR),00000100B ; INT2ES \leftarrow 1 (change edge selection) NOP 8 machine cycles NOP LD (ILL),01111111B ; IL7 \leftarrow 0 (clear interrupt latch) EI ; IMF \leftarrow 1 (enable interrupt service) LD (TC1CR),01111000B ; TC1S \leftarrow 11 (start TC1) ``` Note 9: 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 ← 0 (specifies high-impedance) DI ; IMF ← 0 (disables interrupt service) SET (SYSCR1). STOP ; STOP ← 1 (activates stop mode) LDW (IL), 111101110101111B ; IL11, 7, 5, 3 ← 0 (clears interrupt latches) EI ; IMF ← 1 (enables interrupt service) ``` 3-53-40 Table 1-5. External Interrupts | SOURCE | Pin | Secondary<br>function | Enable | | Edge | | Digital noise reject | |--------|------|-----------------------|----------------------------|--------|---------|------|----------------------| | SOURCE | | | Condition | rising | falling | both | Digital hoise reject | | INT0 | ĪNT0 | P10 | IMF = 1,<br>INT0EN = 1 | _ | 0 | _ | — (hysteresis input) | | INT1 | INT1 | P11 | $IMF \cdot EF_5 = 1$ | INT1ES | INT1ES | _ | Note 1) | | | | | | = 0 | = 1 | | | | INT2 | INT2 | P12/TC1 | $IMF \cdot EF_7 = 1$ | INT2ES | INT2ES | _ | Note 2) | | | | | | = 0 | = 1 | | | | INT3 | INT3 | P50 / TC3 | $IMF \cdot EF_{11} = 1,$ | INT3ES | INT3ES | _ | Note 3) | | | | | | = 0 | = 1 | | | | INT5 | ĪNT5 | P20/STOP | IMF ⋅ EF <sub>15</sub> = 1 | _ | 0 | _ | — (hysteresis input) | - Note 1: Pulses less than 15/fc [s] or 63/fc [s] are cancelled as noise. Pulses equal to or more than 48/fc [s] or 192/fc [s] are regarded as signals. - Note 2: 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. (This circuit is not applied for event counter mode) - Note 3: 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. (This circuit is not applied for event counter mode) Figure 1-30. External Interrupt Control Register # 1.10 Watchdog Timer (WDT) The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or the like, and resumes the CPU to the normal state. The watchdog timer signal for detecting malfunction can be selected either a reset output or a non-maskable interrupt request. However, selection is possible only once after reset. At first the reset output is selected. When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals. # 1.10.1 Watchdog Timer Configuration Figure 1-31. Watchdog Timer Configuration # 1.10.2 Watchdog Timer Control Figure 1-32 shows the watchdog timer control registers (WDTCR1, WDTCR2). The watchdog timer is automatically enabled after reset. - (1) Malfunction detection methods using the watchdog timer - The CPU malfunction is detected as follows. - ① Setting the detection time, selecting output, and clearing the binary counter. - ② Repeatedly clearing the binary counter within the setting detection time. If the CPU malfunction occurs for any cause, the watchdog timer output will become active at the rising of an overflow from the binary counters unless the binary counters are cleared. At this time, when WDTOUT = 1 a reset is generated, which drives the $\overline{\text{RESET}}$ pin low to reset the internal hardware and the external circuits. When WDTOUT = 0, a watchdog timer interrupt (INTWDT) is generated. The watchdog timer temporarily stops counting in the STOP mode including warm-up or IDLE mode, and automatically restarts (continues counting) when the STOP/IDLE mode is released. Figure 1-32. Watchdog Timer Control Registers Operating mode Detection time NORMAL2 At fs = 32.768kHzNORMAL1 **SLOW** At fc = 8MHz2<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^{23}$ / fc, $2^{15}$ / fs 215 / fs 1.048 ms 1 s 221 / fc $2^{21}$ / fc, $2^{13}$ / fs 262.1 ms 250 ms Table 1-6. Watchdog Timer Detection Time # (2) Watchdog Timer Enable 219 / fc 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. 65.5 ms 62.5 ms #### (3) Watchdog Timer Disable The watchdog timer is disabled by writing the disable code (B1<sub>H</sub>) to WDTCR2 after clearing WDTEN (bit 3 in WDTCR1) to "0". The watchdog timer is not disabled if this procedure is reversed and the disable code is written to WDTCR2 before WDTEN is cleared to "0". During disabling the watchdog timer, the binary counters are cleared to "0". 2<sup>19</sup> / fc, 2<sup>11</sup> / fs Example: Disables watchdog timer LDW (WDTCR1), 0B101H ; WDTEN←0, WDTCR1←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 low to reset the internal hardware. The reset output time is $2^{16}$ /fc [s] (8.2 ms at fc = 8 MHz). The $\overline{\text{RESET}}$ pin is sink open drain input / output with pull-up resistor. Note: The high-frequency clock oscillator also turns on when a watchdog timer reset is generated in SLOW mode. Thus, the reset output time is $2^{16}$ /fc. 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 output time must be considered approximate value. Figure 1-33. Watchdog Timer Interrupt / Reset # 1.11 Reset Circuit The 87CM53 has 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-7 shows on-chip hardware initialization by reset action. The internal source reset circuit (watchdog timer reset, address trap reset, and system clock reset) is not initialized when power is turned on. Thus, output from the RESET pin may go low (2<sup>16</sup>/fc [s] (8.2 ms at 8 MHz) when power is turned on. | 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 | ımp status flag (JF) | | Watchdog timer | Enable | | | Interrupt master enable flag | (IMF) | 0 | Output latches of I/O ports | Refer to I/O port circuitry | | | Interrupt individual enable flag<br>Interrupt latches | s (EF)<br>(IL) | 0 | Control registers | Refer to each of control register | | Table 1-7. Initializing Internal Status by Reset Action # 1.11.1 External Reset Input When the RESET pin is held at low for at least 3 machine cycles (12/fcgck [s]) with the power supply voltage within the operating voltage range and oscillation stable, a reset is applied and the internal state is initialized. When the 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-34. Simple Power-on-Reset Circuitry # 1.11.2 Address-Trap-Reset An address-trap-reset is one of fail-safe function that detects CPU malfunction such as endless looping caused by noise or the like, and returns the CPU to the normal state. If the CPU attempts to fetch an instruction from a part of RAM or SFR, an address-trap-reset will be generated. Then, the $\overline{\text{RESET}}$ pin output will go low. The reset time is $2^{16}/\text{fc}$ [s] (8.2 ms at 8 MHz). Figure 1-35. 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 $2^{16}$ /fc [s] (8.2 ms at 8MHz). #### 2. PERIPHERAL HARDWARE 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 peripherals 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 87CM53 SFRs and DBRs. Figure 2-1. SFR & DBR #### 2.2 **I/O Ports** The 87CM53 has 10 parallel input/output ports (72pins) each as follows: | | Primary Function | Secondary Functions | |---------|------------------|---------------------------------------------------------------------------------------------------| | Port P0 | 8-bit I/O port | | | Port P1 | 8-bit I/O port | external interrupt input, timer/counter input/output, and divider output | | Port P2 | 4-bit I/O port | low-frequency resonator connections, external interrupt input, and STOP mode release signal input | | Port P3 | 7-bit I/O port | <del></del> | | Port P4 | 8-bit I/O port | serial interface, TONE output, MELODY1 (sine wave) output | | Port P5 | 5-bit I/O port | MELODY2 (square wave) output, external interrupt input, timer/counter input/output | | Port P6 | 8-bit I/O port | analog input | | Port P7 | 8-bit I/O port | <del></del> | | Port P8 | 8-bit I/O port | Key on wake up input | | Port P9 | 8-bit I/O port | <del></del> | Each output port contains a latch, which holds the output data. All input ports do not have latches, so the external input data should either be held externally until read or reading should be performed several times before processing. Figure 2-2 shows input/output timing examples. External data is read from an I/O port in the S1 state of the read cycle during execution of the read instruction. This timing can not be recognized from outside, so that transient input such as chattering must be processed by the program. Output data output changes in the S2 state of the write cycle during execution of the instruction which writes to an I/O port. Figure 2-2. Input/Output Timing (Example) When reading an I/O port except programmable I/O ports, whether the pin input data or the output latch contents are read depends on the instructions, as shown below: (1) Instructions that read the output latch contents (src).b, CF ① XCH r, (src) 4 LD - ⑤ LD (pp).b,CF - ② CLR/SET/CPL (src).b - ⑥ ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), n - ③ CLR/SET/CPL (pp).g - (src) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL) 3-53-48 - (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) For the programmable Input/Output ports, when data are read from the port, pins set to the output mode read a value of the output latch. The control output pins, and etc. are also set to the output mode. Thus a value of the output latch is read, which may be different from a value of the pins. # 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 (POCR). Port P0 is configured as an input if its corresponding POCR bit is cleared to "0", and as an output if its corresponding POCR 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 the POCR contents. Therefore initial output data should be written into the output latch before setting POCR. Figure 2-3. Port P0 and P0CR Example: Setting the upper 4 bits of port P0 as an input port and the lower 4 bits as an output port (Initial output data are 1010<sub>R</sub>). LD (P0), 00001010B ; Sets initial data to P0 output latches LD (P0CR), 00001111B ; Sets the port P0 input/output mode Note 1: Ports set to the input mode read the pin input states. When input pin and output pin 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.) 3-53-49 1999-08-23 # 2.2.2 Port P1 (P17 to P10) Port P1 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P1 input/output control register (P1CR). Port P1 is configured as an input if its corresponding P1CR bit is cleared to "0", and as an output if its corresponding P1CR bit is set to "1". During reset, the P1CR is initialized to "0", which configures port P1 as an input. The P1 output latches are also initialized to "0". Port P1 is also used as an external interrupt input, a timer/counter input, and a divider output. When used as secondary function pin, the input pins should be set to the input mode, and the output pins should be set to the output mode and beforehand the output latch should be set to "1". It is recommended that pins P11 and P12 should be used as external interrupt inputs, timer/counter input, or input ports. The interrupt latch is set at the rising or falling edge of the output when used as output ports. Pin P10 (INTO) can be configured as either an I/O port or an external interrupt input with INTOEN (bit 6 in EINTCR). During reset, pin P10 (INTO) is configured as an input port P10. Figure 2-4. Port P1 and P1CR Example: Sets P17, P16 and P14 as output ports, P13 and P11 as input ports, and the others as function pins. Internal output data is "1" for the P17 and P14 pins, and "0" for the P16 pin. LD (EINTCR), 01000000B ; INT0EN←1 LD (P1), 10111111B ; P17←1, P14←1, P16←0 LD (P1CR), 11010000B Note 1: Ports set to the input mode read the pin states. When input pin and output pin 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.) 3-53-50 1999-08-23 # 2.2.3 Port P2 (P23 to P20) Port P2 is a 4-bit input/output port. It is also used as an external interrupt input, and low-frequency crystal connection pins. When used as an input port, or a secondary function pin, the output latch should be set to "1". During reset, the output latches are initialized to "1". A low-frequency crystal (32.768 kHz) is connected to pins P21 (XTIN) and P22 (XTOUT) in the dual-clock mode. In the single-clock mode, pins P21 and P22 can be used as normal input/output ports. It is recommended that pin P20 should be used as an external interrupt input, a STOP mode release signal input, or an input port. If used as an output port, the interrupt latch is set on the falling edge of the output pulse. When a read instruction is executed for port P2, bits 7 to 4 read in "1". Figure 2-5. Port P2 Note: When using the P20 pin as an output port, the following cautions are needed. It is recommended that the P20 pin is used as the external interrupt input, STOP release signal input or the input port. - 1) The interrupt latch of the INT5 is specified at the falling edge which the output of the P20 pin is changed from H to L. - 2) When bit 4 (OUTEN) of the SYSCR1 (0038H) is "0" in the stop mode, the P20 pin is set to "Hi-Z". - Ex.: When the stop mode is released by the external RESET and the P20 pin is used as an output pin, malfunctions occur as follows: When the P20 pin is set to the stop mode with "L" output, the output of the P20 pin is changed from "L" to "Hi-Z". (The voltage level is set to "H" due to external pull-up resistor.) The stop mode is released immediately after entering to the stop mode. Thus, the stop mode is released incorrectly before released by the external RESET. In this case, the P20 output must be set to "H" before entering to the stop mode. Additionally, the stop mode is set after setting bit 6 (RELM) of the SYSCR1 (0038H) to "0" (edge release). 3) When the stop mode is not used, note 1) mentioned above. # 2.2.4 Port P3 (P36 to P30) Port P3 is an 7-bit input/output port. When used as an input port, the output latch should be set to "1". The output latches are initialized to "1" during reset. When a read instruction is executed for port P3, bits 7 read in "1". Figure 2-6. Port P3 Example 1: Output the immediate data 1A<sub>H</sub> to the P3 port. LD (P3), 1AH ; $P3\leftarrow 1A_H$ Example 2: Inverts the output of the lower 4bits (P33 - P30) of the P3 port. XOR (P3), 00001111B ; P33 to P30 $\leftarrow$ P33 to P30 1999-08-23 # 2.2.5 Port P4 (P47 to P40) Port P4 can specify input or output on a bit basis and select either the tri-state or the open drain. It also functions as an 8-bit general-purpose I/O port, tone outputs (TONE, MLELODY1), UART I/Os, and SIO I/Os. To use Port P4 as UART input or SIO input pin, set the input mode. To use Port P4 as UART output or SIO output pin, set the output mode after setting the output latch to "1". To use Port P4 as TONE or MELODY1, set the output mode. Port P4 is set to either input or output by the port P4 I/O control register 1 (P4CR1). The tri-state or the open drain is specified by the port P4 I/O control register 2 (P4CR2). At reset, the P4CR1 is initialized to "0", and it is set to the input mode. The P4CR2 is initialized to "1", and it is set to the tri-state. The latch of the port P4 is initialized to "1". The P4CR1 is a write only register. Figure 2-7. Port P4 Note 1: Ports set to the input mode read the pin states. When input pin and output pin 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 P4CR1 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.) # 2.2.6 Port P5 (P54 to P50) Port P5 can specify input or output on a bit basis and select either the tri-state or the open drain. It also functions as an 8-bit general-purpose I/O port, an external interrupt input, TC3 input, TC5 output (PWM, PDO), MLELODY2 output. To use Port P5 as an external input or TC3 input pin, set the input mode. To use Port P5 as TC5 output pin, set the output mode after setting the output latch to "1". To use Port P5 as MELODY2, set the output mode. Port P5 is set to either input or output by the port P5 I/O control register 1 (P5CR1). The tri-state or the open drain is specified by the port P5 I/O control register 2 (P5CR2). At reset, the P5CR1 is initialized to "0", and it is set to the input mode. The P5CR2 is initialized to "1", and it is set to the tri-state. The latch of the port P5 is initialized to "1". The P5CR1 is a write only register. Figure 2-8. Port P5 Note 1: Ports set to the input mode read the pin states. When input pin and output pin 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 P5CR1 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.) # 2.2.7 Port P6 (P67 to P60) Port P6 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. It also functions as an 8-bit general-purpose I/O port, an analog input for the A/D converter. To use Port P6 as an analog input pin, set the input mode. Port P6 is set to either input or output by the port P6 I/O control register 1 (P6CR). At reset, the P6CR is initialized to "0", and it is set to the input mode. The latch of the port P6 is initialized to "0". The P6CR is a write only register. When a read instruction is executed for the port P6, pins set to the output mode read a value of the output latch. Pins set to the input mode read an external input value. (They read "0" at level "L" and "1" at level "H".) When the AINDS (bit 4 of the ADCCR) of the A/D converter control register (ADCCR) is "0", a pin selected by the SAIN (bit 0 to 3 of the ADCCR) are set to "1" without reading an external input value. Figure 2-9. Port P6 - Note 1: Ports set to the input mode read the pin states. When input pin and output pin exist in Port P6 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 P6CR 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.) - Note 3: Unused analog input pins cannot be configured as output mode when AINDS = 0. # 2.2.8 Ports P7 (P77 - P70) Port P7 can specify input or output on a bit basis and select either the tri-state or the open drain. It also functions as an 8-bit general-purpose I/O port. Port P7 is set to either input or output by the port P7 I/O control register 1 (P7CR1). The tri-state or the open drain is specified by the port P7 I/O control register 2 (P7CR2). At reset, the P7CR1 is initialized to "0", and it is set to the input mode. The P7CR2 is initialized to "1", and it is set to the tri-state. The latch of the port P7 is initialized to "0". The P7CR1 is a write only register. Figure 2-10. Port 7 and P7CR Note 1: Ports set to the input mode read the pin states. When input pin and output pin exist in Port P7 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 P7CR1 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.) # 2.2.9 Port P8 (P87 to P80) Port P8 can specify input or output on a bit basis and select either the pull-up resistor is set or not. It also functions as an 8-bit general-purpose I/O port, Key on wake-up. To use Port P8 as Key on wake-up pin, set the input mode. Port P8 is set to either input or output by the port P8 I/O control register (P8CR). Port P8 is set to pull-up resistor or not is specified by the port P8 pull-up resistor control register (P8PUCR). At reset, the P8CR is initialized to "0", and it is set to the input mode. The P8PUCR is initialized to "0". The latch of the port P8 is initialized to "0". The P8CR is a write only register. Figure 2-11. Port 8 and P8CR Note 1: Ports set to the input mode read the pin states. When input pin and output pin exist in Port P8 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 P8CR 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.) # 2.2.10 Ports P9 (P97 - P90) Port P9 can specify input or output on a bit basis and select either the tri-state or the open drain. It also functions as an 8-bit general-purpose I/O port. Port P9 is set to either input or output by the port P9 I/O control register 1 (P9CR1). The tri-state or the open drain is specified by the port P9 I/O control register 2 (P9CR2). At reset, the P9CR1 is initialized to "0", and it is set to the input mode. The P9CR2 is initialized to "1", and it is set to the tri-state. The latch of the port P9 is initialized to "0". The P9CR1 is a write only register. Figure 2-12. Port 9 and P9CR Note 1: Ports set to the input mode read the pin states. When input pin and output pin exist in Port P9 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 P9CR1 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.) # 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-13. (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-13. Time Base Timer Figure 2-14. Time Base Timer and Divider Output Control Register NORMAL1/2, IDLE1/2 mode Interrupt Frequency **TBTCK** SLOW, SLEEP mode DV7CK = 1 DV7CK = 0 At fc = 8 MHzAt $fs = 32.768 \, \text{kHz}$ fs / 2<sup>15</sup> $fs/2^{15}$ 000 fc / 2<sup>23</sup> 0.95 Hz 1 Hz $fs/2^{13}$ $fc/2^{21}$ $fs/2^{13}$ 001 3.81 4 fs / $2^8$ $fc/2^{16}$ 010 122.07 128 $fc/2^{14}$ 011 fs / 2<sup>6</sup> 488.28 512 100 $fc/2^{13}$ fs / 2<sup>5</sup> 976.56 1024 $fc/2^{12}$ $fs/2^4$ 101 1953.12 2048 $fc\,/\,2^{11}$ 110 $fs / 2^3$ 3906.25 4096 $fc/2^9$ 111 fs / 2 15625 16384 Table 2-1. Time Base Timer Interrupt Frequency # 2.4 Divider Output (DVO) Figure 2-15. Divider Output Control Register A 50% duty pulse can be output using the divider output circuit, which is useful for piezo-electric buzzer drive. Divider output is from pin P13 (DVO). The P13 output latch should be set to "1" and then the P13 should be configured as an output mode. Divider output circuit is controlled by the control register (TBTCR) shown in Figure 2-11. Example : 1 kHz pulse output (at fc = 8MHz) SET (P1).3 ; P13 output latch $\leftarrow$ 1 LD (P1CR), 00001000B ; Configures P13 as an output mode LD (TBTCR), 10000000B ; DVOEN $\leftarrow$ 1, DVOCK $\leftarrow$ 00 Table 2-2. Frequency of Divider Output | DVOCK | Frequency of<br>Divider Output | | I At tc = 4.194304 MHz I At tc = 8 MHz | | At fs = 32.768 kHz | | |-------|--------------------------------|---------------------|----------------------------------------|-------------|--------------------|-------| | 00 | fc / 2 <sup>13</sup> or | fs / 2 <sup>5</sup> | 0.512 [kHz] | 0.976 [kHz] | 1.024 | [kHz] | | 01 | fc / 2 <sup>12</sup> | fs / 2 <sup>4</sup> | 1.024 | 1.953 | 2.048 | | | 10 | fc / 2 <sup>11</sup> | fs / 2 <sup>3</sup> | 2.048 | 3.906 | 4.096 | | | 11 | fc / 2 <sup>10</sup> | fs / 2 <sup>2</sup> | 4.096 | 7.812 | 8.192 | | Figure 2-16. Divider Output # 2.5 16-bit Timer/Counter 1 (TC1)2.5.1 Configuration Figure 2-17. Timer/Counter 1 #### 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-18. Timer Registers and TC1 Control Register gear ratio is set to 1/8, DV1G (TC1CK = 10) can not operate correctly. #### 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 counter is cleared. The current contents of up-counter can be transferred to TREG1B by setting SCAP1 (bit 6 in TC1CR) to "1" (software capture function). SCAP1 is automatically cleared to "0" after capaturing. Table 2-3. Timer/Counter 1 Source Clock (Internal Clock) | | Source cloc | k | Resol | ution | Maximum time setting | | | |----------------------------------------------|--------------------------|--------------------------|---------------|--------------------|----------------------|--------------------|--| | NORMAL1/2, IDLE1/2 modes | | SLOW SLEED | | | | | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP modes | At fc = 8 MHz | At fs = 32.768 kHz | At fc = 8 MHz | At fs = 32.768 kHz | | | fc / 2 <sup>11</sup> | fs / 2 <sup>3</sup> [Hz] | fs / 2 <sup>3</sup> [Hz] | 256 μs | 244.14 μs | 16.8 s | 16.0 s | | | fc / 2 <sup>7</sup> | fc / 2 <sup>7</sup> | - | 16 <i>μ</i> s | _ | 1.0 s | - | | | fc / 2 <sup>6</sup> | fc / 2 <sup>6</sup> | - | <b>8</b> μs | - | 524.2 ms | - | | | fc / 2 <sup>5</sup> | fc / 2 <sup>5</sup> | - | 4 μs | - | 262.1 ms | - | | | fc / 2 <sup>4</sup> [Hz] fc / 2 <sup>4</sup> | | _ | <b>2</b> μs | _ | 131.1 ms | _ | | 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). LD (TC1CR), 00000000B ; Sets the TC1 mode and source clock LDW (TREG1A), 1000H ; Sets the timer register (1 s $\div$ 23 / fs = 1000 $_{\rm H}$ ) SET (EIRL).EF4 ; enable INTTC1 EI LD (TC1CR), 00010000B ; Starts TC1 Note: TC1CR is a write-only register, which cannot start by [SET(TC1CR).4] instruction. Example 2 : Software capture LD (TC1CR), 01010000B ; SCAP1 $\leftarrow$ 1 (Captures) LD WA, (TREG1B) ; Reads captured value Figure 2-19. Timer Mode Timing Chart #### (2) External Trigger Timer mode In this mode, counting up is started by an external trigger. This trigger is the edge of the TC1 pin input. Either the rising or falling edge can be selected with INT2ES. Edge selection is the same as for the external interrupt input INT2 pin. Source clock is used an internal clock selected with TC1CK. The contents of TREG1A is compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to "0" and halted. The counter is restarted by the selected edge of the TC1 pin input. When the edge input is opposite to the edge input way of the count start trigger at METTI (bit 6 in TC1CR) = 1, the counter is cleared, and count stops. In this mode, pulse input with a constant pulse width generates interrupt. When METT1 is "0", the opposite edge input is ignored. The edge of TC1 pin input before match detection is also ignored for both "H" and "L" level. The TC1 pin input has the same noise rejection as the INT2 pin; therefore, pulses of 7/fc [s] or less are rejected as noise. A pulse width of 24/fc [s] or more is required for edge detection in NORMAL1/2 or IDLE1/2 mode. The noise rejection circuit is turned off in SLOW and SLEEP modes. But, a pulse width of 2 machine cycle or more is required. Example 1 : Generates interrupt after 100 $\mu$ s from TC1 pin input rising edge (at fc = 8 MHz, DVCK in CGCR = "010"). (FINITOR) 00000000 | LD | (EINTCR), 00000000B | ; INTZES←0 (rising eage) | |-----|---------------------|------------------------------------------------------------| | LDW | (TREG1A), 0032H | ; $100 \mu \text{s} \div 2^4 / \text{fc} = 32_{\text{H}}$ | | SET | (EIRL).EF4 | ; Enables INTTC1 interrupt | | EI | | | | LD | (TC1CR), 00111000B | ; Starts TC1 external trigger, METT = ( | 3-53-65 · INTOFF ( O / minimum and ma) Example 2: When "L" level pulses of 4ms or more is input to TC1 pin, generates interrupt. (at fc = 8 MHz) LD (EINTCR), 00000100B ; INT2ES $\leftarrow$ 1 ("L" level) LDW (TREG1A), 00FAH ; $4 \text{ ms} \div 2^7 / \text{fc} = \text{FA}_H$ SET (EIRL).EF4 ; Enables INTTC1 interrupt ΕI LD (TC1CR), 01110100B ; Starts TC1 external trigger, METT = 1 Figure 2-20. 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 INT2ES in EINTCR. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Counting up resumes after the counter is cleared. The maximum applied frequency is fcgck/2<sup>4</sup> [Hz] in NORMAL1/2 or IDLE1/2 mode and fs/2<sup>4</sup> [Hz] in SLOW or SLEEP mode. But, a pulse width of 2 machine cycles or more is required for both "H" and "L" level. Setting SCAP1 to "1" transferres the current contents of up-counter to TREG1B (software capture function). SCAP is automatically cleared after capturing. Figure 2-21. Event Counter Mode Timing Chart (INT2ES = 1) #### (4) Window mode Counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC1 pin input (window pulse) and an internal clock. The contents of TREG1A are compared with the contents of up-counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Positive or negative logic for the TC1 pin input can be selected with INT2ES. Setting SCAP1 to "1" transferes the current contents of up-counter to TREG1B. It is necessary that the maximum applied frequency (TC1 input) be such that the counter value can be analyzed by the program. That is, the frequency must be considerably slower than the selected internal clock. Figure 2-22. Window Mode Timing Chart #### (5) Pulse width measurement mode Counting is started by the external trigger (set to external trigger start by TC1S). The trigger can be selected either the rising or falling edge of the TC1 pin input. The source clock is used an internal clock. On the next falling (rising) edge, the counter contents are transferred to TREG1B and an INTTC1 interrupt is generated. The counter is cleared when the single edge capture mode is set. When double edge capture is set, the counter continues and, at the next rising (falling) edge, the counter contents are again transferred to TREG1B. If a falling (rising) edge capture value is required, it is necessary to read out TREG1B contents until a rising (falling) edge is detected. Falling or rising edge is selected with INT2ES, and single edge or double edge is selected with MCAP1 ( bit 6 in TC1CR). ``` Example: Duty measurement (Resolution fc/2<sup>7</sup> [Hz]) CLR (INTTC1SW). 0 ``` ``` INTTC1 service switch initial setting LD (EINTCR), 00000000B Sets the rise edge at the INT2 edge LD (TC1CR), 00000110B Sets the TC1 mode and source clock (EIRL). 4 Enables INTTC1 SET ΕI (TC1CR), 00110110B LD Starts TC1 with an external trigger ÷ PINTTC1: CPL (INTTC1SW). 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) 3 RETI ÷ VINTTC1: DW PINTTC1 ``` 1999-08-23 Figure 2-23. Pulse Width Measurement Mode Timing Chart #### (6) Programmable 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 P14 (PPG) pin. In the case of PPG output, beforehand the P14 should be set to the output mode, and the P14 output latch should be set to "1". 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. Example: "H" level 800 $\mu$ s, "L"" level 200 $\mu$ s pulse output (at fc = 8 MHz, DVCK in CGCR = "010") SET (P1).4 ; P14 output latch←1 LD (P1CR), 00010000B ; Sets P14 to an output mode LD (TC1CR), 10001011B ; Sets PPG output mode LDW (TREG1A), 01F4H ; Sets a period (1 ms $\div$ 2 $\mu$ s = 01F4 $_{\rm H}$ ) LDW (TREG1B), 0064H ; Sets "L" level pulse width (200 $\mu$ s $\div$ 2 $\mu$ s = 0064 $_{\rm H}$ ) LD (TC1CR), 10010011B ; Start Figure 2-24. PPG Output Figure 2-25. PPG Output Mode Timing Chart # 2.6 16-bit Timer/Counter 2 (TC2) # 2.6.1 Configuration Figure 2-26. 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-27. 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) | tor Timer/ | Counter 2 | |------------|--------------|------------------|------------|-----------| | | | | | | | Source clock | | | | Resolution | | Maximum time setting | | |----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------|------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------| | NORMAL1/2, IDLE1/2 mode | | SLOW mode SLEEP mode | | NO: | Solution | iviaximum 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><br>fc/2 <sup>8</sup><br>fc/2 <sup>6</sup><br>fc/2 <sup>5</sup><br>fc/2 <sup>4</sup><br>- | fs/2 <sup>15</sup> [Hz]<br>fs/2 <sup>5</sup><br>fc/2 <sup>8</sup><br>fc/2 <sup>6</sup><br>fc/2 <sup>5</sup><br>fc/2 <sup>4</sup><br>-<br>fs | fs/2 <sup>15</sup> [Hz]<br>fs/2 <sup>5</sup><br>-<br>-<br>-<br>-<br>fc (Note) | fs / 2 <sup>15</sup> [Hz]<br>fs / 2 <sup>5</sup><br>-<br>-<br>-<br>-<br>- | 1.05 s<br>1.02 ms<br>32 | 1 s<br>1 ms<br>-<br>-<br>-<br>-<br>-<br>-<br>30.5 μs | 19.1 hour 1.1 min 2.1 s 524.2 ms 262.1 ms 131.1 ms 7.936 ms | 18.2 hour<br>1 min<br>-<br>-<br>-<br>-<br>-<br>2 s | Note: "fc" can be used only in the timer mode. This is used for warm up when switching from SLOW mode to NORMAL2 mode. Example: Sets the timer mode with source clock fc/24 [Hz] and generates an interrupt every 25 ms (at fc = 8 MHz, DVCK in CGCR = "010"). LD (TC2CR), 00001100B ; Sets the TC2 mode and source clock LDW (TREG2), 30D4H ; Sets TREG2 ( $25ms \div 2^4/fc = 30D4_H$ ) SET (EIRH).EF14 ; Enable INTTC2 Ε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 fcgck/24 [Hz] in NORMAL1/2 or IDLE1/2 mode, and fs/24 [Hz] in SLOW or SLEEP mode. But, a pulse width of 2 machine cycles or more is required for both "H" and "L" level. Example: Sets the event counter mode and generates an INTT2 interrupt 640 counts later. LD (TC2CR), 00011100B ; Sets the TC2 mode LDW (TREG2), 640 ; Sets TREG2 SET (EIRH).EF14 ; Enable INTTC2 Ε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. Example: Inputs "H" level pulse of 120 ms or more and generates interrupt. (at fc = 8 MHz). LDW (TREG2), 0078H ; Sets TREG2 (120 ms $\div$ 2<sup>13</sup>/fc = 0078<sub>H</sub>) SET (EIRH).EF14 ; Enables INTTC2 interrupt ΕI LD (TC2CR), 00100101B ; Starts TC2 Figure 2-28. Window Mode Timing Chart ## 2.7 8-Bit Timer/Counter 3 (TC3) ### 2.7.1 Configuration Figure 2-29. Timer/Counter 3 #### 2.7.2 Control The timer/counter 3 is controlled by a timer/counter 3 control register (TC3CR) and two 8-bit timer registers (TREG3A and TREG3B). Reset does not affect these timer registers. Figure 2-30. Timer Register 3A/3B and TC3 Control Register #### 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 cl | ock | | Res | olution | Maximum time setting | | | | |----------------------------------------------|-------------------------------------------------|--------------------------|------------|----------|------------------------|------------------------|-------|---------------------|--| | NORMAL1/2, IDLE1/2 mode | | | | ives | olution | iviaximum time setting | | | | | DV7CK = 0 | DV7CK = 1 | SLOW, SLEEP mode | At fc = | 8 MHz | At fs = 32.768 kHz | At fc = | 8 MHz | At fs = 32.768 kHz | | | fc / 2 <sup>12</sup><br>fc / 2 <sup>10</sup> | fs / 2 <sup>4</sup> [Hz]<br>fs / 2 <sup>2</sup> | fs / 2 <sup>4</sup> [Hz] | 512<br>128 | μS<br>μS | 488.28 μs<br>122.07 μs | 131.1<br>32.6 | | 124.5 ms<br>31.1 ms | | | fc / 2 <sup>7</sup> | fc / 2 <sup>7</sup> | _ | 16 | μS | | 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 fcgck/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), 00001100B; Sets TC3 mode and 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. When the TREG3A has been read out, capture and overflow detection resumes. Thus, it is general to read out TREG3B before reading out TREG3A. Figure 2-31. Timing Chart for Capture Mode (INT3ES = 0) ## 2.8 8-bit Timer/Counter 5 (TC5) ## 2.8.1 Configuration Figure 2-32. Timer/Counter 5 (TC5) #### 2.8.2 Control The TC5 is controlled by a timer/counter 5 control register (TC5CR) and an 8-bit timer register 5 (TREG5). Figure 2-33. Timer/Counter 5 Timer register, Control register #### 2.8.3 Function TC5 has 3 operating modes: timer, programmable divider output, and pulse width modulation output mode. ## (1) Timer mode In this mode, the internal clock is used for counting up. The contents of the timer register 5 (TREG5) is compared with the contents of the up-counter. Matching with TREG5 generates a timer/counter 5 interrupt (INTTC5) and clears the counter. Counting up resumes after the counter is cleared. | • | Source clock | ( | resol | ution | maximum setting time | | | |---------------------------|--------------------------|------------------------|----------------|-------------|----------------------|-------------|--| | NORMAL1/2, | IDLE1/2 mode | SLOW, SLEEP mode | fc = 8 MHz | fs = 32.768 | fc = 8 MHz | fs = 32.768 | | | DV7CK = 0 | DV7CK = 1 | JEOW, JEEE Mode | IC = O IVII 12 | kHz | IC = O IVII IZ | 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> | fc / 2 <sup>7</sup> | _ | 16 <i>μ</i> s | - | 4.1 ms | _ | | | fc / 2 <sup>6</sup> | fc / 2 <sup>6</sup> | _ | 8 μs | _ | 2.0 ms | _ | | | fc / 2 <sup>5</sup> | fc / 2 <sup>5</sup> | _ | 4 μs | _ | 1.0 ms | _ | | | fc / 2 <sup>4</sup> | fc / 2 <sup>4</sup> | _ | 2 μs | _ | 0.5 ms | _ | | Table 2-6. Source Clock (Internal clock) for TC5 ### (2) Programmable divider output (PDO) mode The internal clock is used for counting up. The contents of the TREG5 are compared with the contents of the up-counter. The timer F/F5 output is toggled and the counter is cleared each time a match is found. The timer F/F5 output is inverted and output to the PDO (P52) pin. In the case of PDO output, beforehand the P52 should be set to the output mode, and the P52 output latch should be set to "1". This mode can be used for 50% duty pulse output. INTTC5 interrupt is generated each time the PDO output is toggled. Example : 1024 Hz pulse output (at fc = 4.194304 MHz) SET (P5).2 ; P52 output latch←1 LD (P5CR1), 00000100B LD (TC5CR), 00001010B ; Sets to TC5 modes and source clock LD (TREG5), 10H ; $(1/1024 \div 2^{7}/fc) \div 2 = 10_{H}$ LD (TC5CR), 00101010B ; Starts TC5 Figure 2-34. PDO Mode Timing Chart #### (3) Pulse width modulation (PWM) output mode PWM output with a resolution of 8-bits is possible. The internal clock is used for counting up. The contents of the TREG5 is compared with the contents of the up-counter. If a match is found, the timer F/F5 output is toggled. The counter continues counting and, when an overflow occurs, the timer F/F5 output is again toggled and the counter is cleared. The timer F/F5 output is inverted and output to the PWM (P52) pin. In the case of PWM output, beforehand the P52 should be set to the output mode, and the P52 output latch should be set to "1". An INTTC5 interrupt is generated when an overflow occurs. TREG5 is configured a 2- stage shift register and, during output, will not switch until one output cycle is completed even if TREG5 is overwritten; therefore, output can be altered continuously. Also, the first time, TREG5 is shifted by setting TC5S (bit 5 in TC5CR) to "1" after data are loaded to TREG5. Note 1: PWM output mode can be used in only NORMAL1/2 or IDLE1/2 mode. Note 2: Do not overwrite TREG5 only when an INTTC5 interrupt is generated. Usually, TREG5 is overwritten in the routine of INTTC5 interrupt service. Figure 2-35. PWM Output Mode Timing Chart | Table 2-7. | TREG5 | minimum / | ' maximum v | alue setting | |------------|-------|-----------|-------------|--------------| | | | | | | | acor rotio | 1/ | <b>′</b> 1 | 1, | /2 | 1, | /4 | 1/8 | | |-------------------|-----|------------|-----|-----|-----|-----|-----|-----| | gear ratio | min | max | min | max | min | max | min | max | | fc/2 <sup>2</sup> | 3 | 253 | 4 | 252 | 6 | 250 | 10 | 246 | | fc/2 | 4 | 252 | 6 | 250 | 10 | 246 | 18 | 238 | | fc | 6 | 250 | 10 | 246 | 18 | 238 | 34 | 222 | #### **PWM** output | Source | fc = 3.58 MHz | | fc = 3.84 MHz | | fc = 4.00 MHz | | fc = 4.19 MHz | | fc = 8.00 MHz | | |-------------------|---------------|-------------------|---------------|-----------------|---------------|-------------------|---------------|------------------|---------------|------------------------| | clock | Resolution | Repeat<br>cycle | Resolution | Repeat<br>cycle | Resolution | Repeat<br>cycle | Resolution | Repeat<br>cycle | Resolution | Repeat<br>cycle | | fc/2 <sup>2</sup> | 1117.32 ns | <b>286</b> .03 μs | 1041.67 ns | 266.67 $\mu$ s | 1000.00 ns | <b>256</b> .00 μs | 954.65 ns | 244.39 $\mu$ s | 500.00 ns | 128.00 <i>μ</i> s | | fc/2 | 558.66 ns | 143.02 <i>μ</i> s | 520.83 ns | 133.33 $\mu$ s | 500.00 ns | 128.00 μs | 477.33 ns | 122.20 $\mu$ s | 250.00 ns | 64.00 μs | | fc | 279.33 ns | 71.51 <i>μ</i> s | 260.42 ns | 66.67 μs | 250.00 ns | 64.00 μs | 238.66 ns | 61.10 <i>μ</i> s | 125.00 ns | $32.00~\mu \mathrm{s}$ | ## 2.9 Serial Interface (SIO) The 87CM53 has one clocked-synchronous 8-bit serial interface. Serial interface have an 8-byte transmit and receive data buffer that can automatically and continuously transfer up to 64 bits of data. The serial interfaces are connected to external devices via pins P45 (SO), P44 (SI), P43 (SCK). The serial interface pins are also used as port P4. When used as input pins, the input pins should be set to the input mode. When used as output pins, beforehand the output pins should be set to the output mode, and output latch should be set to "1". In the transmit mode, pin P44 can be used as normal I/O port, and in the receive mode, the pin P45 can be used as normal I/O ports. ### 2.9.1 Configuration Figure 2-36. Serial Interfaces #### 2.9.2 Control The serial interfaces are controlled by SIO control registers (SIOCR1/SIOCR2). The serial interface status can be determined by reading SIO status register (SIOSR). The transmit and receive data buffer is controlled by the BUF (bits 2-0 in SIOCR2). The data buffer is assigned to address 0FF0<sub>H</sub> - 0FF7<sub>H</sub> for SIO in the DBR area, and can continuously transfer up to 8 words (bytes or nibbles) at one time. When the specified number of words has been transferred, a buffer empty (in the transmit mode) or a buffer full (in the receive mode or transmit/receive mode) interrupt (INTSIO) is generated. When the internal clock is used as the serial clock in the 8-bit receive mode and the 8-bit transmit/receive mode, a fixed interval wait can be applied to the serial clock for each word transferred. Four different wait times can be selected with WAIT (bits 4 and 3 in SIOCR2). | SIO Con | trol Regist | ers 1 | | | | | |-------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--|--| | SIOCR1<br>(0020 <sub>H</sub> ) | 7 6 | 5 4 3 2<br>SIOM , | 1 0<br>SCK (Initial value: 0000 0000) | | | | | (002011) | SIOS | Indicate transfer start/stop | 0 : Stop<br>1 : Start | | | | | | SIOINH | Continue/abort transfer | 0 : Continue transfer<br>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 DV3G ÷ 2 (fc/2 <sup>5</sup> ÷ 2, fc/2 <sup>6</sup> ÷ 2) Note 4 011 : Internal clock DV2G ÷ 2 (fc/2 <sup>4</sup> ÷ 2, fc/2 <sup>5</sup> ÷ 2, fc/2 <sup>6</sup> ÷ 2) Note 4 111 : External clock (input from SCK pin) | | | | | SIOSR | Note | e3: SIOCR1 is write-only regis<br>as bit operate, etc.<br>e4: The DV2G can be set to eight<br>by the DVCR of the clock of<br>must be set to fc/24, fc/25<br>and to fc/26 at the gear ra<br>1/8, DV2G ÷ 2 and DV3G ÷ | If to "1" when setting the transfer mode or serial clock. ters, which cannot access any of in read-modify-write instruction ther fc/24, fc/25 or fc/26, and the DV3G can be set to either fc/25 gear control register (CGCR). When the DV2G and DV3G are used or fc/26 at the gear ratio = 1/1, to fc/25 or fc/26 at the gear ratio atio = 1/4. When they are set to other values or the gear ratio 2 (SCK = 011, 010) can not operate correctly. 1 0 1 1 0 11 11 (Initial value: 0011 1111) | or fc/2 <sup>6</sup><br>ed, they<br>io = 1/2, | | | | 0020 <sub>H</sub> ) | SIOF | Serial transfer operating status monitor | 0: Transfer terminated 1: Transfer in process (After SIOS is cleared to "0", SIOF is cleared to "0" at the termination of transfer or setting of SIOINH. | read | | | | | SEF | Shift operating status monitor | 0 : Shift operation terminated 1 : Shift operation in process | | | | | SIO Con<br>SIOCR2<br>(0021 <sub>H</sub> ) | trol Regist | 5 4 3 2 | 1 0 BUF (Initial value: ***0 0000) | | | | | | WAIT | Wait control | Always sets "00" except 8-bit transmit/receive mode. $00: T_f = T_D \text{ (non-wait)}$ $01: T_f = 2T_D$ $10: T_f = 4T_D$ $11: T_f = 8T_D$ (wait) | | | | | | | | Buffer address used | 1 | | | 1999-08-23 Figure 2-37. SIO Control Registers and Status Registers ### (1) Serial Clock ### a. Clock Source SCK (bits 2 - 0 in SIOCR) is able to select the following: #### 1 Internal Clock Any of four frequencies can be selected. The serial clock is output to the outside on the $\overline{SCK}$ pin. The $\overline{SCK}$ pin goes high when transfer starts. 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 of Berlan Clock Natio | | | | | | | | | | | | | |-------------------------------|-------------------------------|--------------------------|---------------|---------------|---------------|---------------|---------------|----------------|--|--|--|--|--| | | Serial clock | | | | | | | | | | | | | | NORMAL1/2, IDLE1/2 mode SLOW, | | | | Transfer rate | | | | | | | | | | | DV7CK = 0 | DV7CK = 1 | SLEEP mode | fc = 8.00 MHz | fc = 4.19 MHz | fc = 4.00 MHz | fc = 3.84 MHz | fc = 358 MHz | fs = 32.768MHz | | | | | | | fc / 2 <sup>13</sup> [Hz] | fs / 2 <sup>5</sup> [Hz] | fs / 2 <sup>5</sup> [Hz] | 0.95 Kbit/s | 0.50 Kbit/s | 0.48 Kbit/s | 0.46 Kbit/s | 0.43 Kbit/s | 1 Kbit/s | | | | | | | fc / 2 <sup>8</sup> | fc / 2 <sup>8</sup> | _ | 30.52 Kbit/s | 15.98 Kbit/s | 15.26 Kbit/s | 14.65 Kbit/s | 13.66 Kbit/s | _ | | | | | | | fc / 2 <sup>7</sup> | fc / 2 <sup>7</sup> | _ | 61.04 Kbit/s | 31.97 Kbit/s | 30.52 Kbit/s | 29.30 Kbit/s | 27.31 Kbit/s | _ | | | | | | | fc / 2 <sup>6</sup> | fc / 2 <sup>6</sup> | — | 122.07 Kbit/s | 63.93 Kbit/s | 61.04 Kbit/s | 58.59 Kbit/s | 54.63 Kbit/s | | | | | | | | fc / 2 <sup>5</sup> | fc / 2 <sup>5</sup> | | 244.14 Kbit/s | 127.87 Kbit/s | 122.07 Kbit/s | 117.19 Kbit/s | 109.25 Kbit/s | | | | | | | Table 2-8. Serial Clock Rate Note: 1 Kbit = 1024 bit 3-53-81 1999-08-23 Figure 2-38. Clock Source (Internal Clock) ### ② External Clock An external clock connected to the $\overline{SCK}$ pin is used as the serial clock. In this case, the P43 ( $\overline{SCK}$ ) must be set to the input mode. To ensure shifting, a pulse width of at least 4 machine cycles is required. This pulse is needed for the shift operation to execute certainly. Actually, there is necessary processing time for interrupting, writing, and reading. The minimum pulse is determined by setting the mode and the program. ### b. Shift edge The leading edge is used to transmit, and the trailing edge is used to receive. - ① Leading Edge Transmitted data are shifted on the leading edge of the serial clock (falling edge of the SCK pin input/output). - ② Trailing Edge Received data are shifted on the trailing edge of the serial clock (rising edge of the SCK pin input/output). Figure 2-39. Shift Edge #### (2) Number of Bits to Transfer Either 4-bit or 8-bit serial transfer can be selected. When 4-bit serial transfer is selected, only the lower 4 bits of the transmit/receive data buffer register are used. The upper 4 bits are cleared to "0" when receiving. The data is transferred in sequence starting at the least significant bit (LSB). #### (3) Number of Words to Transfer Up to 8 words consisting of 4 bits of data (4-bit serial transfer) or 8 bits (8-bit serial transfer) of data can be transferred continuously. The number of words to be transferred is loaded to BUF. An INTSIO interrupt is generated when the specified number of words has been transferred. If the number of words is to be changed during transfer, the serial interface must be stopped before making the change. The number of words can be changed during automatic-wait operation of an internal clock. In this case, the serial interface is not required to be stopped. Figure 2-40. Number of Bits to Transfer (Example : 4-bit serial transfer) #### 2.9.3 Transfer Mode SIOM (bits 5 - 3 in SIOCR1) is used to select the transmit, receive, or transmit/receive mode. #### (1) 4-bit and 8-bit Transmit Modes In these modes, the SIOCR1 is set to the transmit mode and then the data to be transmitted first are written to the data buffer registers (DBR). After the data are written, the transmission is started by setting SIOS to "1". The data are then output sequentially to the SO pin in synchronous with the serial clock, starting with the least significant bit (LSB). As soon as the LSB has been output, the data are transferred from the data buffer register to the shift register. When the final data bit has been transferred and the data buffer register is empty, an INTSIO (buffer empty) interrupt is generated to request the next transmitted data. When the internal clock is used, the serial clock will stop and an automatic-wait will be initiated if the next transmitted data are not loaded to the data buffer register by the time the number of data words specified with the BUF has been transmitted. Writing even one word of data cancels the automatic-wait; therefore, when transmitting two or more words, always write the next word before transmission of the previous word is completed. Note: Automatic-waits are also canceled by writing to a DBR not being used as a transmit data buffer register; therefore, during SIO do not use such DBR for other applications. For example, when 3 words are transmitted, do not use the DBR of the remained 5 words. When an external clock is used, the data must be written to the data buffer register before shifting next data. Thus, the transfer speed is determined by the maximum delay time from the generation of the interrupt request to writing of the data to the data buffer register by the interrupt service program. When the transmit is started, after the SIOF goes "high" output from the SO pin holds final bit of the last data until falling edge of the SCK. The transmission is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer empty interrupt service program. That the transmission has ended can be determined from the status of SIOF (bit 7 in SIOSR) because SIOF is cleared to "0" when a transfer is completed. When SIOINH is set, the transmission is immediately ended and SIOF is cleared to "0". If it is necessary to change the number of words, SIOS should be cleared to "0", then BUF must be rewritten after confirming that SIOF has been cleared to "0". When an external clock is used, it is also necessary to clear SIOS to "0" before shifting the next data; otherwise, dummy data will be transmitted and the operation will end. 3-53-84 1999-08-23 Figure 2-41. Transfer Mode (Example: 8-bit, 1 Word Transfer) Figure 2-42. Transmitted Data Hold Time at End of Transmit #### (2) 4-bit and 8-bit Receive Modes After setting the control registers to the receive mode, set SIOS to "1" to enable receiving. The data are then transferred to the shift register via the SI pin in synchronous with the serial clock. When one word of data has been received, it is transferred from the shift register to the data buffer register (DBR). When the number of words specified with the BUF has been received, an INTSIO (buffer full) interrupt is generated to request that these data be read out. The data are then read from the data buffer registers by the interrupt service program. When the internal clock is used, and the previous data are not read from the data buffer register before the next data are received, the serial clock will stop and an automatic-wait will be initiated until the data are read. A wait will not be initiated if even one data word has been read. Note: Waits are also canceled by reading a DBR not being used as a received data buffer register is read; therefore, during SIO do not use such DBR for other applications. When an external clock is used, the shift operation is synchronized with the external clock; therefore, the previous data are read before the next data are transferred to the data buffer register. If the previous data have not been read, the next data will not be transferred to the data buffer register and the receiving of any more data will be canceled. When an external clock is used, the maximum transfer speed is determined by the delay between the time when the interrupt request is generated and when the data received have been read. The receiving is ended by clearing SIOS to "0" or setting SIOINH to "1" in buffer full interrupt service program. When SIOINH is set, the receiving is immediately ended and SIOF is cleared to "0". When SIOS is cleared, the current data are transferred to the buffer. After SIOS cleaned, the transmissions is ended at the time that the final bit of the data being shifted has been output. That the transmission has ended can be determined from the status of SIOF (bit 7 in SIOSR). SIOF is cleared to "0" when the transmission is ended. If it is necessary to change the number of words in external clock operation, SIOS should be cleared to "0" then BUF must be rewritten after confirming that SIOF has been cleared to "0". If it is necessary to change the number of words in internal clock, during automatic-wait operation which occurs after completion of data receive, BUF must be rewritten before the received data is read out. Note: The buffer contents are lost when the transfer mode is switched. If it should become necessary to switch the transfer mode, end receiving by clearing SIOS to "0", read the last data and then switch the transfer mode. 3-53-86 1999-08-23 Figure 2-43. Receive Mode (Example: 8-bit, 1 word, internal clock) #### (3) 8-bit Transmit/Receive Mode After setting the control registers to the 8-bit transmit/receive mode, write the data to be transmitted first to the data buffer registers (DBR). After that, enable transceiving by setting SIOS to "1". When transmitting, the data are output from the SO pin at leading edges of the serial clock. When receiving, the data are input to the SI pin at the trailing edges of the serial clock. 8-bit data are transferred from the shift register to the data buffer register. An INTSIO interrupt is generated when the number of data words specified with the BUF has been transferred. The interrupt service program reads the received data from the data buffer register and then writes the data to be transmitted. The data buffer register is used for both transmitting and receiving; therefore, always write the data to be transmitted after reading the received data. When the internal clock is used, a wait is initiated until the received data are read and the next data are written. A wait will not be initiated if even one data word has been written. Note: 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 receive is started, after the SIOF goes "high" output from the SO pin holds final bit of the last data until falling edge of the SCK. Clear SIOS to "0" to SIOINH to "1" in INTSIO interrupt service program to end transmit/receive mode. 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. The transmit/receive is ended at the time that the final bit of the data being shifted has been output. The end of transmit/receive can be determined from the status of SIOF (bit 7 in SIOSR). SIOF is cleared to "0" when the transmit/receive is ended. When SIOINH is set, the transmit/receive is immediately ended and SIOF is cleared to "0". If the number of words is to be changed during transfer, SIOS must be cleared to "0" and BUF is rewritten after confirmed that SIOF clearing to "0". The number of words can be changed during automatic-wait operation of an internal clock. In this case, BUF must be rewritten before the final transmitted/received data is read out. When SIOINH is set, the transmit/receive operation is immediately ended and SIOF is cleared to "0". If it is necessary to change the number of words in external clock operation, SIOS should be cleared to "0", then BUF must be rewritten after confirming that Siof has been cleared to "0". If it is necessary to change the number of words in internal clock, during automatic-wait operation which occurs after completion of transmit / receive operation, BUF must be rewritten before reading and writing of the receive/transmit data. 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-44. Transmit/Receive Mode (Example: 8-bit, 1word, internal clock) Figure 2-45. Transmitted Data Hold Time at End of Transmit/Receive # 2.10 UART (Asynchronous serial interface) The 87CM53 has 1 channel of UART (asynchronous serial interface). The UART is connected to external devices via RxD and TxD. RxD is also used as P40; TxD, as P41. When used as RxD pin, P40 should be set to the input mode. When used as TxD pin, beforehand P41 should be set to the output mode and the output latch should be set to "1". ## 2.10.1 Configuration Figure 2-46. UART #### **2.10.2 Control** UART is controlled by the UART control registers (UARTCR1, UARTCR2). The operating status can be monitored using the UART status register (UARTSR). Figure 2-47. UART control register | | ТВЕР | Transmit data buffer empty flag | 0 : –<br>1 : Transmit data buffer empty | | | | |-------------------------------|---------------|---------------------------------|-----------------------------------------------------------------------------------|--|--|--| | | TEND | Transmit end flag | 0: Transmit data buffer empty 1: Transmit end 0: - 1: Receive data buffer full | | | | | | RBFL | Receive data buffer full flag | | | | | | | OERR | Overrun error flag | 0 : No overrun error<br>1 : Overrun error | | | | | | FERR | Framing error flag | 0 : No framing error<br>1 : Framing error | | | | | | PERR | Parity error flag | 0 : No parity error<br>1 : Parity error | | | | | UART red | ceive data bu | offer (Initial value 0000 00 | 000) read only | | | | | RDBUF<br>(0024 <sub>H</sub> ) | 7 6 | 5 4 3 2 1 | 0 | | | | | UART tra | ınsmit data b | ouffer (Initial value 0000 00 | 000) write only | | | | | TDBUF<br>(0024 <sub>H</sub> ) | 7 6 | 5 4 3 2 1 | 0 | | | | Figure 2-48. UART Status Register and Data Buffer Registers ## 2.10.3 Transfer Data Format In UART, a one-bit start bit (low level), stop bit (bit length selectable at high level, by STBT), and parity (select parity in PE; even-or odd-numbered parity by EVEN) are added to the transfer data. The transfer data formats are shown as follow. Frame length PΕ STBT 10 11 12 Start bit0 bit1 bit6 bit7 0 Stop1 0 Start bit0 bit1 bit6 bit7 Stop1 Stop2 1 Start bit0 bit1 bit6 bit7 Parity Stop1 1 0 Start bit0 bit7 1 bit1 bit6 Parity Stop1 Stop2 1 Table 2-9. ### 2.10.4 Transfer Rate The baud rate of UART is set of BRG (bit 0, 1, and 2 in UARTCR1) . The example of the baud rate shown as follows. | Ta | h | ۵ | 2- | 1 | በ | | |----|---|---|----|---|---|--| | ıa | v | | | | v | | | BRG | Sourse clock | | | | | | | | | |-----|--------------|--------------|--|--|--|--|--|--|--| | ВКС | 8 MHz | 4 MHz | | | | | | | | | 000 | 38400 [baud] | 19200 [baud] | | | | | | | | | 001 | 19200 | 9600 | | | | | | | | | 010 | 9600 | 4800 | | | | | | | | | 011 | 4800 | 2400 | | | | | | | | | 100 | 2400 | 1200 | | | | | | | | | 101 | 1200 | 600 | | | | | | | | Transfer rate = $\frac{\text{Transfer clock}}{16}$ When TC5 is used as the UART transfer rate (when BRG = 110), the transfer clock and transfer rate are detarmined as follows: Transfer rate = $$\frac{\text{Transfer clock}}{16}$$ Transfer clock = interrupt cycle = $$\frac{\text{TC5 source clock}}{\text{TREG5 set value}}$$ Note: When INTTC5 interrupt of the TC5 is used as the transfer clock, use it on the conditions that the INTTC5 operates correctly. It is recommended to use the TC5 in the timer mode. ### 2.10.5 Data Sampling The UART receiver keeps sampling input using the clock selected by BRG (bit 0, 1, and 2 in UARTCR1) until a start bit is detected in RxD pin input. RT clock starts at the falling edge of the RxD pin. Once a start bit is detected, the start bit, data bits, stop bit(s), and parity bit are sampled at three times of RT7, RT8, and RT9 during one receiver clock interval (RT clock). (RT0 is the position where the bit supposedly starts). Bit is determined according to majority rule (the data are the same twice or more out of three samplings). Figure 2-49. Data Samping ### 2.10.6 STOP Bit Length Select a transmit stop bit length (1 or 2 bits) by STBT (bit5 in UARTCR1) ### 2.10.7 Parity Set parity/no parity by PE; set parity type (odd-or even-numbered) by EVEN (bit 4 in UARTCR1). #### 2.10.8 Transmit / Receive #### (1) Data transmit Set TXE (bit 7 in UARTCR1) to 1. Read UARTSR to check TBEP = 1, then write data in TDBUF (transmit data buffer). Writing data in TDBUF zero-clears TBEP, transfers the data to the transmit shift register and the data are sequentially output from the TxD pin. The data output include a one-bit start bit, stop bits whose number is specified in STBT (bit 5 in UARTCR1) and a parity bit if parity addition is specified. Select the data transfer baud rate using bits 0 to 2 in UARTCR1. When data transmit starts, transmit buffer empty flag TBEP is zero-cleared and an INTTX interrupt is generated. When transmitting data, first read UARTSR, then write data in TDBUF. Otherwise, TBEP is not zero-cleared and transmit does not start. #### (2) Data receive Set RXE (bit 6 in UARTCR1) to 1. When data are received via the RxD pin, the receive data are transferred to RDBUF (receive data buffer). At this time, the data transmitted include a start bit and stop bit(s) and a parity bit if parity addition is specified. When stop bit(s) are received, data only are extracted and transferred to RDBUF (receive data buffer). Then the receive buffer full flag RBFL is set and an INTRX interrupt is generated. Select the data transfer baud rate using bits 0 to 2 in UARTCR1. If an overrun error (OERR) occurs when data are received, the data are not transferred to RDBUF (receive data buffer) but discarded; data in the RDBUF are not affected. ## 2.10.9 Status Flag / Interrupt Signal ### (1) Parity error When parity determined using the receive data bits differs from the received parity bit, the parity error flag PERR is set in UARTSR. Reading UARTSR then RDBUF clears PERR. Figure 2-50. Generation of Parity Error ### (2) Framing error When 0 is sampled as the stop bit in the receive data, framing error flag FERR is set. Reading UARTSR then RDBUF clears FERR. Figure 2-51. Generation of Framing Error ### (3) Overrun error When all bits in the next data are received while unread data are still in RDBUF, overrun error flag OERR is set. In this case, the receive data is discarded; data in RDBUF are not affected. Reading UARTSR then RDBUF clears OERR. Figure 2-52. Generation of Overrun Error #### (4) Receive data buffer full Loading the received data in RDBUF sets receive data buffer full flag RBFL. Reading UARTSR then RDBUF clears the RBFL. Figure 2-53. Generation of Receive Buffer Full ### (5) Transmit data buffer empty When no data is in the transmit buffer TDBUF, TBEP is set, that is, when data in TDBUF are transferred to the transmit shift register and data transmit starts, transmit data buffer empty flag TBEP is set. Reading UARTSR then writing the data to TDBUF clears TBEP. Figure 2-54. Generation of Transmit Buffer Empty #### (6) Transmit end flag When data are transmitted and no data is in TDBUF (TBEP = 1), transmit end flag TEND is set. Writing data to TDBUF then staring data transmit clears TEND. Figure 2-55. Generation of Transmit Buffer Empty #### 2.11 Tone Generator TMP87CM53 incorporates a Dual Tone Multi Frequency (DTMF) generator, which generates dial tone signals for the tone dialing system, and a melody generator, which generates melody frequencies. The tone dial signal is one of 16 types of DTMF synthetic waves obtained by overlapping selected sine waves, one from the low-frequency group consisting of four frequencies, and one from the high-frequency group consisting of four frequencies. (DTMF; Dual Tone Multi Frequency) ### 2.11.1 Configuration of Tone Generator Figure 2-56 shows the configuration of the DTMF generator and melody generator. The tone generator consists of a frequency/deviation frequency divider which generates the DTMF/melody basic clock (dtgck) from fc, programmable dividers (ROW/COLUMN) which generate tone ROW/COLUMN frequency from dtgck, sine wave synthesizers, an adder (TONE) which adds and outputs ROW/COLUMN sine waves, a programmable divider which generates melody frequencies from dtgck, a sine wave synthesizer (compatible with COLUMN), an amp (MELODY1) which outputs melody sine waves, and a melody square wave output device (MELODY2). Figure 2-56. Configuration of Tone Generator #### 2.11.2 Tone Control ### (1) DTMF Basic clock control DTMF is based on a 480kHz basic tone clock (dtgck); therefore, GCSEL needs to be set with the generator clock register (GCCR) so that dtgck is at 480kHz. The melody is based on 960kHz; therefore, when MOLODY mode is selected, dtgck is automatically set to 960kHz. Do not change the setting values once they are programmed. Note 1: GCCR is a write-only register; therefore, it cannot be operated with read modify commands (SET, CLR and other bit operation commands; AND, OR and other multiplication commands). Note 2: When executing read commands with GCCR, bits 3 to 7 are read as "1". Figure 2-57. Basic Clock Select Register ### (2) DTMF and melody control register The tone is controlled by generator mode select (DTMFCR) and generator data select (DTMFDR). | DTMFCR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |----------------------|-------------------|----------------------------------|--------------------------------------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-------|----------------|------------|-----| | (002D <sub>H</sub> ) | | | | CSEL | MELS | MEL1S | MEL2S | DTMFS | (Initial value | ***0 0000) | | | | CSEL | Opera | tion selec | t | | 0 : Disa<br>1 : Ena | | | | | | | | MSEL | Mode | select | | | 0 : DTMF mode<br>1 : MELODY mode | | | | | | | | MEL1S | Pin fu | nction sel | ect 1 | | 0 : P46 input/output 1 : MELODY 1 output (sine wave) | | | | | R/W | | | MEL2S | Pin fu | nction sel | ect 2 | | 0 : P53 input/output 1 : MELODY2 output (square wave) | | | | | | | | DTMFS | Pin fu | nction sel | ect 3 | | | input/out<br>IE output | • | | | | | DTMFDR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | (002E <sub>H</sub> ) | | ROW/ | NOTE | | | COLUMN/OCTAVE (Initial value 0000 0000 | | | | | | | | ROW /<br>NOTE | I select/see Table 2-13 for tone | | | | | 1 ()()1() · Outputs a single tone of 769 2Hz | | | | | | | COLUMN<br>/OCTAVE | freque | MN tone o<br>ency selec<br>octave se | t/ see Tab | le 2- 00<br>01 | 0001 : Outputs a single tone of 1212.1Hz 0010 : Outputs a single tone of 133.3Hz 0100 : Outputs a single tone of 1481.5Hz 1000 : Outputs a single tone of 1621.6Hz | | | | | R/W | Figure 2-58. Mode Select Register/Data Register #### 2.11.3 Function #### (1) DTMF function When using tone output (DTMFCR bits 4, 3 and 0) with CSEL and DTMFS set to "1" and MSEL set to "0", set P47 to output mode. When DTMFS is set to "1", tone output will be enabled. When both ROW and COLUMN codes are disabled, the intermediate level of the sine wave will be output. When MLSEL is set to "1", the intermediate level will be output but will differ from the previous intermediate level. When DTMFS is set to "0", DTMFS becomes a port regardless of DTMF status. When P47 is set to the output mode, the output changes to the output latch value. If P47 is set to open drain with input/output control register 2 (P4CR2) and the output latch is set to "1", the output becomes "Hi-Z". Note: To maintain precision during tone output, do not output through ports P4 to P7. Table 2-11 Tone Output Frequencies and Deviations from Standard Frequency | | Frequency | Standard<br>frequency | fc = 3.84 MHz<br>fc = 4.00 MHz<br>fc = 8.00 MHz | | fc = 3.58 MHz | | fc = 4.19 MHz | | |--------|-----------|-----------------------|-------------------------------------------------|---------------|---------------|---------------|---------------|--------------| | | code | (Hz) | output | deviation (%) | output | deviation (%) | output | deviation(%) | | R | 0001 | 697 | 697.674 | 0.10 % | 698.029 | 0.15 % | 696.013 | - 0.14 % | | ο̈ν | 0010 | 770 | 769.230 | - 0.10 % | 769.621 | - 0.05 % | 767.399 | - 0.34 % | | VV | 0100 | 852 | 857.143 | 0.60 % | 857.579 | 0.66 % | 855.102 | 0.36 % | | | 1000 | 941 | 937.500 | - 0.37 % | 937.976 | - 0.32 % | 935.268 | - 0.61 % | | С | 0001 | 1209 | 1212.121 | 0.26 % | 1212.737 | 0.31 % | 1209.235 | 0.02 % | | O<br>L | 0010 | 1336 | 1333.333 | - 0.20 % | 1334.011 | - 0.15 % | 1330.158 | - 0.44 % | | U<br>M | 0100 | 1477 | 1481.481 | 0.30 % | 1482.234 | 0.35 % | 1477.954 | 0.07 % | | N | 1000 | 1633 | 1621.622 | - 0.70 % | 1622.446 | - 0.65 % | 1617.761 | - 0.93 % | Note: Except error of are frequency Table 2-12 Correspondence between Dial Keys and Frequency Select Codes Set as ROW and COLUMN Data in DTMFDR | | | COLUMN data | | | | | |----------|-----------------------|----------------|----------------|----------------|--|--| | | Frequency select code | 0001<br>(1209) | 0010<br>(1336) | 0100<br>(1477) | | | | | 0001 (697) | 1 | 2 | 3 | | | | ROW data | 0010 (770) | 4 | 5 | 6 | | | | | 0100 (852) | 7 | 8 | 9 | | | | | 1000 (941) | * | 0 | # | | | | | | Турі | cal dial key p | pads | | | ( ): Standard frequency in Hz #### (2) MELODY function When using MELODY1 output (DTMFCR bits 4, 3 and 2/1) with CSEL, MSEL and MEL1S/MEL2S set to "1". When using MELODY1 set P46 to the output mode. When using MELODY2 output, set P53 to the output mode. When MEL1S is set to "1", MELODY1 will be output. When NOTE or OCTAVE codes are disabled, the intermediate level of the sine wave will be output. When MSEL are set to "0", the intermediate level will be output but will differ from the previous intermediate level. When MEL1S is set to "0", MEL1S becomes a port regardless of MELODY status. When P46 is set to the output mode, the output changes to the output latch value. If P46 is set to open drain with input/output control register 2 (P4CR2) and the output latch is set to "1", the output becomes "Hi-Z". MEL2S and P53 perform the same function. When output latch is set to "1" and set to open drain without pull-up resistor, the output becomes "Hi-Z". Note: To maintain precision during MELODY1 output, do not output through ports P4 to P7. Example: Output signal corresponding to 5A code. | LD | (GCCR), 04H | ; Selects source frequency of 4M. | | |----|---------------|--------------------------------------------|-------------| | LD | (P4CR1), 40H | ; Set P46 to output mode. | | | | \$ | | | | LD | (DTMFCR), 1EH | ; Controls port (selects MELODY1 or MELODY | <b>2</b> ). | | LD | (DTMFCR), 00H | ; Sets invalid NOTE data. | | | LD | (DTMFCR), 01H | ; Sets valid OCTAVE data. | | | LD | (DTMFCR), 61H | ; Sets valid NOTE data. | | **Melody Output Frequency Deviation** Table 2-13. | Octave | Note select | | Target | | l MHz<br>) MHz | 3 58 | MHz | 4 10 | MHz | |-------------|-------------|------|-----------|-------------|----------------|-------------|-----------------|-------------|---------------| | select code | code | Code | frequency | | MHz | 3.50 | 101112 | 7.13 | 7101112 | | (OCTABE) | (NOTE) | | (Hz) | output (Hz) | deviation (%) | output (Hz) | deviation (%) | output (Hz) | deviation (%) | | **00 | 0000 | _ | _ | _ | _ | _ | _ | _ | _ | | **00 | 0001 | 4E | 329.628 | 329.670 | 0.01 % | 329.838 | 0.06 % | 328.89 | - 0.23 % | | **00 | 0010 | 4F | 349.228 | 348.837 | - 0.11 % | 349.015 | - 0.06 % | 348.01 | - 0.35 % | | **00 | 0011 | 4F# | 369.994 | 370.370 | 0.10 % | 370.558 | 0.15 % | 369.49 | - 0.14 % | | **00 | 0100 | 4G | 391.995 | 389.611 | - 0.61 % | 389.808 | <b>-</b> 0.56 % | 388.68 | - 0.84 % | | **00 | 0101 | 4G# | 415.305 | 416.667 | 0.33 % | 416.878 | 0.38 % | 415.67 | 0.09 % | | **00 | 0110 | 4A | 440.000 | 441.177 | 0.27 % | 441.401 | 0.32 % | 440.13 | 0.03 % | | **00 | 0111 | 4A# | 466.164 | 468.750 | 0.55 % | 468.988 | 0.61 % | 467.63 | 0.32 % | | **00 | 1000 | 4B | 493.883 | 491.803 | - 0.42 % | 492.053 | - 0.37 % | 490.63 | - 0.66 % | | **00 | 1001 | 5C | 523.251 | 526.316 | 0.59 % | 526.583 | 0.64 % | 525.06 | 0.35 % | | **00 | 1010 | 5C# | 554.365 | 555.556 | 0.21 % | 555.838 | 0.27 % | 554.23 | - 0.02 % | | **00 | 1011 | 5D | 587.330 | 588.235 | 0.15 % | 588.534 | 0.21 % | 586.83 | - 0.08 % | | **00 | 1100 | 5D# | 622.254 | 625.000 | 0.44 % | 625.318 | 0.49 % | 623.51 | 0.20 % | | **00 | 1101 | _ | _ | 200.000 | _ | 200.102 | _ | 199.52 | _ | | **00 | 1110 | _ | _ | 267.857 | _ | 267.993 | _ | 267.22 | _ | | **00 | 1111 | _ | _ | 333.333 | _ | 333.503 | - | 332.54 | _ | | **01 | 0000 | _ | _ | _ | _ | - | _ | _ | _ | | **01 | 0001 | 5E | 659.255 | 659.341 | 0.01 % | 659.676 | 0.06 % | 657.77 | - 0.23 % | | **01 | 0010 | 5F | 698.456 | 697.675 | - 0.11 % | 698.029 | - 0.06 % | 696.01 | - 0.35 % | | **01 | 0011 | 5F# | 739.989 | 740.741 | 0.10 % | 741.117 | 0.15 % | 738.98 | - 0.14 % | | **01 | 0100 | 5G | 783.991 | 779.221 | - 0.61 % | 779.617 | <b>-</b> 0.56 % | 777.37 | - 0.85 % | | **01 | 0101 | 5G# | 830.609 | 833.334 | 0.33 % | 833.757 | 0.38 % | 831.35 | 0.09 % | | **01 | 0110 | 5A | 880.000 | 882.353 | 0.27 % | 882.801 | 0.32 % | 880.25 | 0.03 % | | **01 | 0111 | 5A# | 932.328 | 937.500 | 0.55 % | 937.976 | 0.61 % | 935.27 | 0.32 % | | **01 | 1000 | 5B | 987.767 | 983.607 | - 0.42 % | 984.106 | - 0.37 % | 981.26 | - 0.66 % | | **01 | 1001 | 6C | 1046.502 | 1052.632 | 0.59 % | 1053.166 | 0.64 % | 1050.13 | 0.35 % | | **01 | 1010 | 6C# | 1108.731 | 1111.111 | 0.21 % | 1111.676 | 0.27 % | 1108.47 | - 0.02 % | | **01 | 1011 | 6D | 1174.659 | 1176.471 | 0.15 % | 1177.068 | 0.21 % | 1173.67 | - 0.08 % | | **01 | 1100 | 6D# | 1244.508 | 1250.000 | 0.44 % | 1250.635 | 0.49 % | 1247.02 | 0.20 % | | **01 | 1101 | _ | _ | 400.000 | _ | 400.203 | _ | 399.05 | _ | | **01 | 1110 | _ | _ | 535.714 | _ | 535.986 | _ | 534.44 | _ | | **01 | 1111 | _ | _ | 666.667 | _ | 667.005 | _ | 665.08 | _ | | **10 | 0000 | _ | _ | _ | _ | _ | _ | _ | _ | | **10 | 0001 | 6E | 1318.510 | 1318.681 | 0.01 % | 1319.351 | 0.06 % | 1315.54 | - 0.23 % | | **10 | 0010 | 6F | 1396.913 | 1395.349 | - 0.11 % | 1396.058 | - 0.06 % | 1392.03 | - 0.35 % | | **10 | 0011 | 6F# | 1479.978 | 1481.481 | 0.10 % | 1482.234 | 0.15 % | 1477.95 | - 0.14 % | | **10 | 0100 | 6G | 1567.982 | 1558.442 | - 0.61 % | 1559.234 | <b>-</b> 0.56 % | 1554.73 | - 0.85 % | | **10 | 0101 | 6G# | 1661.219 | 1666.667 | 0.33 % | 1667.514 | 0.38 % | 1662.70 | 0.09 % | | **10 | 0110 | 6A | 1760.000 | 1764.706 | 0.27 % | 1765.603 | 0.32 % | 1760.50 | 0.03 % | | **10 | 0111 | 6A# | 1864.655 | 1875.000 | 0.55 % | 1875.953 | 0.61 % | 1870.54 | 0.32 % | | **10 | 1000 | 6B | 1975.533 | 1967.213 | - 0.42 % | 1968.213 | - 0.37 % | 1962.53 | - 0.66 % | | **10 | 1001 | 7C | 2093.005 | 2105.263 | 0.59 % | 2106.333 | 0.64 % | 2100.25 | 0.35 % | | **10 | 1010 | 7C# | 2217.461 | 2222.222 | 0.21 % | 2223.351 | 0.27 % | 2216.93 | - 0.02 % | | **10 | 1011 | 7D | 2349.318 | 2352.941 | 0.15 % | 2354.137 | 0.21 % | 2347.34 | - 0.08 % | | **10 | 1100 | 7D# | 2489.016 | 2500.000 | 0.44 % | 2501.270 | 0.49 % | 2494.05 | 0.20 % | | **10 | 1101 | _ | 800.000 | 800.000 | _ | 800.407 | _ | 798.10 | _ | | **10 | 1110 | _ | 1067.000 | 1071.428 | _ | 1071.972 | Ī | 1068.88 | _ | | **10 | 11110 | | 1333.000 | 1333.333 | _ | 1334.011 | _ | 1330.16 | - | | **11 | **** | | - | - | _ | _ | _ | - | _ | | | | | | | | | | | | Note 1: \* don't care Note 2: Except error of osc frequency ## **Tone Generator Output Waveform** ### MELODY Generator (Sine Wave: MELODY1 Output) ### MELODY Generator (Square Wave: MELODY2 Output) #### **DTMF** Generator (Dual-tone Mode: **TONE** Output) **DTMF** Generator (Single-tone Mode: TONE Output) 3-53-101 1999-08-23 ## **Tone Output Test** The 87CM53 has no test mode to test tone outputs. When the waveform needs testing and adjusting, a program must be made in advance. Figure 2-59. Single-Tone Waveform Figure 2-60. Dual-Tone Waveform ### 2.12 8-bit A/D Converter (ADC) The 87CM53 has an 8-channel multiplexed-input 8-bit successive approximate type A/D converter with sample and hold. The analog power source (VAREF) automatically cut off in stop mode and when analog input is disabled. ### 2.12.1 Configuration Figure 2-61. A/D Converter ### **2.12.2 Control** The A/D converter is controlled by the A/D converter control register (ADCCR). Reading EOCF in ADCCR determines the A/D converter operating state; reading the A/D conversion value register (ADCDR) determines the A/D conversion value. Figure 2-62. A/D Converter Result Register Figure 2-63. A/D Converter Control Register and A/D Conversion Result Register ### 2.12.3 Operation The high side of an analog reference voltage is applied to VAREF pin, and the low side is applied to VASS pin. The reference voltage between VAREF and VASS is divided into the voltage corresponding with bits by ladder resistance. The reference voltage is compared with an analog input voltage and A/D conversion is performed. Channels operating on analog input must be set to the input pin with P6 input/output control (P6CR). #### (1) Start of A/D conversion Prior to A/D conversion start, select one pin among analog input channels (AIN7 to AIN0) using the SAIN (bit 3 - 0 in ADCCR). Clear AINDS (bit 4 in ADCCR) to 0. 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. Set A/D conversion time using the ACK (bit 5 in ADCCR). To start A/D conversion, set A/D conversion to "1" using the ADS (bit 6 in ADCCR). A/D conversion time is from A/D conversion start to A/D conversion result being set in ADCDR. When ACK = 0, 184/fcgck [s] (46 machine cycles) is necessary. That is, when fcgck = fc = 8 MHz, the A/D conversion time is 23 $\mu$ s. After A/D conversion, the EOCF (bit 7 in ADCCR) is set to "1" indicating end of conversion. Setting the ADS to "1" during A/D conversion resumes conversion from the beginning. The analog input voltage is sampled every 4 machine cycles after A/D conversion start. Note: Keeping the same level of an analog input during 4 Machine Cycle Time is necessary for charging the sample hold circuit which has a resistor (typ. 5 k) and a capacitor (typ. 12pF). #### (2) Reading of A/D conversion result Read the conversion value stored in the A/D conversion register after the end of conversion is confirmed. (EOCF = 1) The EOCF is automatically cleared to "0" when reading the ADCDR. When the conversion result is read out during A/D conversion, the invalid value is read out. #### (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 A/D conversion value become indefinite. Thus EOCF is maintained to "0" after returned from the STOP mode. However, if the STOP mode is started after the end of conversion (EOCF = 1), the ADCDR contents are held. Figure 2-64. A/D conversion Timing chart Example: After AIN pin 4 is selected as an analog input channel, A/D conversion is started. EOCF is confirmed and the converted result is read out. It is saved to address 009E<sub>H</sub> in RAM. ; AIN SELECT ΙD (ADCCR), 00000100B selects AIN4 ; A/D CONVERT START (ADCCR). 6 ADS = 1SET SLOOP (ADCCR), 7 TEST EOCF = 1? T, SLOOP JRS ; RESULT DATA READ (9EH), (ADCDR) Figure 2-65 shows the relationship between An analog input voltage and A/D converted 8-bit digital value. Figure 2-65. Analog Input Voltage vs A/D Conversion Result (typ.) ## 2.13 Key on Wake-Up With the 87CM53 stop mode can be released with STOP pin (P20) and STPR0 to STPR7 pins (P80 to P87). ## 2.13.1 Configuration Figure 2-66. Key on Wake-Up #### **2.13.2** Control The stop mode release control register (STOPCR) can be used to set stop mode release for STPR0 to STPR7 pins for each bit. The P8 pull-up control register (P8PUCR) can be used to set the pull-up resistance for each bit. STPR0 to STPR7 pins to be used must be set to input pins with the port 8 input/output control register (P8CR). Initiate stop mode with system control register 1 (SYSCR1), and release stop mode by setting one of the STPR0 to STPR7 pins to "L" level. (see Note 1.) When using the key wake-up function (STPR0 to STPR7), use RELM, which selects the stop mode release, to select the level mode (SYSCR1 bit 6 to "1"). Confirm the status of STPR0 to STPR7 pins by reading the P8 port, and verify that the level of each pin is set to "H" before initiating stop mode. Figure 2-67. Stop Release Control Registor ### INPUT/OUTPUT CIRCUITRY ## (1) Control pins The input / output circuitries of the 87CM53 control pins are shown below. Please specify either the single-clock mode or the dual-clock mode 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 | Resonator connecting pins (high-frequency) $R_f = 1.2 \ M\Omega \ (typ.)$ $R_0 = 1.5 \ k\Omega \ (typ.)$ | | XTIN (P21)<br>XTOUT (P22) | Input<br>Output | NM1 NM2 Osc. enable XTEN OVDD fs Refer to port P2 XTIN XTOUT | Resonator connecting pins (low-frequency) $R_f = 6 \ M\Omega \ (typ.)$ $R_o = 220 \ k\Omega \ (typ.)$ In only dual-clock mode | | RESET | 1/0 | Address-trap-reset Watchdog timer reset System-clock-reset | Sink open drain output Hysteresis input Pull-up resistor $R_{IN} = 220 \text{ k}\Omega \text{ (typ.)}$ $R = 1 \text{ k}\Omega \text{ (typ.)}$ | | STOP/INT5<br>(P20) | Input | P20 STOP/INT5 | Hysteresis input $R=1\ k\Omega\ (typ.)$ | | TEST | Input | R <sub>IN</sub> × M | Pull-down resistor $R_{\text{IN}} = 70 \text{ k}\Omega \text{ (typ.)}$ $R = 1 \text{ k}\Omega \text{ (typ.)}$ | Note1: The TEST pin of the 87PM53 does not have a pull-down resistor. Be sure to fix the TEST pin to low in MCU mode. Note2: The 87PM53 is placed in the single-clock mode during reset. (NM1) # (2) Input/output ports The input/output circuitries of the 87CM53 input/output ports are shown below. | PORT | I/O | INPUT/OUTPUT CIRCUITRY | REMARKS | |----------|-----|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------| | P0<br>P6 | 1/0 | disable A R | Tri-state I/O $R = 1k\Omega \text{ (typ.)}$ | | P1 | I/O | initial "Hi-Z" | Tri-state I/O Hysteresis input $R = 1k\Omega \text{ (typ.)}$ | | P2 | I/O | P20, P23 initial "Hi-Z" VDD O R R | Sink open drain output Hysteresis input $R = 1k\Omega \text{ (typ.)}$ | | P3 | I/O | initial "Hi-Z" | Sink open drain output $High \ current \ output$ $R = 1k\Omega \ (typ.)$ | | P4<br>P5 | I/O | initial "Hi-Z" p-ch Control disable | Sink open drain or Tri-state I/O (Programable port option) Hysterisis input $R = 1k\Omega$ (typ.) | | P7<br>P9 | I/O | initial "Hi-Z" p-ch Control disable | Sink open drain or Tri-state I/O (Programable port option) $R = 1k\Omega \text{ (typ.)}$ | | P8 | I/O | initial "Hi-Z" P.U Control RIN disable | Tri-state I/O Programable Pull-up resistor $R_{IN} = 70k\Omega \ (typ.)$ $R = 1k\Omega \ (typ.)$ Hysterisis input | ## **Electrical Characteristics** Absolute Maximum Ratings $(V_{SS} = 0 V)$ | Parameter | Symbol | Pins | Ratings | Unit | | |---------------------------------|---------------------|------------------------------------------|--------------------------------|------|--| | Supply Voltage | VDD | | – 0.3 to 6.5 | ٧ | | | Input Voltage | $V_{IN}$ | | – 0.3 to V <sub>DD</sub> + 0.3 | V | | | Output Voltage | V <sub>OUT</sub> | | – 0.3 to V <sub>DD</sub> + 0.3 | V | | | 0.10.16.0001(0.01.1) | I <sub>OUT1</sub> | Ports P0, P1, P2, P4, P5, P6, P7, P8, P9 | 3.2 | | | | Output Current (Per 1pin) | I <sub>OUT2</sub> | Port P3 | 30 | mA | | | 0.10.16.00.17.1.1 | Σ I <sub>OUT1</sub> | Ports P0, P1, P2, P4, P5, P6, P7, P8, P9 | 160 | | | | Output Current (Total) | Σ I <sub>OUT2</sub> | Port P3 | 120 | mA | | | Power Dissipation [Topr = 70°C] | PD | | 350 | mW | | | Soldering Temperature (time) | Tsld | | 260 (10s) | °C | | | Storage Temperature | Tstg | | – 55 to 125 | °C | | | Operating Temperature | Topr | | – 30 to 60 | °C | | Note: The absolute maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded. **Recommended Operating Conditions** $(V_{SS} = 0 \text{ V}, \text{ Topr} = -30 \text{ to } 60^{\circ}\text{C})$ | Parameter | Symbol | Pins | C | Conditions | Min | Max | Unit | |--------------------|------------------|-------------------------|--------------------------------|------------------------|----------------------|----------------------|--------| | | | | f- 0 MII- | NORMAL1, 2 mode | 4.5 | | | | | | | fc = 8 MHz | IDLE1, 2 mode | 4.5 | | | | | | | NORMAL1, 2 mode | | | | | | Supply Voltage | $V_{DD}$ | | fc ≤ 4.2 MHz | IDLE1, 2 mode | 2.2 | 5.5 | V | | | | | fs = | SLOW mode | Note 2 | | | | | | | 32.768 kHz | SLEEP mode | | | | | | | | | STOP mode | 2.0 | | | | | V <sub>IH1</sub> | Except hysteresis input | V <sub>DD</sub> ≧ 4.5 V | | $V_{DD} \times 0.70$ | | \<br>\ | | Input High Voltage | V <sub>IH2</sub> | Hysteresis input | | | $V_{DD} \times 0.75$ | V <sub>DD</sub> | | | | V <sub>IH3</sub> | | V | V <sub>DD</sub> <4.5 V | | | | | | $V_{IL1}$ | Except hysteresis input | | V >4.5V | | $V_{DD} \times 0.30$ | | | Input Low Voltage | $V_{IL2}$ | Hysteresis input | v | <sub>DD</sub> ≧ 4.5 V | 0 | $V_{DD} \times 0.25$ | V | | | $V_{IL3}$ | | V | <sub>DD</sub> <4.5 V | | $V_{DD} \times 0.10$ | | | | fc | VIN VOLIT | V <sub>DD</sub> = 4.5 to 5.5 V | | 3.58 | 8.0 | MHz | | Clock Frequency | 10 | XIN, XOUT $V_{DD} =$ | | = 2.7 to 5.5 V | 3.30 | 4.19 | IVITZ | | | fs | XTIN, XTOUT | | | 30.0 | 34.0 | kHz | Note 1: The recommended operating conditions for a device are operating conditions under which it can be guaranteed that the device will operate as specified. If the device is used under operating conditions other than the recommended operating conditions (supply voltage, operating temperature range, specified AC/DC values etc.), malfunction may occur. Thus, when designing products which include this device, ensure that the recommended operating conditions for the device are always adhered to. Note 2: Clock frequency fc: The supply voltage range of the conditions shows the value in NORMAL1, 2 modes and IDLE 1,2 modes. Note 3: When the A/D converter is used, VDD must be set to $\geq 2.7 \text{ V}$ . D.C. Characteristics $(V_{SS} = 0 \text{ V}, \text{ Topr} = -30 \text{ to } 60^{\circ}\text{C})$ | Parameter | Symbol | Pins | Conditions | | Min | Тур. | Max | Unit | |--------------------------------|------------------|---------------------------------------------|----------------------------------------------------------------------|----------------|----------------|----------|------|--------| | Hysteresis Voltage | V <sub>HS</sub> | Hysteresis input | | | _ | 0.9 | _ | V | | | I <sub>IN1</sub> | TEST | V - F.F.V | | | | | | | Input Current | I <sub>IN2</sub> | Sink open drain port and tri-<br>state port | $V_{DD} = 5.5 V$ | | _ | _ | ± 2 | μΑ | | | I <sub>IN3</sub> | RESET, STOP | V <sub>IN</sub> = 5.5 V / 0 V | | | | | | | Input Resistance | R <sub>IN2</sub> | RESET | | | 100 | 220 | 450 | | | | R <sub>IN</sub> | P8 pull-up resistor | | | 30 | 70 | 150 | kΩ | | Output Leakage<br>Current | I <sub>LO</sub> | Sink open drain port and tri-<br>state port | V <sub>DD</sub> = 5.5 V, V <sub>OUT</sub> | = 5.5 V | _ | _ | 2 | μΑ | | Output High Voltage | V <sub>OH2</sub> | Tri-state port | V <sub>DD</sub> = 4.5 V, I <sub>OH</sub> = -0.7 mA | | 4.1 | _ | ı | V | | Output Low Voltage | V <sub>OL</sub> | Except XOUT and P3 | $V_{DD} = 4.5 \text{ V, } I_{OL} = 100 \text{ M}$ | 1.6 mA | _ | _ | 0.4 | V | | Output Low Current | I <sub>OL3</sub> | Port P3 | V <sub>DD</sub> = 4.5 V, V <sub>OL</sub> = | 1.0 V | _ | 20 | - | mA | | Supply Current in | | | $V_{DD} = 5.5 V$ | TONE no output | l <del>_</del> | 9 | 12 | | | NORMAL 1, 2 mode | 1 | | $V_{IN} = 5.3 \text{ V} / 0.2 \text{ V}$ | TONE output | L= | 10.5 | 13.5 | | | Supply Currnt in IDLE | | | fc = 8 MHz | TONE no output | ↓ <del>_</del> | 4.5 | 6.5 | 1 | | 1, 2 mode | I <sub>DD</sub> | | fs = 32.768 kHz | TONE output | - | 6.0 | 8.0 | mA | | Supply Currnt in | טטי | | $V_{DD} = 2.2 V$ | TONE no output | L <del>_</del> | 1.5 | 2.5 | , '''A | | NORMAL 1, 2 mode | 1 | | $V_{IN} = 2.2 \text{ V} / 0.2 \text{ V}$ | TONE output | L <del>-</del> | 2.0 | 3.0 | | | Supply Currnt in IDLE | | | fc = 4.2 MHz | TONE no output | <del>-</del> | 0.8 | 1.8 | - | | 1, 2 mode | | | fs = 32.768 kHz | TONE output | - | 1.3 | 2.3 | | | Supply Current in | | | $V_{DD} = 3.0 \text{ V}$ | | _ | 30 | 60 | μA | | SLOW mode | 4 | | $V_{IN} = 2.8 \text{ V} / 0.2 \text{ V}$ | | | 30 | 30 | μ, | | Supply Current in | I <sub>DD</sub> | | fs = 32.768 kHz | | _ | 15 | 30 | μA | | SLEEP mode | | | \/ F.F.\/ | | | <u> </u> | | μ | | Supply Current in STOP<br>mode | | | $V_{DD} = 5.5 \text{ V}$<br>$V_{IN} = 5.3 \text{ V} / 0.2 \text{ V}$ | | | 0.5 | 10 | μΑ | Note 1: Typical values show those at Topr = $25^{\circ}$ C, $V_{DD}$ = 5 V. Note 2: Input current: The current through pull-up or pull-down resistor is not included. A/D Conversion Characteristics $(V_{SS} = 0 \text{ V}, V_{DD} = 2.7 \text{ to } 5.5 \text{ V}, Topr = -30 \text{ to } 60^{\circ}\text{C})$ | Parameter | Symbol | Conditions | Min | Тур. | Max | Unit | |--------------------------|-------------------|---------------------------------------------------------------------------|------------------|------|-------------------|------| | | V <sub>AREF</sub> | | 2.7 | _ | $V_{DD}$ | | | Analog Reference Voltage | V <sub>ASS</sub> | $V_{AREF} - V_{ASS} \ge 2.5 \text{ V}$ | V <sub>SS</sub> | _ | 1.5 | \ \ | | Analog Input Voltage | V <sub>AIN</sub> | $V_{DD} = V_{AREF} = 5.0 \text{ V}$<br>$V_{SS} = V_{ASS} = 0.0 \text{ V}$ | V <sub>ASS</sub> | _ | V <sub>AREF</sub> | V | | Analog Supply Current | I <sub>REF</sub> | | _ | 0.5 | 1.0 | > | | Nonlinearity Error | | V <sub>DD</sub> = 2.7 to 5.5 V | _ | _ | ± 1 | | | Zero Point Error | | V <sub>SS</sub> = 0.0 V | _ | _ | ± 1 | mA | | Full Scale Error | | V <sub>AREF</sub> = 2.700 V, 5.000 V | _ | _ | ± 1 | | | Total Error | | V <sub>ASS</sub> = 0.000 V | _ | _ | ± 2 | LSB | $Note: Total\ Error\ =\ total\ number\ of\ each\ type\ error\ excluding\ guantization\ error.$ **Tone Output Characteristics** $(V_{SS} = 0 \text{ V}, V_{DD} = 2.2 \text{ to } 5.5 \text{ V}, Topr = -30 \text{ to } 60^{\circ}\text{C})$ | Parameter | Symbol Conditions | | Min | Тур. | Max | Unit | |------------------------------------|-------------------|-----------------------------------------------------------------------|-----|------|------|-------| | Tone Output Voltage (ROW) | V <sub>TONE</sub> | $RL \ge 10 \text{ k}\Omega$ , $V_{DD} = 2.2 \text{ V}$ | 126 | 150 | 178 | mVrms | | Pre-Emphasis High Band (COL / ROW) | PEHB | PEHB = 20 log (COL/ROW) | 1 | 2 | 3 | dB | | Output Distortion | DIS | | _ | _ | 5 | % | | | | fc = 3.84 MHz, 4.00 MHz, 8.00 MHz<br>(Except error of osc. frequency) | _ | _ | 0.7 | | | Frequency Stability | △f | fc = 3.58 MHz<br>(Except error of osc. frequency) | _ | _ | 0.66 | % | | | | fc = 4.19 MHz<br>(Except error of osc. frequency) | _ | _ | 0.93 | | A.C. Characteristics $(V_{SS} = 0 \text{ V}, \text{ Topr} = -40 \text{ to } 85^{\circ}\text{C})$ | Parameter | Symbol | Conditions | Min | Тур. | Max | Unit | |------------------------------|------------------|-------------------------------------------|-----------|------|----------|---------| | | | In NORMAL1, 2 mode (gear ratio) | 0 5 (1/1) | - | 8.9(1/8) | | | Mashina Cuala Tima | 44 | In IDLE1, 2 mode (gear ratio) | 0.5 (1/1) | | | | | Machine Cycle Time | tcy | In SLOW mode | 117.6 | | 133.3 | $\mu$ S | | | | In SLEEP mode | 117.6 | | 133.3 | | | High Level Clock Pulse Width | t <sub>WCH</sub> | For external clock operation (XIN input) | F0 | | | | | Low Level Clock Pulse Width | t <sub>WCL</sub> | fc = 8 MHz | 50 | _ | _ | ns | | High Level Clock Pulse Width | t <sub>WSH</sub> | For external clock operation (XTIN input) | 14.7 | | | _ | | Low Level Clock Pulse Width | t <sub>WSL</sub> | fs = 32.768 kHz | 14.7 | ı | _ | μS | ## **Recommended Oscillating Condition** | Parameter | Oscillator | Frequency | Recommen | Recommended Oscillator | | ed Condition | |----------------|---------------------------------------------|------------|----------------|------------------------|-------|--------------| | rarameter | Oscillator Prequency Recommended Oscillator | | C <sub>1</sub> | <b>C</b> <sub>2</sub> | | | | | | 8 MHz | KYOCERA | KBR8.0M | | | | | Ceramic Resonator | | KYOCERA | KBR4.0MS | 30 pF | 30 pF | | High-frequency | | 4 MHz | MURATA | CSA4.00MG | | | | | | 8 MHz | тоуосом | 210B 8.0000 | | | | | Crystal Oscillator | 4 MHz | точосом | 204B 4.0000 | 20 pF | 20 pF | | Low-frequency | Crystal Oscillator | 32.768 kHz | NDK | MX-38T | 15 pF | 15 pF | Note: When it is used in high electrical field, an electrical shield of the package is recommended to retain normal operations Note: To obtain an accurate oscillating frequency the condenser capacity must be adjusted on the set.