### **Description** The HD404629 Series is part of the HMCS400-Series microcomputers designed to increase program productivity and also incorporate largecapacity memory. Each microcomputer has a high precision dual-tone multifrequency (DTMF) generator, LCD controller/driver, A/D converter, input capture circuit, 32-kHz oscillator for clock, and four low-power dissipation modes. The HD404629 Series includes four chips: the HD404628 with 8-kword ROM; the HD4046212 with 12-kword ROM; the HD404629 with 16-kword ROM; the HD4074629 with 16-kword PROM. A program can be written to the PROM by a PROM writer, which can dramatically shorten system development periods and smooth the process from debugging to mass production. #### **Features** - 16,384-word × 10-bit ROM (the ZTAT™ version is 27256-compatible) - 1,876-digit × 4-bit RAM - 44 I/O pins, including 10 high-current pins (15 mA, max.) and 20 pins multiplexed with LCD segment pins - Four timer/counters - 8-bit input capture circuit - Three timer outputs (including two PWM outputs) - Two event counter inputs (including one doubleedge function) - · Clock-synchronous 8-bit serial interface - A/D converter (4 channels × 8 bits) - LCD controller/driver (52 segments × 4 commons) - · On-chip DTMF generator - · Built-in oscillators - Main clock: 4-MHz ceramic (an external clock is also possible) - Subclock: 32.768-kHz crystal - Eleven interrupt sources - Five by external sources, including three double-edge functions - Six by internal sources - Subroutine stack up to 16 levels, including interrupts - · Four low-power dissipation modes - Subactive mode - Standby mode - Watch mode - Stop mode - One external input for transition from stop mode to active mode - Instruction cycle time (min.): 1 μs (f<sub>OSC</sub> = 4 MHz) - · Operation voltage $V_{CC} = 2.7 \text{ V to } 6.0 \text{ V (HD404629)}$ $V_{CC} = 2.7 \text{ V to } 5.5 \text{ V (HD4074629)}$ - · Two operating modes - MCU mode - MCU/PROM mode (HD4074629 only) # **Ordering Information** | Туре | <b>Product Name</b> | Model Name | ROM (Words) | Package | |----------|---------------------|-------------------|-------------|------------------------------------| | Mask ROM | HD404628 | HD404628H | 8,192 | 100-pin plastic QFP<br>(FP-100B) | | | | HD404628FS | _ | 100-pin plastic QFP<br>(FP-100A) | | | | HD404628TF | _ | 100-pin plastic TQFP<br>(TFP-100B) | | | HD4046212 | HD4046212H | 12,288 | 100-pin plastic QFP<br>(FP-100B) | | | | HD4046212FS | <del></del> | 100-pin plastic QFP<br>(FP-100A) | | | | HD4046212TF | <del></del> | 100-pin plastic TQFP<br>(TFP-100B) | | | HD404629 | HD404629H | 16,384 | 100-pin plastic QFP<br>(FP-100B) | | | | HD404629FS | | 100-pin plastic QFP<br>(FP-100A) | | | | HD404629TF | _ | 100-pin plastic TQFP<br>(TFP-100B) | | ZTAT™ | HD4074629 | HD4074629H 16,384 | | 100-pin plastic QFP<br>(FP-100B) | | | | HD4074629FS | <del></del> | 100-pin plastic QFP<br>(FP-100A) | | | | HD4074629TF | _ | 100-pin plastic TQFP<br>(TFP-100B) | ### Pin Arrangement # Pin Arrangement # **Pin Description** | | | Pin N | umber | | | |------------------|-----------------------------------------------------------------------------|---------------------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Item | Symbol | FP-100B<br>TFP-100B | FP-100A | I/O | Function | | Power | V <sub>cc</sub> | 97 | 99 | | Applies power voltage | | supply | GND | 13 | 15 | | Connected to ground | | Test | TEST | 7 | 9 | I | Used for factory testing only: Connect this pin to V <sub>CC</sub> | | Reset | RESET | 10 | 12 | 1 | Resets the MCU | | Oscillator | OSC <sub>1</sub> | 8 | 10 | 1 | Input/output pins for the internal oscillator circuit: | | | OSC <sub>2</sub> | 9 | 11 | 0 | Connect them to a ceramic oscillator or connect OSC <sub>1</sub> to an external oscillator circuit | | | X1 | 11 | 13 | ı | Used for a 32.768-kHz crystal for clock purposes. | | | X2 | 12 | 14 | 0 | If not to be used, fix the X1 pin to V <sub>CC</sub> and leave the X2 pin open. | | Port | D <sub>0</sub> -D <sub>9</sub> | 14–23 | 16–25 | 1/0 | Input/output pins addressed by individual bits; pins D <sub>0</sub> –D <sub>9</sub> are high-current pins that can each supply up to 15 mA | | | D <sub>10</sub> , D <sub>11</sub> | 24, 25 | 26, 27 | 1 | Input pins addressable by individual bits | | | R0 <sub>0</sub> -R7 <sub>3</sub> | 26-57 | 28–59 | 1/0 | Input/output pins addressable in 4-bit units | | Interrupt | INT <sub>0</sub> , INT <sub>1</sub> ,<br>INT <sub>2</sub> -INT <sub>4</sub> | 25–29 | 27–31 | ı | Input pins for external interrupts | | Stop clear | STOPC | 24 | 26 | ı | Input pin for transition from stop mode to active mode | | Serial | SCK | 35 | 37 | 1/0 | Serial interface clock input/output pin | | interface | SI | 36 | 38 | 1 | Serial interface receive data input pin | | | so | 37 | 39 | 0 | Serial interface transmit data output pin | | Timer | TOB, TOC,<br>TOD | 30–32 | 32–34 | 0 | Timer output pins | | | EVNB, EVND | 33, 34 | 35, 36 | 1 | Event count input pins | | LCD | V <sub>1</sub> , V <sub>2</sub> , V <sub>3</sub> | 94–96 | 96-98 | | Power pins for LCD controller/driver; may be left open during operation since they are connected by internal voltage division resistors. Voltage conditions are: $V_{CC} \ge V_1 \ge V_2 \ge V_3 \ge GND$ | | | COM1-COM4 | 90-93 | 92-95 | 0 | Common signal pins for LCD | | | SEG1-SEG52 | 38-89 | 40-91 | 0 | Segment signal pins for LCD | | A/D<br>converter | AV <sub>CC</sub> | 1 | 3 | | Power pin for A/D converter: Connect it to the same potential as $V_{CC}$ , as physically close to the $V_{CC}$ pin as possible | | | AV <sub>SS</sub> | 6 | 8 | | Ground for AV <sub>CC</sub> : Connect it to the same potential as GND, as physically close to the GND pin as possible | | | AN <sub>0</sub> -AN <sub>3</sub> | 2–5 | 4–7 | ı | Analog input pins for A/D converter | | DTMF | TONER | 99 | 1 | 0 | Output pin for DTMF row signals | | | TONEC | 98 | 100 | 0 | Output pin for DTMF column signals | | | VT <sub>ref</sub> | 100 | 2 | | Reference voltage pin for DTMF signals. Voltage conditions are: $V_{CC} \ge VT_{ref} \ge GND$ | # **Block Diagram** # **Memory Map** #### **ROM Memory Map** The ROM memory map is shown in figure 1 and described below. Vector Address Area (\$0000-\$000F): Reserved for JMPL instructions that branch to the start addresses of the reset and interrupt routines. After MCU reset or an interrupt, program execution continues from the vector address. Zero-Page Subroutine Area (\$0000-\$003F): Reserved for subroutines. The program branches to a subroutine in this area in response to the CAL instruction. Pattern Area (\$0000-\$0FFF): Contains ROM data that can be referenced with the P instruction. Program Area (\$0000-\$1FFF: HD404628; \$0000-\$2FFF: HD4046212; \$0000-\$3FFF; HD404629, HD4074629): Used for program coding. Figure 1 ROM Memory Map #### **RAM Memory Map** The MCU contains a 1,876-digit × 4-bit RAM area consisting of a memory register area, an LCD data area, a data area, and a stack area. In addition, an interrupt control bits area, special register area, and register flag area are mapped onto the same RAM memory space as a RAM-mapped register area outside the above areas. The RAM memory map is shown in figure 2 and described below. #### RAM-Mapped Register Area (\$000-\$03F): - Interrupt Control Bits Area (\$000-\$003) This area is used for interrupt control bits (figure 3). These bits can be accessed only by RAM bit manipulation instructions (SEM/SEMD, REM/REMD, and TM/TMD). However, note that not all the instructions can be used for each bit. Limitations on using the instructions are shown in figure 4. - Special Function Register Area (\$004-\$01F, \$024-\$03F) This area is used as mode registers and data registers for external interrupts, serial interface, timer/counters, LCD, A/D converter, and as data control registers for I/O ports. The structure is shown in figures 2 and 5. These registers can be classified into three types: write-only (W), read-only (R), and read/write (R/W). The SEM, SEMD, REM, and REMD instructions can be used for the LCD control register (LCR: \$01B), but RAM bit manipulation instructions cannot be used for other registers. - Register Flag Area (\$020-\$023) This area is used for the DTON, WDON, and other register flags and interrupt control bits (fig- ure 3). These bits can be accessed only by RAM bit manipulation instructions (SEM/SEMD, REM/REMD, and TM/TMD). However, note that not all the instructions can be used for each bit. Limitations on using the instructions are shown in figure 4. Memory Register (MR) Area (\$040-\$04F): Consisting of 16 addresses, this area (MR0-MR15) can be accessed by register-register instructions (LAMR and XMRA). The structure is shown in figure 6. LCD Data Area (\$050-\$083): Used for storing 52-digit LCD data which is automatically output to LCD segments as display data. Data 1 lights the corresponding LCD segment; data 0 extinguishes it. Refer to the LCD description for details. Data Area (\$090-\$3BF): 464 digits from \$090 to \$25F have three banks, which can be selected by setting the bank register (V: \$03F). Before accessing this area, set the bank register to the required value (figure 7). The area from \$260 to \$3BF is accessed without setting the bank register. Stack Area (\$3C0-\$3FF): Used for saving the contents of the program counter (PC), status flag (ST), and carry flag (CA) at subroutine call (CAL or CALL instruction) and for interrupts. This area can be used as a 16-level nesting subroutine stack in which one level requires four digits. The data to be saved and the save conditions are shown in figure 6. The program counter is restored by either the RTN or RTNI instruction, but the status and carry flags can only be restored by the RTNI instruction. Any unused space in this area is used for data storage. Figure 2 RAM Memory Map | | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | | |--------|------------------------------------------|------------------------------------|---------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------|--|--|--| | 0 | IM <u>O</u><br>(IM of INT <sub>0</sub> ) | IFO<br>(IF of INT <sub>0</sub> ) | RSP<br>(Reset SP bit) | IE<br>(Interrupt<br>enable flag) | \$000 | | | | | 1 | IMTA<br>(IM of timer A) | IFTA<br>(IF of timer A) | IM1<br>(IM of INT <sub>1</sub> ) | IF1<br>(IF of INT <sub>1</sub> ) | \$001 | | | | | 2 | IMTC<br>(IM of timer C) | IFTC<br>(IF of timer C) | IMTB<br>(IM of timer B) | IFTB<br>(IF of timer B) | \$002 | | | | | 3 | IMAD<br>(IM of A/D) | IFAD<br>(IF of A/D) | IMTD<br>(IM of timer D) | IFTD<br>(IF of timer D) | \$003 | | | | | '<br>! | Interrupt control bits area | | | | | | | | | | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | | | 32 | DTON<br>(Direct transfer<br>on flag) | ADSF<br>(A/D start flag) | WDON<br>(Watchdog<br>on flag) | LSON<br>(Low speed<br>on flag) | \$020 | | | | | 33 | RAME<br>(RAM enable<br>flag) | Not used | ICEF<br>(Input capture<br>error flag) | ICSF<br>(Input capture<br>status flag) | \$021 | | | | | 34 | IM3<br>(IM of INT <sub>3</sub> ) | IF3<br>(IF of INT <sub>3</sub> ) | IM2<br>(IM of INT <sub>2</sub> ) | IF2<br>(IF of INT <sub>2</sub> ) | \$022 | | | | | 35 | IMS<br>(IM of serial<br>interface) | IFS<br>(IF of serial<br>interface) | IM4<br>(IM of INT <sub>4</sub> ) | IF4<br>(IF of INT <sub>4</sub> ) | \$023 IF: Interrupt request flag IM: Interrupt mask IE: Interrupt enable flag SP: Stack pointer | | | | | Į . | Register flag area | | | | | | | | Figure 3 Configuration of Interrupt Control Bits and Register Flag Areas | | SEM/SEMD | REM/REMD | TM/TMD | | |----------|-----------------------------|--------------|-----------|--| | ΙE | | | | | | IM | Allowed | Allowed | Allowed | | | LSON | | | | | | IF | | | | | | ICSF | ] Net assessed | A11 | Allowed | | | ICEF | Not executed | Allowed | | | | RAME | | | | | | RSP | Not executed | Allowed | Inhibited | | | WDON | Allowed | Not executed | Inhibited | | | ADSF | Allowed | Inhibited | Allowed | | | DTON | Not executed in active mode | Allowed | A II | | | DTON | Used in subactive mode | Allowed | Allowed | | | Not used | Not executed | Not executed | Inhibited | | Note: WDON is reset by MCU reset or by STOPC enable for stop mode cancellation. The REM or REMD instruction must not be executed for ADSF during A/D conversion. DTON is always reset in active mode. If the TM or TMD instruction is executed for the inhibited bits or non-existing bits, the value in ST becomes invalid. Figure 4 Usage Limitations of RAM Bit Manipulation Instructions | | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | |---------------------------|-----------------------------------|-----------------------------------------------------|-----------------------------------|-----------------------------------|--------|-----|------------------------------------------------------------------------| | \$000 | | | | | | | | | \$003 | | Interrupt conf | IOI OILS AFER | | | | | | PMRA \$004 | Not used | Not used | R2 <sub>2</sub> /SI | R2 <sub>3</sub> /SO | | | | | SMRA \$005 | R2 <sub>1</sub> /SCK | Serial transn | nit clock speed | selection 1 | | | | | SRL \$006 | | Serial data regis | | | | | | | SRU \$007 | | erial data regis | | | | | | | TMA \$008 | *1 | | urce selection ( | | | | | | TMB1 \$009 | *2 | | urce selection ( | ilmer B) | | | | | TRBL/TWBL \$00A | | Timer B registe | | | | | | | TRBU/TWBU \$00B | *3 | Timer B registe<br>R2 <sub>3</sub> /SO PMOS control | | notical coloction | | | | | MIS \$00C <br>TMCI \$00D | *2 | | urce selection ( | | | | | | TRCL/TWCL \$00E | | Timer C registe | | union O/ | | | | | TROU/TWOU \$00F | | Timer C registe | | | | | | | TMDI \$010 | *2 | | urce selection ( | timer D) | | | | | TRDL/TWDL \$011 | _ | Timer D registe | | | | | | | TRDU/TWDU \$012 | *** | Timer D registe | | | | | | | TMB2 \$013 | Not used | | Timer-B output | mode selection | | | | | TMC2 \$014 | Not used | | output mode s | | | | | | TMD2 \$015 | *4 | Timer-D | output mode s | election | | | | | AMR \$016 | Analog chan | nel selection | Not used | *5 | | | | | ADRL \$017 | | A/D data regist | er (lower digit) | | | | | | ADRU \$018 | | A/D data regist | | | | | | | \$019 | | out frequency | TONER outp | | | | | | \$01A | *6 | *7 | DTMF enable | Not used | | | | | LCR \$01B | Not used | *8 | *9 | *10 | | | | | LMR \$01C | | source selection | LCD duty cy | | | | | | LOR1 \$01D | R3 <sub>3</sub> /SEG4 | R3 <sub>2</sub> /SEG3 | R3 <sub>1</sub> /SEG2 | R3 <sub>0</sub> /SEG1 | | | | | LOR2 \$01E | R4 <sub>3</sub> /SEG8 | P4 <sub>2</sub> /SEG7 | R4 <sub>1</sub> /SEG6 | R4 <sub>0</sub> /SEG5 | | | | | LOR3 \$01F | Not used | R7/SEG17-20 | R6/SEG13-16 | R5/SEG9-12 | | | | | \$020 | | Register | tiao area | | | | | | \$023 | | r logisto. | nag aroa | | | | | | PMRB \$024 | R0 <sub>3</sub> /INT <sub>4</sub> | R02/INT3 | R0 <sub>1</sub> /INT <sub>2</sub> | RO <sub>0</sub> /INT <sub>1</sub> | | | | | PMRC \$025 | D <sub>11</sub> /INT <sub>0</sub> | D <sub>10</sub> /STOPC | R2/EVND | R1 <sub>3</sub> /EVNB | | | | | ESR1 \$026 | | edge selection | | edge selection | | | | | ESR2 \$027 | | n edge selection | INT <sub>4</sub> detection | edge selection | | | | | SMRB \$028 | Not used | Not used | *11 | *12 | | | | | SSR \$029 | *13 | *14 | Clock select | Not used | | | | | | | Not | used | | | | | | DCD0 \$02C | Port D <sub>3</sub> DCR | Port D <sub>2</sub> DCR | Port D <sub>1</sub> DCR | Port D <sub>0</sub> DCR | | | | | DCD1 \$02D | Port D <sub>7</sub> DCR | Port D <sub>6</sub> DCR | Port D <sub>5</sub> DCR | Port D <sub>4</sub> DCR | | | | | DCD2 \$02E | Not used | Not used | Port D <sub>9</sub> DCR | Port D <sub>8</sub> DCR | | | | | | | | used | | Notes. | 1. | Timer-A/time-base | | | | Port R0 <sub>2</sub> DCR | | | | 2. | Auto-reload on/off | | DCR1 \$031 | | Port R1 <sub>2</sub> DCR | | | | | Pull-up MOS control<br>Input capture selection | | DCR2 \$032 | | Port R2 <sub>2</sub> DCR | | | | | A/D conversion time | | DCR3 \$033 | | Port R3 <sub>2</sub> DCR | | | | 6. | TONEC output control | | DCR4 \$034 | | Port R4 <sub>2</sub> DCR | | | | | TONER output control Display on/off in watch mode | | DCR5 \$035 | | <del>,</del> | · · · · · · | Port R5 <sub>0</sub> DCR | | 9. | LCD power switch | | DCR6 \$036 | | Port R6 <sub>2</sub> DCR | | | | | LCD display on/off | | DCR7 \$037 | POR H7 <sub>3</sub> DCR | Port R7 <sub>2</sub> DCR | PORH/1DCH | POR H/ <sub>0</sub> DCH | | | SO output level control in idle states Transmit clock source selection | | | | Not | used | | | 13. | 32-kHz oscillation stop | | V \$03F | Not used | Not used | Rank 0 to be | nk 2 selection | , | 14. | 32-kHz oscillation division ratio | | ¥ \$03F | 110.0360 | 110.0000 | 1 | | | | | Figure 5 Special Function Register Area Figure 6 Configuration of Memory Registers and Stack Area, and Stack Position | 3it | 3 | 2 | 1 | 0 | | |--------------|----------|-------------------------------|-----------------|-----|---| | nitial value | - | - | 0 | 0 | 7 | | Read/Write | _ | <del>-</del> | R/W | R/W | _ | | Bit name | Not used | Not used | <b>V</b> 1 | VO | | | V1 | VO I | Bank area se | election | | | | | | | | | ] | | V1<br>0 | | Bank area se<br>Bank 0 is sel | | | | | | 0 1 | | lected | | | | | 0 1 | Bank 0 is se | ected<br>lected | | | Figure 7 Bank Register (V) guaranteed. ### **Functional Description** #### Registers and Flags The MCU has nine registers and two flags for CPU operations. They are shown in figure 8 and described below. Accumulator (A), B Register (B): Four-bit registers used to hold the results from the arithmetic logic unit (ALU) and transfer data between memory, I/O, and other registers. W Register (W), X Register (X), Y Register (Y): Two-bit (W) and four-bit (X and Y) registers used for indirect RAM addressing. The Y register is also used for D-port addressing. SPX Register (SPX), SPY Register (SPY): Fourbit registers used to supplement the X and Y registers. Carry Flag (CA): One-bit flag that stores any ALU overflow generated by an arithmetic operation. CA is affected by the SEC, REC, ROTL, and ROTR instructions. A carry is pushed onto the stack during an interrupt and popped from the stack by the RTNI instruction—but not by the RTN instruction. Figure 8 Registers and Flags Status Flag (ST): One-bit flag that latches any overflow generated by an arithmetic or compare instruction, not-zero decision from the ALU, or result of a bit test. ST is used as a branch condition of the BR, BRL, CAL, and CALL instructions. The contents of ST remain unchanged until the next arithmetic, compare, or bit test instruction is executed, but become 1 after the BR, BRL, CAL, or CALL instruction is read, regardless of whether the instruction is executed or skipped. The contents of ST are pushed onto the stack during an interrupt and popped from the stack by the RTNI instruction—but not by the RTN instruction. **Program Counter (PC):** 14-bit binary counter that points to the ROM address of the instruction being executed. Stack Pointer (SP): Ten-bit pointer that contains the address of the stack area to be used next. The SP is initialized to \$3FF by MCU reset. It is decremented by 4 when data is pushed onto the stack, and incremented by 4 when data is popped from the stack. The top four bits of the SP are fixed at 1111, so a stack can be used up to 16 levels. The SP can be initialized to \$3FF in another way: by resetting the RSP bit with the REM or REMD instruction. #### Reset The MCU is reset by inputting a high-level voltage to the RESET pin. At power-on or when stop mode is cancelled, RESET must be high for at least one $t_{RC}$ to enable the oscillator to stabilize. During operation, RESET must be high for at least two instruction cycles. Initial values after MCU reset are listed in table 1. #### Interrupts The MCU has 11 interrupt sources: five external signals ( $\overline{INT_0}$ , $\overline{INT_1}$ , $\overline{INT_2}$ – $\overline{INT_4}$ ), four timer/counters (timers A, B, C, and D), serial interface, and A/D converter. An interrupt request flag (IF), interrupt mask (IM), and vector address are provided for each interrupt source, and an interrupt enable flag (IE) controls the entire interrupt process. Some vector addresses are shared by two different interrupts. They are timer B and INT<sub>2</sub>, timer C and INT<sub>3</sub>, timer D and INT<sub>4</sub>, and A/D converter and serial interface interrupts. So the type of request that has occurred must be checked at the beginning of interrupt processing. Interrupt Control Bits and Interrupt Processing: Locations \$000 to \$003 and \$022 to \$023 in RAM are reserved for the interrupt control bits which can be accessed by RAM bit manipulation instructions. The interrupt request flag (IF) cannot be set by software. MCU reset initializes the interrupt enable flag (IE) and the IF to 0 and the interrupt mask (IM) to 1. A block diagram of the interrupt control circuit is shown in figure 9, interrupt priorities and vector addresses are listed in table 2, and interrupt processing conditions for the 11 interrupt sources are listed in table 3. An interrupt request occurs when the IF is set to 1 and the IM is set to 0. If the IE is 1 at that point, the interrupt is processed. A priority programmable logic array (PLA) generates the vector address assigned to that interrupt source. The interrupt processing sequence is shown in figure 10 and an interrupt processing flowchart is shown in figure 11. After an interrupt is acknowledged, the previous instruction is completed in the first cycle. The IE is reset in the second cycle, the carry, status, and program counter values are pushed onto the stack during the second and third cycles, and the program jumps to the vector address to execute the instruction in the third cycle. Program the JMPL instruction at each vector address, to branch the program to the start address of the interrupt program, and reset the IF by a software instruction within the interrupt program. Table 1 Initial Values After MCU Reset | Item | | Abbr. | Initial<br>Value | Contents | |---------------------|-----------------------------------|-----------------------------|------------------|------------------------------------------------------------------| | Program cou | inter | (PC) | \$0000 | Indicates program execution point from start address of ROM area | | Status flag | | (ST) | 1 | Enables conditional branching | | Stack pointe | r | (SP) | \$3FF | Stack level 0 | | Interrupt | Interrupt enable flag | (IE) | 0 | Inhibits all interrupts | | flags/mask | Interrupt request flag | (IF) | 0 | Indicates there is no interrupt request | | | Interrupt mask | (IM) | 1 | Prevents (masks) interrupt requests | | 1/0 | Port data register | (PDR) | All bits 1 | Enables output at level 1 | | | Data control register | (DCD0,<br>DCD1) | All bits 0 | Turns output buffer off (to high impedance) | | | | (DCD2) | 00 | _ | | | | (DCR0<br>-DCR7) | All bits 0 | _ | | | Port mode register A | (PMRA) | 00 | Refer to description of port mode register A | | | Port mode register B | (PMRB) | 0000 | Refer to description of port mode register B | | | Port mode register C bits 3, 1, 0 | (PMRC3,<br>PMRC1,<br>PMRC0) | 000 | Refer to description of port mode register C | | | Detection edge select register 1 | (ESR1) | 0000 | Disables edge detection | | | Detection edge select register 2 | (ESR2) | 0000 | Disables edge detection | | Timer/ | Timer mode register A | (TMA) | 0000 | Refer to description of timer mode register A | | counters, | Timer mode register B1 | (TMB1) | 0000 | Refer to description of timer mode register B1 | | serial<br>interface | Timer mode register B2 | (TMB2) | 00 | Refer to description of timer mode register B2 | | | Timer mode register C1 | (TMC1) | 0000 | Refer to description of timer mode register C1 | | | Timer mode register C2 | (TMC2) | - 000 | Refer to description of timer mode register C2 | | | Timer mode register D1 | (TMD1) | 0000 | Refer to description of timer mode register D1 | | | Timer mode register D2 | (TMD2) | 0000 | Refer to description of timer mode register D2 | | | Serial mode register A | (SMRA) | 0000 | Refer to description of serial mode register A | | | Serial mode register B | (SMRB) | 00 | Refer to description of serial mode register B | | | Prescaler S | (PSS) | \$000 | <del>-</del> | | | Prescaler W | (PSW) | \$00 | | | | Timer counter A | (TCA) | \$00 | | | | Timer counter B | (TCB) | \$00 | | | | Timer counter C | (TCC) | \$00 | | | | Timer counter D | (TCD) | \$00 | _ | | | Timer write register B | (TWBU,<br>TWBL) | \$X0 | _ | | | Timer write register C | (TWCU,<br>TWCL) | \$X0 | _ | | | Timer write register D | (TWDU,<br>TWDL) | \$X0 | - | | | Octal counter | (OC) | 000 | | | A/D | A/D mode register | (AMR) | 00 - 0 | Refer to description of A/D mode register | | | A/D data register | (ADRL,<br>ADRU) | \$80 | Refer to description of A/D data register | Table 1 Initial Values After MCU Reset (cont) | Item | | Abbr. | Initial<br>Value | Contents | |---------------|---------------------------------------|-----------------|------------------|-----------------------------------------------------------------------------------| | LCD | LCD control register | (LCR) | - 000 | Refer to description of LCD control register | | | LCD mode register | (LMR) | 0000 | Refer to description of LCD duty-cycle/clock control register | | | LCD output register 1 | (LOR1) | 0000 | Sets R-port/LCD segment pins to R port mode | | | LCD output register 2 | (LOR2) | 0000 | | | | LCD output register 3 | (LOR3) | - 000 | | | DTMF | Tone generator mode register | (TGM) | 0000 | Refer to description of tone generator mode register | | | Tone generator control register | (TGC) | 000 - | Refer to description of tone generator control register | | Bit registers | Low speed on flag | (LSON) | 0 | Refer to description of operating modes | | | Watchdog timer on flag | (WDON) | 0 | Refer to description of timer C | | | A/D start flag | (ADSF) | 0 | Refer to description of A/D converter | | | Direct transfer on flag | (DTON) | 0 | Refer to description of operating modes | | | Input capture status flag | (ICSF) | 0 | Refer to description of timer D | | | Input capture error flag | (ICEF) | 0 | Refer to description of timer D | | Others | Miscellaneous register | (MIS) | 0000 | Refer to description of operating modes, I/O, and serial interface | | | System clock select register bits 2–0 | (SSR2<br>-SSR0) | 000 | Refer to description of operating modes, oscillation circuits, and DTMF generator | | | Bank register | (V) | 00 | Refer to description of RAM memory map | Notes: 1. The statuses of other registers and flags after MCU reset are shown in the following table. 2. X indicates invalid value. - indicates that the bit does not exist. | Item | Abbr. | Status After Cancel-<br>lation of Stop Mode<br>by STOPC Input | Status After Cancel-<br>lation of Stop Mode<br>by RESET Input | Status After all Other<br>Types of Reset | | | |------------------------------------|--------------|---------------------------------------------------------------|---------------------------------------------------------------|--------------------------------------------------------|--|--| | Carry flag | (CA) | | s are not guaranteed; | Pre-MCU-reset values | | | | Accumulator | (A) | values must be initiali | zed by program | are not guaranteed; val-<br>ues must be initialized by | | | | B register | (B) | _ | | program | | | | W register | (W) | _ | | | | | | X/SPX register | (X/SPX) | _ | | | | | | Y/SPY register | (Y/SPY) | _ | | | | | | Serial data registe | r (SRL, SRU) | <del>-</del> | | | | | | RAM | | Pre-stop-mode values | are retained | | | | | RAM enable flag | (RAME) | 1 | 0 | 0 | | | | Port mode register 1 bit 2 | (PMRC12) | Pre-stop-mode values are retained | 0 | 0 | | | | System clock select register bit : | (SSR3) | <b></b> | | | | | Table 2 Vector Addresses and Interrupt Priorities | Reset/Interrupt | Priority | Vector Address | |---------------------------|----------|----------------| | RESET, STOPC* | | \$0000 | | INT <sub>0</sub> | 1 | \$0002 | | INT <sub>1</sub> | 2 | \$0004 | | Timer A | 3 | \$0006 | | Timer B, INT <sub>2</sub> | 4 | \$0008 | | Timer C, INT <sub>3</sub> | 5 | \$000A | | Timer D, INT <sub>4</sub> | 6 | \$000C | | A/D, Serial | 7 | \$000E | | | | | Note: \* The STOPC interrupt request is valid only in stop mode. Figure 9 Interrupt Control Circuit **Table 3 Interrupt Processing and Activation Conditions** | | Interrupt Source | | | | | | | | | |-----------------------------------|------------------|------------------|---------|-----------------------------|-----------------------------|-----------------------------|------------------|--|--| | Interrupt<br>Control Bit | INTo | ĪNT <sub>1</sub> | Timer A | Timer B or INT <sub>2</sub> | Timer C or INT <sub>3</sub> | Timer D or INT <sub>4</sub> | A/D or<br>Serial | | | | IE | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | IFO · IMO | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | | IF1 · IM1 | * | 1 | 0 | 0 | 0 | 0 | 0 | | | | IFTA · ĪMTĀ | * | * | 1 | 0 | 0 | 0 | 0 | | | | IFTB · IMTB<br>+ IF2 · IM2 | * | * | * | 1 | 0 | 0 | 0 | | | | IFTC · <u>IMTC</u><br>+ IF3 · IM3 | * | * | * | * | 1 | 0 | 0 | | | | IFTD · IMTD<br>+ IF4 · IM4 | * | * | * | * | * | 1 | 0 | | | | IFAD · IMAD<br>+ IFS · IMS | * | * | * | * | * | * | 1 | | | Note: Bits marked \* can be either 0 or 1. Their values have no effect on operation. Figure 10 Interrupt Processing Sequence Figure 11 Interrupt Processing Flowchart Interrupt Enable Flag (IE: \$000, Bit 0): Controls the entire interrupt process. It is reset by the interrupt processing and set by the RTNI instruction, as listed in table 4. External Interrupts ( $\overline{INT_0}$ , $\overline{INT_1}$ , $INT_2$ - $INT_4$ ): Five external interrupt signals. External Interrupt Request Flags (IF0-IF4: \$000, \$001, \$022, \$023): IF0 and IF1 are set at the falling edge of signals input to $\overline{INT_0}$ and $\overline{INT_1}$ , and IF2-IF4 are set at the rising or falling edge of signals input to INT2-INT4, as listed in table 5. The INT2-INT4 interrupt edges are selected by the detection edge select registers (ESR1, ESR2: \$026, \$027) as shown in figures 12 and 13. External Interrupt Masks (IM0-IM4: \$000, \$001, \$022, \$023): Prevent (mask) interrupt requests caused by the corresponding external interrupt request flags, as listed in table 6. Timer A Interrupt Request Flag (IFTA: \$001, Bit 2): Set by overflow output from timer A, as listed in table 7. Timer A Interrupt Mask (IMTA: \$001, Bit 3): Prevents (masks) an interrupt request caused by the timer A interrupt request flag, as listed in table 8. Timer B Interrupt Request Flag (IFTB: \$002, Bit 0): Set by overflow output from timer B, as listed in table 9. Timer B Interrupt Mask (IMTB: \$002, Bit 1): Prevents (masks) an interrupt request caused by the timer B interrupt request flag, as listed in table 10. Table 4 Interrupt Enable Flag (IE: \$000, Bit 0) | IE | Interrupt<br>Enabled/Disabled | |----|-------------------------------| | 0 | Disabled | | 1 | Enabled | Table 5 External Interrupt Request Flags (IF0–IF4: \$000, \$001, \$022, \$023) | IFO-IF4 | Interrupt Request | | |---------|-------------------|--| | 0 | No | | | 1 | Yes | | Table 6 External Interrupt Masks (IM0-IM4: \$000, \$001, \$022, \$023) | IMO-IM4 | Interrupt Request | | |---------|-------------------|--| | 0 | Enabled | | | 1 | Disabled (masked) | | Table 7 Timer A Interrupt Request Flag (IFTA: \$001, Bit 2) | IFTA | Interrupt Request | | |------|-------------------|--| | 0 | No | | | 1 | Yes | | Table 8 Timer A Interrupt Mask (IMTA: \$001, Bit 3) | IMTA | Interrupt Request | | |------|-------------------|--| | 0 | Enabled | | | 1 | Disabled (masked) | | Table 9 Timer B Interrupt Request Flag (IFTB: \$002, Bit 0) | IFTB | Interrupt Request | |------|-------------------| | 0 | No | | 1 | Yes | Table 10 Timer B Interrupt Mask (IMTB: \$002, Bit 1) | IMTB | Interrupt Request | | |------|-------------------|--| | 0 | Enabled | | | 1 | Disabled (masked) | | ### Detection edge selection register 1 (ESR1: \$026) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | ESR13 | ESR12 | ESR11 | ESR10 | | ESR13 | ESR12 | INT <sub>3</sub> detection edge | |-------|-------|---------------------------------| | 0 | 0 | No detection | | | 1 | Falling-edge detection | | 1 | 0 | Rising-edge detection | | | 1 | Double-edge detection* | | ESR11 | ESR10 | INT <sub>2</sub> detection edge | |-------|-------|---------------------------------| | 0 | 0 | No detection | | | 1 | Falling-edge detection | | 1 | 0 | Rising-edge detection | | | 1 | Double-edge detection* | Note: \* Both falling and rising edges are detected. Figure 12 Detection Edge Selection Register 1 (ESR1) # Detection edge selection register 2 (ESR2: \$027) Bit 3 2 0 Initial value 0 0 0 0 W W W Read/Write W Bit name ESR23 ESR22 ESR21 ESR<sub>20</sub> | ESR23 | ESR22 | EVND detection edge | | |-------|-------|------------------------|--| | 0 | 0 | No detection | | | | 1 | Falling-edge detection | | | 1 | 0 | Rising-edge detection | | | | 1 | Double-edge detection* | | | ESR21 | ESR20 | INT <sub>4</sub> detection edge | |-------|-------|---------------------------------| | 0 | o | No detection | | | 1 | Falling-edge detection | | 1 | 0 | Rising-edge detection | | | 1 | Double-edge detection* | Note: \* Both falling and rising edges are detected. Figure 13 Detection Edge Selection Register 2 (ESR2) Timer C Interrupt Request Flag (IFTC: \$002, Bit 2): Set by overflow output from timer C, as listed in table 11. Timer C Interrupt Mask (IMTC: \$002, Bit 3): Prevents (masks) an interrupt request caused by the timer C interrupt request flag, as listed in table 12. Timer D Interrupt Request Flag (IFTD: \$003, Bit 0): Set by overflow output from timer D, or by the rising or falling of signals input to EVND when the input capture function is used, as listed in table 13. Timer D Interrupt Mask (IMTD: \$003, Bit 1): Prevents (masks) an interrupt request caused by the timer D interrupt request flag, as listed in table 14. Serial Interrupt Request Flag (IFS: \$023, Bit 2): Set when data transfer is completed or when data transfer is suspended, as listed in table 15. Serial Interrupt Mask (IMS: \$023, Bit 3): Prevents (masks) an interrupt request caused by the serial interrupt request flag, as listed in table 16. A/D Interrupt Request Flag (IFAD: \$003, Bit 2): Set at the completion of A/D conversion, as listed in table 17. A/D Interrupt Mask (IMAD: \$003, Bit 3): Prevents (masks) an interrupt request caused by the A/D interrupt request flag, as listed in table 18. Table 11 Timer C Interrupt Request Flag (IFTC: \$002, Bit 2) | IFTC | Interrupt Request | | |------|-------------------|--| | 0 | No | | | 1 | Yes | | Table 15 Serial Interrupt Request Flag (IFS: \$023, Bit 2) | IFS | Interrupt Request | |-----|-------------------| | 0 | No | | 1 | Yes | Table 12 Timer C Interrupt Mask (IMTC: \$002, Bit 3) | IMTC | Interrupt Request | | |------|-------------------|--| | 0 | Enabled | | | 1 | Disabled (masked) | | Table 16 Serial Interrupt Mask (IMS: \$023, Bit 3) | IMS | Interrupt Request | |-----|-------------------| | 0 | Enabled | | 1 | Disabled (masked) | Table 13 Timer D Interrupt Request Flag (IFTD: \$003, Bit 0) | IFTD | Interrupt Request | | |------|-------------------|--| | 0 | No | | | 1 | Yes | | Table 17 A/D Interrupt Request Flag (IFAD: \$003, Bit 2) | IFAD | Interrupt Request | | |------|-------------------|--| | 0 | No | | | 1 | Yes | | Table 14 Timer D Interrupt Mask (IMTD: \$003, Bit 1) | IMTD | Interrupt Request | | |------|-------------------|--| | 0 | Enabled | | | 1 | Disabled (masked) | | Table 18 A/D Interrupt Mask (IMAD: \$003, Bit 3) | IMAD | Interrupt Request | | |------|-------------------|--| | 0 | Enabled | | | 1 | Disabled (masked) | | ## **Operating Modes** The MCU has five operating modes as shown in table 19. The operations in each mode are listed in tables 20 and 21. Transitions between operating modes are shown in figure 14. **Active Mode:** All MCU functions operate according to the clock generated by the system oscillator $OSC_1$ and $OSC_2$ . Table 19 Operating Modes and Clock Status | | | Mode Name | | | | | |----------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------| | | - | Active | Standby | Stop | Watch | Subactive*2 | | Activation<br>method | • | RESET cancellation, interrupt request, STOPC cancellation in stop mode, STOP/SBY instruction in subactive mode (when direct transfer is selected) | SBY<br>instruction | STOP<br>instruction<br>when<br>TMA3 = 0 | STOP<br>instruction<br>when<br>TMA3 = 1 | INT <sub>0</sub> or timer A interrupt request from watch mode | | Status | System oscillator | | | Stopped | Stopped | Stopped | | | Subsystem oscillator | ) | | *1 | | | | Cancella<br>method | tion | RESET input,<br>STOP/SBY<br>instruction | RESET input,<br>interrupt<br>request | RESET input,<br>STOPC input<br>in stop mode | RESET input,<br>INT <sub>0</sub> or timer A<br>interrupt<br>request | RESET input,<br>STOP/SBY<br>instruction | Notes: implies in operation. - Operating or stopping the oscillator can be selected by setting bit 3 of the system clock select register (SSR: \$029). - 2. Subactive mode is an optional function; specify it on the function option list. Table 20 Operations in Low-Power Dissipation Modes | Stop Mode | Watch Mode | Standby Mode | Subactive Mode*2 | |-----------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reset | Retained | Retained | | | Retained | Retained | Retained | | | Reset | | | | | Reset | Stopped | | | | Reset | Stopped | | | | Reset | Stopped | | | | Reset | Stopped*3 | | | | Reset | Stopped | | Stopped | | Reset | *4 | | элоррос | | Reset | Reset | Stopped | Reset | | Reset*1 | Retained | Retained | 110001 | | | Reset Retained Reset | Reset Retained Retained Retained Reset Reset Stopped Reset Stopped Reset Stopped Reset Stopped Reset Stopped Reset Stopped Reset Reset Reset | Reset Retained Retained Retained Retained Reset Reset Stopped | Notes: implies in operation. - 1. Output pins are at high impedance. - 2. Subactive mode is an optional function specified on the function option list. - 3. Transmission/Reception is activated if a clock is input in external clock mode. However, interrupts stop. - 4. When a 32-kHz clock source is used. Table 21 I/O Status in Low-Power Dissipation Modes | | Output | | Input | | |----------------------------------|--------------------------------------------|----------------|--------------------------------|--| | | Standby Mode,<br>Watch Mode | Stop Mode | Active Mode,<br>Subactive Mode | | | D <sub>0</sub> -D <sub>9</sub> | Retained | High impedance | Input enabled | | | D <sub>10</sub> -D <sub>11</sub> | | | Input enabled | | | R0-R7 | Retained or output of peripheral functions | High impedance | Input enabled | | Figure 14 MCU Status Transitions Standby Mode: In standby mode, the oscillators continue to operate, but the clocks related to instruction execution stop. Therefore, the CPU operation stops, but all RAM and register contents are retained, and the D or R port status, when set to output, is maintained. Peripheral functions such as interrupts, timers, and serial interface continue to operate. The power dissipation in this mode is lower than in active mode because the CPU stops. The MCU enters standby mode when the SBY instruction is executed in active mode. Standby mode is terminated by a RESET input or an interrupt request. If it is terminated by RESET input, the MCU is reset as well. After an interrupt request, the MCU enters active mode and executes the next instruction after the SBY instruction. If the interrupt enable flag is 1, the interrupt is then processed; if it is 0, the interrupt request is left pending and normal instruction execution continues. A flowchart of operation in standby mode is shown in figure 15. Figure 15 MCU Operation Flowchart Stop Mode: In stop mode, all MCU operations stop and RAM data is retained. Therefore, the power dissipation in this mode is the least of all modes. The OSC<sub>1</sub> and OSC<sub>2</sub> oscillator stops. For the X1 and X2 oscillator to operate or stop can be selected by setting bit 3 of the system clock select register (SSR: \$029; operating: SSR3 = 0, stop: SSR3 = 1) (figure 27). The MCU enters stop mode if the STOP instruction is executed in active mode when bit 3 of timer mode register A (TMA: \$008) is set to 0 (TMA3 = 0) (figure 44). Stop mode is terminated by a RESET input or a STOPC input as shown in figure 16. RESET or STOPC must be applied for at least one t<sub>RC</sub> to stabilize oscillation (refer to the AC Characteristics section). When the MCU restarts after stop mode is cancelled, all RAM contents before entering stop mode are retained, but the accuracy of the contents of the accumulator, B register, W register, X/SPX register, Y/SPY register, carry flag, and serial data register cannot be guaranteed. Watch Mode: In watch mode, the clock function (timer A) using the X1 and X2 oscillator and the LCD function operate, but other function operations stop. Therefore, the power dissipation in this mode is the second least to stop mode, and this mode is convenient when only clock display is used. In this mode, the OSC<sub>1</sub> and OSC<sub>2</sub> oscillator stops, but the X1 and X2 oscillator operates. The MCU enters watch mode if the STOP instruction is executed in active mode when TMA3 = 1, or if the STOP or SBY instruction is executed in subactive mode. Watch mode is terminated by a RESET input or a timer-A/ $\overline{INT_0}$ interrupt request. For details of RESET input, refer to the Stop Mode section. When terminated by a timer-A/ $\overline{INT_0}$ interrupt request, the MCU enters active mode if LSON = 0, or subactive mode if LSON = 1. After an interrupt request is generated, the time required to enter active mode is $t_{RC}$ for a timer A interrupt, and $T_X$ (where $T + t_{RC} < T_X < 2T + t_{RC}$ ) for an $\overline{INT_0}$ interrupt, as shown in figures 17 and 18. Operation during mode transition is the same as that at standby mode cancellation (figure 15). Figure 16 Timing of Stop Mode Cancellation Subactive Mode: The OSC<sub>1</sub> and OSC<sub>2</sub> oscillator stops and the MCU operates with a clock generated by the X1 and X2 oscillator. In this mode, functions except the A/D conversion operate. However, because the operating clock is slow, the power dissipation becomes low, next to watch mode. The CPU instruction execution speed can be selected as 244 µs or 122 µs by setting bit 2 (SSR2) of the system clock select register (SSR: \$029). Note that the SSR2 value must be changed in active mode. If the value is changed in subactive mode, the MCU may malfunction. When the STOP or SBY instruction is executed in subactive mode, the MCU enters either watch or active mode, depending on the statuses of the low speed on flag (LSON: \$020, bit 0) and the direct transfer on flag (DTON: \$020, bit 3). Subactive mode is an optional function that the user must specify on the function option list. Interrupt Frame: In watch and subactive modes, $\phi_{CLK}$ is applied to timer A and the $\overline{INT_0}$ circuit. Prescaler W and timer A operate as the time-base and generate the timing clock for the interrupt frame. Three interrupt frame lengths (T) can be selected by setting the miscellaneous register (MIS: \$00C) (figure 18). In watch and subactive modes, the timer-A/ $\overline{\text{INT}_0}$ interrupt is generated synchronously with the interrupt frame. The interrupt request is generated synchronously with the interrupt strobe timing except during transition to active mode. The falling edge of the $\overline{\text{INT}_0}$ signal is input asynchronously with the interrupt frame timing, but it is regarded as input synchronously with the second interrupt strobe clock after the falling edge. An overflow and interrupt request in timer A is generated synchronously with the interrupt strobe timing. Figure 17 Interrupt Frame Direct Transition from Subactive Mode to Active Mode: Available by controlling the direct transfer on flag (DTON: \$020, bit 3) and the low speed on flag (LSON: \$020, bit 0). The procedures are described below: - Set LSON to 0 and DTON to 1 in subactive mode. - · Execute the STOP or SBY instruction. - The MCU automatically enters active mode from subactive mode after waiting for the MCU internal processing time and oscillation stabilization time (figure 19). - Notes: 1. The DTON flag can be set only in subactive mode. It is always reset in active mode. - The transition time (T<sub>D</sub>) from subactive mode to active mode: $$t_{RC} < T_D < T + t_{RC}$$ | Miscellaneous register (MIS: \$00C) | | | | | |-------------------------------------|------|------|------|------| | Bit | 3 | 2 | 1 | 0 | | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | MIS3 | MIS2 | MIS1 | MIS0 | | MIS3 | MIS2 | |-----------|------------| | Buffer co | ntrol. | | Refer to | figure 41. | | MIS1 | MIS0 | T*1 | t <sub>RC</sub> *1 | Oscillation circuit conditions | |------|------|------------|--------------------|--------------------------------| | 0 0 | | 0.24414 ms | 0.12207 ms | External clock input | | | | | 0.24414 ms*2 | | | 0 | 1 | 15.625 ms | 7.8125 ms | Ceramic oscillator | | 1 | 0 | 62.5 ms | 31.25 ms | | | 1 | 1 | Not used | | | Notes: 1. The values of T and t<sub>RC</sub> are applied when a 32.768-kHz crystal oscillator is used. 2. The value is applied only when direct transfer operation is used. Figure 18 Miscellaneous Register (MIS) Figure 19 Direct Transition Timing Stop Mode Cancellation by STOPC: The MCU enters active mode from stop mode by inputting STOPC as well as by RESET. In either case, the MCU starts instruction execution from the starting address (address 0) of the program. However, the value of the RAM enable flag (RAME: \$021, bit 3) differs between cancellation by STOPC and by RESET. When stop mode is cancelled by RESET. RAME = 0; when cancelled by $\overline{STOPC}$ , RAME = 1. RESET can cancel all modes, but STOPC is valid only in stop mode; STOPC input is ignored in other modes. Therefore, when the program requires to confirm that stop mode has been cancelled by STOPC (for example, when the RAM contents before entering stop mode is used after transition to active mode), execute the TEST instruction to the RAM enable flag (RAME) at the beginning of the program. MCU Operation Sequence: The MCU operates in the sequence shown in figures 20 to 22. It is reset by an asynchronous RESET input, regardless of its status. The low-power mode operation sequence is shown in figure 22. With the IE flag cleared and an interrupt flag set together with its interrupt mask cleared, if a STOP/SBY instruction is executed, the instruction is cancelled (regarded as an NOP) and the following instruction is executed. Before executing a STOP/SBY instruction, make sure all interrupt flags are cleared or all interrupts are masked. Figure 20 MCU Operating Sequence (Power On) Figure 21 MCU Operating Sequence (MCU Operation Cycle) Figure 22 MCU Operating Sequence (Low-Power Mode Operation) Notes: 1. LCD display off in watch or subactive mode. If the HD404629/HD4074629 is to be used with the LCD display off in watch mode or subactive mode, execute the following operations before the MCU enters watch mode (i.e., before the STOP instruction is executed). First: LOAD \$0 to LCR Second: LOAD \$3 to LMR When the MCU enters active mode again from watch or subactive mode, execute the following operations. First: LOAD appropriate value to LMR for active mode Second: LOAD appropriate value to LCR for active mode These operations are shown in figure 23. Figure 23 Programming Flowchart (LCD Display Off in Watch or Subactive Mode) Notes: 2. When the MCU is in watch mode or subactive mode, if the high level period before the falling edge of $\overline{INT_0}$ is shorter than the interrupt frame, $\overline{INT_0}$ is not detected. Also, if the low level period after the falling edge of $\overline{INT_0}$ is shorter than the interrupt frame, $\overline{INT_0}$ is not detected. Edge detection is shown in figure 24. The level of the $\overline{INT_0}$ signal is sampled by a sampling clock. When this sampled value changes to low from high, a falling edge is detected. In figure 25, the level of the $\overline{\text{INT}_0}$ signal is sampled by an interrupt frame. In (a) the sampled value is low at point A, and also low at point B. Therefore, a falling edge is not detected. In (b), the sampled value is high at point A, and also high at point B. A falling edge is not detected in this case either. When the MCU is in watch mode or subactive mode, keep the high level and low level period of $\overline{INT_0}$ longer than interrupt frame. Figure 24 Edge Detection Figure 25 Sampling Example #### **Internal Oscillator Circuit** A block diagram of the clock generation circuit is shown in figure 26. As shown in table 22, a ceramic oscillator can be connected to $OSC_1$ and $OSC_2$ , and a 32.768-kHz oscillator can be connected to X1 and X2. The system oscillator can also be operated by an external clock. Bit 1 (SSR1) of the system clock select register (SSR: \$029) must be set according to the frequency of the oscillator connected to $OSC_1$ and $OSC_2$ (figure 27). Note: If the system clock select register (SSR: \$029) setting does not match the oscillator frequency, DTMF generator and subsystems using the 32.768-kHz oscillation will malfunction. Figure 26 Clock Generation Circuit | System clock select register (SSR: \$029) | | | | | |-------------------------------------------|------|------|------|------| | Bit | 3 | 2 | 1 | 0 | | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | SSR3 | SSR2 | SSR1 | SSR0 | | SSR3 32-kHz oscillation stop | | |------------------------------|-----------------------------------| | 0 | Oscillation operates in stop mode | | 1 | Oscillation stops in stop mode | | SSR2 | 32-kHz oscillation division ratio selection | | |------|---------------------------------------------|--| | 0 | f <sub>SUB</sub> = f <sub>X</sub> /8 | | | 11 | f <sub>SUB</sub> = f <sub>X</sub> /4 | | | SSR1 | SSR0 | System clock selection | |------|------|------------------------| | 0 | 0 | 400 kHz | | 0 | 1 | 800 kHz | | 1 | 0 | 2 MHz | | 1 | 1 | 4 MHz | Note: SSR3 is cleared only by a RESET input. SSR3 will not be cleared by a STOPC input during stop mode, and will retain its value. SSR3 will also not be cleared upon entering stop mode. Figure 27 System Clock Select Register (SSR) Figure 28 Typical Layouts of Crystal and Ceramic Oscillator #### **Table 22 Oscillator Circuit Examples** #### **Circuit Configuration Circuit Constants** External clock operation External osc, oscillator OSC, Ореп Ceramic oscillator: CSB400P22 (Murata) Ceramic oscillator CSB400P (Murata) (OSC<sub>1</sub>, OSC<sub>2</sub>) $R_f = 1 M\Omega \pm 20\%$ $C_1 = C_2 = 220 \text{ pF} \pm 5\%$ C, Ceramic oscillator: CSB800J122 OSC<sub>1</sub> (Murata), CSB800J (Murata) Ceramic $R_f = 1 M\Omega \pm 20\%$ oscillator 무 R.3 $C_1 = C_2 = 220 \text{ pF} \pm 5\%$ OSC<sub>2</sub> Ceramic oscillator: CSA2.00MG (Murata) $C_2$ 777 $R_f = 1 M\Omega \pm 20\%$ **GND** $C_1 = C_2 = 30 \text{ pF} \pm 20\%$ Ceramic oscillator: CSA4.00MG (Murata) $R_i = 1 M\Omega \pm 20\%$ $C_1 = C_2 = 30 \text{ pF} \pm 20\%$ Crystal oscillator: 32.768 kHz: MX38T Crystal oscillator (Nippon Denpa) C<sub>1</sub> (X1, X2) $C_1 = C_2 = 20 \text{ pF} \pm 20\%$ **X1** $R_S$ : 14 k $\Omega$ Crystal Co: 1.5 pF oscillator **X2** $C_2$ GND Cs Rs Co - Notes: 1. Circuit constants differ by the different types of crystal oscillators, ceramic oscillators, and with the stray capacitance of the board, so consult the manufacturer of the oscillator to determine the circuit parameters. - 2. The wiring between the OSC<sub>1</sub>, OSC<sub>2</sub> (X1 and X2 pins), and the other elements should be as short as possible, and must not cross other wiring. Refer to figure 28. - 3. If not using a 32.768-kHz crystal oscillator, fix the X1 pin to $V_{CC}$ and leave the X2 pin open. # Input/Output The MCU has 42 input/output pins $(D_0-D_9, R0_0-R7_3)$ and 2 input pins $(D_{10}, D_{11})$ . The features are described below. - Ten pins (D<sub>0</sub>-D<sub>9</sub>) are high-current input/output pins. - The D<sub>10</sub> and D<sub>11</sub>, and R0<sub>0</sub>—R7<sub>3</sub> input/output pins are multiplexed with peripheral function pins such as for the timers or serial interface. For these pins, the peripheral function setting is done prior to the D or R port setting. Therefore, when a peripheral function is selected for a pin, the pin function and input/output selection are automatically switched according to the setting. - · Input or output selection for input/output pins - and port or peripheral function selection for multiplexed pins are set by software. - Peripheral function output pins are CMOS output pins. Only the R2<sub>3</sub>/SO pin can be set to NMOS open-drain output by software. - In stop mode, the MCU is reset, and therefore peripheral function selection is cancelled. Input/output pins are in high-impedance state. - Each input/output pin has a built-in pull-up MOS, which can be individually turned on or off by software. I/O buffer configuration is shown in figure 29, programmable I/O circuits are listed in table 23, and I/O pin circuit types are shown in table 24. Table 23 Programmable I/O Circuits | MIS3 (bit 3 of MIS) | | 0 | | | 1 | | | | | |---------------------|------|---|---|----|----|---|----|----|----| | DCD, DCR | | 0 | | | 1 | | 0 | | 1 | | PDR | | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | CMOS buffer | PMOS | | _ | | On | _ | _ | _ | On | | | NMOS | _ | | On | _ | _ | _ | On | | | Pull-up MOS | | _ | _ | _ | | _ | On | | On | Note: - indicates off status. Figure 29 I/O Buffer Configuration Table 24 Circuit Configurations of I/O Pins Table 24 Circuit Configurations of I/O Pins (cont) Notes: 1. The MCU is reset in stop mode, and peripheral function selection is cancelled. The HLT signal becomes low, and input/output pins enter high-impedance state. 2. The HLT signal is 1 in watch and subactive modes. **D Port** ( $D_0$ – $D_{11}$ ): Consist of 10 input/output pins and 2 input pins addressed by one bit. $D_0$ – $D_9$ are high-current I/O pins, and $D_{10}$ and $D_{11}$ are input-only pins. Pins $D_0$ - $D_9$ are set by the SED and SEDD instructions, and reset by the RED and REDD instructions. Output data is stored in the port data register (PDR) for each pin. All pins $D_0$ - $D_{11}$ are tested by the TD and TDD instructions. The on/off statuses of the output buffers are controlled by D-port data control registers (DCD0-DCD2: \$02C-\$02E) that are mapped to memory addresses (figure 30). Pins $D_{10}$ and $D_{11}$ are multiplexed with peripheral function pins $\overline{STOPC}$ and $\overline{INT_0}$ , respectively. The peripheral function modes of these pins are selected by bits 2 and 3 (PMRC2, PMRC3) of port mode register C (PMRC: \$025) (figure 31). R Ports (R00-R73): 32 input/output pins addressed in 4-bit units. Data is input to these ports by the LAR and LBR instructions, and output from them by the LRA and LRB instructions. Output data is stored in the port data register (PDR) for each pin. The on/off statuses of the output buffers of the R ports are controlled by R-port data control registers (DCR0-DCR7: \$030-\$037) that are mapped to memory addresses (figure 30). Pins R0<sub>0</sub>-R0<sub>3</sub> are multiplexed with peripheral pins INT<sub>1</sub>-INT<sub>4</sub>, respectively. The peripheral function modes of these pins are selected by bits 0-3 (PMRB0-PMRB3) of port mode register B (PMRB: \$024) (figure 32). Pins R1<sub>0</sub>-R1<sub>2</sub> are multiplexed with peripheral pins TOB, TOC, and TOD, respectively. The peripheral function modes of these pins are selected by bits 0 and 1 (TMB20, TMB21) of timer mode register B2 (TMB2: \$013), bits 0-2 (TMC20-TMC22) of timer mode register C2 (TMC2: \$014), and bits 0-3 (TMD20-TMD23) of timer mode register D2 (TMD2: \$015) (figures 33, 34, and 35). Pins R13 and R20 are multiplexed with peripheral pins EVNB and EVND, respectively. The peripheral function modes of these pins are selected by bits 0 and 1 (PMRC0, PMRC1) of port mode register C (PMRC: \$025) (figure 31). Pins R2<sub>1</sub>-R2<sub>3</sub> are multiplexed with peripheral pins SCK, SI, and SO, respectively. The peripheral function modes of these pins are selected by bit 3 (SMRA3) of serial mode register A (SMRA: \$005), and bits 0 and 1 (PMRA0, PMRA1) of port mode register A (PMRA: \$004), as shown in figures 36 and 37. Ports R3 and R4 are multiplexed with segment pins SEG1-SEG8, respectively. The function modes of these pins can be selected by individual pins, by setting LCD output registers 1 and 2 (LOR1, LOR2: \$01D, \$01F) (figures 38 and 39). Ports R5-R7 are multiplexed with segment pins SEG9-SEG20, respectively. The function modes of these pins can be selected in 4-pin units by setting LCD output register 3 (LOR3: \$01F) (figure 40). Pull-Up MOS Transistor Control: A programcontrolled pull-up MOS transistor is provided for each input/output pin other than input-only pins $D_{10}$ and $D_{11}$ . The on/off status of all these transistors is controlled by bit 3 (MIS3) of the miscellaneous register (MIS: \$00C), and the on/off status of an individual transistor can also be controlled by the port data register (PDR) of the corresponding pin—enabling on/off control of that pin alone (table 23 and figure 41). The on/off status of each transistor and the peripheral function mode of each pin can be set independently. How to Deal with Unused I/O Pins: I/O pins that are not needed by the user system (floating) must be connected to $V_{CC}$ to prevent LSI malfunctions due to noise. These pins must either be pulled up to $V_{CC}$ by their pull-up MOS transistors or by resistors of about 100 k $\Omega$ . | | Data control | register | (DCD0 to | 2: \$02C :<br>7: \$030 t | to \$02E)<br>to \$037) | | |-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------|--------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | | DCD0, DCD1 | | | | • | | | | Bit | 3 | 2 | 1 1 | 0 | | | | Initial value | 0 | 0 | 0 | 0 | | | | Read/Write | W | W | w | w | J | | | Bit name | DCD03,<br>DCD13 | DCD02,<br>DCD12 | DCD01,<br>DCD11 | DCD00,<br>DCD10 | | | | DCD2 | | | | | | | | Bit | 3 | 2 | 1 | 0 | 1 | | | Initial value | | | 0 | 0 | | | | Read/Write | | _ | W | W | • | | | Bit name | Not used | Not used | DCD21 | DCD20 | | | | DCR0 to DCR | 7 | | | | | | | Bit | 3 | 2 | 1 | 0 | | | | Initial value | 0 | 0 | 0 | 0 | | | | Read/Write | W | W | W | W | l e e e e e e e e e e e e e e e e e e e | | | Bit name | DCR03-<br>DCR73 | DCR02-<br>DCR72 | DCR01-<br>DCR71 | DCR00-<br>DCR70 | | | | | | | | | | | | All Rite | CMOS | Buffer On | iO# Salaa | tion | | | | All Bits | | Buffer On | | tion | | | | 0 | Off (hig | Buffer On | | tion | | | | | | | | tion | | | Correspondence | 0 | Off (hig | h-impedan | | tion | | | Correspondence | 0<br>1<br>e between ports a | Off (hig | h-impedan | ce) | | | | Register Name | 0<br>1<br>between ports a | Off (hig<br>On | h-impedan DCR bits Bit 2 | ce) | Bit 1 | Bit 0 | | Register Name | 0<br>1<br>e between ports a<br>Bit 3 | Off (hig<br>On | DCR bits Bit 2 D2 | ce) | | <b>Bit 0</b><br>D <sub>0</sub> | | Register Name | 0<br>1<br>between ports a | Off (hig<br>On | h-impedan DCR bits Bit 2 | ce) | Bit 1 | | | Register Name | 0<br>1<br>e between ports a<br>Bit 3 | Off (hig<br>On | DCR bits Bit 2 D2 | ce) | Bit 1 | D <sub>o</sub> | | DCD0 DCD1 | 0<br>1<br>e between ports a<br>Bit 3 | Off (hig<br>On | DCR bits Bit 2 D2 | (e) | Bit 1<br>D <sub>1</sub> | D <sub>0</sub> | | DCD0 DCD1 DCD2 | 0 1 between ports a Bit 3 D3 D7 — | Off (hig<br>On | DCR bits Bit 2 D2 D6 | (e) | Bit 1 D1 D5 D9 | D <sub>0</sub> D <sub>4</sub> D <sub>8</sub> | | DCD0 DCD1 DCD2 DCR0 | Do between ports a Bit 3 D3 D7 | Off (hig<br>On | DCR bits Bit 2 D2 D6 R02 | (e) | Bit 1 D <sub>1</sub> D <sub>5</sub> D <sub>9</sub> RO <sub>1</sub> | D <sub>0</sub> D <sub>4</sub> D <sub>8</sub> R0 <sub>0</sub> | | Pegister Name DCD0 DCD1 DCD2 DCR0 DCR1 | 0<br>1<br>e between ports a<br>Bit 3<br>D <sub>3</sub><br>D <sub>7</sub><br>—<br>R0 <sub>3</sub><br>R1 <sub>3</sub> | Off (hig<br>On | DCR bits Bit 2 D2 D6 R02 R12 | (e) | Bit 1 D1 D5 D9 R01 R11 | D <sub>0</sub> D <sub>4</sub> D <sub>8</sub> R0 <sub>0</sub> R1 <sub>0</sub> | | DCD0 DCD1 DCD2 DCR0 DCR1 DCR2 | 0<br>1<br>8 between ports a<br>Bit 3<br>D <sub>3</sub><br>D <sub>7</sub><br>—<br>R0 <sub>3</sub><br>R1 <sub>3</sub> | Off (hig<br>On | DCR bits Bit 2 D2 D6 R02 R12 R22 | (e) | Bit 1 D1 D5 D9 R01 R11 R21 | D <sub>0</sub> D <sub>4</sub> D <sub>8</sub> R0 <sub>0</sub> R1 <sub>0</sub> R2 <sub>0</sub> | | DCD0 DCD1 DCD2 DCR0 DCR1 DCR2 DCR3 | 0<br>1<br>between parts a<br>Bit 3<br>D <sub>3</sub><br>D <sub>7</sub><br>—<br>R0 <sub>3</sub><br>R1 <sub>3</sub><br>R2 <sub>3</sub> | Off (hig<br>On | DCR bits Bit 2 D2 D6 R02 R12 R22 R32 R42 | (e) | Bit 1 D1 D5 D9 R01 R11 R21 R31 R41 | D <sub>0</sub> D <sub>4</sub> D <sub>8</sub> R0 <sub>0</sub> R1 <sub>0</sub> R2 <sub>0</sub> R3 <sub>0</sub> R4 <sub>0</sub> | | Pegister Name DCD0 DCD1 DCD2 DCR0 DCR1 DCR2 DCR3 DCR4 | 0<br>1<br>8 between ports a<br>Bit 3<br>D <sub>3</sub><br>D <sub>7</sub><br>—<br>R0 <sub>3</sub><br>R1 <sub>3</sub><br>R2 <sub>3</sub><br>R3 <sub>3</sub><br>R4 <sub>3</sub> | Off (hig<br>On | DCR bits Bit 2 D2 D6 R02 R12 R22 | (e) | Bit 1 D <sub>1</sub> D <sub>5</sub> D <sub>9</sub> RO <sub>1</sub> R1 <sub>1</sub> R2 <sub>1</sub> | D <sub>0</sub> D <sub>4</sub> D <sub>8</sub> R0 <sub>0</sub> R1 <sub>0</sub> R2 <sub>0</sub> | Figure 30 Data Control Registers (DCD, DCR) ## Port mode register C (PMRC: \$025) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|--------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | PMRC3 | PMRC2* | PMRC1 | PMRC0 | | PMRC3 | D <sub>11</sub> /INT <sub>0</sub> mode selection | |-------|--------------------------------------------------| | 0 | D <sub>11</sub> | | 1 | INT <sub>0</sub> | | PMRC0 | R1 <sub>3</sub> /EVNB mode selection | |-------|--------------------------------------| | 0 | R13 | | 1 | EVNB | | PMRC2 | D <sub>10</sub> /STOPC mode selection | |-------|---------------------------------------| | 0 | D <sub>10</sub> | | 1 | STOPC | | PMRC1 | R2 <sub>0</sub> /EVND mode selection | |-------|--------------------------------------| | 0 | R2 <sub>0</sub> | | 1 | EVND | Note: \* PMRC2 is reset to 0 only by RESET input. When STOPC is input in stop mode, PMRC2 is not reset but retains its value. Figure 31 Port Mode Register C (PMRC) ## Port mode register B (PMRB: \$024) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | PMRB3 | PMRB2 | PMRB1 | PMRB0 | | PMRB3 | R0 <sub>3</sub> /INT <sub>4</sub> mode selection | |-------|--------------------------------------------------| | 0 | R0 <sub>3</sub> | | 1 | INT <sub>4</sub> | | PMRB2 | R0 <sub>2</sub> /INT <sub>3</sub> mode selection | |-------|--------------------------------------------------| | 0 | R0 <sub>2</sub> | | 1 | INT <sub>3</sub> | | PMRB0 | R0 <sub>0</sub> /INT <sub>1</sub> mode selection | |-------|--------------------------------------------------| | 0 | R0 <sub>0</sub> | | 1 | INT <sub>1</sub> | | PMRB1 | R0 <sub>1</sub> /INT <sub>2</sub> mode selection | |-------|--------------------------------------------------| | 0 | R0 <sub>1</sub> | | 1 | INT <sub>2</sub> | Figure 32 Port Mode Register B (PMRB) # Timer mode register B2 (TMB2: \$013) | Bit | 3 | 2 | 1 | 0 | |---------------|------------|----------|-------|-------| | Initial value | <b> </b> - | _ | 0 | 0 | | Read/Write | | | R/W | R/W | | Bit name | Not used | Not used | TMB21 | TMB20 | | TMB21 | TMB20 | R1 <sub>0</sub> /TC | OB mode selection | |-------|-------|---------------------|----------------------| | 0 | 0 | R1 <sub>0</sub> | R1 <sub>0</sub> port | | | 1 | ТОВ | Toggle output | | 1 | 0 | тов | 0 output | | | 1 | ТОВ | 1 output | Figure 33 Timer Mode Register B2 (TMB2) # Timer mode register C2 (TMC2: \$014) | Bit | 3 | 2 | 1 | 0 | | |---------------|----------|-------|-------|-------|--| | Initial value | - | 0 | 0 | 0 | | | Read/Write | | R/W | R/W | R/W | | | Bit name | Not used | TMC22 | TMC21 | TMC20 | | | TMC22 | TMC21 | TMC20 | R1₁/TC | C mode selection | |-------|-------|-------|-----------------|----------------------| | 0 | 0 | 0 | R1 <sub>1</sub> | R1 <sub>1</sub> port | | | | 1 | TOC | Toggle output | | | 1 | 0 | TOC | 0 output | | | | 1 | TOC | 1 output | | 1 | 0 | 0 | | Inhibited | | | | 1 | | | | | 1 | 0 | | | | | | 1 | TOC | PWM output | Figure 34 Timer Mode Register C2 (TMC2) ## Timer mode register D2 (TMD2: \$015) | Bit | 3 | 2 | 11 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | R/W | R/W | R/W | R/W | | Bit name | TMD23 | TMD22 | TMD21 | TMD20 | | TMD23 | TMD22 | TMD21 | TMD20 | R1 <sub>2</sub> /TC | DD mode selection | |-------|-------|-------|-------|---------------------|--------------------------------------| | 0 | 0 | 0 | 0 | R12 | R1 <sub>2</sub> port | | | | | 1 | TOD | Toggle output | | | | 1 | 0 | TOD | 0 output | | | | | 1 | TOD | 1 output | | | 1 | 0 | 0 | _ | Inhibited | | | | | 1 | | | | i | | 1 | 0 | | | | | | | 1 | TOD | PWM output | | 1 | × | × | × | R12 | Input capture (R1 <sub>2</sub> port) | X: Don't care Figure 35 Timer Mode Register D2 (TMD2) # Serial mode register A (SMRA: \$005) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | SMRA3 | SMRA2 | SMRA1 | SMRA0 | | SMRA3 | R2 <sub>1</sub> /SCK<br>mode selection | |-------|----------------------------------------| | 0 | R2 <sub>1</sub> | | 1 | SCK | | SMRA2 | SMRA1 | SMRA0 | SCK | Clock source | Prescaler<br>division<br>ratio | |-------|-------|-------|--------|----------------|--------------------------------| | 0 | 0 | 0 | Output | Prescaler | +2048 | | | | 1 | Output | Prescaler | +512 | | | 1 | 0 | Output | Prescaler | +128 | | | | 1 | Output | Prescaler | +32 | | 1 | 0 | 0 | Output | Prescaler | +8 | | | | 1 | Output | Prescaler | +2 | | | 1 | 0 | Output | System clock | _ | | | | 1 | Input | External clock | _ | Figure 36 Serial Mode Register A (SMRA) #### Port mode register A (PMRA: \$004) Bit Initial value 0 0 Read/Write W W Bit name Not used Not used PMRA1 PMRA0 PMRA1 R2<sub>2</sub>/SI mode selection PMRA0 R2<sub>3</sub>/SO mode selection 0 R22 0 R23 1 SI 1 SO Figure 37 Port Mode Register A (PMRA) Figure 38 LCD Output Register 1 (LOR1) # LCD output register 2 (LOR2: \$01E) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | LOR23 | LOR22 | LOR21 | LOR20 | | LOR23 | R4 <sub>3</sub> /SEG8 mode selection | |-------|--------------------------------------| | 0 | R43 | | 1 | SEG8 | | R4 <sub>1</sub> /SEG5 mode selection | |--------------------------------------| | R4 <sub>1</sub> | | SEG5 | | | | LOR22 | R4 <sub>2</sub> /SEG7 mode selection | |-------|--------------------------------------| | 0 | R4 <sub>2</sub> | | 1 | SEG7 | | LOR20 | R4 <sub>0</sub> /SEG6 mode selection | |-------|--------------------------------------| | 0 | R4 <sub>0</sub> | | 1 | SEG6 | Figure 39 LCD Output Register 2 (LOR2) # LCD output register 3 (LOR3: \$01F) | Bit | 3 | 2 | 1 | 0 | |---------------|----------|-------|-------|-------| | Initial value | _ | 0 | 0 | 0 | | Read/Write | | W | W | W | | Bit name | Not used | LOR32 | LOR31 | LOR30 | | LOR32 | R7/SEG17-SEG20 mode selection | |-------|-------------------------------| | 0 | R7 | | 1 | SEG17-SEG20 | | LOR31 | R6/SEG13-SEG16 mode selection | |-------|-------------------------------| | 0 | R6 | | 1 | SEG13-SEG16 | | LOR30 | R5/SEG9-SEG12 mode selection | |-------|------------------------------| | 0 | R5 | | 1 | SEG9-SEG12 | Figure 40 LCD Output Register 3 (LOR3) | | ous register | (10110. 40 | 00, | | | | |---------------|-----------------------------|------------|------|----------------------------------------------------------------|-------------------------------|-----------| | Bit | 3 | 2 | 1 | 0 | | | | Initial value | 0 | 0 | 0 | 0 | | | | Read/Write | W | W | W | W | | | | Bit name | MIS3 | MIS2 | MIS1 | MIS0 | | | | | | | | | | | | MIS3 | Pull-up MO:<br>on/off selec | | MIS2 | CMOS buffer<br>on/off selection<br>for pin R2 <sub>3</sub> /SO | MIS1 | MISO | | 0 | Off | | 0 | On | t <sub>RC</sub> selection. | | | 1 | On | | 1 | Off | Refer to figure operation mod | 18 in the | Figure 41 Miscellaneous Register (MIS) #### **Prescalers** The MCU has the following two prescalers, S and $\boldsymbol{w}$ The prescalers operating conditions are listed in table 25, and the prescalers output supply is shown in figure 42. The timers A-D input clocks except external events, the serial transmit clock except the external clock, and the LCD circuit operating clock are selected from the prescaler outputs, depending on corresponding mode registers. #### **Prescaler Operation** Prescaler S: 11-bit counter that inputs the system clock signal. After being reset to \$000 by MCU reset, prescaler S divides the system clock. Prescaler S keeps counting, except in watch and subactive modes and at MCU reset. Prescaler W: Five-bit counter that inputs the X1 input clock signal (32-kHz crystal oscillation) divided by eight. After being reset to \$00 by MCU reset, prescaler W divides the input clock. Prescaler W can be reset by software. **Table 25 Prescaler Operating Conditions** | Prescaler | Input Clock | Reset Conditions | Stop Conditions | |-------------|--------------------------------------------------------------------------------|---------------------|----------------------------------------| | Prescaler S | System clock (in active and standby mode), Subsystem clock (in subactive mode) | MCU reset | MCU reset,<br>stop mode,<br>watch mode | | Prescaler W | 32-kHz crystal oscillation | MCU reset, software | MCU reset,<br>stop mode | Figure 42 Prescaler Output Supply #### **Timers** The MCU has four timer/counters (A to D). • Timer A: Free-running timer • Timer B: Multifunction timer • Timer C: Multifunction timer · Timer D: Multifunction timer Timer A is an 8-bit free-running timer. Timers B-D are 8-bit multifunction timers, whose functions are listed in table 26. The operating modes are selected by software. #### Timer A **Timer A Functions:** Timer A has the following functions. - · Free-running timer - · Clock time-base The block diagram of timer A is shown in figure 43. # **Timer A Operations:** Free-running timer operation: The input clock for timer A is selected by timer mode register A (TMA: \$008). Timer A is reset to \$00 by MCU reset and incremented at each input clock. If an input clock is applied to timer A after it has reached \$FF, an overflow is generated, and timer A is reset to \$00. The overflow sets the timer A interrupt request flag (IFTA: \$001, bit 2). Timer A continues to be incremented after reset to \$00, and therefore it generates regular interrupts every 256 clocks. • Clock time-base operation: Timer A is used as a clock time-base by setting bit 3 (TMA3) of timer mode register A (TMA: \$008) to 1. The prescaler W output is applied to timer A, and timer A generates interrupts at the correct timing based on the 32.768-kHz crystal oscillation. In this case, prescaler W and timer A can be reset to \$00 by software. **Registers for Timer A Operation:** Timer A operating modes are set by the following registers. Timer mode register A (TMA: \$008): Four-bit write-only register that selects timer A's operating mode and input clock source as shown in figure 44. **Table 26 Timer Functions** | Functions | | Timer A | Timer B | Timer C | Timer D | |-----------|----------------|-----------|-----------|--------------|--------------| | Clock | Prescaler S | Available | Available | Available | Available | | source | Prescaler W | Available | | _ | _ | | | External event | _ | Available | <del>_</del> | Available | | Timer | Free-running | Available | Available | Available | Available | | functions | Time-base | Available | | | | | | Event counter | | Available | | Available | | | Reload | - | Available | Available | Available | | | Watchdog | | | Available | <del>.</del> | | | Input capture | _ | | _ | Available | | Timer | Toggle | | Available | Available | Available | | outputs | 0 output | | Available | Available | Available | | | 1 output | _ | Available | Available | Available | | | PWM | _ | | Available | Available | | | | | | | | Note: — implies not available. Figure 43 Block Diagram of Timer A # Timer mode register A (TMA: \$008) | Bit | 3 | 2 | 1 | 0 | |---------------|------|------|------|------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | TMA3 | TMA2 | TMA1 | TMA0 | | ТМАЗ | TMA2 | TMA1 | TMA0 | Source<br>prescaler | Input clock frequency | Operating mode | | |------|------|------|------|--------------------------|-----------------------|----------------|--| | 0 | 0 | 0 | 0 | PSS 2048t <sub>cyc</sub> | | Timer A mode | | | | | | 1 | PSS | 1024t <sub>cyc</sub> | | | | | | 1 | 0 | PSS | 512t <sub>cyc</sub> | | | | İ , | | | 1 | PSS | 128t <sub>cyc</sub> | | | | | 1 | 0 | 0 | PSS | 32t <sub>cyc</sub> | | | | | | | 1 | PSS | 8t <sub>cyc</sub> | | | | | | 1 | 0 | PSS | 4t <sub>cyc</sub> | | | | | | | 1 | PSS | 2t <sub>cyc</sub> | | | | 1 | 0 | 0 | 0 | PSW | 32twcyc | Time-base | | | | | | 1 | PSW | 16twcyc | mode | | | | | 1 | 0 | PSW | 8t <sub>Wcyc</sub> | | | | | | | 1 | PSW | 2t <sub>Wcyc</sub> | | | | | 1 | 0 | 0 | PSW | 1/2twcyc | | | | | | | 1 | Inhibited | | | | | : | | 1 | × | PSW and TCA reset | | | | #### X : Don't care Note: 1. $t_{Wcyc} = 244.14 \mu s$ (when a 32.768-kHz crystal oscillator is used) 2. Timer counter overflow output period (seconds) = input clock period (seconds) × 256. If PSW of TCA reset is selected while the LCD is operating, LCD operation halts (power switch goes off and all SEG and COM pins are grounded).When an LCD is connected for display, the PSW and TCA reset periods must be set in the program to the minimum. The division ratio must not be modified during time-base mode operation, otherwise an overflow cycle error will occur. Figure 44 Timer Mode Register A (TMA) #### Timer B **Timer B Functions:** Timer B has the following functions. - · Free-running/reload timer - · External event counter - Timer output operation (toggle, 0, and 1 outputs) The block diagram of timer B is shown in figure 45. #### **Timer B Operations:** Free-running/reload timer operation: The freerunning/reload operation, input clock source, and prescaler division ratio are selected by timer mode register B1 (TMB1: \$009). Timer B is initialized to the value set in timer write register B (TWBL: \$00A, TWBU: \$00B) by software and incremented by one at each clock input. If an input clock is applied to timer B after it has reached \$FF, an overflow is generated. In this case, if the reload timer function is enabled, timer B is initialized to its initial value set in timer write register B; if the free-running timer function is enabled, the timer is initialized to \$00 and then incremented again. The overflow sets the timer B interrupt request flag (IFTB: \$002, bit 0). IFTB is reset by software or MCU reset. Refer to figure 3 and table 1 for details. External event counter operation: Timer B is used as an external event counter by selecting external event input as input clock source. In this case, pin R1<sub>3</sub>/EVNB must be set to EVNB by port mode register C (PMRC: \$025). Timer B is incremented by one at each falling edge of signals input to pin EVNB. The other operation is basically the same as the free-running/reload timer operation. Timer output operation: The following three output modes can be selected for timer B by setting timer mode register B2 (TMB2: \$013). Toggle 0 output 1 output By selecting the timer output mode, pin R1<sub>0</sub>/TOB is set to TOB. The output from TOB is reset low by MCU reset. - Toggle output: When toggle output mode is selected, the output level is inverted if a clock is input after timer B has reached \$FF. By using this function and reload timer function, clock signals can be output at a required frequency for the buzzer. The output waveform is shown in figure 46. - 0 output: When 0 output mode is selected, the output level is pulled low if a clock is input after timer B has reached \$FF. Note that this function must be used only when the output level is high. - 1 output: When 1 output mode is selected, the output level is set high if a clock is input after timer B has reached \$FF. Note that this function must be used only when the output level is low. Figure 45 Block Diagram of Timer B Figure 46 Timer Output Waveform Registers for Timer B Operation: By using the following registers, timer B operation modes are selected and the timer B count is read and written. Timer mode register B1 (TMB1: \$009) Timer mode register B2 (TMB2: \$013) Timer write register B (TWBL: \$00A, TWBU: \$00B) Timer read register B (TRBL: \$00A, TRBU: \$00B) Bit name Port mode register C (PMRC: \$025) Timer mode register B1 (TMB1: \$009): Fourbit write-only register that selects the free-running/reload timer function, input clock source, and the prescaler division ratio as shown in figure 47. It is reset to \$0 by MCU reset. Writing to this register is valid from the second instruction execution cycle after the execution of the previous timer mode register B1 write instruction. Setting timer B's initialization by writing to timer write register B (TWBL: \$00A, TWBU: \$00B) must be done after a mode change becomes valid. | Timer mode register B1 (TMB1: \$009) | | | | | | | | |--------------------------------------|---|---|---|---|--|--|--| | Bit | 3 | 2 | 1 | 0 | | | | | Initial value | 0 | 0 | 0 | 0 | | | | | Read/Write | W | W | W | W | | | | TMB13 TMB12 TMB11 TMB10 | TMB13 | Free-running/reload timer selection | |-------|-------------------------------------| | 0 | Free-running timer | | 1 | Reload timer | | | | | TMB12 | TMB11 | TMB10 | Input clock period and input clock source | |-------|-------|-------|----------------------------------------------| | 0 | 0 | 0 | 2048t <sub>cyc</sub> | | | | 1 | 512t <sub>cyc</sub> | | | 1 | 0 | 128t <sub>cyc</sub> | | | | 1 | 32t <sub>cyc</sub> | | 1 | 0 | 0 | 8t <sub>cyc</sub> | | | | 1 | 4t <sub>cyc</sub> | | | 1 | 0 | 2t <sub>cyc</sub> | | | | 1 | R1 <sub>3</sub> /EVNB (external event input) | Figure 47 Timer Mode Register B1 (TMB1) | Timer mode | register B2 | ? (TMB2: \$ | \$013) | | |---------------|-------------|-------------|--------|-------| | Bit | 3 | 2 | 1 | 0 | | Initial value | _ | | 0 | 0 | | Read/Write | _ | _ | R/W | R/W | | Bit name | Not used | Not used | TMB21 | TMB20 | | TMB21 | TMB20 | R1 <sub>0</sub> /TOB mode selection | | | | |-------|-------|--------------------------------------|---------------|--|--| | 0 | 0 | R1 <sub>0</sub> R1 <sub>0</sub> port | | | | | | 1 | ТОВ | Toggle output | | | | 1 | 0 | ТОВ | 0 output | | | | | 1 | ТОВ | 1 output | | | Figure 48 Timer Mode Register B2 (TMB2) - Timer mode register B2 (TMB2: \$013): Two-bit read/write register that selects the timer B output mode as shown in figure 48. It is reset to \$0 by MCU reset. - Timer write register B (TWBL: \$00A, TWBU: \$00B): Write-only register consisting of the lower digit (TWBL) and the upper digit (TWBU) as shown in figures 49 and 50. The lower digit is reset to \$0 by MCU reset, but the upper digit value is invalid. Timer B is initialized by writing to timer write register B. In this case, the lower digit (TWBL) must be written to first, but writing only to the lower digit does not change the timer B value. Timer B is initialized to the value in timer write register B at the same time the upper digit (TWBU) is written to. When timer write register B is written to again and if the lower digit value needs no change, writing only to the upper digit initializes timer B. Timer read register B (TRBL: \$00A, TRBU: \$00B): Read-only register consisting of the lower digit (TRBL) and the upper digit (TRBU) that holds the count of the timer B upper digit (figures 51 and 52). The upper digit (TRBU) must be read first. At this time, the count of the timer B upper digit is obtained, and the count of the timer B lower digit is latched to the lower digit (TRBL). After this, by reading TRBL, the count of timer B when TRBU is read can be obtained. Port mode register C (PMRC: \$025): Write-only register that selects R1<sub>3</sub>/EVNB pin function as shown in figure 53. It is reset to \$0 by MCU reset. Figure 49 Timer Write Register B Lower Digit (TWBL) Figure 50 Timer Write Register B Upper Digit (TWBU) # Timer read register B (lower digit) (TRBL: \$00A) Bit 3 2 1 0 Initial value Undefined Undefined Undefined Undefined Read/Write R R R Bit name TRBL3 TRBL2 TRBL1 TRBL0 Figure 51 Timer Read Register B Lower Digit (TRBL) Figure 52 Timer Read Register B Upper Digit (TRBU) Figure 53 Port Mode Register C (PMRC) #### Timer C **Timer C Functions:** Timer C has the following functions. - · Free-running/reload timer - · Watchdog timer - Timer output operation (toggle, 0, 1, and PWM outputs) The block diagram of timer C is shown in figure 54. #### **Timer C Operations:** Free-running/reload timer operation: The freerunning/reload operation, input clock source, and prescaler division ratio are selected by timer mode register C1 (TMC1: \$00D). Timer C is initialized to the value set in timer write register C (TWCL: \$00E, TWCU: \$00F) by software and incremented by one at each clock input. If an input clock is applied to timer C after it has reached \$FF, an overflow is generated. In this case, if the reload timer function is enabled, timer C is initialized to its initial value set in timer write register C; if the free-running timer function is enabled, the timer is initialized to \$00 and then incremented again. The overflow sets the timer C interrupt request flag (IFTC: \$002, bit 2). IFTC is reset by software or MCU reset. Refer to figure 3 and table 1 for details. Watchdog timer operation: Timer C is used as a watchdog timer for detecting out-of-control program routines by setting the watchdog on flag (WDON: \$020, bit 1) to 1. If a program routine runs out of control and an overflow is generated, the MCU is reset. Program run can be controlled by initializing timer C by software before it reaches \$FF. Timer output operation: The following four output modes can be selected for timer C by setting timer mode register C2 (TMC2: \$014). Toggle 0 output 1 output PWM output By selecting the timer output mode, pin R1<sub>1</sub>/TOC is set to TOC. The output from TOC is reset low by MCU reset. - Toggle output: The operation is basically the same as that of timer-B's toggle output. - 0 output: The operation is basically the same as that of timer-B's 0 output. - 1 output: The operation is basically the same as that of timer-B's 1 output. - PWM output: When PWM output mode is selected, timer C provides the variable-duty pulse output function. The output waveform differs depending on the contents of timer mode register C1 (TMC1: \$00D) and timer write register C (TWCL: \$00E, TWCU: \$00F). The output waveform is shown in figure 46. Figure 54 Block Diagram of Timer C Registers for Timer C Operation: By using the following registers, timer C operation modes are selected and the timer C count is read and written. Timer mode register C1 (TMC1: \$00D) Timer mode register C2 (TMC2: \$014) Timer write register C (TWCL: \$00E, TWCU: \$00F) Timer read register C (TRCL: \$00E, TRCU: \$00F) Timer mode register C1 (TMC1: \$00D): Fourbit write-only register that selects the free-running/reload timer function, input clock source, and the prescaler division ratio as shown in figure 55. It is reset to \$0 by MCU reset. Writing to this register is valid from the second instruction execution cycle after the execution of the previous timer mode register C1 write instruction. Setting timer C's initialization by writing to timer write register C (TWCL: \$00E, TWCU: \$00F) must be done after a mode change becomes valid. | Timer mode register C1 (TMC1: \$00D) | | | | | | | | |--------------------------------------|-------|-------|-------|-------|--|--|--| | Bit | 3 | 2 | 11 | 0 | | | | | Initial value | 0 | 0 | 0 | 0 | | | | | Read/Write | W | W | W | W | | | | | Bit name | TMC13 | TMC12 | TMC11 | TMC10 | | | | | TMC13 | Free-running/reload timer selection | |-------|-------------------------------------| | 0 | Free-running timer | | 1 | Reload timer | | TMC12 | TMC11 | TMC10 | Input clock period | |-------|-------|-------|----------------------| | 0 | 0 | 0 | 2048t <sub>cyc</sub> | | | | 1 | 1024t <sub>cyc</sub> | | | 1 | 0 | 512t <sub>cyc</sub> | | | | 1 | 128t <sub>cyc</sub> | | 1 | 0 | 0 | 32t <sub>cyc</sub> | | | | 1 | 8t <sub>cyc</sub> | | | 1 | О | 4t <sub>cyc</sub> | | | | 1 | 2t <sub>cyc</sub> | Figure 55 Timer Mode Register C1 (TMC1) - Timer mode register C2 (TMC2: \$014): Threebit read/write register that selects the timer C output mode as shown in figure 56. It is reset to \$0 by MCU reset. - Timer write register C (TWCL: \$00E, TWCU: \$00F): Write-only register consisting of the lower digit (TWCL) and the upper digit (TWCU). The operation of timer write register C is basically the same as that of timer write register B (TWBL: \$00A, TWBU: \$00B). - Timer read register C (TRCL: \$00E, TRCU: \$00F): Read-only register consisting of the lower digit (TRCL) and the upper digit (TRCU) that holds the count of the timer C upper digit. The operation of timer read register C is basically the same as that of timer read register B (TRBL: \$00A, TRBU: \$00B). | Bit | 3 | 2 | 1 | 0 | | | |--------------|----------|-------|-------|---------------------------------------|-----------------|----------------------| | nitial value | _ | 0 | 0 | 0 | | | | Read/Write | | R/W | R/W | R/W | | | | Bit name | Not used | TMC22 | TMC21 | TMC20 | | | | | | | | · · · · · · · · · · · · · · · · · · · | | | | | | TMC22 | TMC21 | TMC20 | R1₁/TC | OC mode selection | | | | 0 | 0 | 0 | R1 <sub>1</sub> | R1 <sub>1</sub> port | | | | | | 1 | TOC | Toggle output | | | | | 1 | 0 | TOC | 0 output | | | | | | 1 | TOC | 1 output | | | | 1 | 0 | 0 | _ | Inhibited | | | | | | 1 | | | | | | | 1 | 0 | | | | | | | | 1 | TOC | PWM output | Figure 56 Timer Mode Register C2 (TMC2) Figure 57 Timer Write Register C Lower Digit (TWCL) Figure 58 Timer Write Register C Upper Digit (TWCU) Figure 59 Timer Read Register C Lower Digit (TRCL) Figure 60 Timer Read Register C Upper Digit (TRCU) #### Timer D **Timer D Functions:** Timer D has the following functions. - · Free-running/reload timer - · External event counter - Timer output operation (toggle, 0, 1, and PWM outputs) - · Input capture timer The block diagram for each operation mode of timer D is shown in figures 61 and 62. #### **Timer D Operations:** Free-running/reload timer operation: The freerunning/reload operation, input clock source, and prescaler division ratio are selected by timer mode register D1 (TMD1; \$010). Timer D is initialized to the value set in timer write register D (TWDL: \$011, TWDU: \$012) by software and incremented by one at each clock input. If an input clock is applied to timer D after it has reached \$FF, an overflow is generated. In this case, if the reload timer function is enabled, timer D is initialized to its initial value set in timer write register D; if the free-running timer function is enabled, the timer is initialized to \$00 and then incremented again. The overflow sets the timer D interrupt request flag (IFTD: \$003, bit 0). IFTD is reset by software or MCU reset. Refer to figure 3 and table 1 for details. External event counter operation: Timer D is used as an external event counter by selecting the external event input as an input clock source. In this case, pin R2<sub>0</sub>/EVND must be set to EVND by port mode register C (PMRC: \$025). Either falling or rising edge, or both falling and rising edges of input signals can be selected as the external event detection edge by detection edge select register 2 (ESR2: \$027). When both rising and falling edges detection is selected, the time between the falling edge and rising edge of input signals must be $2t_{\rm cvc}$ or longer. Timer D is incremented by one at each detection edge selected by detection edge select register 2 (ESR2: \$027). The other operation is basically the same as the free-running/reload timer operation. Timer output operation: The following four output modes can be selected for timer D by setting timer mode register D2 (TMD2: \$015). Toggle 0 output 1 output PWM output By selecting the timer output mode, pin R1<sub>2</sub>/TOD is set to TOD. The output from TOD is reset low by MCU reset. - Toggle output: The operation is basically the same as that of timer-B's toggle output. - 0 output: The operation is basically the same as that of timer-B's 0 output. - 1 output: The operation is basically the same as that of timer-B's 1 output. - PWM output: The operation is basically the same as that of timer-C's PWM output. - Input capture timer operation: The input capture timer counts the clock cycles between trigger edges input to pin EVND. Either falling or rising edge, or both falling and rising edges of input signals can be selected as the trigger input edge by detection edge select register 2 (ESR2: \$027). When a trigger edge is input to EVND, the count of timer D is written to timer read register D (TRDL: \$011, TRDU: \$012), and the timer D interrupt request flag (IFTD: \$003, bit 0) and the input capture status flag (ICSF: \$021, bit 0) are set. Timer D is reset to \$00, and then incremented again. While ICSF is set, if a trigger input edge is applied to timer D, or if timer D generates an overflow, the input capture error flag (ICEF: \$021, bit 1) is set. ICSF and ICEF are reset to 0 by MCU reset or by writing 0. By selecting the input capture operation, pin R1<sub>2</sub>/TOD is set to R1<sub>2</sub> and timer D is reset to \$00. Figure 61 Block Diagram of Timer D (Free-Running/Reload Timer) Figure 62 Block Diagram of Timer D (Input Capture Timer) Registers for Timer D Operation: By using the following registers, timer D operation modes are selected and the timer D count is read and written. Timer mode register D1 (TMD1: \$010) Timer mode register D2 (TMD2: \$015) Timer write register D (TWDL: \$011, TWDU: \$012) Timer read register D (TRDL: \$011, TRDU: \$012) Port mode register C (PMRC: \$025) Detection edge select register 2 (ESR2: \$027) Timer mode register D1 (TMD1: \$010): Fourbit write-only register that selects the free-running/reload timer function, input clock source, and the prescaler division ratio as shown in figure 63. It is reset to \$0 by MCU reset. Writing to this register is valid from the second instruction execution cycle after the execution of the previous timer mode register D1 (TMD1: \$010) write instruction. Setting timer D's initialization by writing to timer write register D (TWDL: \$011, TWDU: \$012) must be done after a mode change becomes valid. When selecting the input capture timer operation, select the internal clock as the input clock source. | Timer mode register D1 (TMD1: \$010) | | | | | | | |--------------------------------------|-------|-------|-------|-------|--|--| | Bit | 3 | 2 | 1 | 0 | | | | Initial value | 0 | 0 | 0 | 0 | | | | Read/Write | W | W | W | W | | | | Bit name | TMD13 | TMD12 | TMD11 | TMD10 | | | | TMD13 | Free-running/reload timer selection | |-------|-------------------------------------| | 0 | Free-running timer | | 1 | Reload timer | | TMD12 | TMD11 | TMD10 | Input clock period and input clock source | |-------|-------|-------|-------------------------------------------------| | 0 | 0 | 0 | 2048t <sub>cyc</sub> | | | | 1 | 512t <sub>cyc</sub> | | | 1 | 0 | 128t <sub>cyc</sub> | | | | 1 | 32t <sub>cyc</sub> | | 1 | 0 | 0 | 8t <sub>cyc</sub> | | | | 1 | 4t <sub>cyc</sub> | | | 1 | 0 | 2t <sub>cyc</sub> | | | | 1 | R2 <sub>0</sub> /EVND<br>(external event input) | Figure 63 Timer Mode Register D1 (TMD1) - Timer mode register D2 (TMD2: \$015): Fourbit read/write register that selects the timer D output mode and input capture operation as shown in figure 64. It is reset to \$0 by MCU reset. - Timer write register D (TWDL: \$011, TWDU: \$012): Write-only register consisting of the lower digit (TWDL) and the upper digit (TWDU). The operation of timer write register D is basically the same as that of timer write register B (TWBL: \$00A, TWBU: \$00B). - Timer read register D (TRDL: \$011, TRDU: \$012): Read-only register consisting of the lower digit (TRDL) and the upper digit (TRDU). The operation of timer read register D is basical- ly the same as that of timer read register B (TRBL: \$00A, TRBU: \$00B). When the input capture timer operation is selected and if the count of timer D is read after a trigger is input, either the lower or upper digit can be read first. - Port mode register C (PMRC: \$025): Write-only register that selects R2<sub>0</sub>/EVND pin function as shown in figure 53. It is reset to \$0 by MCU reset. - Detection edge select register 2 (ESR2: \$027): Write-only register that selects the detection edge of signals input to pin EVND as shown in figure 69. It is reset to \$0 by MCU reset. | Timer mode register D2 (TMD2: \$015) | | | | | | | | |--------------------------------------|-------|-------|-------|-------|--|--|--| | Bit | 3 | 2 | 1 | 0 | | | | | Initial value | 0 | 0 | 0 | 0 | | | | | Read/Write R/W R/W R/W | | | | | | | | | Bit name | TMD23 | TMD22 | TMD21 | TMD20 | | | | | TMD23 | TMD22 | TMD21 | TMD20 | R1 <sub>2</sub> /TOD mode selection | | | |-------|-------|-------|-------|-------------------------------------|------------------------------------------------------|--| | 0 | 0 | 0 | 0 | R1 <sub>2</sub> | R1 <sub>2</sub> port | | | | | | 1 | TOD | Toggle output | | | | | 1 | 0 | TOD | 0 output | | | | | | 1 | TOD | 1 output | | | | 1 | 0 | 0 | - | Inhibited | | | | | | 1 | | | | | | | 1 | 0 | | | | | | | | 1 | TOD | PWM output | | | 1 | × | × | × | R12 | R1 <sub>2</sub> Input capture (R1 <sub>2</sub> port) | | X: Don't care Figure 64 Timer Mode Register D2 (TMD2) Figure 65 Timer Write Register D Lower Digit (TWDL) Figure 66 Timer Write Register D Upper Digit (TWDU) Figure 67 Timer Read Register D Lower Digit (TRDL) Figure 68 Timer Read Register D Upper Digit (TRDU) # Detection edge register 2 (ESR2: \$027) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | ESR23 | ESR22 | ESR21 | ESR20 | | ESR23 | ESR22 | EVND detection edge | |-------|-------|------------------------| | 0 | 0 | No detection | | | 1 | Falling-edge detection | | 1 | 0 | Rising-edge detection | | : | 1 | Double-edge detection* | | ESR21 | ESR20 | INT₄ detection edge | | |-------|-------|------------------------|--| | 0 | 0 | No detection | | | | 1 | Falling-edge detection | | | 1 | 0 | Rising-edge detection | | | | 1 | Double-edge detection* | | Note: \* Both falling and rising edges are detected. Figure 69 Detection Edge Select Register 2 (ESR2) #### Note on Use When using the timer output as PWM output, note the following point. From the update of the timer write register untill the occurrence of the overflow interrupt, the PWM output differs from the period and duty settings, as shown in table 27. The PWM output should therefore not be used until after the overflow interrupt following the update of the timer write register. After the overflow, the PWM output will have the set period and duty cycle. Table 27 PWM Output Following Update of Timer Write Register #### **Serial Interface** The serial interface serially transfers and receives 8-bit data, and includes the following features. - · Multiple transmit clock sources - -External clock - -Internal prescaler output clock - -System clock - · Output level control in idle states Five registers, an octal counter, and a multiplexer are also configured for the serial interface as follows. Serial data register (SRL: \$006, SRU: \$007) Serial mode register A (SMRA: \$005) Serial mode register B (SMRB: \$028) Miscellaneous register (MIS: \$00C) Octal counter (OC) Selector The block diagram of the serial interface is shown in figure 70. Figure 70 Block Diagram of Serial Interface #### **Serial Interface Operation** Selecting and Changing the Operating Mode: Table 28 lists the serial interface's operating modes. To select an operating mode, use one of these combinations of port mode register A (PMRA: \$004) and serial mode register A (SMRA: \$005) settings; to change the operating mode, always initialize the serial interface internally by writing data to serial mode register A. Note that the serial interface is initialized by writing data to serial mode register A. Refer to the following Serial Mode Register A section for details. **Pin Setting:** The R2<sub>1</sub>/SCK pin is controlled by writing data to serial mode register A (SMRA: \$005). The R2<sub>2</sub>/SI and R2<sub>3</sub>/SO pins are controlled by writing data to port mode register A (PMRA: \$004). Refer to the following Registers for Serial Interface section for details. Transmit Clock Source Setting: The transmit clock source is set by writing data to serial mode register A (SMRA: \$005) and serial mode register B (SMRB: \$028). Refer to the following Registers for Serial Interface section for details. Data Setting: Transmit data is set by writing data to the serial data register (SRL: \$006, SRU: \$007). Receive data is obtained by reading the contents of the serial data register. The serial data is shifted by the transmit clock and is input from or output to an external system. The output level of the SO pin is invalid until the first data is output after MCU reset, or until the output level control in idle states is performed. Transfer Control: The serial interface is activated by the STS instruction. The octal counter is reset to 000 by this instruction, and it increments at the rising edge of the transmit clock. When the eighth transmit clock signal is input or when serial transmission/receive is discontinued, the octal counter is reset to 000, the serial interrupt request flag (IFS: \$023, bit 2) is set, and the transfer stops. When the prescaler output is selected as the transmit clock, the transmit clock frequency is selected as $4t_{cyc}$ to $8192t_{cyc}$ by setting bits 2 to 0 (SMRA2-SMRA0) of serial mode register A (SMRA: \$005) and bit 0 (SMRB0) of serial mode register B (SMRB: \$028) as listed in table 29. Operating States: The serial interface has the following operating states; transitions between them are shown in figure 71. STS wait state Transmit clock wait state Transfer state Continuous clock output state (only in internal clock mode) - STS wait state: The serial interface enters STS wait state by MCU reset (00, 10 in figure 71). In STS wait state, the serial interface is initialized and the transmit clock is ignored. If the STS instruction is then executed (01, 11), the serial interface enters transmit clock wait state. - Transmit clock wait state: Transmit clock wait state is between the STS execution and the falling edge of the first transmit clock. In transmit clock wait state, input of the transmit clock (02, 12) increments the octal counter, shifts the serial data register, and enters the serial interface in transfer state. However, note that if continuous clock output mode is selected in internal clock mode, the serial interface does not enter transfer state but enters continuous clock output state (17). The serial interface enters STS wait state by writing data to serial mode register A (SMRA: \$005) (04, 14) in transmit clock wait state. • Transfer state: Transfer state is between the falling edge of the first clock and the rising edge of the eighth clock. In transfer state, the input of eight clocks or the execution of the STS instruction sets the octal counter to 000, and the serial interface enters another state. When the STS instruction is executed (05, 15), transmit clock wait state is entered. When eight clocks are input, transmit clock wait state is entered (03) in external clock mode, and STS wait state is entered (13) in internal clock mode. In internal clock mode, the transmit clock stops after outputting eight clocks. In transfer state, writing data to serial mode register A (SMRA: \$005) (06, 16) initializes the serial interface, and STS wait state is entered. If the state changes from transfer to another state, the serial interrupt request flag (IFS: \$023, bit 2) is set by the octal counter that is reset to 000. Continuous clock output state (only in internal clock mode): Continuous clock output state is entered only in internal clock mode. In this state, the serial interface does not transmit/ receive data but only outputs the transmit clock from the SCK pin. When bits 1 and 0 (PMRA1, PMRA0) of port mode register A (PMRA: \$004) are 00 in transmit clock wait state and if the transmit clock is input (17), the serial interface enters continuous clock output state. If serial mode register A (SMRA: \$005) is written to in continuous clock output mode (18), STS wait state is entered. Output Level Control in Idle States: In idle states, that is, STS wait state and transmit clock wait state, the output level of the SO pin can be controlled by setting bit 1 (SMRB1) of serial mode register B (SMRB: \$028) to 0 or 1. The output level control example is shown in figure 72. Note that the output level cannot be controlled in transfer state. Transmit Clock Error Detection (In External Clock Mode): The serial interface will malfunction if a spurious pulse caused by external noise conflicts with a normal transmit clock during transfer. A transmit clock error of this type can be detected as shown in figure 73. Table 28 Serial Interface Operating Modes | SMRA PMRA | | MRA | | |-----------|-------|-------|------------------------------| | Bit 3 | Bit 1 | Bit 0 | Operating Mode | | 1 | 0 | 0 | Continuous clock output mode | | | | 1 | Transmit mode | | | 1 | 0 | Receive mode | | | | 1 | Transmit/receive mode | Table 29 Serial Transmit Clock (Prescaler Output) | SMRB | | SMR | 4 | | | |-------|-------|-------|-------|--------------------------|--------------------------| | Bit 0 | Bit 2 | Bit 1 | Bit 0 | Prescaler Division Ratio | Transmit Clock Frequency | | 0 | 0 | 0 | 0 | ÷ 2048 | 4096t <sub>cyc</sub> | | | | | 1 | + 512 | 1024t <sub>cyc</sub> | | | | 1 | 0 | ÷ 128 | 256t <sub>cyc</sub> | | | | | 1 | ÷ 32 | 64t <sub>cyc</sub> | | | 1 | 0 | 0 | ÷ 8 | 16t <sub>cyc</sub> | | | | | 1 | ÷ 2 | 4t <sub>cyc</sub> | | 1 | 0 | 0 | 0 | + 4096 | 8192t <sub>cyc</sub> | | | | | 1 | ÷ 1024 | 2048t <sub>cyc</sub> | | | | 1 | 0 | + 256 | 512t <sub>cyc</sub> | | | | | 1 | + 64 | 128t <sub>cyc</sub> | | | 1 | 0 | 0 | + 16 | 32t <sub>cyc</sub> | | | | | 1 | ÷ <b>4</b> | 8t <sub>cyc</sub> | If more than eight transmit clocks are input in transfer state, at the eighth clock including a spurious pulse by noise, the octal counter reaches 000, the serial interrupt request flag (IFS: \$023, bit 2) is set, and transmit clock wait state is entered. At the falling edge of the next normal clock signal, the transfer state is entered. After the transfer completion processing is performed and IFS is reset, writing to serial mode register A (SMRA: \$005) changes the state from transfer to STS wait. At this time IFS is set again, and therefore the error can be detected. #### Notes on Use: · Initialization after writing to registers: If port - mode register A (PMRA: \$004) is written to in transmit clock wait state or in transfer state, the serial interface must be initialized by writing to serial mode register A (SMRA: \$005) again. - Serial interrupt request flag (IFS: \$023, bit 2) set: If the state is changed from transfer to another by writing to serial mode register A (SMRA: \$005) or executing the STS instruction during the first low pulse of the transmit clock, the serial interrupt request flag is not set. To set the serial interrupt request flag, serial mode register A write or STS instruction execution must be programmed to be executed after confirming that the $\overline{SCK}$ pin is at 1, that is, after executing the input instruction to port R2. Figure 71 Serial Interface State Transitions Figure 72 Example of Serial Interface Operation Sequence Figure 73 Transmit Clock Error Detection #### Registers for Serial Interface The serial interface operation is selected, and serial data is read and written by the following registers. Serial Mode Register A (SMRA: \$005) Serial Mode Register B (SMRB: \$028) Serial Data Register (SRL: \$006, SRU: \$007) Port Mode Register A (PMRA: \$004) Miscellaneous Register (MIS: \$00C) Serial Mode Register A (SMRA: \$005): This register has the following functions (figure 74). - R2<sub>1</sub>/SCK pin function selection - · Transfer clock selection - · Prescaler division ratio selection - Serial interface initialization Serial mode register A (SMRA: \$005) is a 4-bit write-only register. It is reset to \$0 by MCU reset. A write signal input to serial mode register A (SMRA: \$005) discontinues the input of the transmit clock to the serial data register and octal counter, and the octal counter is reset to 000. Therefore, if a write is performed during data transfer, the serial interrupt request flag (IFS: \$023, bit 2) is set. Written data is valid from the second instruction execution cycle after the write operation, so the STS instruction must be executed at least two cycles after that. Serial Mode Register B (SMRB: \$028): This register has the following functions (figure 75). - · Prescaler division ratio selection - Output level control in idle states Serial mode register B is a 2-bit write-only register. It cannot be written during data transfer. By setting bit 0 (SMRB0) of this register, the prescaler division ratio is selected. Only bit 0 (SMRB0) can be reset to 0 by MCU reset. By setting bit 1 (SMRB1), the output level of the SO pin is controlled in idle states. The output level changes at the same time that SMRB1 is written to. | Serial mode register A (SMRA: \$005) | | | | | |--------------------------------------|-------|-------|-------|-------| | Bit | 3 | 2 | 1 | 0 | | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | SMRA3 | SMRA2 | SMRA1 | SMRA0 | | SMRA3 | R2 <sub>1</sub> /SCK<br>mode selection | |-------|----------------------------------------| | 0 | R2 <sub>1</sub> | | 1 | SCK | | SMRA2 | SMRA1 | SMRA0 | SCK | Clock source | Prescaler<br>division ratio | |-------|-------|-------|--------|----------------|-----------------------------| | 0 | 0 | 0 | Output | Prescaler | Refer to | | | | 1 | | | table 29 | | | 1 | 0 | | | | | | | 1 | | | | | 1 | 0 | 0 | | | | | | | 1 | | | | | | 1 | 0 | Output | System clock | | | | | 1 | input | External clock | | Figure 74 Serial Mode Register A (SMRA) Serial Data Register (SRL: \$006, SRU: \$007): This register has the following functions (figures 76 and 77). - · Transmission data write and shift - · Receive data shift and read Writing data in this register is output from the SO pin, LSB first, synchronously with the falling edge of the transmit clock; data is input, LSB first, through the SI pin at the rising edge of the transmit clock. Input/output timing is shown in figure 78. Data cannot be read or written during serial data transfer. If a read/write occurs during transfer, the accuracy of the resultant data cannot be guaranteed. Figure 75 Serial Mode Register B (SMRB) Figure 76 Serial Data Register (SRL) Figure 77 Serial Data Register (SRU) Port Mode Register A (PMRA: \$004): This register has the following functions (figure 79). - R2<sub>2</sub>/SI pin function selection - R2<sub>3</sub>/SO pin function selection Port mode register A (PMRA: \$004) is a 2-bit write-only register, and is reset to \$0 by MCU reset. Miscellaneous Register (MIS: \$00C): This register has the following function (figure 80). R2<sub>3</sub>/SO pin PMOS control Miscellaneous register (MIS: \$00C) is a 4-bit write-only register and is reset to \$0 by MCU reset. Figure 78 Serial Interface Output Timing Figure 79 Port Mode Register A (PMRA) # Miscellaneous register (MIS: \$00C) | Bit | 3 | 2 | 1 | 0 | |---------------|------|------|------|------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | MIS3 | MIS2 | MIS1 | MIS0 | | MIS3 | Pull-up MOS on/off selection | |------|------------------------------| | 0 | Off | | 1 | On | | | | | MIS2 | R2 <sub>3</sub> /SO PMOS on/off selection | |------|-------------------------------------------| | 0 | On | | 1 | Off | | MIS1 | MIS0 | tac | |------|------|------------| | 0 | 0 | 0.12207 ms | | | | 0.24414 ms | | | 1 | 7.8125 ms | | 1 | 0 | 31.25 ms | | | 1 | Not used | Figure 80 Miscellaneous Register (MIS) #### A/D Converter The MCU has a built-in A/D converter that uses a successive approximation method with a resistor ladder. It can measure four analog inputs with 8-bit resolution. As shown in the block diagram of figure 81, the A/D converter has a 4-bit A/D mode register, a 1-bit A/D start flag, and a 4-bit plus 4-bit A/D data register. A/D Mode Register (AMR: \$016): Four-bit write-only register which selects the A/D conversion period and indicates analog input pin information. Bit 0 of the A/D mode register selects the A/D conversion period, and bits 3 and 2 select a channel, as shown in figure 82. A/D Data Register (ADRL: \$017, ADRU: \$018): Eight-bit read-only register consisting of a 4-bit lower digit and 4-bit upper digit. This register is not cleared by reset. After the completion of A/D conversion, the resultant eight-bit data is held in this register until the start of the next conversion (figures 83, 84, and 85). A/D Start Flag (ADSF: \$020, Bit 2): One-bit flag that initiates A/D conversion when set to 1. At the completion of A/D conversion, the converted data is stored in the A/D data register and the A/D start flag is cleared. Refer to figure 86. Figure 81 Block Diagram of A/D Converter Note on Use: Use the SEM and SEMD instructions to write data to the A/D start flag (ADSF: \$020, bit 2), but make sure that the A/D start flag is not written to during A/D conversion. Data read from the A/D data register (ADRL: \$017, ADRU: \$018) during A/D conversion cannot be guaranteed. The A/D converter does not operate in the stop, watch, and subactive modes because of the OSC clock. During these low-power dissipation modes, current through the resistor ladder is cut off to decrease the power input. Figure 82 A/D Mode Register (AMR) Figure 83 A/D Data Registers (ADRU, ADRL) # A/D data register (lower digit) (ADRL: \$017) Bit 3 2 1 0 Initial value 0 0 0 0 Read/Write R R R R Bit name ADRL3 ADRL2 ADRL1 ADRL0 Figure 84 A/D Data Register Lower Digit (ADRL) Figure 85 A/D Data Register Upper Digit (ADRU) Figure 86 A/D Start Flag (ADSF) #### **DTMF Generation Circuit** The MCU provides a dual-tone multifrequency (DTMF) generation circuit. The DTMF signal consists of two sine waves to access the switching system. Figure 87 shows the DTMF keypad and frequencies. Each key enables tones to be generated corresponding to each frequency. Figure 88 shows a block diagram of the DTMF circuit. The OSC clock (400 kHz, 800 kHz, 2 MHz, or 4 MHz) is changed into four clock signals through the division circuit (1/2, 1/5, and 1/10). The DTMF circuit uses one of the four clock signals, which is selected by the system clock select register (SSR: \$029) depending on the OSC clock frequency. The DTMF circuit has transformed programmable dividers, sine wave counters, and control registers. The DTMF generation circuit is controlled by the following three registers. Tone Generator Mode Register (TGM: \$019): Four-bit write-only register, which controls output frequencies as shown in figure 89, and is reset to \$0 by MCU reset. Tone Generator Control Register (TGC: \$01A): Three-bit write-only register, which controls the start/stop of the DTMF signal output as shown in figure 90, and is reset to \$0 by MCU reset. TONER and TONEC output can be independently controlled by bits 3 and 2 (TGC3, TGC2), and the DTMF circuit is controlled by bit 1 (TGC1) of this register. System Clock Select Register (SSR: \$029): Four-bit write-only register. This register must be set to the value specified in figure 91 depending on the frequency of the oscillator connected to the OSC<sub>1</sub> and OSC<sub>2</sub> pins. Note that if the combination of the oscillation frequency and the value in this register is different from that specified in figure 91, the DTMF output frequencies will differ from the correct frequencies as listed in figure 89. Figure 87 DTMF Keypad and Frequencies Figure 88 Block Diagram of DTMF Circuit # Tone generator mode register (TGM: \$019) | Bit | 3 | 2 | 1 | 0 | |---------------|------|------|------|------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | TGM3 | TGM2 | TGM1 | TGM0 | | ТСМЗ | TGM2 | TONEC output frequencies | |------|------|----------------------------| | 0 | 0 | f <sub>C1</sub> (1,209 Hz) | | 0 | 1 | f <sub>C2</sub> (1,336 Hz) | | 1 | 0 | f <sub>C3</sub> (1,477 Hz) | | 1 | 1 | f <sub>C4</sub> (1,633 Hz) | | TGM1 | TGM0 | TONER output frequencies | |------|------|--------------------------| | 0 | 0 | f <sub>R1</sub> (697 Hz) | | 0 | 1 | f <sub>R2</sub> (770 Hz) | | 1 | 0 | f <sub>R3</sub> (852 Hz) | | 1 | 1 | f <sub>R4</sub> (941 Hz) | Figure 89 Tone Generator Mode Register (TGM) ## Tone generator control register (TGC: \$01A) | Bit | 3 | 2 | 1 | 0 | |---------------|------|------|------|----------| | Initial value | 0 | 0 | 0 | - | | Read/Write | W | w | w | | | Bit name | TGC3 | TGC2 | TGC1 | Not used | | GC3 | FONEC output control (column) | |-----|-------------------------------| | 0 1 | No output | | 1 - | TONEC output (active) | | | | | TGC1 | DTMF enable bit | |------|-----------------| | 0 | DTMF disable | | 1 | DTMF enable | | TGC2 | TONER output control (row) | |------|----------------------------| | 0 | No output | | 1 | TONER output (active) | Figure 90 Tone Generator Control Register (TGC) **DTMF Output:** The sine waves of the row-group and column-group are individually converted in the D/A conversion circuit which provides a highprecision ladder resistance. The DTMF output pins (TONER, TONEC) transmit the sine waves of the row-group and column-group, respectively. Figure 92 shows the tone output equivalent circuit. Figure 93 shows the output waveform. One cycle of this wave consists of 32 slots. Therefore, the output waveform is stable with little distortion. Table 30 lists the frequency deviation of the MCU from standard DTMF signals. Table 30 Frequency Deviation of the MCU from Standard DTMF | | Standard DTMF (Hz) | MCU (Hz) | Deviation from Standard (%) | |----|--------------------|----------|-----------------------------| | R1 | 697 | 694.44 | -0.37 | | R2 | 770 | 769.23 | -0.10 | | R3 | 852 | 851.06 | -0.11 | | R4 | 941 | 938.97 | -0.22 | | C1 | 1,209 | 1,212.12 | 0.26 | | C2 | 1,336 | 1,333.33 | -0.20 | | СЗ | 1,477 | 1,481.48 | 0.30 | | C4 | 1,633 | 1,639.34 | 0.39 | Note: This frequency deviation value does not include the frequency deviation due to the oscillator element. Also note that in this case the ratio of the high level and low level widths in the oscillator waveform due to the oscillator element will be 50%:50%. #### System clock select register (SSR: \$029) | Bit | 3 | 2 | . 1 | 0 | |---------------|------|------|------|------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | SSR3 | SSR2 | SSR1 | SSR0 | | SSR3 | 32-kHz oscillation stop | |------|-----------------------------------| | 0 | Oscillation operates in stop mode | | 1 | Oscillation stops in stop mode | | SSR2 | 32-kHz oscillation division ratio selection | | |------|---------------------------------------------|--| | 0 | f <sub>SUB</sub> = f <sub>X</sub> /8 | | | 1 | f <sub>SUB</sub> = f <sub>X</sub> /4 | | | SSR1 | SSR0 | System clock selection | |------|------|------------------------| | 0 | 0 | 400 kHz | | 0 | 1 | 800 kHz | | 1 | 0 | 2 MHz | | 1 | 1 | 4 MHz | Note: SSR3 is cleared only by a RESET input. SSR3 will not be cleared by a STOPC input during stop mode, and will retain its value. SSR3 will also not be cleared upon entering stop mode. Figure 91 System Clock Select Register (SSR) Figure 92 Tone Output Equivalent Circuit Figure 93 Waveform of Tone Output #### LCD Controller/Driver The MCU has an LCD controller and driver which drive 4 common signal pins and 52 segment pins. The controller consists of a RAM area in which display data is stored, a display control register (LCR: \$01B), and a duty-cycle/clock-control register (LMR: \$01C) (figure 94). Four duty cycles and the LCD clock are pro- grammable, and a built-in dual-port RAM ensures that display data can be automatically transmitted to the segment signal pins without program intervention. If a 32-kHz oscillation clock is selected as the LCD clock source, the LCD can even be used in watch mode, in which the system clock stops. Figure 94 Block Diagram of Liquid Crystal Display Control System LCD Data Area and Segment Data (\$050-\$083): As shown in figure 95, each bit of the storage area corresponds to one of four duty cycles. If data is written to an area corresponding to a certain duty cycle, it is automatically output to the corresponding segments as display data. LCD Control Register (LCR: \$01B): Three-bit write-only register which controls LCD blanking, on/off switching of the liquid-crystal display's power supply division resistor, and display in watch and subactive modes, as shown in figure 96. · Blank/display Blank: Segment signals are turned off, regardless of LCD RAM data setting. Display: LCD RAM data is output as segment signals. · Power switch on/off Off: The power switch is off. On: The power switch is on and $V_1$ is $V_{CC}$ . · Watch/subactive mode display Off: In watch and subactive modes, all common and segment pins are grounded and the liquid-crystal power switch is turned off. On: In watch and subactive modes, LCD RAM data is output as segment signals. LCD Duty-Cycle/Clock Control Register (LMR: \$01C): Four-bit write-only register which selects the display duty cycle and LCD clock source, as shown in figure 97. The dependence of frame frequency on duty cycle is listed in table 31. LCD Output Register 1 (LOR1: \$01D): Writeonly register used to specify ports R3<sub>0</sub>-R3<sub>3</sub> as pins SEG1-SEG4 by individual pins (figure 98). | | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-----|-------|-------|-------|-------|-------|-----|-------|-------|-------|-------|-------| | 80 | SEG1 | SEG1 | SEG1 | SEG1 | \$050 | 106 | SEG27 | SEG27 | SEG27 | SEG27 | \$06. | | 81 | SEG2 | SEG2 | SEG2 | SEG2 | \$051 | 107 | SEG28 | SEG28 | SEG28 | SEG28 | \$061 | | 82 | SEG3 | SEG3 | SEG3 | SEG3 | \$052 | 108 | SEG29 | SEG29 | SEG29 | SEG29 | \$060 | | 83 | SEG4 | SEG4 | SEG4 | SEG4 | \$053 | 109 | SEG30 | SEG30 | SEG30 | SEG30 | \$060 | | 84 | SEG5 | SEG5 | SEG5 | SEG5 | \$054 | 110 | SEG31 | SEG31 | SEG31 | SEG31 | \$06 | | 85 | SEG6 | SEG6 | SEG6 | SEG6 | \$055 | 111 | SEG32 | SEG32 | SEG32 | SEG32 | \$06 | | 86 | SEG7 | SEG7 | SEG7 | SEG7 | \$056 | 112 | SEG33 | SEG33 | SEG33 | SEG33 | \$07 | | 87 | SEG8 | SEG8 | SEG8 | SEG8 | \$057 | 113 | SEG34 | SEG34 | SEG34 | SEG34 | \$07 | | 88 | SEG9 | SEG9 | SEG9 | SEG9 | \$058 | 114 | SEG35 | SEG35 | SEG35 | SEG35 | \$07 | | 89 | SEG10 | SEG10 | SEG10 | SEG10 | \$059 | 115 | SEG36 | SEG36 | SEG36 | SEG36 | \$07 | | 90 | SEG11 | SEG11 | SEG11 | SEG11 | \$05A | 116 | SEG37 | SEG37 | SEG37 | SEG37 | \$07 | | 91 | SEG12 | SEG12 | SEG12 | SEG12 | \$05B | 117 | SEG38 | SEG38 | SEG38 | SEG38 | \$07 | | 92 | SEG13 | SEG13 | SEG13 | SEG13 | \$05C | 118 | SEG39 | SEG39 | SEG39 | SEG39 | \$07 | | 93 | SEG14 | SEG14 | SEG14 | SEG14 | \$05D | 119 | SEG40 | SEG40 | SEG40 | SEG40 | \$07 | | 94 | SEG15 | SEG15 | SEG15 | SEG15 | \$05E | 120 | SEG41 | SEG41 | SEG41 | SEG41 | \$07 | | 95 | SEG16 | SEG16 | SEG16 | SEG16 | \$05F | 121 | SEG42 | SEG42 | SEG42 | SEG42 | \$07 | | 96 | SEG17 | SEG17 | SEG17 | SEG17 | \$060 | 122 | SEG43 | SEG43 | SEG43 | SEG43 | \$07 | | 97 | SEG18 | SEG18 | SEG18 | SEG18 | \$061 | 123 | SEG44 | SEG44 | SEG44 | SEG44 | \$07 | | 98 | SEG19 | SEG19 | SEG19 | SEG19 | \$062 | 124 | SEG45 | SEG45 | SEG45 | SEG45 | \$07 | | 99 | SEG20 | SEG20 | SEG20 | SEG20 | \$063 | 125 | SEG46 | SEG46 | SEG46 | SEG46 | \$07 | | 100 | SEG21 | SEG21 | SEG21 | SEG21 | \$064 | 126 | SEG47 | SEG47 | SEG47 | SEG47 | \$07 | | 101 | SEG22 | SEG22 | SEG22 | SEG22 | \$065 | 127 | SEG48 | SEG48 | SEG48 | SEG48 | \$07 | | 102 | SEG23 | SEG23 | SEG23 | SEG23 | \$066 | 128 | SEG49 | SEG49 | SEG49 | SEG49 | \$08 | | 103 | SEG24 | SEG24 | SEG24 | SEG24 | \$067 | 129 | SEG50 | SEG50 | SEG50 | SEG50 | \$08 | | 104 | SEG25 | SEG25 | SEG25 | SEG25 | \$068 | 130 | SEG51 | SEG51 | SEG51 | SEG51 | \$08 | | 105 | SEG26 | SEG26 | SEG26 | SEG26 | \$069 | 131 | SEG52 | SEG52 | SEG52 | SEG52 | \$01 | Figure 95 Configuration of LCD RAM Area (for Dual-Port RAM) LCD Output Register 2 (LOR2: \$01E): Writeonly register used to specify ports R4<sub>0</sub>-R4<sub>3</sub> as pins SEG5-SEG8 by individual pins (figure 99). LCD Output Register 3 (LOR3: \$01F): Writeonly register used to specify ports R5-R7 as pins SEG9-SEG20 in 4-pin units (figure 100). Large Liquid-Crystal Panel Drive and V<sub>LCD</sub>: To drive a large-capacity LCD, decrease the resistance of the built-in division resistors by attaching external resistors in parallel, as shown in figure 101. The size of these resistors cannot be simply calcu- lated from the LCD load capacitance because the matrix configuration of the LCD complicates the paths of charge/discharge currents flowing through the capacitors—the resistance will also vary with lighting conditions. This size must be determined by trial-and-error, taking into account the power dissipation of the device using the LCD, but a resistance of 1 to $10~\mathrm{k}\Omega$ would usually be suitable. (Another effective method is to attach capacitors of $0.1~\mathrm{to}~0.3~\mu\mathrm{E}$ ) Always turn off the power switch (set bit 1 of the LCR to 0) before changing the liquid-crystal drive voltage $(V_{LCD})$ . Figure 96 LCD Control Register (LCR) | Bit | 3 | 2 | 1 | 0 | |---------------|------|------|------|------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | w | w | | Bit name | LMR3 | LMR2 | LMR1 | LMR0 | | LMR3 | LMR2 | Input clock source selection | |------|------|-----------------------------------------------------------------| | 0 | 0 | CL0 (32.768-kHz × duty/64: when 32.768-kHz oscillation is used) | | 0 | 1 | CL1 (fosc × duty cycle/1024) | | 1 | 0 | CL2 (fosc × duty cycle/8192) | | 1 | 1 | CL3 (refer to table 30) | | LMR1 | LMR0 | Duty cycle selection | | |------|------|----------------------|--| | 0 | 0 | 1/4 duty | | | 0 | 1 | 1/3 duty | | | 1 | 0 | 1/2 duty | | | 1 | 1 | Static | | Figure 97 LCD Duty-Cycle/Clock Control Register (LMR) Table 31 LCD Frame Frequencies for Different Duty Cycles | Frame Frequencie | | |------------------|--| | | | | | | | Duty Cycle | LMR3 | LMR2 | | f <sub>OSC</sub> = 400 kHz | f <sub>OSC</sub> =<br>800 kHZ | f <sub>OSC</sub> =<br>2 MHz | f <sub>OSC</sub> =<br>4 MHz | | |------------|------|---------|------|----------------------------|-------------------------------|-----------------------------|-----------------------------|--| | Static | 0 | 0 | CL0 | | 5 | 12 Hz | | | | | | 1 | CL1 | 390.6 Hz | 781.3 Hz | 1953 Hz | 3906 Hz | | | • | 1 | 0 | CL2 | 48.8 Hz | 97.7 Hz | 244.1 Hz | 488.3 Hz | | | | | 1 | CL3* | 24.4 Hz | 48.8 Hz | 122.1 Hz | 244.1 Hz | | | | | | | | 6- | 4 Hz | | | | 1/2 | 0 | 0 | CL0 | | 2 | 56 Hz | | | | | | 1 | CL1 | 195.3 Hz | 390.6 Hz | 976.6 Hz | 1953 Hz | | | | 1 | 0 | CL2 | 24.4 Hz | 48.8 Hz | 122.1 Hz | 244.1 Hz | | | | | 1 | CL3* | 12.2 Hz | 24.4 Hz | 61 Hz | 122.1 Hz | | | | | | | • | 3: | 2 Hz | | | | 1/3 0 | 0 | 0 | CLO | | 170.7 Hz | | | | | | | 1 | CL1 | 130.2 Hz | 260.4 Hz | 651 Hz | 1302 Hz | | | | 1 - | 0 | CL2 | 16.3 Hz | 32.6 Hz | 81.4 Hz | 162.8 Hz | | | | | 1 | CL3* | 8.1 Hz | 16.3 Hz | 40.7 Hz | 81.4 Hz | | | | | | | | 2 | 1.3 Hz | | | | 1/4 | 0 | 0 0 CL0 | | | 1: | 28 Hz | | | | | | 1 | CL1 | 97.7 Hz | 195.3 Hz | 488.3 Hz | 976.6 Hz | | | | 1 | 0 | CL2 | 12.2 Hz | 24.4 Hz | 61 Hz | 122.1 Hz | | | | | 1 | CL3* | 6.1 Hz | 12.2 Hz | 30.5 Hz | 61 Hz | | | | | | | | 10 | 6 Hz | | | Note: \* The division ratio depends on the value of bit 3 of timer mode register A (TMA). Upper value: When TMA3 = 0, CL3 = $f_{OSC} \times duty \ cycle/16384$ . Lower value: When TMA3 = 1, CL3 = 32.768 kHz $\times duty \ cycle/512$ . # LCD output register 1 (LOR1: \$01D) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | w | W | | Bit name | LOR13 | LOR12 | LOR11 | LOR10 | | LOR13 | R3 <sub>3</sub> /SEG4 mode selection | |-------|--------------------------------------| | 0 | R3 <sub>3</sub> | | 1 | SEG4 | | LOR11 | R3 <sub>1</sub> /SEG2 mode selection | |-------|--------------------------------------| | 0 | R3 <sub>1</sub> | | 1 | SEG2 | | LOR12 | R3 <sub>2</sub> /SEG3 mode selection | |-------|--------------------------------------| | 0 | R3 <sub>2</sub> | | 1 | SEG3 | | LOR10 | R3 <sub>0</sub> /SEG1 mode selection | |-------|--------------------------------------| | 0 | R3 <sub>0</sub> | | 1 | SEG1 | Figure 98 LCD Output Register 1 (LOR1) # LCD output register 2 (LOR2: \$01E) | Bit | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------| | Initial value | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | | Bit name | LOR23 | LOR22 | LOR21 | LOR20 | | LOR23 | R4 <sub>3</sub> /SEG8 mode selection | |-------|--------------------------------------| | 0 | R43 | | 1 | SEG8 | | LOR21 | R4 <sub>1</sub> /SEG6 mode selection | |-------|--------------------------------------| | 0 | R4 <sub>1</sub> | | 1 | SEG6 | | LOR22 | R4 <sub>2</sub> /SEG7 mode selection | |-------|--------------------------------------| | 0 | R4 <sub>2</sub> | | 1 | SEG7 | | LOR20 | R4 <sub>0</sub> /SEG5 mode selection | |-------|--------------------------------------| | 0 | R4 <sub>0</sub> | | 1 | SEG5 | Figure 99 LCD Output Register 2 (LOR2) # LCD output register 3 (LOR3: \$01F) | Bit | 3 | 2 | 1 | 00 | |---------------|----------|-------|-------|-------| | Initial value | | 0 | 0 | 0 | | Read/Write | | W | W | W | | Bit name | Not used | LOR32 | LOR31 | LOR30 | | LOR32 | R7/SEG17-SEG20 mode selection | |-------|-------------------------------| | 0 | R7 | | 1 | SEG17-SEG20 | | LOR30 | R5/SEG9-SEG12 mode selection | |-------|------------------------------| | 0 | R5 | | 1 | SEG9-SEG12 | | LOR31 | R6/SEG13-SEG16 mode selection | |-------|-------------------------------| | 0 | R6 | | 1 | SEG13-SEG16 | Figure 100 LCD Output Register 3 (LOR3) Figure 101 LCD Connection Examples # **Notes on Mounting** Assemble all parts including the HD404629 Series on a board, noting the points described below. - Connect layered ceramic type capacitors (about 0.1 μF) between AV<sub>CC</sub> and AV<sub>SS</sub>, between V<sub>CC</sub> and GND, and between used analog pins and AV<sub>SS</sub>. - 2. Connect unused analog pins to AVSS. Figure 102 Example of Connections (1) Between the $V_{CC}$ and GND lines, connect capacitors designed for use in ordinary power supply circuits. An example connection is described in figure 103. No resistors can be inserted in series in the power supply circuit, so the capacitors should be connected in parallel. The capacitors are a large capacitance $C_1$ and a small capacitance $C_2$ . Figure 103 Example of Connections (2) # Programmable ROM (HD4074629) The HD4074629 is a ZTAT™ microcomputer with built-in PROM that can be programmed in PROM mode. # **PROM Mode Pin Description** | Pin N | lo. | MCU Mod | le | PROM N | lode | Pin l | No. | MCU Mode PF | | PROM | PROM Mode | | |---------------------|---------|-----------------------------------|-----|-----------------|------|---------------------|---------|-----------------------------------|-----|-----------------|-----------|--| | FP-100B<br>TFP-100B | FP-100A | Pin<br>Name | 1/0 | Pin<br>Name | 1/0 | FP-100B<br>TFP-100B | FP-100A | Pin<br>Name | 1/0 | Pin<br>Name | 1/0 | | | 1 | 3 | AV <sub>CC</sub> | • | V <sub>CC</sub> | | 29 | 31 | R0 <sub>3</sub> /INT <sub>4</sub> | 1/0 | | | | | 2 | 4 | AN <sub>0</sub> | ı | | | 30 | 32 | R1 <sub>0</sub> /TOB | 1/0 | A <sub>5</sub> | ı | | | 3 | 5 | AN <sub>1</sub> | 1 | | | 31 | 33 | R1 <sub>1</sub> /TOC | I/O | A <sub>6</sub> | 1 | | | 4 | 6 | AN <sub>2</sub> | I | | | 32 | 34 | R1 <sub>2</sub> /TOD | 1/0 | A <sub>7</sub> | 1 | | | 5 | 7 | AN <sub>3</sub> | 1 | | | 33 | 35 | R1 <sub>3</sub> /EVNB | 1/0 | A <sub>8</sub> | ı | | | 6 | 8 | AV <sub>SS</sub> | | GND | | 34 | 36 | R2 <sub>0</sub> /EVND | 1/0 | A <sub>0</sub> | Ĭ | | | 7 | 9 | TEST | I | TEST | 1 | 35 | 37 | R2 <sub>1</sub> /SCK | I/O | A <sub>10</sub> | ī | | | 8 | 10 | OSC <sub>1</sub> | 1 | V <sub>CC</sub> | | 36 | 38 | R2 <sub>2</sub> /SI | 1/0 | A <sub>11</sub> | ı | | | 9 | 11 | OSC <sub>2</sub> | 0 | ********** | | 37 | 39 | R2 <sub>3</sub> /SO | I/O | A <sub>12</sub> | l l | | | 10 | 12 | RESET | ł | RESET | 1 | 38 | 40 | R3 <sub>0</sub> /SEG1 | 1/0 | A <sub>13</sub> | 1 | | | 11 | 13 | X1 | ı | GND | | 39 | 41 | R3 <sub>1</sub> /SEG2 | 1/0 | A <sub>14</sub> | ı | | | 12 | 14 | X2 | 0 | | | 40 | 42 | R3 <sub>2</sub> /SEG3 | 1/0 | Ο <sub>0</sub> | 1/0 | | | 13 | 15 | GND | | GND | | 41 | 43 | R3 <sub>3</sub> /SEG4 | I/O | 01 | 1/0 | | | 14 | 16 | Do | 1/0 | CE | 1 | 42 | 44 | R4 <sub>0</sub> /SEG5 | 1/0 | 02 | 1/0 | | | 15 | 17 | D <sub>1</sub> | 1/0 | ŌĒ | ı | 43 | 45 | R4 <sub>1</sub> /SEG6 | 1/0 | 03 | 1/0 | | | 16 | 18 | D <sub>2</sub> | I/O | V <sub>CC</sub> | | 44 | 46 | R4 <sub>2</sub> /SEG7 | 1/0 | 04 | 1/0 | | | 17 | 19 | D <sub>3</sub> | I/O | V <sub>cc</sub> | | 45 | 47 | R4 <sub>3</sub> /SEG8 | 1/0 | O <sub>5</sub> | 1/0 | | | 18 | 20 | D <sub>4</sub> | I/O | | | 46 | 48 | R5 <sub>0</sub> /SEG9 | 1/0 | O <sub>6</sub> | 1/0 | | | 19 | 21 | D <sub>5</sub> | I/O | | | 47 | 49 | R5 <sub>1</sub> /SEG10 | I/O | 07 | 1/0 | | | 20 | 22 | D <sub>6</sub> | 1/0 | | | 48 | 50 | R5 <sub>2</sub> /SEG11 | 1/0 | O <sub>4</sub> | 1/0 | | | 21 | 23 | D <sub>7</sub> | I/O | | | 49 | 51 | R5 <sub>3</sub> /SEG12 | 1/0 | O <sub>3</sub> | 1/0 | | | 22 | 24 | D <sub>8</sub> | I/O | | | 50 | 52 | R6 <sub>0</sub> /SEG13 | I/O | 02 | 1/0 | | | 23 | 25 | D <sub>9</sub> | 1/0 | | | 51 | 53 | R6 <sub>1</sub> /SEG14 | 1/0 | 01 | 1/0 | | | 24 | 26 | D <sub>10</sub> /STOPC | I/O | A <sub>9</sub> | 1 | 52 | 54 | R6 <sub>2</sub> /SEG15 | 1/0 | O <sub>0</sub> | 1/0 | | | 25 | 27 | D <sub>11</sub> /INT <sub>0</sub> | 1/0 | V <sub>PP</sub> | | 53 | 55 | R6 <sub>3</sub> /SEG16 | 1/0 | V <sub>cc</sub> | | | | 26 | 28 | R0 <sub>0</sub> /INT <sub>1</sub> | 1/0 | M <sub>0</sub> | ı | 54 | 56 | R7 <sub>0</sub> /SEG17 | 1/0 | A <sub>1</sub> | 1 | | | 27 | 29 | R0 <sub>1</sub> /INT <sub>2</sub> | I/O | M <sub>1</sub> | 1 | 55 | 57 | R7 <sub>1</sub> /SEG18 | I/O | A <sub>2</sub> | Ī | | | 28 | 30 | R0 <sub>2</sub> /INT <sub>3</sub> | I/O | | | 56 | 58 | R7 <sub>2</sub> /SEG19 | 1/0 | A <sub>3</sub> | ı | | | | | | | | | | | | | | | | Notes on next page. # **PROM Mode Pin Description (cont)** | Pin N | lo. | MCU Mod | de | PROM I | Mode | Pin I | No. | MCU Mode PROM | | PROM | M Mode | | |---------------------|---------|------------------------|-----|----------------|------|---------------------|---------|-------------------|----|-----------------|-------------|--| | FP-100B<br>TFP-100B | FP-100A | Pin<br>Name | I/O | Pin<br>Name | 1/0 | FP-100B<br>TFP-100B | FP-100A | Pin<br>Name | VO | Pin<br>Name | I/O | | | 57 | 59 | R7 <sub>3</sub> /SEG20 | I/O | A <sub>4</sub> | 1 | 79 | 81 | SEG42 | 0 | | | | | 58 | 60 | SEG21 | 0 | | | 80 | 82 | SEG43 | 0 | | | | | 59 | 61 | SEG22 | 0 | | | 81 | 83 | SEG44 | 0 | | | | | 60 | 62 | SEG23 | 0 | | | 82 | 84 | SEG45 | 0 | | | | | 61 | 63 | SEG24 | 0 | | | 83 | 85 | SEG46 | 0 | | | | | 62 | 64 | SEG25 | 0 | | | 84 | 86 | SEG47 | 0 | | | | | 63 | 65 | SEG26 | 0 | | | 85 | 87 | SEG48 | 0 | | - | | | 64 | 66 | SEG27 | 0 | | | 86 | 88 | SEG49 | 0 | | | | | 65 | 67 | SEG28 | 0 | | | 87 | 89 | SEG50 | 0 | | | | | 66 | 68 | SEG29 | 0 | | | 88 | 90 | SEG51 | 0 | | | | | 67 | 69 | SEG30 | 0 | | | 89 | 91 | SEG52 | 0 | | | | | 68 | 70 | SEG31 | 0 | | | 90 | 92 | COM1 | 0 | | | | | 69 | 71 | SEG32 | 0 | | | 91 | 93 | COM2 | 0 | • | | | | 70 | 72 | SEG33 | 0 | | | 92 | 94 | СОМЗ | 0 | | | | | 71 | 73 | SEG34 | 0 | | | 93 | 95 | COM4 | 0 | | | | | 72 | 74 | SEG35 | 0 | | | 94 | 96 | V <sub>1</sub> | | | <del></del> | | | 73 | 75 | SEG36 | 0 | | | 95 | 97 | V <sub>2</sub> | | | | | | 74 | 76 | SEG37 | 0 | | | 96 | 98 | V <sub>3</sub> | | | · | | | 75 | 77 | SEG38 | 0 | | | 97 | 99 | V <sub>CC</sub> | | V <sub>CC</sub> | | | | 76 | 78 | SEG39 | 0 | | _ | 98 | 100 | TONEC | 0 | | | | | 77 | 79 | SEG40 | 0 | | - | 99 | 1 | TONER | 0 | | | | | 78 | 80 | SEG41 | 0 | | | 100 | 2 | VT <sub>ref</sub> | | | | | Notes: 1. I/O: Input/output pin, I: Input pin, O: Output pin 2. Each of O<sub>0</sub>-O<sub>4</sub> has two pins; before using, each pair must be connected together. #### **Programming the Built-In PROM** The MCU's built-in PROM is programmed in PROM mode. PROM mode is set by pulling $\overline{\text{TEST}}$ , $\overline{\text{M}}_0$ , and $\overline{\text{M}}_1$ low, and RESET high as shown in figure 104. In PROM mode, the MCU does not operate, but it can be programmed in the same way as any other commercial 27256-type EPROM using a standard PROM programmer and a 100-to-28-pin socket adapter. Recommended PROM programmers and socket adapters are listed in table 32. Since an HMCS400-series instruction is ten bits long, the HMCS400-series MCU has a built-in conversion circuit to enable the use of a generalpurpose PROM programmer. This circuit splits each instruction into five lower bits and five upper bits that are read from or written to consecutive addresses. This means that if, for example, 16 kwords of built-in PROM are to be programmed by a general-purpose PROM programmer, a 32-kbyte address space (\$0000-\$7FFF) must be specified. Table 32 Recommended PROM Programmers and Socket Adapters | .PROM Programmer | | Socket Adapter | | | | |------------------|------------|----------------|-----------------------------------------------------------|---------|--| | Manufacturer | Model name | Package | ackage Model Name Manufacturer P-100B HS462ESH01H Hitachi | | | | DATA I/O Corp. | 121B, | FP-100B | HS462ESH01H | Hitachi | | | | 29B | FP-100A | HS462ESF01H | | | | | | TFP-100B | HS4629ESN01H | | | | AVAL Corp. | PKW-1000 | FP-100B | HS462ESH01H | | | | | | FP-100A | HS462ESF01H | | | | | | TFP-100B | HS4629ESN01H | | | Figure 104 PROM Mode Connections #### Warnings Always specify addresses \$0000 to \$7FFF when programming with a PROM programmer. If address \$8000 or higher is accessed, the PROM may not be programmed or verified correctly. Set all data in unused addresses to \$FF. Note that the plastic-package version cannot be erased and reprogrammed. 2. Make sure that the PROM programmer, socket adapter, and LSI are aligned correctly (their pin 1 positions match), otherwise overcurrents may damage the LSI. Before starting programming, make sure that the LSI is firmly fixed in the socket adapter and the socket adapter is firmly fixed onto the programmer. PROM programmers have two voltages (V<sub>PP</sub>): 12.5 V and 21 V. Remember that ZTAT<sup>™</sup> devices require a V<sub>PP</sub> of 12.5 V—the 21-V setting will damage them. 12.5 V is the Intel 27256 setting. ## **Programming and Verification** The built-in PROM of the MCU can be programmed at high speed without risk of voltage stress or damage to data reliability. Programming and verification modes are selected as listed in table 33. For details of PROM programming, refer to the following Notes on PROM Programming section. **Table 33 PROM Mode Selection** | | | | Pin | | |-----------------------|------|------|-----------------|--------------------------------| | Mode | CE | ŌĒ | V <sub>PP</sub> | O <sub>0</sub> -O <sub>7</sub> | | Programming | Low | High | V <sub>PP</sub> | Data input | | Verification | High | Low | V <sub>PP</sub> | Data output | | Programming inhibited | High | High | V <sub>PP</sub> | High impedance | ## **Addressing Modes** #### **RAM Addressing Modes** The MCU has three RAM addressing modes, as shown in figure 105 and described below. Register Indirect Addressing Mode: The contents of the W, X, and Y registers (10 bits in total) are used as a RAM address. When the area from \$090 to \$25F is used, a bank must be selected by the bank register (V: \$03F). Direct Addressing Mode: A direct addressing instruction consists of two words. The first word contains the opcode, and the contents of the second word (10 bits) are used as a RAM address. Memory Register Addressing Mode: The memory registers (MR), which are located in 16 addresses from \$040 to \$04F, are accessed with the LAMR and XMRA instructions. Figure 105 RAM Addressing Modes #### ROM Addressing Modes and the P Instruction The MCU has four ROM addressing modes, as shown in figure 106 and described below. **Direct Addressing Mode:** A program can branch to any address in the ROM memory space by executing the JMPL, BRL, or CALL instruction. Each of these instructions replaces the 14 program counter bits (PC<sub>13</sub>-PC<sub>0</sub>) with 14-bit immediate data. Current Page Addressing Mode: The MCU has 64 pages of ROM with 256 words per page. A program can branch to any address in the current page by executing the BR instruction. This instruction replaces the eight low-order bits of the program counter $(PC_7-PC_0)$ with eight-bit immediate data. If the BR instruction is on a page boundary (address 256n + 255), executing that instruction transfers the PC contents to the next physical page, as shown in figure 108. This means that the execution of the BR instruction on a page boundary will make the program branch to the next page. Note that the HMCS400-series cross macroassembler has an automatic paging feature for ROM pages. Zero-Page Addressing Mode: A program can branch to the zero-page subroutine area located at 0000-003F by executing the CAL instruction. When the CAL instruction is executed, 6 bits of immediate data are placed in the six low-order bits of the program counter (PC<sub>5</sub>-PC<sub>0</sub>), and 0s are placed in the eight high-order bits (PC<sub>13</sub>-PC<sub>6</sub>). Table Data Addressing Mode: A program can branch to an address determined by the contents of four-bit immediate data, the accumulator, and the B register by executing the TBR instruction. P Instruction: ROM data addressed in table data addressing mode can be referenced with the P instruction as shown in figure 107. If bit 8 of the ROM data is 1, eight bits of ROM data are written to the accumulator and the B register. If bit 9 is 1, eight bits of ROM data are written to the R1 and R2 port output registers. If both bits 8 and 9 are 1, ROM data is written to the accumulator and the B register, and also to the R1 and R2 port output registers at the same time. The P instruction has no effect on the program counter. 267 Hitachi Figure 106 ROM Addressing Modes Figure 107 P Instruction Figure 108 Branching when the Branch Destination is on a Page Boundary ### **Absolute Maximum Ratings** | Item | Symbol | Value | Unit | Notes | |----------------------------------|--------------------------|---------------------------------|------|-------| | Supply voltage | V <sub>cc</sub> | -0.3 to +7.0 | ٧ | | | Programming voltage | V <sub>PP</sub> | -0.3 to +14.0 | ٧ | 1 | | Pin voltage | V <sub>T</sub> | -0.3 to (V <sub>CC</sub> + 0.3) | ٧ | | | Total permissible input current | Σl <sub>o</sub> | 100 | mA | 2 | | Total permissible output current | <b>-</b> Σl <sub>o</sub> | 50 | mA | 3 | | Maximum input current | I <sub>o</sub> | 4 | mA | 4, 5 | | | | 30 | mA | 4, 6 | | Maximum output current | -l <sub>o</sub> | 4 | mA | 7, 8 | | Operating temperature | Topr | -20 to +75 | °C | | | Storage temperature | T <sub>stg</sub> | -55 to +125 | °C | | Notes: Permanent damage may occur if these absolute maximum ratings are exceeded. Normal operation must be under the conditions stated in the electrical characteristics tables. If these conditions are exceeded, the LSI may malfunction or its reliability may be affected. - 1. Applies to D<sub>11</sub> (V<sub>PP</sub>) of the HD4074629. - The total permissible input current is the total of input currents simultaneously flowing in from all the I/O pins to ground. - The total permissible output current is the total of output currents simultaneously flowing out from V<sub>CC</sub> to all I/O pins. - 4. The maximum input current is the maximum current flowing from each I/O pin to ground. - 5. Applies to R0--R7. - 6. Applies to D<sub>0</sub>-D<sub>9</sub>. - 7. The maximum output current is the maximum current flowing out from V<sub>CC</sub> to each I/O pin. - 8. Applies to D<sub>0</sub>-D<sub>9</sub> and R0-R7. #### **Electrical Characteristics** DC Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) | Item | Symbol | Pin(s) | Min | Тур | Max | Unit | Test Condition | Notes | |-------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----|-----------------------|------|-------------------------------------------------------------------|-------| | Input high voltage | V <sub>IH</sub> | RESET, SCK,<br>SI, INT <sub>0</sub> , INT <sub>1</sub> ,<br>INT <sub>2</sub> , INT <sub>3</sub> ,<br>INT <sub>4</sub> , STOPC,<br>EVNB, EVND | 0.9V <sub>CC</sub> | _ | V <sub>CC</sub> + 0.3 | V | _ | | | | | OSC <sub>1</sub> | V <sub>CC</sub> - 0.3 | | V <sub>CC</sub> + 0.3 | ٧ | External clock operation | | | input low<br>voltage | V <sub>IL</sub> | RESET, SCK,<br>SI, INT <sub>0</sub> , INT <sub>1</sub> ,<br>INT <sub>2</sub> , INT <sub>3</sub> ,<br>INT <sub>4</sub> , STOPC,<br>EVNB, EVND | -0.3 | | 0.1V <sub>CC</sub> | V | _ | | | | | OSC <sub>1</sub> | -0.3 | | 0.3 | ٧ | External clock operation | | | Output high voltage | V <sub>OH</sub> | SCK, SO, TOB,<br>TOC, TOD | V <sub>CC</sub> - 1.0 | | | ٧ | -l <sub>OH</sub> = 0.5 mA | | | Output low voltage | V <sub>OL</sub> | SCK, SO, TOB,<br>TOC, TOD | _ | _ | 0.4 | ٧ | I <sub>OL</sub> = 0.4 mA | | | I/O leakage<br>current | 1112 | RESET, SCK,<br>SI, INT <sub>0</sub> , INT <sub>1</sub> ,<br>INT <sub>2</sub> , INT <sub>3</sub> ,<br>INT <sub>4</sub> , STOPC,<br>EVNB, EVND,<br>OSC <sub>1</sub> , TOB,<br>TOC, TOD, SO | _ | | 1.0 | μА | V <sub>in</sub> = 0 V to V <sub>CC</sub> | 1 | | Current dissipation in | I <sub>CC1</sub> | V <sub>cc</sub> | _ | 5 | 9 | mA | V <sub>CC</sub> = 5.0 V,<br>f <sub>OSC</sub> = 4 MHz | 2, 4 | | active mode | I <sub>CC2</sub> | V <sub>CC</sub> | _ | 0.6 | 1.8 | mA | V <sub>CC</sub> = 3.0 V,<br>f <sub>OSC</sub> = 800 kHz | 2, 4 | | Current<br>dissipation in<br>standby mode | I <sub>SBY1</sub> | V <sub>cc</sub> | | 1.2 | 3 | mA | V <sub>CC</sub> = 5.0 V,<br>f <sub>OSC</sub> = 4 MHz,<br>LCD on | 3, 4 | | | I <sub>SBY2</sub> | V <sub>cc</sub> | | 0.2 | 0.7 | mA | V <sub>CC</sub> = 3.0 V,<br>f <sub>OSC</sub> = 800 kHz,<br>LCD on | 3, 4 | Notes on next page. DC Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) (cont) | Item | Symbol | Pin(s) | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | |---------------------------------------------|-------------------|-----------------|-----|-----|-----|------|----------------------------------------------------------------------------|-------| | Current<br>dissipation in<br>subactive mode | I <sub>SUB</sub> | V <sub>CC</sub> | _ | 35 | 70 | μΑ | HD404628,<br>HD4046212,<br>HD404629:<br>V <sub>CC</sub> = 3.0 V,<br>LCD on | 5 | | | | | _ | 70 | 150 | μА | HD4074629:<br>V <sub>CC</sub> = 3.0 V,<br>LCD on | 5 | | Current dissipation in | l <sub>WTC1</sub> | V <sub>CC</sub> | _ | 18 | 40 | μΑ | V <sub>CC</sub> = 3.0 V,<br>LCD on | 5 | | watch mode | I <sub>WTC2</sub> | V <sub>CC</sub> | | 8 | 15 | μА | V <sub>CC</sub> = 3.0 V,<br>LCD off | 5 | | Current dissipation in stop mode | ISTOP | V <sub>CC</sub> | | 1 | 10 | μA | V <sub>CC</sub> = 3.0 V, 5<br>no 32-kHz oscillator | | | Stop mode retaining voltage | V <sub>STOP</sub> | V <sub>CC</sub> | 2 | _ | | ٧ | No 32-kHz<br>oscillator | 6 | Notes: 1. Output buffer current is excluded. I<sub>CC1</sub> and I<sub>CC2</sub> are the source currents when no I/O current is flowing while the MCU is in reset state. Test conditions: MCU: Reset Pins: RESET at V<sub>CC</sub> (V<sub>CC</sub> - 0.3 V to V<sub>CC</sub>) TEST at V<sub>CC</sub> (V<sub>CC</sub> - 0.3 V to V<sub>CC</sub>) I<sub>SBY1</sub> and I<sub>SBY2</sub> are the source currents when no I/O current is flowing while the MCU timer is operating. Test conditions: MCU: I/O reset Serial interface stopped DTMF stopped Standby mode Pins: RESET at GND (0 V to 0.3 V) TEST at $V_{CC}$ ( $V_{CC} - 0.3 \text{ V to } V_{CC}$ ) 4. The current dissipation is in proportion to f<sub>OSC</sub> while the MCU is operating or is in standby mode. The value of the dissipation current when f<sub>OSC</sub> = x MHz is given by the following equation: Maximum value (f<sub>OSC</sub> = x MHz) = x/4 × maximum value (f<sub>OSC</sub> = 4 MHz) 5. These are the source currents when no I/O current is flowing. Test conditions: Pins: RESET at GND (0 V to 0.3 V) $\overline{\text{TEST}}$ at $V_{CC}$ ( $V_{CC} - 0.3$ V to $V_{CC}$ ) $D_{11}$ (V<sub>PP</sub>) at V<sub>CC</sub> (V<sub>CC</sub> - 0.3 V to V<sub>CC</sub>) for the HD4074629 6. RAM data retention. I/O Characteristics for Standard Pins (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) | Item | Symbol | Pin(s) | Min | Тур | Max | Unit | Test Condition | Note | |--------------------------------------|------------------|----------------------------------------------|-----------------------|-----|-----------------------|------|----------------------------------------------------------------------------------|------| | Input high voltage | V <sub>IH</sub> | D <sub>10</sub> , D <sub>11</sub> ,<br>R0R7 | 0.7V <sub>CC</sub> | _ | V <sub>CC</sub> + 0.3 | ٧ | _ | | | Input low voltage | V <sub>IL</sub> | D <sub>10</sub> , D <sub>11</sub> ,<br>R0–R7 | -0.3 | | 0.3V <sub>CC</sub> | ٧ | _ | | | Output high voltage | V <sub>OH</sub> | R0-R7 | V <sub>CC</sub> - 1.0 | | _ | ٧ | -I <sub>OH</sub> = 0.5 mA | | | Output low voltage | V <sub>O</sub> Ĺ | R0-R7 | _ | _ | 0.4 | ٧ | i <sub>OL</sub> = 0.4 mA | | | VO leakage I <sub>IL</sub> current | 111 | D <sub>10</sub> , R0–R7 | _ | | 1 | μA | V <sub>in</sub> = 0 V to V <sub>CC</sub> | 1 | | | | D <sub>11</sub> | | | 1 | μА | HD404628,<br>HD4046212,<br>HD404629:<br>V <sub>in</sub> = 0 V to V <sub>CC</sub> | 1 | | | | | _ | | 1 | μА | HD4074629:<br>V <sub>in</sub> = V <sub>CC</sub> - 0.3 V<br>to V <sub>CC</sub> | 1 | | | | | _ | | 20 | μА | HD4074629:<br>V <sub>in</sub> = 0 V to 0.3 V | 1 | | Puil-up MOS<br>current | -l <sub>PU</sub> | R0-R7 | 5 | 30 | 90 | μА | V <sub>CC</sub> = 3.0 V,<br>V <sub>in</sub> = 0 V | | Note: 1. Output buffer current is excluded. I/O Characteristics for High-Current Pins (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) | item | Symbol | Pin(s) | Min | Тур | Max | Unit | <b>Test Condition</b> | Note | |------------------------|------------------|--------------------------------|-----------------------|-----|-----------------------|------|--------------------------------------------------------------|------| | Input high voltage | V <sub>IH</sub> | D <sub>0</sub> D <sub>9</sub> | 0.7V <sub>CC</sub> | _ | V <sub>CC</sub> + 0.3 | ٧ | _ | | | Input low voltage | V <sub>IL</sub> | D <sub>0</sub> D <sub>9</sub> | -0.3 | | 0.3V <sub>CC</sub> | ٧ | | | | Output high voltage | V <sub>OH</sub> | D <sub>0</sub> –D <sub>9</sub> | V <sub>CC</sub> - 1.0 | | _ | ٧ | -l <sub>OH</sub> = 0.5 mA | | | Output low | V <sub>OL</sub> | D <sub>0</sub> -D <sub>9</sub> | | _ | 0.4 | ٧ | I <sub>OL</sub> = 0.4 mA | | | voltage | | | _ | _ | 2.0 | ٧ | I <sub>OL</sub> = 15 mA,<br>V <sub>CC</sub> = 4.5 V to 6.0 V | 1 | | I/O leakage<br>current | 1 <sub> </sub> | D <sub>0</sub> D <sub>9</sub> | | _ | 1 | μА | V <sub>in</sub> = 0 V to V <sub>CC</sub> | 2 | | Pull-up MOS<br>current | -l <sub>PU</sub> | D <sub>0</sub> –D <sub>9</sub> | 5 | 30 | 90 | μА | V <sub>CC</sub> = 3 V,<br>V <sub>in</sub> = 0 V | | Note: 1. The test condition of HD4074629 is $V_{CC} = 4.5 \text{ V}$ to 5.5 V. 2. Output buffer current is excluded. LCD Circuit Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) | item | Symbol | Pin(s) | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | |--------------------------------------------|------------------|----------------|-----|-----|-----------------|------|--------------------------------|-------| | Segment driver voltage drop | V <sub>DS</sub> | SEG1-SEG52 | _ | | 0.6 | ٧ | I <sub>PD</sub> = 3 μA | 1 | | Common driver voltage drop | V <sub>DC</sub> | COM1-COM4 | _ | | 0.3 | ٧ | l <sub>PD</sub> = 3 μA | 1 | | LCD power<br>supply division<br>resistance | R <sub>W</sub> | _ | 100 | 300 | 900 | kΩ | Between V <sub>1</sub> and GND | | | LCD voltage | V <sub>LCD</sub> | V <sub>1</sub> | 2.7 | | V <sub>CC</sub> | ٧ | _ | 2 | Notes: 1. V<sub>DS</sub> and V<sub>DC</sub> are the voltage drops from power supply pins V<sub>1</sub>, V<sub>2</sub>, V<sub>3</sub>, and GND to each segment pin and each common pin, respectively. 2. When $V_{LCD}$ is supplied from an external source, the following relations must be retained: $V_{CC} \ge V_1 \ge V_2 \ge V_3 \ge GND$ DTMF Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) | Item | Symbol | Pin | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | |-------------------------|------------------|-------|-----|-----|-----|-------------------|-------------------------------------------------------------------------|-------| | Tone output voltage (1) | V <sub>OR</sub> | TONER | 500 | 660 | _ | mV <sub>rms</sub> | $VT_{ref} - GND = 2.0 V$ ,<br>$R_L = 100 k\Omega$ | 1 | | Tone output voltage (2) | V <sub>OC</sub> | TONEC | 520 | 690 | | mV <sub>rms</sub> | $VT_{ref}$ – GND = 2.0 V,<br>R <sub>L</sub> = 100 k $\Omega$ | 1 | | Tone output distortion | % <sub>DIS</sub> | _ | | 3 | 7 | % | Short circuit<br>between TONER<br>and TONEC,<br>R <sub>L</sub> = 100 kΩ | 2 | | Tone output ratio | dB <sub>CR</sub> | | | 2.5 | | dB | Short circuit<br>between TONER<br>and TONEC,<br>R <sub>L</sub> = 100 kΩ | 2 | Notes: 1. See figure 109. 2. See figure 110. 3. 400 kHz, 800 kHz, 2 MHz, or 4 MHz can be used as the operating frequency (fosc). A/D Converter Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) | Item | Symbol | Pin(s) | Min | Тур | Max | Unit | Test Condition Note | |-------------------------------------------------------|------------------|----------------------------------|-----------------------|-----------------|-----------------------|------------------|------------------------------------------------------| | Analog power voltage | AV <sub>CC</sub> | AV <sub>CC</sub> | V <sub>CC</sub> - 0.3 | v <sub>cc</sub> | V <sub>CC</sub> + 0.3 | ٧ | AV <sub>CC</sub> ≥ 2.7 V | | Analog input voltage | AV <sub>in</sub> | AN <sub>0</sub> -AN <sub>3</sub> | AV <sub>SS</sub> | | AV <sub>CC</sub> | ٧ | | | Current between AV <sub>CC</sub> and AV <sub>SS</sub> | I <sub>AD</sub> | _ | _ | 50 | 150 | μА | $V_{CC} = AV_{CC} = 5.0 \text{ V}$ | | Analog input capacitance | CA <sub>in</sub> | AN <sub>0</sub> -AN <sub>3</sub> | | 15 | _ | pF | | | Resolution | _ | | 8 | 8 | 8 | Bit | | | Number of inputs | _ | _ | 0 | _ | 4 | Chan-<br>nel | _ | | Absolute accuracy | | _ | | | ± 2.0 | LSB | $T_a = 25$ °C,<br>$V_{CC} = 4.5-5.5$ V | | Conversion time | _ | | 34 | _ | 67 | t <sub>cyc</sub> | _ | | Input impedance | _ | AN <sub>0</sub> -AN <sub>3</sub> | 1 | _ | | МΩ | f <sub>OSC</sub> = 1 MHz,<br>V <sub>in</sub> = 0.0 V | AC Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) | Item | Symbol | Pin(s) | Min | Тур | Max | Unit | Test Condition | Notes | |--------------------|---------------------|-------------------------------------|------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | Clock oscillation | fosc | OSC <sub>1</sub> , OSC <sub>2</sub> | _ | 400 | _ | kHz | 1/4 division | 1 | | frequency | | | _ | 800 | | kHz | 1/4 division | 1 | | | | | | 2 | _ | MHz | 1/4 division | 1 | | | | | | 4 | | MHz | 1/4 division;<br>HD404628,<br>HD4046212,<br>HD404629:<br>V <sub>CC</sub> = 3.0 to 6.0 V;<br>HD4074629:<br>V <sub>CC</sub> = 3.5 to 5.5 V | 1 | | | | X1, X2 | | 32.768 | | kHz | | | | Instruction cycle | t <sub>cyc</sub> | | _ | 10 | _ | μs | f <sub>OSC</sub> = 400 kHz | | | time | | | _ | 5 | | μs | f <sub>OSC</sub> = 800 kHz | | | | | | | 2 | | μs | f <sub>OSC</sub> = 2 MHz | | | ÷ | | | | 1 | | μs | $\begin{split} &f_{OSC} = 4 \text{ MHz;} \\ &HD404628, \\ &HD4046212, \\ &HD404629: \\ &V_{CC} = 3.0 \text{ to } 6.0 \text{ V;} \\ &HD4074629: \\ &V_{CC} = 3.5 \text{ to } 5.5 \text{ V} \end{split}$ | | | | t <sub>subcyc</sub> | _ | _ | 244.14 | | μS | 32-kHz oscillator,<br>1/8 division | | | | | | | 122.07 | | μS | 32-kHz oscillator,<br>1/4 division | | | Oscillation | t <sub>RC</sub> | OSC <sub>1</sub> , OSC <sub>2</sub> | | | 7.5 | ms | Ceramic oscillator | 2 | | stabilization time | | X1, X2 | _ | <u>—</u> | 3 | S | T <sub>a</sub> = -10°C <b>to</b><br>+60°C | 3 | | External clock | t <sub>CPH</sub> | OSC <sub>1</sub> | 1100 | | | ns | f <sub>OSC</sub> = 400 kHz | 4 | | high width | | | 550 | | _ | ns | f <sub>OSC</sub> = 800 kHz | 4 | | | | | 215 | | _ | ns | f <sub>OSC</sub> = 2 MHz | 4 | | | | | 105 | | _ | ns | f <sub>OSC</sub> = 4 MHz | 4 | | External clock | t <sub>CPL</sub> | OSC <sub>1</sub> | 1100 | | | ns | f <sub>OSC</sub> = 400 kHz | 4 | | low width | | | 550 | _ | _ | ns | f <sub>OSC</sub> = 800 kHz | 4 | | | | | 215 | | | ns | f <sub>OSC</sub> = 2 MHz | 4 | | | | | 105 | | _ | ns | f <sub>OSC</sub> = 4 MHz | 4 | | External clock | t <sub>CPr</sub> | OSC <sub>1</sub> | _ | | 150 | ns | f <sub>OSC</sub> = 400 kHz | 4 | | rise time | | | | | 75 | ns | f <sub>OSC</sub> = 800 kHz | 4 | | | | | | _ | 35 | ns | f <sub>OSC</sub> = 2 MHz | 4 | | | | | _ | _ | 20 | ns | f <sub>OSC</sub> = 4 MHz | 4 | | | | | | | | | | | Notes on next page. AC Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) (cont) | Item | Symbol | Pin(s) | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | |----------------------------------------------------------------|-------------------|----------------------------------------------------|-----|----------|-----|-------------------------------------------|-----------------------------------------------------------------------------|-------| | External clock fall time | t <sub>CPf</sub> | OSC <sub>1</sub> | | _ | 150 | ns | f <sub>OSC</sub> = 400 kHz | 4 | | | | | | | 75 | ns | f <sub>OSC</sub> = 800 kHz | 4 | | | | | | | 35 | ns | f <sub>OSC</sub> = 2 MHz | 4 | | | | ··· | | | 20 | ns | f <sub>OSC</sub> = 4 MHz | 4 | | INT <sub>0</sub> -INT <sub>4</sub> , EVNB,<br>EVND high widths | t <sub>IH</sub> | INT <sub>0</sub> -INT <sub>4</sub> ,<br>EVNB, EVND | 2 | _ | | t <sub>cyc</sub> /<br>t <sub>subcyc</sub> | <del>_</del> | 5 | | INT <sub>0</sub> -INT <sub>4</sub> , EVNB,<br>EVND low widths | t <sub>IL</sub> | INT <sub>0</sub> -INT <sub>4</sub> ,<br>EVNB, EVND | 2 | _ | | t <sub>cyc</sub> /<br>t <sub>subcyc</sub> | | 5 | | RESET high width | t <sub>RSTH</sub> | RESET | 2 | _ | | t <sub>cyc</sub> | | 6 | | STOPC low width | t <sub>STPL</sub> | STOPC | 1 | _ | _ | t <sub>RC</sub> | | 7 | | RESET fall time | t <sub>RSTf</sub> | RESET | _ | | 20 | ms | _ | 6 | | STOPC rise time | t <sub>STPr</sub> | STOPC | _ | | 20 | ms | _ | 7 | | Input capacitance | C <sub>in</sub> | All pins<br>except D <sub>11</sub> | _ | | 15 | pF | f = 1 MHz<br>V <sub>in</sub> = 0 V, | | | | | D <sub>11</sub> | _ | <u> </u> | 15 | pF | HD404628,<br>HD4046212,<br>HD404629:<br>f = 1 MHz,<br>V <sub>in</sub> = 0 V | | | | | | | | 180 | pF | HD4074629:<br>f = 1 MHz,<br>V <sub>in</sub> = 0 V | | - Notes: 1. If f<sub>OSC</sub> = 400 kHz or 800 kHz, bit 1 of the system clock selector register (SSR: \$029) must be set to 0 (SSR1 = 0); if f<sub>OSC</sub> = 2 or 4 MHz, the same bit must be set to 1 (SSR1 = 1). - 2. The oscillation stabilization time is the period required for the oscillator to stabilize after V<sub>CC</sub> reaches 2.7 V at power-on, or after RESET input goes high or STOPC input goes low when stop mode is cancelled. At power-on or when stop mode is cancelled, RESET or STOPC must be input for at least t<sub>RC</sub> to ensure the oscillation stabilization time. If using a ceramic oscillator, contact its manufacturer to determine what stabilization time is required since it will depend on the circuit constants and stray capacitances. - 3. The oscillation stabilization time is the period required for the oscillator to stabilize after V<sub>CC</sub> reaches 2.7 V at power-on, or after RESET input goes high or STOPC input goes low when stop mode is cancelled. Contact the manufacturer of the crystal oscillator used to determine what stabilization time is required since it will depend on the circuit constants and stray capacitances. - 4. Refer to figure 111. - Refer to figure 112. The t<sub>cyc</sub> unit applies when the MCU is in standby or active mode. The t<sub>subcyc</sub> unit applies when the MCU is in watch or subactive mode. - 6. Refer to figure 113. - 7. Refer to figure 114. Serial Interface Timing Characteristics (HD404628, HD4046212, HD404629: $V_{CC}$ = 2.7 to 6.0 V, GND = 0 V, $T_a$ = -20°C to +75°C; HD4074629: $V_{CC}$ = 2.7 to 5.5 V, GND = 0 V, $T_a$ = -20°C to +75°C, unless otherwise specified) #### **During Transmit Clock Output** | Item | Symbol | Pin | Min | Тур | Max | Unit | Test Condition | Note | |-------------------------------|-------------------|-----|-----|-----|-----|-------------------|--------------------------|------| | Transmit clock cycle time | t <sub>Scyc</sub> | SCK | 1.0 | | _ | t <sub>cyc</sub> | Load shown in figure 116 | 1 | | Transmit clock high width | tsckh | SCK | 0.5 | _ | _ | t <sub>Scyc</sub> | Load shown in figure 116 | 1 | | Transmit clock low width | t <sub>SCKL</sub> | SCK | 0.5 | | _ | t <sub>Scyc</sub> | Load shown in figure 116 | 1 | | Transmit clock rise time | tsckr | SCK | | _ | 200 | ns | Load shown in figure 116 | 1 | | Transmit clock fall time | <sup>t</sup> sckf | SCK | | _ | 200 | ns | Load shown in figure 116 | 1 | | Serial output data delay time | t <sub>DSO</sub> | SO | | | 500 | ns | Load shown in figure 116 | 1 | | Serial input data setup time | t <sub>SSI</sub> | SI | 300 | _ | | ns | _ | 1 | | Serial input data hold time | <sup>t</sup> HSI | SI | 300 | | | ns | _ | 1 | Note: 1. Refer to figure 115. #### **During Transmit Clock Input** | Item | Symbol | Pin | Min | Тур | Max | Unit | <b>Test Condition</b> | Note | |-------------------------------|--------------------|-----|-----|-----|-----|-------------------|--------------------------|------| | Transmit clock cycle time | t <sub>Scyc</sub> | SCK | 1.0 | _ | _ | t <sub>cyc</sub> | | 1 | | Transmit clock high width | t <sub>sck</sub> H | SCK | 0.5 | - | _ | t <sub>Scyc</sub> | _ | 1 | | Transmit clock low width | †SCKL | SCK | 0.5 | _ | _ | t <sub>Scyc</sub> | _ | 1 | | Transmit clock rise time | tsckr | SCK | _ | _ | 200 | ns | _ | 1 | | Transmit clock fall time | tsckf | SCK | _ | _ | 200 | ns | _ | 1 | | Serial output data delay time | t <sub>DSO</sub> | so | | _ | 500 | ns | Load shown in figure 116 | 1 | | Serial input data setup time | t <sub>ssı</sub> | SI | 300 | | | ns | _ | 1 | | Serial input data hold time | t <sub>HSI</sub> | SI | 300 | _ | | ns | _ | 1 | Note: 1. Refer to figure 115. Figure 109 Tone Output Load Circuit Figure 112 Interrupt Timing Figure 110 Distortion and $dB_{CR}$ Load Circuit Figure 113 Reset Timing Figure 111 External Clock Timing Figure 114 STOPC Timing 279 Hitachi Figure 115 Serial Interface Timing Figure 116 Timing Load Circuit #### **Notes on ROM Out** Please pay attention to the following items regarding ROM out. On ROM out, fill the ROM area indicated below with 1s to create the same data size as a 16-kword version (HD404629). A 16-kword data size is required to change ROM data to mask manufacturing data since the program used is for a 16-kword version. This limitation applies when using an EPROM or a data base. | HD404629 Series | | | | | |-------------------------------------------------------------------------|-----------------------|---------------|-------------------------|----------------------| | HD404629 Option List | : | | | | | Please check off the appropri<br>enter the necessary informati | | [ | Date of order | / / | | enter the necessary miormau | OII. | | Customer | | | | | Ì | Department | | | | | | Name | | | | | Ì | ROM code name | | | | | | LSI number | | | 1. ROM Size | | | | <u> </u> | | ☐ HD404628 8-kword | | | | | | ☐ HD4046212 12-kword | ı | | | | | ☐ HD404629 16-kword | <u> </u> | | | | | | | | | | | 2. Optional Functions | | | | | | * With 32-kHz CPU oper | | | | | | * Without 32-kHz CPU o | | | | | | Without 32-kHz CPU o | <u> </u> | | | | | Note: * Options marked with | an asterisk require a | subsystem cr | ystal oscillator (X1, X | (2). | | ROM Code Media Please specify the first ty EPROM on-package mic | | | | ner), when using the | | EPROM: The upper bits | | xed together. | The upper five bits a | | | ☐ EPROM: The upper bits | | | | | | 4. Oscillator for OSC1 and | OSC2 | | | | | Ceramic oscillator | f = MHz | | | | | External clock | f = MHz | | | | | 5. Stop Mode Used Not used | | | | | | 5. Package FP-100B FP-100A TFP-100B | | | | |