### **CMOS 4-BIT MICROCONTROLLER** # **TMP47C647F, TMP47C847F** The 47C647/847 are high speed and high performance 4-bit single chip microcomputers based on the TLCS-470 series with a LCD driver, A/D converter and the pulse output circuit used for drive of the buzzer and so on. The 47C647/847 is possible to stop the CPU at the standby period and decrease the power consumption in the Home electric appliance. | PART No. | ROM | RAM | PACKAGE | EPROM | |------------|--------------|-------------|--------------------|---------------| | TMP47C647F | 6144 × 8-bit | 384 × 4-bit | OFD90 D 1430 0 90D | TN4D47D947\/F | | TMP47C847F | 8192 × 8-bit | 512 × 4-bit | QFP80-P-1420-0.80B | TMP47P847VF | #### **FEATURES** - ◆4-bit signal chip mocrocomputer - ♦Instruction execution time: 1.3 $\mu$ s (at 6 MHz), 244 $\mu$ s (at 32.8 kHz) - ♦92 basic instrutions - Table look-up instructions - 5-bit to 8-bit data conversion instruction - ◆Subroutine nesting: 15 levels max. - ◆6 interrupt sources (External: 2, Internal: 4) All sources have independent latchs each, and multiple interrupt control is available. - **♦**1/O port (35 pins) - Input 2 ports 5 pinsOutput 2 ports 8 pins - I/O 6 ports 22 pins - ◆Interval Timer - **◆Two 12-bit Timer/Counters** Timer, event counter, and pulse width measurement mode - ◆Watchdog Timer - ◆Serial Interface with 8-bit buffer - Simutltaneous transmission and reception is available. - External/internal clock, leading/trailing edge, and 4/8-bit mode - ◆8-bit successive approximate type A/D converter - With sample and hold - 8 analog inputs - Conversion time : 32 $\mu$ s (at 6 MHz) - **♦**Pluse Output Output frequency select ♦ High current outputs LED direct drive is available (typ. 10 mA $\times$ 8 bits) - **♦**LCD driver - LCD direct drive is available (max. 12-digit display at 1/4 duty LCD) - 1/4, 1/3, 1/2 duties or static drive are programmably selectable. - ◆Dual-clock operation High-speed/Low-power-consumption operating mode ♦ Hold function Battery/Capacitor back-up - **♦SLEEP** function - Battery/Capacitor back-up - LCD is displaying - ◆Real Time Emulator: BM47C847F0A # **PIN FUNCTION** | PIN NAME | Input/Output | FUNCTION | NS | |-----------------------------|---------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------| | K03 to K00 | Input | 4-bit input port | | | P13 to P10 P23 to P20 | Output | 4-bit output port with latch. 8-bit data are output by the 5-bit to 8-bit data | conversion instruction [OUTB @HL]. | | P42 to P40 | 1/0 | 3-bit I/O port with latch When used as input port, the latch must be se | t to "1". | | R63 (AIN7)<br>to R50 (AIN0) | I/O (Input) | 4-bit I/O port with latch. When used as input port, the latch must be set to "1". | A/D converter analog input | | R73 (XTOUT) | I/O (Output) | | Resonator connecting pin (Low-freq.). | | R72 (XTIN) | I/O (Input) | 4-bit I/O port with latch. When used as input port, watchdog timer | For inputting external clock, XTIN is used and XTOUT is opened. | | R71 ( <del>WTO</del> ) | I/O (Output) | output, the latch must be set to "1". | Watchdog timer output | | R70 (PULSE) | I/O (Output) | | Pulse output | | R83 (T1) | | 4-bit I/O port with latch. | Timer/Counter 1 external input | | R82 (INT1) | 10 (1 ) | When used as input port, external interrupt input pin, or timer/counter external input | External interrpt 1 input | | R81 (T2) | I/O (Input) | pin, the latch must be set to "1". | Timer/Counter 2 external input | | R80 (ĪNT2) | | | External interrpt 2 input | | R92 ( <del>SCK</del> ) | I/O(I/O) | | Serial clock I/O | | R91 (SO) | I/O (Output) | 3-bit I/O port with latch. When used as input port or serial port, the latch must be set to "1". | Serial data output | | R90 (SI) | I/O (Input) | laten must be set to 1. | Serial data input | | SEG31 to SEG0 | Output | LCD Segment drive output | | | COM4 to COM1 | Output | LCD Common drive output | | | XIN | Input | Resonator connecting pin (High-frequency) . | | | XOUT | Output | For inputting external clock, XIN is used and X | OUT is opened. | | RESET | Input | Reset signal input | | | HOLD (KEO) | Input (Input) | HOLD request/release signal input | Sence input | | TEST | Input | Test pin for out-going test. Be opened or fixed | to low level. | | VDD | | +5V | | | VSS | | 0V (GND) | | | VLC | Power supply | LCD drive power supply | | | VAREF | | A/D converter analog reference voltage (High) | ) | | VASS | | A/D converter analog reference voltage (Low) | | #### **OPERATIONAL DESCRIPTION** Concerning the 47C647/847 the configuration and functions of hardwares are described. As the description has been provided with priority on those parts differing from the 47C660/860, the technical data sheets for the 47C660/860 shall also be referred to. ## 1. SYSTEM CONFIGURATION INTERNAL CPU FUNCTION Except for the system control circuit, the CPU core functions are the same as those of the 47C660/860. - ◆ PERIPHERAL HARDWARE FUNCTION - 1) I/O Ports - 2 Interval Timer - 3 Timer/Counter - 4 Watchdog Timer - **5** Pulse Output - 6 LCD Driver - ⑦ A/D Converter - 8 Serial Interface The following are explanations of functions ( $\bigcirc$ , $\bigcirc$ , $\bigcirc$ and $\bigcirc$ ) which have been added to the 47C647/847 or which are different from those of the 47C660/860, and the system clock control circuit. ## 2. CPU CORE FUNCTIONS # 2.1 SYSTEM CONTROL CIRCUIT It is possible to switch from SLOW operating mode to SLEEP operating mode which maintains the internal status under low power consumption, and also to HOLD operating mode which reduces power consumption. In SLEEP operating mode, all operations except a timing generator (TG) binary counter and a LCD driver are suspended. # 2.1.1 System Clock Controller The system clock controller starts or stops the high-frequency and low-frequency clock oscillator and switches between the basic clocks. The operating mode is generally divided into the single-clock mode and the dual-clock mode, which are controlled by command. Figure 2-1. Operating Mode Transition Diagram ## (1) System clock control System clock control is performed by the command register (OP16). During reset, this register is initialized to "0" and the single-clock mode is selected. Each state at operating mode switching can be read from the status register (IP0E). Figure 2-2. System Clock Control Command Register / Status Register #### (2) Instruction cycle The instruction execution and on-chip peripheral hardware operations are performed in synchronization with the basic clock. The smallest unit of instruction execution is called the "instruction cycle". The TLCS-470 series instruction set has 3 kinds of instructions, 1-cycle instruction to 3-cycle instruction. Each instruction cycle consists of 4 states (S1 through S4). Each state consists of 2 basic clock pulses. Figure 2-3. Instruction Cycle # 2.1.2 Operating Mode There are two operating mode: the single-clock and the Dual-clock mode. #### (1) Dual-clock mode In this mode, the Normal-2 operation is generally performed by generating the instruction cycle from the high-frequency clock (fc). As required, the instruction cycle is generated by the low-frequency clock (fs), and the lower consumption power operation is performed by transferring SLOW operation to HOLD operation. The following describes the switching between the Normal-2, SLOW and HOLD operations in the dual clock mode. At reset, the command register is initialized to the single-clock mode. Since the low-frequency clock is not oscillated, Normal-2 operation in the dual clock mode must be set first. The low frequency clock starts oscillating by transferring to Normal-2 operation. #### a. Switching from Normal-2 operation to SLOW operation Setting DCLK1 (bit 1 of OP16) to "1" switches Normal-2 operation to SLOW operation. However it takes a few seconds to get a stable oscillation of the low-frequency clock. Therefore if there is possible to switch from Normal-2 operation to SLOW operation, wait until the low-frequency clock is stable or check the oscillation state by a program. SMF status (bit 1 of 1P0E) is available to check it. When the high-frequency clock (fc/27) is input to the 8th stage of TG, first sets SLCK (bit 2 of OP16) to "1" and input the low-frequency clock (fs). Then, SMF is monitored by a program. After confirming that SMF is changed "1" to "0" to "1" or "0" to "1" to "0", set DCLK1 to "1". At this time, the high-frequency clock oscillator stops. #### b. Returning from SLOW operation to Normal-2 operation Bit 1 of the command register is cleared to "0" and, at the same time, the warm-up time for return is set to DWUT. When the warm-up time has passed, the Normal-2 operation takes place. By monitoring SLS (bit 0 of the status register), the current operating mode can be known. Figure 2-4. System Clock Switching Timing #### c. Shifting from the SLOW operation to the HOLD operation By setting the command in the command register (OP10), the low-frequency clock oscillation stops and the HOLD operation starts. After being released the HOLD operation, the operation mode is NORMAL-1. # d. Shifting from the SLOW operation to the SLEEP operation After selecting the return conditions using the return conditions selection register (OP17), shift to SLEEP operation (refer to the SLEEP operation mode explanation) by setting the command in the command register (OP10). Occurrence of the selected condition returns to SLOW operation. Note1. The command register (OP10) is used for both HOLD operation control and SLEEP operation control. This register is used for HOLD operation control when accessed during Normal-1 operation and for SLEEP operation control when accessed during SLOW operation. - Note2. The SLOW operating mode can be switched to either the SLEEP or the HOLD mode, it is necessary to select which mode to be switched by the bit 7 of command register (OP17). - Note3. During SLOW operation and SLEEP operation, oscillation of the high-frequency clock is automatically halted to enable low power supply voltage operation and low power consumption operation. However, while less power is consumed by the oscillator and internal hardware, the amount of power consumed by the pin interface (dependent on external circuitry and programs) is not directly related to the low power consumption operation mode; therefore, caution is required during system design and interface circuit design. Also, the execution of instructions is not interrupted by switching to SLOW operation but, in some cases, there is influence on some of the peripheral hardware functions; therefore, refer to the explanations of the various operations. #### (2) Single-clock mode In this mode, only the high-frequency clock oscillator is used. Pins R72 (XTIN) and R73 (XTOUT) become the ordinary I/O port. The HOLD operating mode is available for reducing power consumption. It is controlled by the command register (OP10). In this mode, therefore, the system clock control command register (OP16) need not be manipulated. # 2.1.3 SLEEP Operation Mode The SLEEP operation mode suspends all SLOW operation operations except for the low-frequency clock, TG binary counter and LCD driver, and retains the internal status with low power consumption without stopping the clock function and LCD display. Figure 2-6. Command Register, Return Conditions Selection register The operation in edge release mode and level release mode are the same as in HOLD operating mode. In order to start SLEEP operation, select the return condition by the selection register (OP17) during SLOW operation. Then, set the start command in the command register (OP10). In addition, SLEEP operation can be controlled by K0 pin input. This is also selected by the command register (OP17). For switching from SLOW to HOLD or SLEEP operating mode, select the upper bit of Port address (OP17). SLEEP operation is then return to SLOW operation when the conditions selected with the return conditions selection register occur. Figure 2-7. Return Conditions and operation Mode # 2.1.4 HOLD Operation Mode The HOLD feature stops the system and holds the systems internal states active before stop with a low power. The HOLD operation is controlled by the command register (OP10) and the HOLD pin input. The HOLD pin input state can be known by the status register (IP0E or IP10). HOLD operating mode can be controlled by HOLD pin as well as by K0 port, selected by the command register (OP17). Figure 2.9 shows the connection between HOLD pin input and HOLD control signal. Figure 2-8. HOLD Operation Mode Command Register/Status Register Figure 2-9. HOLD Pin Input and HOLD Control Signal Figure 2-10. Return Conditions Selection Command Register Other than that, the HOLD operation mode is the same as for the 47C860. For details, refer to the 47C860 technical data. ## 3. PERIPHERAL HARDWARE FUNCTION ## 3.1 Input / Output Ports The 47C647 / 847 have 10 built-in input/output ports as follows: ① K0 ; 4-bit input ② P1, P2 ; 4-bit output 3 R4 ; 3-bit input / output 4 R5, R6 ; 4-bit input / output (also used for A/D converter analog inputs) ⑤ R7 ; 4-bit input / output (also used for resonator connection, watchdog timer output, pulse output) © R8; 4-bit input / output (also used for external interrupt input, timer/counter input) ⑦ R9 ; 3-bit input / output (also used as a serial port) 8 KE ; 1-bit sense input (also used for hold request / release signal input) This section describes ports of $3 \sim 5$ , 8 which are changed from 47C660/860. Table 3-1 lists the port address assignments and the I/O 'instructions that can access the ports. ### (1) Port R4 (R42-R40) These ports are 3-bit I/O ports with latch. The latch is initialized to "1" during reset. When used as input port, the latch should be set to "1". Figure 3-1. Port R4 #### (2) R5 (R53-R50), R6 (R63-R60) These ports are 4-bit I/O ports with a latch. When used as an input port, the latch must be set to "1". The latch is initialized to "1" during reset. Ports R5 and R6 are 4-bit I/O ports with latch shared by the analog inputs for A/D converter. When used as an input ports or analog inputs, the latch should be set to "1". If other port is used as an output, be careful not to execute the output instruction for any port during A/D conversion in order to keep accuracy of conversion. The latch is initialized to "1" and analog input is selected R50 (AINO) pin during reset. Figure 3-2. Ports R5, R6 ## (3) Port R7 (R73-R70) Port R7 is shared by the low-frequency resonator connection pins (XTIN, XTOUT), pulse output pin (PULSE) and the watchdog timer output pin (WTO). For the dual-clock mode operation, the low-frequency resonator (32.768 kHz), is connected to R72 (XTIN) and R73 (XTOUT) pins. For the single-clock mode operation, R72 and R73 pins are used for the ordinary I/O ports. When the watchdog timer is used, R71 (WTO) becomes the watchdog timer output pin. The watchdog timer output is the logical AND output with the port R71 output latch. To use the R71 pin for an ordinary I/O port, the watchdog timer must be disabled (with the watchdog timer output set to "1"). When the pulse output is used, R70 (PULSE) becomes the pulse output pin. The pulse output is the logical AND output with the port R70 output latch. To use the R70 pin for an ordinary I/O port, the pulse output must be disabled (with the pulse output set to "1"). Figure 3-3. Port R7 (4) In the 47C647 and 847, the KE port functions as follows. The logic arithmetic results of KEO pin input and KO port input are set into the least significant bit of IPOE and the most significant bit of IP10. For details, see HOLD operation mode in section 2.1.4. Table 3-1. Port Address Assignments and Available I/O Instructions | ţ | | +100 | , | | Input/C | Input/Output instruction | tion | | | |-----------------|------------------------------|-----------------------------------|------------|-----------|------------|--------------------------|-----------|-------------|-------------------| | address | | | IN %p, A | OUT A, %p | i<br>i | i i | SET %p, b | TEST %p, b | SET @L | | (**) | Input (IP**) | Output (OP**) | IN %p, @HL | | OUI #K, %p | OUTB @HL | CLR %p, b | теѕтР %р, b | CLK @L<br>TEST @L | | <sup>н</sup> 00 | K0 input port | | 0 | I | 1 | I | 1 | Ō | ı | | 01 | P1 output latch | P1 output port | 0 | 0 | 0 | (Note2) | _ | 0 | ı | | 05 | P2 output latch | P2 output port | 0 | 0 | 0 | | | 0 | 1 | | 03 | | | L | L | L | 1 | 1 | 1 | 1 | | 04 | R4 input port | R4 output port | 0 | 0 | 0 | I | 0 | 0 | 0 | | 02 | R5 input port (Analog input) | R5 output port | 0 | 0 | 0 | I | 0 | 0 | 0 | | 90 | R6 input port (Analog input) | | 0 | 0 | 0 | l | 0 | 0 | 0 | | 07 | R7 input port | R7 output port (Pulse output) | 0 | 0 | 0 | I | 0 | 0 | 0 | | 88 | R8 input port | R8 output port | 0 | 0 | 0 | I | 0 | 0 | ı | | 6 | R9 input port | R9 output port | 0 | 0 | 0 | l | 0 | 0 | ı | | 8 | | | I | I | I | I | ı | ı | ı | | 89 | | | I | I | ı | İ | ı | ı | ı | | 0 | | | ı | ı | ı | I | ı | ı | ı | | OD | | 1 | ı | I | ı | I | ı | I | ı | | 0E | Status input (Note 3) | | 0 | ı | I | I | ı | 0 | ı | | 0F | Serial receive buffer | Serial transmit buffer | 0 | 0 | 0 | 1 | 1 | ı | - | | 10 <sub>H</sub> | HOLD pin status | Hold/SLEEP operating mode control | 0 | 0 | 1 | 1 | 1 | 1 | ı | | = | | | ı | ı | ı | I | ı | ı | ı | | 12 | A / D converted value | A / Danalog input selector | 0 | 0 | I | I | ı | ı | ı | | 13 | A / D status input | A / D start register | 0 | 0 | I | I | I | ı | I | | 14 | | | ı | ı | I | I | I | I | I | | 15 | | Watchdog timer control | ı | 0 | I | I | I | I | I | | 16 | | System clock control | ı | 0 | ı | I | l | I | ı | | 17 | | Hold/SLEEP operation control | ı | 0 | ı | İ | I | I | I | | 18 | | Pulse output control | ı | 0 | ı | I | I | J | ĺ | | 19 | | Interval Timer interrupt control | ı | 0 | I | I | ı | ı | ı | | 4 | | LCD driver control 1 | ı | 0 | ı | ı | I | I | ı | | 18 | | LCD driver control 2 | ı | 0 | ı | I | I | J | ĺ | | 10 | | Timer/Counter 1 control | ı | 0 | ı | l | ı | ı | ı | | 10 | | Timer/Counter 2 control | ı | 0 | ı | I | I | ı | ı | | 1E | | Serial interface control 1 | ı | 0 | ı | l | ı | ı | ı | | 1F | | Serial interface control 2 | | $\odot$ | ı | 1, | 1 | ı | I | Note 1: "——" means the reserved state. Unavailable for the user programs. The 5-bit to 8-bit data conversion instruction [OUTB @HL], automatic access to ports P1 and P2. The status input of serial interface, clock generator, and $\overline{HOLD}$ ( $\overline{KEO}$ ) pin. Note 2: Note 3: # 3.2 Pulse output circuit The 47C647/847 has a built-in one-channel pulse output to use in driving, for example, a buzzer. Eight different pulse output frequencies can be selected by command. Pulses are output from the PULSE pin. The PULSE pin is also used as the R70 pin. When used as the PULSE pin, the R70 output latch is set to "1". Figure 3-4. Pulse output circuit # 3.2.1 Control of pulse output circuit The pulse output circuit is controlled by the command register (OP18). Pulses are output by setting EPULS to "1". Pulse output is disabled (by clearing OP18 to "0") during hold operation. 3 2 1 0 EPULS FPULS (Initial value 0000) EPULS Pulse output control 0: Disable 1: Enable Pulse output control command resister (Port address OP18) | <b>L</b> | | | | |----------|------------------------------|------------------------------|------| | FPULS | Pulse output frequency selec | rt T | | | | Example:A | at fc = 4.19 MH <sub>Z</sub> | | | 000: | fc/(2 <sup>9</sup> ×8) [Hz] | 1.024 [kHz] | | | 001: | fc/(2 <sup>9</sup> ×7) | 1.170 | | | 010: | fc/(2 <sup>9</sup> ×6) | 1.365 | | | 011: | fc/(2 <sup>9</sup> ×5) | 1.638 | | | 100: | fc/(29×4) | 2.048 | | | 101: | fc/(2 <sup>9</sup> ×3) | 2.731 | | | 110: | fc/(2 <sup>9</sup> ×2) | 4.096 | | | 111: | fc/(2 <sup>9</sup> ×1) | 8.192 | Note | Note. fc: Basic clock frequency $[H_z]$ Figure 3-5. Pulse output command resister #### 3.3 LCD Driver The 47C647/847 have the circuit that directly drives the liquid crystal display (LCD) and its control circuit. The 47C647/847 have following connecting pins with LCD. - ① Segment output port 32 pins (SEG31-SEG0) - ② Common output port 4 pins (COM4-COM1) In addition, VLC pin is provided as the drive power pin. The devices that can be directly driven is selectable from LCD of following drive methods. ``` ① 1/4 Duty (1/3 Bias) LCD ...... Max. 128 Segment (16 disits × 8 segments) ② 1/3 Duty (1/3 Bias) LCD ...... Max. 96 Segment (12 disits × 8 segments) ③ 1/3 Duty (1/2 Bias) LCD ...... Max. 96 Segment (12 disits × 8 segments) ④ 1/2 Duty (1/2 Bias) LCD ...... Max. 64 Segment (8 disits × 8 segments) ⑤ Static LCD ...... Max. 32 Segment (4 disits × 8 segments) ``` ## 3.3.1 Configruation of LCD driver Figure 3-6. LCD Driver #### 3.3.2 Control of LCD driver circuit The LCD driver is controlled by the command register 1,2 (OP1A, OP1B). Further, when the command register 1 is accessed, the most significant bit of the command register 2 must be set to "0" (Blanking). Figure 3-7. LCD Driver control Command Register #### (1) Driving methods of LCD driver Driving methods of LCD is selected 5 kind of DTY (bit 2-0 of command register 2). The drive method is initialized according to LCD used in the initial program. ① 1/4 Duty (1/3 Bias) ② 1/3 Duty (1/3 Bias) 3 1/3 Duty (1/2 Bias) 4 1/2 Duty (1/2 Bias) **⑤** Static Figure 3-8. LCD drive waveform (COM-SEG pins) ## (2) Frame frequency Frame frequency (f<sub>F</sub>) is set according to the drive method and base frequency as shown in the following table 3-2. The base frequency is selected by SLF (the lower 2 bits of the command register) according to the reference clock frequency fc and fs. Table 3-2. Setting of LCD Frame Frequency ### a. At the single clock mode | CI E | BASE FREQUENCY | | FRAME FREQ | UENCY [Hz] | | |------|------------------------------|------------------------------|---------------------------------------|---------------------------------------|-------------| | SLF | [Hz] | 1/4 DUTY | 1/3 DUTY | 1/2 DUTY | STATIC | | 10 | <u>fc</u><br>2 <sup>16</sup> | <u>fc</u><br>2 <sup>16</sup> | $\frac{4}{3} \cdot \frac{fc}{2^{16}}$ | $\frac{4}{2} \cdot \frac{fc}{2^{16}}$ | fc<br>216 | | | fc = 4 MHz | 61 | 81 | 122 | 61 | | | fc | fc | _4fc_ | _4fc_ | fc | | 01 | <b>2</b> 15 | <b>2</b> 15 | 3 2 <sup>15</sup> | 2 2 <sup>15</sup> | <b>2</b> 15 | | | fc = 4 MHz | 122 | 163 | 244 | 122 | | | fc | fc | _4fc | _4fc | fc | | 00 | <b>2</b> 13 | <b>2</b> 13 | 3 213 | 2 213 | <b>2</b> 13 | | | fc = 1 MHz | 122 | 163 | 244 | 122 | Note . fc ; High-frequency clock [Hz] ## b. At the dual clock mode | 61.5 | BASE FREQUENCY | | FRAME FREC | UENCY [Hz] | | |------|-----------------------------|-----------------|------------------------------------|------------|-----------------| | SLF | [Hz] | 1/4 DUTY | 1/3 DUTY | 1/2 DUTY | STATIC | | 10 | <u>fs</u><br>2 <sup>9</sup> | | $\frac{4}{3} \cdot \frac{fs}{2^9}$ | 4 · fs 29 | fs<br> | | | fs = 32 KHz | 61 | 83 | 125 | 61 | | 01 | <u>fs</u><br>28 | <u>fs</u><br>28 | $\frac{4}{3} \cdot \frac{fs}{2^8}$ | 4 · fs 28 | <u>fs</u><br>28 | | | fs = 32 KHz | 125 | 167 | 250 | 125 | Note . fs; Low-frequency clock [Hz] ### (3) LCD drive voltage The LCD drive voltage (V<sub>LCD</sub>) is given by the difference in potential (V<sub>DD</sub>-V<sub>LC</sub>) between pins VDD and VLC. Therefore, when the CPU operating voltage and LCD drive voltage are the same, the VLC pin is connected to the VSS pin. The LCDs light only when the difference in potential between the segment output and common output is $\pm V_{LCD}$ , and turn off at all other times. During reset, the power switch of the LCD driver is turned off automatically, shutting off the VLC voltage. Both the segment output and common output become V<sub>DD</sub> level at this time and the LCDs turn off. The power switch is turned on to supply VLC voltage to the LCD driver by setting EDSP (bit 3 of the command register 2) to " $1_B$ ". After that, the power switch will not turn off even during blanking (setting EDSP to " $01_B$ ") and the VLC voltage continues to flow. The power switch is turned off during hold operation low power consumption by turning off the LCD. When hold operation is released the status in effect immediately before the hold operation is reinstated. # 3.3.3 LCD display operation #### (1) Display data setting Display data are stored to the display data area (Max 32 words) in the data memory (bank0). The display data stored to the display data area (address 20-3F<sub>H</sub>) are read automatically and sent to the LCD driver by the hardware. The LCD driver generates the segment signals and common signals in accordance with the display data and drive method. Therefore, display patterns can be changed by only overwriting the contents of the display data area with a program. The table look up instruction is mainly used for this overwriting. Figure 3-9 shows the correspondence between the display data area and the SEG/COM pins. The LCD light when the display data is "1" and turn off when "0". The number of segment which can be driven differs depending on the LCD drive method therefore, the number of display data area bits used to store the data also differs. Consequently, data memory not used to store display data and data memory for which the addresses are not connected to LCD can be used to store ordinary user's processing data. Table 3-3. Drivinig Method and Bit for Display Data | Driving methods | bit 3 | bit 2 | bit 1 | bit 0 | |-----------------|-------|-------|-------|-------| | 1 / 4 Duty | сом4 | сомз | COM2 | сом1 | | 1 / 3 Duty | - | сомз | сом2 | сом1 | | 1 / 2 Duty | ı | - | COM2 | сом1 | | Static | _ | _ | - | сом1 | Note. - ; This bit is not used for display data. Figure 3-9. LCD Display Data Area (Bank 0) #### (2) Blanking Blanking is applied by setting EDSP to "0" and turns off the LCD by outputting the non light operation level to the COM pin. The SEG pin continuously outputs the signal level in accordance with the display data and drive method. With static drive, no voltage is applied between the COM and SEG pins when the LCD is turned off by data (display data cleared to "0"), but the COM pin output becomes constant at the $V_{LCD}/2$ level when turning off the LCD by blanking, so the COM and SEG pins are then driven by $V_{LCD}/2$ . #### 3.3.4 Control method of LCD driver #### (1) Initial Setting Flow chart of intial setting are as shown in Figure 3-10. Example: When operating the 47C647/847 with 1/4 duty LCD Setting of LCD drive method using a from frequency of fc/216 [HZ]. LD A, #0000B; Sets the 1/4 duty drive Setting of Frame frequency (SLF) OUT A, %OP1B A, #0010B; Setting of base frequency LD Setting of clear or intial value of display area in the data memory OUT A, %OP1A ; Setting of clear or intial value of Display enable display area in the memory (Release of blanking) LD A, #1000B; Display enable OUT A, %OP1B Figure 3-10. Intial setting of LCD driver #### (2) Store of display data Normally, display data are kept permantly in the program memory and then stored to the display data area by the table look-up instruction. Example of numeric display data using the 1/4 duty LCD are given in Table 3-4. The COM pin and SEG pin connection method is as shown in Figure 3-11. | Num | Display | Display da | | Num | Display | Display dat | | |------|-----------------------------------------|-----------------------|----------------------|------|-----------------------------------------|--------------------|-------------------| | eric | | High order<br>address | Low order<br>address | eric | | High order address | Low order address | | 0 | | 1101 | 1111 | 5 | | 1011 | 0101 | | 1 | *************************************** | 0000 | 0110 | 6 | | 1111 | 0101 | | 2 | | 1110 | 0011 | 7 | *************************************** | 0001 | 0111 | | 3 | | 1010 | 0111 | 8 | | 1111 | 0111 | | 4 | ************************************** | 0011 | 0110 | 9 | | 1011 | 0111 | Table 3-4. Example of display data (1/4 Duty LCD) Futher, example numeric display data (in the same way as in Table 3-4) using the 1/3 duty LCD are given in Table 3-5. The COM pin and SEG pin connection method is as shown in Figure 3-12. Figure 3.12 Example of COM and SEG connection. Table 3-5. Example of display data (1/3 Duty LCD) | | Disp | lay data men | nory | | Disp | lay data men | nory | |---------|--------------------------|----------------------------|-------------------------|---------|--------------------------|----------------------------|-------------------------| | Numeric | High<br>order<br>address | Middle<br>order<br>address | Low<br>order<br>address | Numeric | High<br>order<br>address | Middle<br>order<br>address | Low<br>order<br>address | | 0 | **11 | *101 | *111 | 5 | **01 | *111 | *010 | | 1 | **00 | *000 | *011 | 6 | **11 | *111 | *010 | | 2 | **10 | *111 | *001 | 7 | **01 | *001 | *011 | | 3 | **00 | *111 | *011 | 8 | **11 | *111 | *011 | | 4 | **01 | *101 | *011 | 9 | **01 | *111 | *011 | Note. \*; don't care Figure 3-13. 1/4 Duty (1/3 Bias) Drive Figure 3-14. 1/3 Duty (1/3 Bias) Drive Figure 3-16. 1/2 Duty (1/2 Bias) Drive Figure 3-17. Static Drive #### 3.4 A/D Converter 47C647/847 have a 8-bit successive approximate type A/D converter and is capable of processing 8 analog inputs. # 3.4.1 Circuit Configuration Figure 3-18. Block Diagram of A/D Converter # 3.4.2 Control of A/D converter The operation of A/D converter is controlled by a command. The command register is accessed as port addresses OP12, OP13, IP12 and IP13. (1) Analog input selector (OP12) Analog inputs (AIN0 through AIN7) are selected by this register. Analog input select command register (Port address OP12) Figure 3-19. Analog input selector ## (2) Start of A/D conversion (OP13) A/D conversion is started when ADS is set to "1". After the conversion is started, ADS is cleared by hardware. If the restart is requested during the conversion, the conversion is started again at the time. Analog input voltage is hold by the sample hole circuit. Figure 3-20. A/D conversion start register ## (3) A/D converter end frag (IP13) End of conversion flag (EOCF) is a single bit flag showing the end of conversion and is set to "1" when conversion ended. When both upper 4 bits and lower 4 bits of a converted value are read or A/D conversion is started, EOCF is cleared to "0". (Port address IP13) 3 2 1 0 EOCF EOCF End of conversion flag 0: Under A/D conversion or before A/D conversion or order to conversion or before to conversion 1: End of A/D conversion A/D converter status register Figure 3-21. A/D converter status register ## (4) A/D converted value register (IP12) An A/D converted value is read by accessing port address IP12. An A/D converted value is read by splitting into upper 4 bits and lower 4 bits by a value of $LR_0$ (LSB of the L registers). When $LR_0 = 0$ , lower 4 bits of the converted value is read. When $LR_0 = 1$ , upper 4 bits of the converted value is read. Figure 3-22. A/D converted value register ## 3.4.3 How to use A/D converter Apply positive of analog reference voltage to the VAREF pin and negative to the VASS pin. The A/D conversion is carried out by splitting reference voltage between VAREF and VASS to bit corresponding voltage by a ladder resistor and making a judgement by comparing it with analog input voltage. ## (1) Start of A/D conversion Prior to conversion, select one of the analog input AIN0 through AIN7 by the analog input selector. Place output of the analog input, which is to be A/D converted, in the high impedance state by setting "1". If other port is used as an output port, be careful not to execute the output instruction for any port during conversion in order to keep accuracy of conversion. A/D conversion is started by setting ADS (bit1 of the A/D conversion start register). When conversion ends after 24 instruction cycles, EOCF showing the end of conversion is set to "1". Analog input voltage is sampled during the following 2 instruction cycles after setting conversion enable ADS. Note. The sample and hold circuit has capacitor ( $C_A = 12 \text{ pF typ.}$ ) with resistor ( $RA = 5 \text{ k}\Omega$ typ.). See I/O circuitry table. This capacitor should be charged or discharged within 2 instruction cycles. ## (2) Reading of an A/D converted value After the end of conversion, read an A/D converted value is read by splitting into lower 4 bits and upper 4 bits by the A/D converted value register (IP12). Lower 4 bits of the A/D converted value can be read when $LR_0 = 0$ and upper 4 bits when $LR_0 = 1$ . Usually an A/D converted value is stored in RAM by an instruction [IN %p, @HL]. Further, if an A/D converted value is read during conversion, it becomes an indefinite value. ## (3) A/D conversion with HOLD operation When the HOLD operation is started during the conversion, the conversion is terminated and an A/D converted value becomes indefinite. Therefore, EOCF is kept clear to "0" after release from the HOLD operation. However, if the HOLD operation is started after the end of conversion (after EOCF has been set), A/D converted value and status of EOCF are held. Example: Selecting analog input (AIN4), starting A/D conversion, monitoring EOCF, and storing lower 4 bits and upper 4 bits of a converted value to RAM [10<sub>H</sub>] and RAM [11<sub>H</sub>] respectively. ``` ; AIN SELECT A, #4H LD A, %OP12 OUT ; A/D START LD A, #1H 0UT A, %OP13 ; EOCF = 1? SLOOP: IN %IP13, A TEST A, 3 В SL00P ; DATA READ LD HL, #10H %IP12, @HL IN INC IN %IP12, @HL ``` # **INPUT/OUTPUT CIRCUITRY** - (1) Control pins - The input/output circuitries of the 47C647/847 control pins are similar to those of the 47C660/860. - (2) I/O Ports The input/output circuitries of the 47C647/847 I/O ports are shown as belows, any one of the circuitries can be chosen by a code (GA to GC) as a mask option. | PORT | I/O | IINPU | T/OUTPUT CIRCUITRY and C | CODE | REMARKS | | | |----------|--------|----------------|------------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------|--|--| | КО | Input | GA | GB OVDD RIN R | GC R <sub>IN</sub> | Pull-up/pull-down resistor $R_{\text{IN}} = 70 \text{ k}\Omega \text{ (typ.)}$ $R = 1 \text{ k}\Omega \text{ (typ.)}$ | | | | P1<br>P2 | Output | | | | Sink open drain output Initial "Hi-Z" High current I <sub>OL</sub> = 10 mA (typ.) | | | | R5<br>R6 | I/O | C <sub>A</sub> | Analog switch C <sub>A</sub> R <sub>A</sub> R R R | | | | | | R4<br>R7 | I/O | | No N | | Sink open drain output Initial "Hi-Z" $R = 1 \text{ k}\Omega \text{ (typ.)}$ | | | | R8<br>R9 | I/O | | N SR SR | | Sink open drain output Initial "Hi-Z" Hysteresis input $R = 1 k\Omega$ (typ.) | | | # **ELECTRICAL CHARACTERISTICS** ABSOLUTE MAXIMUM RATINGS $(V_{SS} = 0V)$ | PARAMETER | SYMBOL | PINS | RATINGS | UNIT | |----------------------------------------------|--------------------|----------------------------|--------------------------------|------| | Supply Voltage | $V_{DD}$ | | – 0.3 to 7 | V | | Supply Voltage (LCD drive) | V <sub>LC</sub> | | - 0.3 to V <sub>DD</sub> + 0.3 | V | | Input Voltage | V <sub>IN</sub> | | - 0.3 to V <sub>DD</sub> + 0.3 | V | | Output Voltage | V <sub>OUT1</sub> | Except sink open drain pin | - 0.3 to V <sub>DD</sub> + 0.3 | ., | | Output Voltage | V <sub>OUT2</sub> | Sink open drain pin | - 0.3 to 10 | V | | | I <sub>OUT1</sub> | Ports P1, P2 | 15 | A | | Output Current (Per 1 pin) | I <sub>OUT2</sub> | Ports R4 to R9 | 3.2 | mA | | Output Current (Total) | Σl <sub>OUT1</sub> | Ports P1, P2 | 60 | mA | | Power Dissipation [T <sub>opr</sub> = 70 °C] | PD | | 600 | mW | | Soldering Temperature (time) | T <sub>sld</sub> | | 260 (10 s) | °C | | Storage Temperature | T <sub>stg</sub> | | – 55 to 125 | °C | | Operating Temperature | T <sub>opr</sub> | | - 40 to 70 | °C | RECOMMENDED OPERATING CONDITIONS $(V_{SS} = 0V, T_{opr} = -40 \text{ to } 70 \text{ °C})$ | PARAMETER | SYMBOL | PINS | CONDITIONS | Min. | Max. | UNIT | |--------------------|------------------|-------------------------|-----------------------|----------------------|----------------------|------| | | | | In the Normal<br>mode | 4.5 | | | | Supply Voltage | V | | In the SLOW mode | 2.7 | 6.0 | v | | Supply voltage | V <sub>DD</sub> | | In the SLEEP mode | 2.7 | 6.0 | | | | | | In the HOLD mode | 2.0 | | | | | V <sub>IH1</sub> | Except Hysteresis Input | V >4.5V | $V_{DD} \times 0.7$ | | | | Input High Voltage | V <sub>IH2</sub> | Hysteresis Input | V <sub>DD</sub> ≧4.5V | $V_{DD} \times 0.75$ | V <sub>DD</sub> | V | | | V <sub>IH3</sub> | | V <sub>DD</sub> <4.5V | $V_{DD} \times 0.9$ | | | | | $V_{IL1}$ | Except Hysteresis Input | V >45V | | $V_{DD} \times 0.3$ | | | Input Low Voltage | $V_{IL2}$ | Hysteresis Input | V <sub>DD</sub> ≧4.5V | 0 | $V_{DD} \times 0.25$ | V | | | V <sub>IL3</sub> | | V <sub>DD</sub> <4.5V | | $V_{DD} \times 0.1$ | | | Clark For average | fc | XIN, XOUT | | 0.4 | 6.0 | MHz | | Clock Frequency | fs | XTIN, XTOUT | | 30.0 | 34.0 | kHz | Note. Input Voltage $V_{IH3}$ , $V_{IL3}$ : in the SLOW, SLEEP and HOLD mode. | | D.C. | CHARACTERISTICS | $(V_{SS} = 0V,$ | |--|------|-----------------|-----------------| |--|------|-----------------|-----------------| | $(V_{SS} = 0V,$ | $T_{opr} =$ | - 40 to | 70°C) | |-----------------|-------------|---------|-------| |-----------------|-------------|---------|-------| | PARAMETER | SYMBOL | PINS | CONDITIONS | Min. | Тур. | Max. | UNIT | |----------------------------------------|-------------------|---------------------------------------------|--------------------------------------------------------|------|------|------|------| | Hysteresis Voltage | V <sub>HS</sub> | Hysteresis Input | | - | 0.7 | _ | V | | Input Current | I <sub>IN1</sub> | Port K0, TEST, RESET, HOLD | V <sub>DD</sub> = 5.5 V, | _ | _ | ± 2 | μA | | . • | I <sub>IN2</sub> | Open drain R port | V <sub>IN</sub> = 5.5 V / 0 V | | | | μ | | Input Low Current | I <sub>IL</sub> | Push-pull R port | $V_{DD} = 5.5 \text{ V}, \ V_{IN} = 0.4 \text{ V}$ | _ | _ | - 2 | mA | | L ( B | R <sub>IN1</sub> | Port K0 with pull-up/pull-<br>down resistor | | 30 | 70 | 150 | 5 | | Input Resistance | R <sub>IN2</sub> | RESET | | 100 | 220 | 450 | kΩ | | Output Leakage<br>Current | I <sub>LO</sub> | Open drain ports P, R | $V_{DD} = 5.5 \text{ V}, \ V_{OUT} = 5.5 \text{ V}$ | _ | _ | 2 | μΑ | | Output High Voltage | Voн | Push-pull R port | $V_{DD} = 4.5 \text{ V}, I_{OH} = -200 \mu\text{A}$ | 2.4 | _ | _ | V | | Output Low Voltage | V <sub>OL2</sub> | Except XOUT XOUT and ports P1, P2 | V <sub>DD</sub> = 4.5 V, I <sub>OL</sub> = 1.6 mA | _ | _ | 0.4 | ٧ | | Output Low Current | I <sub>OL1</sub> | Ports P1, P2 | V <sub>DD</sub> = 4.5 V, I <sub>OL</sub> = 1.0V | _ | 10 | _ | mA | | Segment Output Low<br>Resistance | R <sub>OS1</sub> | SEG pin | | | 20 | | | | Common Output Low<br>Resistance | R <sub>OC1</sub> | COM pin | | _ | 20 | _ | | | Segment Output High<br>Resistance | R <sub>OS2</sub> | SEG pin | | | 200 | | kΩ | | Common Output High<br>Resistance | R <sub>OC2</sub> | COM pin | $V_{DD} = 5 \text{ V}, V_{DD} - V_{LC} = 3 \text{ V}$ | | 200 | _ | | | Segment / Common | V <sub>O2/3</sub> | | | 3.8 | 4.0 | 4.2 | | | | V <sub>O1/2</sub> | SEG / COM pin | | 3.3 | 3.5 | 3.7 | V | | Output Voltage | V <sub>O1/3</sub> | | | 2.8 | 3.0 | 3.2 | | | Supply Current<br>(in the Normal mode) | I <sub>DD</sub> | | $V_{DD} = 5.5 \text{ V}, \ V_{LC} = V_{SS}$ fc = 4 MHz | _ | 3 | 6 | mA | | Supply Current | | $V_{DD} = 3.0 \text{ V}, V_{LC} = V_{SS}$ | _ | 30 | 60 | | | | (in the SLOW mode) | I <sub>DD\$</sub> | | fs = 32.768 kHz | | 15 | 30 | μΑ | | Supply Current<br>(in the HOLD mode) | I <sub>DDH</sub> | | V <sub>DD</sub> = 5.5 V | | 0.5 | 10 | μA | Note 1. Typ. values show those at $T_{opr} = 25 \,^{\circ}\text{C}$ , $V_{DD} = 5 \,^{\circ}\text{V}$ . Note 2. Input Current IIN1; The current through resistor is not included, when the input resistor (pull-up / pull-down) is contained. Note 3. Output Resistance $R_{OS}$ , $R_{OC}$ ; Shows on-resistance at the level switching. Note 4. $V_{O2/3}$ ; Shows 2/3 level output voltage, when the 1/4 or 1/3 duty LCD is used. Note 5. $V_{O1/2}$ ; Shows 1/2 level output voltage, when the 1/2 duty or static LCD is used. Note 6. $V_{O1/3}$ ; Shows 1/3 level output voltage, when the 1/4 or 1/3 duty LCD is used. Note 7. Supply Current I<sub>DD</sub>, I<sub>DDH</sub>; $V_{IN} = 5.3 \text{ V} / 0.2 \text{ V}$ The KO port is open when the input resistor is contained. The voltage applied to the R port is within the valid range. Supply Current $I_{DDS}$ ; VIN = 2.8 V/0.2 V Only low frequency clock is only oscillated (connecting XTIN, XTOUT). Note 8. When using LCD, it is necessary to consider values of $R_{OS1/2}$ and $R_{OC1/2}$ . Note 9. Times for SEG / COM output switching on; R<sub>OS1</sub>, R<sub>OC1</sub>: 2/fs (s) $R_{OS2}$ , $R_{OC2}$ : $1/(n \cdot f_F)$ $(1/n : duty, f_F : frame frequency)$ # A / D CONVERSION CHARACTERISTICS $(T_{opr} = -40 \text{ to } 70 \,^{\circ}\text{C})$ | PARAMETER | SYMBOL | CONDITIONS | Min. | Тур. | Max. | UNIT | |--------------------------------|---------------------|----------------------------------------------------------------|-----------------------|------|-------------------|------| | Analas Bafayanaa Valtasa | V <sub>AREF</sub> | | V <sub>DD</sub> _ 1.5 | _ | V <sub>DD</sub> | | | Analog Reference Voltage | V <sub>ASS</sub> | | V <sub>SS</sub> | _ | 1.5 | V | | Analog Reference Voltage Range | $_{\Delta}V_{AREF}$ | V <sub>AREF</sub> -V <sub>ASS</sub> | 2.5 | _ | _ | V | | Analog Input Voltage | V <sub>AIN</sub> | | V <sub>ASS</sub> | _ | V <sub>AREF</sub> | V | | Analog Supply Current | I <sub>REF</sub> | | _ | 0.5 | 1.0 | mA | | Nonlinearity Error | | V 4550V V 0.0V | _ | _ | ± 1 | | | Zero Point Error | | $V_{DD} = 4.5 \text{ to } 6.0 \text{V}, V_{SS} = 0.0 \text{V}$ | _ | _ | ± 1 | LCD | | Full Scale Error | | $V_{AREF} = V_{DD} \pm 0.001V$ | _ | _ | ± 1 | LSB | | Total Error | | V <sub>ASS</sub> = 0.000V | _ | _ | ± 2 | | # A.C. CHARACTERISTICS $(V_{SS} = 0V, V_{DD} = 4.5 \text{ to } 6.0V, T_{opr} = -40 \text{ to } 70 \,^{\circ}\text{C})$ | PARAMETER | SYMBOL | CONDITIONS | Min. | Тур. | Max. | UNIT | |------------------------------|------------------|--------------------------------|---------------------------|------|------|------| | Instruction Cycle Time | + | in the Normal mode | 1.3 | _ | 20 | μS | | instruction cycle rime | t <sub>cy</sub> | in the SLOW mode | 235 | _ | 267 | μs | | High Level Clock Pulse Width | t <sub>WCH</sub> | For external deals are setting | 00 | | | | | Low Level Clock Pulse Width | t <sub>WCL</sub> | For external clock operation | 80 | - | _ | ns | | Shift data Hold Time | t <sub>SDH</sub> | | 0.5 t <sub>cy</sub> – 300 | _ | _ | ns | | A/D Sampling Time | t <sub>AIN</sub> | fc = 4 MHz | _ | 4 | _ | μS | ### Note. Shift data Hold time: External circuit for SCK pin and SO pin Serial port (completion of transmission) **RECOMMENDED OSCILLATING CONDITIONS** $(V_{SS} = 0V, V_{DD} = 4.5 \text{ to } 6.0V, T_{opr} = -40 \text{ to } 70 ^{\circ}\text{C})$ (1) 6 MHz **Ceramic Resonator** CSA6.00MGU (MURATA) $C_{XIN} = C_{XOUT} = 30 \text{ pF}$ KBR-6.00MS (KYOCERA) $C_{XIN} = C_{XOUT} = 30 \text{ pF}$ (2) 4 MHz **Ceramic Resonator** $\begin{array}{lll} \text{CSA4.00MG} & (\text{MURATA}) & \text{C}_{\text{XIN}} = \text{C}_{\text{XOUT}} = 30 \text{ pF} \\ \text{KBR-4.00MS} & (\text{KYOCERA}) & \text{C}_{\text{XIN}} = \text{C}_{\text{XOUT}} = 30 \text{ pF} \\ \text{FCR4.0M5} & (\text{TDK}) & \text{C}_{\text{XIN}} = \text{C}_{\text{XOUT}} = 33 \text{ pF} \\ \text{Crystal Oscillator} \end{array}$ 204B-6F 4.0000 (TOYOCOM) $C_{XIN} = C_{XOUT} = 20 \text{ pF}$ (3) 400 kHz **Ceramic Resonator** CSB400B (MURATA) $C_{XIN} = C_{XOUT} = 220 \text{ pF}, R_{XOUT} = 6.8 \text{ k}\Omega$ KBR-400B (KYOCERA) $C_{XIN} = C_{XOUT} = 100 \text{ pF}, R_{XOUT} = 10 \text{ k}\Omega$ (4) 32.768 kHz (Vss = 0V, $V_{DD}$ = 2.7 to 6.0V, $T_{opr}$ = -30 to 70 °C) Crystal Oscillator CXTIN, CXTOUT; 10 to 33 pF Note: In order to get the accurate oscillation frequency, the adjustment of capacitors must be required. ## **TYPICAL CHARACTERISTICS**