## E0C6007 Technical Hardware

NOTICE
No part of this material may be reproduced or duplicated in any form or by any means without the written permission of Seiko Epson. Seiko Epson reserves the right to make changes to this material without notice. Seiko Epson does not assume any liability of any kind arising out of any inaccuracies contained in this material or due to its application or use in any product or circuit and, further, there is no representation that this material is applicable to products requiring high level reliability, such as medical products. Moreover, no license to any intellectual property rights is granted by implication or otherwise, and there is no representation or warranty that anything made in accordance with this material will be free from any patent or copyright infringement of a third party. This material or portions thereof may contain technology or the subject relating to strategic products under the control of the Foreign Exchange and Foreign Trade Control Law of Japan and may require an export license from the Ministry of International Trade and Industry or other approval from another government agency. Please note that "EOC" is the new name for the old product "SMC". If "SMC" appears in other manuals understand that it now reads "EOC".

## CONTENTS

CHAPTER 1 OUTLINE ..... 1
1.1 Features ..... 1
1.2 Block Diagram .....  2
1.3 Pin Layout Diagram. .....  3
1.4 Pin Description ..... 3
CHAPTER 2 CPU AND BUILT-IN MEMORY ..... 4
2.1 CPU and Instruction Set ..... 4
2.2 Program Memory (ROM) ..... 9
2.3 Data Memory (RAM) ..... 9
CHAPTER 3 POWER SOURCE ..... 14
3.1 Power Supply System ..... 14
3.2 Heavy Load Protection Mode ..... 15
3.2.1 Control of heavy load protection mode ..... 15
3.2.2 Programming notes ..... 15
3.3 CPU Operating Voltage Change ..... 16
CHAPTER 4 INITIAL RESET ..... 17
4.1 Initial Reset Factors ..... 17
4.1.1 Power-on reset circuit. ..... 17
4.1.2 External initial reset by the \#RESET terminal ..... 17
4.1.3 External initial reset by simultaneous low level input of KOO-K03 terminals ..... 18
4.1.4 Initial reset by watchdog timer ..... 18
4.1.5 Internal register at initial resetting ..... 18
4.2 Watchdog Timer ..... 19
4.2.1 Configuration of watchdog timer ..... 19
4.2.2 Control of watchdog timer ..... 19
4.2.3 Programming notes ..... 19
CHAPTER 5 OSCILLATION CIRCUIT ..... 20
5.1 Configuration of Oscillation Circuit ..... 20
5.2 OSC1 Oscillation Circuit ..... 20
5.3 OSC3 Oscillation Circuit ..... 21
5.4 Operating Voltage Change ..... 22
5.5 Clock Frequency and Instruction Execution Time. ..... 22
5.6 Control of Oscillation Circuit ..... 23
5.7 Programming Notes ..... 25
CHAPTER 6 INPUT/OUTPUT PORTS ..... 26
6.1 Input Port (Kxx) ..... 26
6.1.1 Configuration of input ports ..... 26
6.1.2 Mask option ..... 26
6.1.3 Interrupt function ..... 26
6.1.4 Control of input ports ..... 27
6.1.5 Programming notes ..... 28
6.2 Output Port (Rxx) ..... 29
6.2.1 Configuration of output ports ..... 29
6.2.2 Mask option ..... 29
6.2.3 High impedance control ..... 31
6.2.4 Control of output ports ..... 31
6.2.5 Programming notes ..... 32
6.3 I/O Port (Pxx) ..... 33
6.3.1 Configuration of I/O ports ..... 33
6.3.2 Mask option ..... 33
6.3.3 I/O control register and input/output mode ..... 33
6.3.4 Pull up resistor. ..... 33
6.3.5 Control of I/O ports ..... 34
6.3.6 Programming notes ..... 35
CHAPTER 7 LCD DRIVER ..... 36
7.1 Drive Duty ..... 36
7.2 Mask Option ..... 39
7.3 Display Data Memory ..... 39
7.4 Control of LCD Driver ..... 40
7.5 Programming Note ..... 41
CHAPTER 8 TIMERS ..... 42
8.1 Clock Timer ..... 42
8.1.1 Configuration of clock timer ..... 42
8.1.2 Interrupt function ..... 42
8.1.3 Control of clock timer ..... 43
8.1.4 Programming notes ..... 44
8.2 Stopwatch Timer ..... 45
8.2.1 Configuration of stopwatch timer ..... 45
8.2.2 Count-up pattern ..... 45
8.2.3 Interrupt function ..... 46
8.2.4 Control of stopwatch timer. ..... 47
8.2.5 Programming notes ..... 48
8.3 Programmable Timer ..... 49
8.3.1 Configuration of programmable timer ..... 49
8.3.2 Interrupt function ..... 50
8.3.3 Control of programmable timer . ..... 51
8.3.4 Programming notes ..... 53
CHAPTER 9 SOUND GENERATOR ..... 54
9.1 Configuration of Sound Generator ..... 54
9.2 Mask Option ..... 54
9.3 Frequency Setting ..... 55
9.4 Digital Envelope ..... 55
9.5 1-shot Output ..... 56
9.6 Control of Sound Generator ..... 57
9.7 Programming Notes ..... 59
CHAPTER 10 INTERRUPT AND HALT ..... 60
10.1 Interrupt Factor Flag and Interrupt Mask ..... 61
10.2 Interrupt Vector ..... 62
10.3 Programming Notes ..... 62
CHAPTER 11 SUMMARY OF NOTES ..... 64
11.1 Notes for Low Current Consumption. ..... 64
11.2 Summary of Notes by Function ..... 65
11.3 Precautions on Mounting ..... 69
CHAPTER 12 BASIC EXTERNAL CONNECTION DIAGRAM ..... 71
CHAPTER 13 ELECTRICAL CHARACTERISTICS ..... 72
13.1 Absolute Maximum Rating ..... 72
13.2 Recommended Operating Conditions ..... 72
13.3 DC Characteristics ..... 72
13.4 Analog Circuit Characteristics and Consumed Current ..... 73
13.5 AC Characteristics ..... 74
13.6 Oscillation Characteristics ..... 75
CHAPTER 14 PACKAGE ..... 77
14.1 Plastic Package ..... 77
14.2 Ceramic Package for Test Samples ..... 78
CHAPTER 15 PAD LAYOUT ..... 79
15.1 Diagram of Pad Layout ..... 79
15.2 Pad Coordinates ..... 80

## Chapter 1 OUtLine

The E0C6007 is a microcomputer with a C-MOS 4-bit core CPU E0C6200C as main component, and ROM, RAM, dot matrix LCD driver, time base counter and other circuits built-in.

### 1.1 Features



### 1.2 Block Diagram



Fig. 1.2.1 Block diagram

### 1.3 Pin Layout Diagram

QFP15-100pin


| No. | Pin name | No. | Pin name | No. | Pin name | No. | Pin name |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | VL4 | 26 | N.C. | 51 | N.C. | 76 | N.C. |
| 2 | VL5 | 27 | SEG39 | 52 | SEG15 | 77 | N.C. |
| 3 | CF | 28 | SEG38 | 53 | SEG14 | 78 | N.C. |
| 4 | CE | 29 | SEG37 | 54 | SEG13 | 79 | R43 |
| 5 | CD | 30 | SEG36 | 55 | SEG12 | 80 | R42 |
| 6 | CC | 31 | SEG35 | 56 | SEG11 | 81 | R41 |
| 7 | CB | 32 | SEG34 | 57 | SEG10 | 82 | R40 |
| 8 | CA | 33 | SEG33 | 58 | SEG9 | 83 | R33 |
| 9 | COM0 | 34 | SEG32 | 59 | SEG8 | 84 | R32 |
| 10 | COM1 | 35 | SEG31 | 60 | SEG7 | 85 | \#RESET |
| 11 | COM2 | 36 | SEG30 | 61 | SEG6 | 86 | \#TEST |
| 12 | COM3 | 37 | SEG29 | 62 | SEG5 | 87 | Vss |
| 13 | COM4 | 38 | SEG28 | 63 | SEG4 | 88 | OSC4 |
| 14 | COM5 | 39 | SEG27 | 64 | SEG3 | 89 | OSC3 |
| 15 | COM6 | 40 | SEG26 | 65 | SEG2 | 90 | Vs1 |
| 16 | COM7 | 41 | SEG25 | 66 | SEG1 | 91 | OSC2 |
| 17 | COM8 | 42 | SEG24 | 67 | SEG0 | 92 | OSC1 |
| 18 | COM9 | 43 | SEG23 | 68 | K03 | 93 | VDD |
| 19 | COM10 | 44 | SEG22 | 69 | K02 | 94 | VREF |
| 20 | COM11 | 45 | SEG21 | 70 | K01 | 95 | VL1 |
| 21 | COM12 | 46 | SEG20 | 71 | K00 | 96 | VL2 |
| 22 | COM13 | 47 | SEG19 | 72 | P03 | 97 | VL3 |
| 23 | COM14 | 48 | SEG18 | 73 | P02 | 98 | N.C. |
| 24 | COM15 | 49 | SEG17 | 74 | P01 | 99 | N.C. |
| 25 | N.C. | 50 | SEG16 | 75 | P00 | 100 | N.C. |

N.C.: No Connection

Fig. 1.3.1 Pin layout diagram

### 1.4 Pin Description

Table 1.4.1 Pin description

| Pin name | Pin No. | I/O | Function |  |
| :---: | :---: | :---: | :---: | :---: |
| VdD | 93 | - | Power supply (+) |  |
| Vss | 87 | - | Power supply (-) |  |
| Vs1 | 90 | - | Internal logic system/oscillation system regulated voltage output |  |
| VL1-VL5 | 95-97, 1, 2 | - | LCD system power supply 1/4 bias generated internally, $1 / 5$ bias generated externally $* 1$ |  |
| Vref | 94 | 0 | LCD system power test pin *2 |  |
| CA-CF | 8-3 | - | LCD system voltage booster condenser connecting pin |  |
| OSC1 | 92 | I | Crystal or CR oscillator input *1 |  |
| OSC2 | 91 | O | Crystal or CR oscillator output *1, CD buiil-in |  |
| OSC3 | 89 | 1 | CR or ceramic oscillator input *1 |  |
| OSC4 | 88 | 0 | CR or ceramic oscillator output *1 |  |
| COM0-COM15 | 9-24 | 0 | LCD common output ( $1 / 8$ duty or $1 / 16$ duty is selected on software) |  |
| SEG0-SEG39 | 67-52, 50-27 | O | LCD segment output |  |
| K00-K03 | 71-68 | 1 | Input port (pull up resistor is available by mask option) $* 1$ |  |
| P00-P03 | 75-72 | 1/O | I/O port | Complementary output or Nch open drain output *1 |
| R32 | 84 | 0 | Output port |  |
| R33 | 83 | 0 | Output port or PTCLK output |  |
| R40 | 82 | 0 | Output port or \#FOUT output *1 |  |
| R41 | 81 | 0 | Output port |  |
| R42 | 80 | 0 | Output port, \#BZ output or FOUT output *1 |  |
| R43 | 79 | O | Output port or BZ output *1 |  |
| \#RESET | 85 | 1 | Initial reset input terminal |  |
| \#TEST | 86 | I | Testing input terminal *3 |  |

*1 Selected by mask option
*2 Leave the Vref pin unconnected (N.C.).
*3 The \#TEST pin is used when the IC load is being detected.
During ordinary operation be certain to connect this pin to VDD.

## CHAPTER 2 CPU AND BUILT-IN MEMORY

### 2.1 CPU and Instruction Set

The E0C6007 uses the 4-bit core CPU E0C6200C for its CPU. It has almost the same register configurations, instructions, and other features as the other family devices which use the E0C6200/6200A/6200B, allowing full use of software assets. The instruction set of the E0C6007 has 108 types of instructions, all consisting of one word (12 bits).

For detailed information on the CPU and the instruction set, refer to the "E0C6200/6200A Core CPU Manual".
Note, however, that because E0C6007 does not assume SLEEP operation, the SLP instruction is not available in the E0C6200 instruction set.

The instruction list is shown in Tables 2.1.1(a)-(c).
The following lists the symbols used in the instruction list:

## Symbols associated with registers and memory

| A | A register |
| :--- | :--- |
| B | B register |
| X | XHL register (low order eight bits of index register IX) |
| Y | YHL register (low order eight bits of index register IY) |
| XH | XH register (high order four bits of XHL register) |
| XL | XL register (low order four bits of XHL register) |
| YH | YH register (high order four bits of YHL register) |
| YL | YL register (low order four bits of YHL register) |
| XP | XP register (high order four bits of index register IX) |
| YP | YP register (high order four bits of index register IY) |
| SP | Stack pointer SP |
| SPH | High-order four bits of stack pointer SP |
| SPL | Low-order four bits of stack pointer SP |
| MX, M(X) | Data memory whose address is specified with index register IX |
| MY, M(Y) | Data memory whose address is specified with index register IY |
| Mn, M(n) | Data memory address 000H-00FH (address specified with immediate data n of 00H-0FH) |
| $\mathbf{M ( S P ) ~}$ | Data memory whose address is specified with stack pointer SP |
| $\mathbf{r}, \mathbf{q}$ | Two-bit register code |
|  | r, q is two-bit immediate data; according to the contents of these bits, they indicate registers A, B, and |
|  | MX and MY (data memory whose addresses are specified with index registers IX and IY) |


| $r$ |  | q |  | Register <br> specified |
| :---: | :---: | :---: | :---: | :---: |
| r 1 | r 0 | q 1 | q 0 |  |
| 0 | 0 | 0 | 0 | A |
| 0 | 1 | 0 | 1 | B |
| 1 | 0 | 1 | 0 | MX |
| 1 | 1 | 1 | 1 | MY |

## Symbols associated with program counter

NBP New bank pointer
NPP New page pointer
PCB Program counter bank
PCP Program counter page
PCS Program counter step
PCSH Four high order bits of PCS
PCSL Four low order bits of PCS

| Symbols associated with flags |  |
| :--- | :--- |
| F | Flag register (I, D, Z, C) |
| C | Carry flag |
| Z | Zero flag |
| D | Decimal flag |
| I | Interrupt flag |
| $\downarrow$ | Flag reset |
| $\uparrow$ | Flag set |
| $\hat{\imath}$ | Flag set or reset |
|  |  |
| Associated with immediate data |  |
| p | Five-bit immediate data or label 00H-1FH |
| $\mathbf{s}$ | Eight-bit immediate data or label 00H-OFFH |
| I | Eight-bit immediate data $00 \mathrm{H}-0 \mathrm{FFH}$ |
| $\mathbf{i}$ | Four-bit immediate data $00 \mathrm{H}-\mathrm{OFH}$ |

## Associated with arithmetic and other operations

## + Add

- Subtract
$\wedge \quad$ Logical AND
$\checkmark \quad$ Logical OR
$\forall \quad$ Exclusive-OR
$\star \quad$ Add-subtract instruction for decimal operation when the D flag is set

Table 2.1.1(a) Instruction sets (1)

| Classification | Mnemonic | Operand | Operation Code |  |  | Flag | Clock | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | B A 98 | $7 \begin{array}{llll}7 & 6 & 5 & 4\end{array}$ | 3210 | I D Z C |  |  |
| Branch instructions | PSET | p | $\begin{array}{lllll}1 & 1 & 1 & 0\end{array}$ | $0{ }_{0} 1800 \mathrm{p} 4$ | p3 p2 p1 p0 |  | 5 | $\mathrm{NBP} \leftarrow \mathrm{p} 4, \mathrm{NPP} \leftarrow \mathrm{p} 3 \sim \mathrm{p} 0$ |
|  | JP | s | $\begin{array}{llll}0 & 0 & 0 & 0\end{array}$ | s7 s6 s5 s4 | s3 s2 s1 s0 |  | 5 | $\mathrm{PCB} \leftarrow \mathrm{NBP}, \mathrm{PCP} \leftarrow \mathrm{NPP}, \mathrm{PCS} \leftarrow \mathrm{s} 7 \sim \mathrm{~s} 0$ |
|  |  | C, s | $\begin{array}{lllll}0 & 0 & 1 & 0\end{array}$ | s7 s6 s5 s4 | s3 s2 s1 s0 |  | 5 | $\mathrm{PCB} \leftarrow \mathrm{NBP}, \mathrm{PCP} \leftarrow \mathrm{NPP}, \mathrm{PCS} \leftarrow \mathrm{s} 7 \sim \mathrm{~s} 0$ if $\mathrm{C}=1$ |
|  |  | NC, s | $\begin{array}{lllll}0 & 0 & 1 & 1\end{array}$ | s7 s6 s5 s4 | s3 s2 s1 s0 |  | 5 | $\mathrm{PCB} \leftarrow \mathrm{NBP}, \mathrm{PCP} \leftarrow \mathrm{NPP}, \mathrm{PCS} \leftarrow \mathrm{s} 7 \sim \mathrm{~s} 0$ if $\mathrm{C}=0$ |
|  |  | Z, s | $\begin{array}{lllll}0 & 1 & 1 & 0\end{array}$ | s7 s6 s5 s4 | s3 s2 s1 s0 |  | 5 | $\mathrm{PCB} \leftarrow \mathrm{NBP}, \mathrm{PCP} \leftarrow \mathrm{NPP}, \mathrm{PCS} \leftarrow \mathrm{s} 7 \sim \mathrm{~s} 0$ if $\mathrm{Z}=1$ |
|  |  | NZ, s | $\begin{array}{lllll}0 & 1 & 1 & 1\end{array}$ | s7 s6 s5 s4 | s3 s2 s1 s0 |  | 5 | $\mathrm{PCB} \leftarrow \mathrm{NBP}, \mathrm{PCP} \leftarrow \mathrm{NPP}, \mathrm{PCS} \leftarrow \mathrm{s} 7 \sim \mathrm{~s} 0$ if $\mathrm{Z}=0$ |
|  | JPBA |  | $\begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $\begin{array}{lllll}1 & 1 & 1 & 0\end{array}$ | $\begin{array}{lllll}1 & 0 & 0 & 0\end{array}$ |  | 5 | $\mathrm{PCB} \leftarrow \mathrm{NBP}, \mathrm{PCP} \leftarrow \mathrm{NPP}, \mathrm{PCSH} \leftarrow \mathrm{B}, \mathrm{PCSL} \leftarrow \mathrm{A}$ |
|  | CALL | s | $\begin{array}{lllll}0 & 1 & 0 & 0\end{array}$ | s7 s6 s5 s4 | s3 s2 s1 s0 |  | 7 | $\begin{aligned} & \mathrm{M}(\mathrm{SP}-1) \leftarrow \mathrm{PCP}, \mathrm{M}(\mathrm{SP}-2) \leftarrow \mathrm{PCSH}, \mathrm{M}(\mathrm{SP}-3) \leftarrow \mathrm{PCSL}+1 \\ & \mathrm{SP} \leftarrow \mathrm{SP}-3, \mathrm{PCP} \leftarrow \mathrm{NPP}, \mathrm{PCS} \leftarrow \mathrm{~s} 7 \sim \mathrm{~s} 0 \end{aligned}$ |
|  | CALZ | s | $\begin{array}{llll}0 & 1 & 0 & 1\end{array}$ | s7 s6 s5 s4 | s3 s2 s1 s0 |  | 7 | $\begin{aligned} & \mathrm{M}(\mathrm{SP}-1) \leftarrow \mathrm{PCP}, \mathrm{M}(\mathrm{SP}-2) \leftarrow \mathrm{PCSH}, \mathrm{M}(\mathrm{SP}-3) \leftarrow \mathrm{PCSL}+1 \\ & \mathrm{SP} \leftarrow \mathrm{SP}-3, \mathrm{PCP} \leftarrow 0, \mathrm{PCS} \leftarrow \mathrm{~s} 7 \sim \mathrm{~s} 0 \end{aligned}$ |
|  | RET |  | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $1 \begin{array}{llll}1 & 1 & 0 & 1\end{array}$ | $\begin{array}{llll}1 & 1 & 1 & 1\end{array}$ |  | 7 | $\begin{aligned} & \mathrm{PCSL} \leftarrow \mathrm{M}(\mathrm{SP}), \mathrm{PCSH} \leftarrow \mathrm{M}(\mathrm{SP}+1), \mathrm{PCP} \leftarrow \mathrm{M}(\mathrm{SP}+2) \\ & \mathrm{SP} \leftarrow \mathrm{SP}+3 \end{aligned}$ |
|  | RETS |  | $\begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $1 \begin{array}{llll}1 & 1 & 0 & 1\end{array}$ | $1 \begin{array}{llll}1 & 1 & 1 & 0\end{array}$ |  | 12 | $\begin{aligned} & \mathrm{PCSL} \leftarrow \mathrm{M}(\mathrm{SP}), \mathrm{PCSH} \leftarrow \mathrm{M}(\mathrm{SP}+1), \mathrm{PCP} \leftarrow \mathrm{M}(\mathrm{SP}+2) \\ & \mathrm{SP} \leftarrow \mathrm{SP}+3, \mathrm{PC} \leftarrow \mathrm{PC}+1 \end{aligned}$ |
|  | RETD | $l$ | $0 \begin{array}{llll}0 & 0 & 0 & 1\end{array}$ | $l 7 l 6 l 5 l 4$ | $l 3 l 2 l 1 l 0$ |  | 12 | $\begin{aligned} & \mathrm{PCSL} \leftarrow \mathrm{M}(\mathrm{SP}), \mathrm{PCSH} \leftarrow \mathrm{M}(\mathrm{SP}+1), \mathrm{PCP} \leftarrow \mathrm{M}(\mathrm{SP}+2) \\ & \mathrm{SP} \leftarrow \mathrm{SP}+3, \mathrm{M}(\mathrm{X}) \leftarrow l 3 \sim l 0, \mathrm{M}(\mathrm{X}+1) \leftarrow l 7 \sim l 4, \mathrm{X} \leftarrow \mathrm{X}+2 \end{aligned}$ |
| System <br> control <br> instructions | NOP5 |  | $\begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $1 \begin{array}{llll}1 & 0 & 1 & 1\end{array}$ |  | 5 | No operation (5 clock cycles) |
|  | NOP7 |  | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $\begin{array}{llllll}1 & 1 & 1 & 1\end{array}$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ |  | 7 | No operation (7 clock cycles) |
|  | HALT |  | $\begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $1 \begin{array}{llll}1 & 0 & 0 & 0\end{array}$ |  | 5 | Halt (stop clock) |
| Index operation instructions | INC | X | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{lllll}1 & 1 & 1 & 0\end{array}$ | 0 |  | 5 | $\mathrm{X} \leftarrow \mathrm{X}+1$ |
|  |  | Y | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $\begin{array}{llll}0 & 0 & 0 & 0\end{array}$ |  | 5 | $\mathrm{Y} \leftarrow \mathrm{Y}+1$ |
|  | LD | $\mathrm{X}, \mathrm{x}$ | $\begin{array}{llll}1 & 0 & 1 & 1\end{array}$ | x7 x6 x5 x4 | x3 x2 x1 x0 |  | 5 | $\mathrm{XH} \leftarrow \mathrm{x} 7 \sim \mathrm{x} 4, \mathrm{XL} \leftarrow \mathrm{x} 3 \sim \mathrm{x} 0$ |
|  |  | Y, y | $\begin{array}{lllll}1 & 0 & 0 & 0\end{array}$ | $y 7 \mathrm{y} 6 \mathrm{y} 5 \mathrm{y} 4$ | y3 y2 y1 y0 |  | 5 | $\mathrm{YH} \leftarrow \mathrm{y} 7 \sim \mathrm{y} 4, \mathrm{YL} \leftarrow \mathrm{y} 3 \sim \mathrm{y} 0$ |
|  |  | XP, r | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 0 & 0\end{array}$ | $0 \quad 0 \mathrm{rl} \mathrm{r} 0$ |  | 5 | $\mathrm{XP} \leftarrow \mathrm{r}$ |
|  |  | XH, r | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 0 & 0\end{array}$ | 011 rl r 0 |  | 5 | $\mathrm{XH} \leftarrow \mathrm{r}$ |
|  |  | XL, r | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | 1100000 | $10 \mathrm{rl} \mathrm{r0}$ |  | 5 | $\mathrm{XL} \leftarrow \mathrm{r}$ |
|  |  | YP, r | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 0 & 1\end{array}$ | $0 \quad 0 \mathrm{rl} \mathrm{r0}$ |  | 5 | $\mathrm{YP} \leftarrow \mathrm{r}$ |
|  |  | YH, r | $\begin{array}{lllll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 0 & 1\end{array}$ | 011 rl r 0 |  | 5 | $\mathrm{YH} \leftarrow \mathrm{r}$ |
|  |  | YL, r | $\begin{array}{lllll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 0 & 1\end{array}$ | $10 \mathrm{rl} \mathrm{r0}$ |  | 5 | $\mathrm{YL} \leftarrow \mathrm{r}$ |
|  |  | r, XP | $\begin{array}{lllll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | $0 \quad 0 \mathrm{rl} \mathrm{r} 0$ |  | 5 | $\mathrm{r} \leftarrow \mathrm{XP}$ |
|  |  | r, XH | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | $0 \mathrm{O}^{1} \mathrm{rl} \mathrm{r} 0$ |  | 5 | $\mathrm{r} \leftarrow \mathrm{XH}$ |
|  |  | r, XL | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | 10 rl r 0 |  | 5 | $\mathrm{r} \leftarrow \mathrm{XL}$ |
|  |  | r, YP | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 1 & 1\end{array}$ | $0 \quad 0 \mathrm{rl} \mathrm{r0}$ |  | 5 | $\mathrm{r} \leftarrow \mathrm{YP}$ |
|  |  | r, YH | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1{ }_{1} 00$ | $0 \mathrm{l}^{1} \mathrm{rl} \mathrm{r} 0$ |  | 5 | $\mathrm{r} \leftarrow \mathrm{YH}$ |
|  |  | r, YL | $\begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | $1 \begin{array}{llll}1 & 0 & 1 & 1\end{array}$ | $10 \mathrm{rl} \mathrm{r0}$ |  | 5 | $\mathrm{r} \leftarrow \mathrm{YL}$ |
|  | ADC | XH, i | $\begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | 0 | i3 i2 i1 i0 | $\downarrow \downarrow$ | 7 | $\mathrm{XH} \leftarrow \mathrm{XH}+\mathrm{i} 3 \sim \mathrm{i} 0+\mathrm{C}$ |
|  |  | XL, i | $\begin{array}{lllll}1 & 0 & 1 & 0\end{array}$ | 0 | i3 i2 i1 i0 | $\downarrow \downarrow$ | 7 | $\mathrm{XL} \leftarrow \mathrm{XL}+\mathrm{i} 3 \sim \mathrm{i} 0+\mathrm{C}$ |
|  |  | YH, i | $\begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | 0 | i3 i2 i1 i0 | $\downarrow \downarrow$ | 7 | $\mathrm{YH} \leftarrow \mathrm{YH}+\mathrm{i} 3 \sim \mathrm{i} 0+\mathrm{C}$ |
|  |  | YL, i | $\begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | $\begin{array}{lllll}0 & 0 & 1 & 1\end{array}$ | i3 i2 i1 i0 | $\downarrow \downarrow$ | 7 | $\mathrm{YL} \leftarrow \mathrm{YL}+\mathrm{i} 3 \sim \mathrm{i} 0+\mathrm{C}$ |

Table 2.1.1(b) Instruction sets (2)


Table 2.1.1(c) Instruction sets (3)

| Classification | Mnemonic | Operand | Operation Code |  |  |  |  |  | $\begin{array}{\|c\|} \hline \text { Flag } \\ \hline \text { I D Z C } \end{array}$ | Clock | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | B | B 98 |  |  | $6 \quad 5 \quad 4$ | 3210 |  |  |  |
| Stack operation instructions | POP | YH | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | 1001 | $1 \begin{array}{llll}1 & 0 & 0 & 0\end{array}$ |  | 5 | $\mathrm{YH} \leftarrow \mathrm{M}(\mathrm{SP}), \mathrm{SP} \leftarrow \mathrm{SP}+1$ |
|  |  | YL | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $1 \begin{array}{lll}1 & 0 & 1\end{array}$ | $1 \begin{array}{llll}1 & 0 & 0 & 1\end{array}$ |  | 5 | $\mathrm{YL} \leftarrow \mathrm{M}(\mathrm{SP}), \mathrm{SP} \leftarrow \mathrm{SP}+1$ |
|  |  | F | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $1 \begin{array}{lll}1 & 0 & 1\end{array}$ | $1 \begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | $\downarrow \downarrow \downarrow \downarrow$ | 5 | $\mathrm{F} \leftarrow \mathrm{M}(\mathrm{SP}), \mathrm{SP} \leftarrow \mathrm{SP}+1$ |
|  | LD | SPH, r | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}1 & 1 & 0\end{array}$ | $00^{0} \mathrm{rl} \mathrm{r0}$ |  | 5 | $\mathrm{SPH} \leftarrow \mathrm{r}$ |
|  |  | SPL, r | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}1 & 1 & 1\end{array}$ | $0 \quad 0 \mathrm{rl} \mathrm{r} 0$ |  | 5 | $\mathrm{SPL} \leftarrow \mathrm{r}$ |
|  |  | r, SPH | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}1 & 1 & 0\end{array}$ | $0{ }_{0} 1 \mathrm{rl} \mathrm{r} 0$ |  | 5 | $\mathrm{r} \leftarrow \mathrm{SPH}$ |
|  |  | r, SPL | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{lll}1 & 1 & 1\end{array}$ | $0 \mathrm{l}^{1} \mathrm{rl} \mathrm{r} 0$ |  | 5 | $\mathrm{r} \leftarrow$ SPL |
| Arithmetic instructions | ADD | r, i | 1 | $1 \begin{array}{lll}1 & 0 & 0\end{array}$ |  |  | $0 \mathrm{rl} \mathrm{r0}$ | i3 i2 i1 i0 | $\star \downarrow \downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r}+\mathrm{i} 3 \sim \mathrm{i} 0$ |
|  |  | r, q | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $\begin{array}{llll}0 & 0 & 0\end{array}$ | r1 r0 q1 q0 | $\star \downarrow \downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r}+\mathrm{q}$ |
|  | ADC | r, i | 1 | $1 \begin{array}{llll}1 & 0 & 0\end{array}$ |  |  | 1 rl r 0 | i3 i2 i1 i0 | $\star \downarrow \downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r}+\mathrm{i} 3 \sim \mathrm{i} 0+\mathrm{C}$ |
|  |  | r, q | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $\begin{array}{llll}0 & 0 & 1\end{array}$ | r1 r0 q1 q0 | $\star \downarrow \downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r}+\mathrm{q}+\mathrm{C}$ |
|  | SUB | r, q | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $\begin{array}{llll}0 & 1 & 0\end{array}$ | r1 r0 q1 q0 | $\star \downarrow \downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r}-\mathrm{q}$ |
|  | SBC | r, i | 1 | $\begin{array}{llll}1 & 0 & 1\end{array}$ |  |  | $1 \mathrm{rl} \mathrm{r0}$ | i3 i2 i1 i0 | $\star \downarrow \downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r}-\mathrm{i} 3 \sim \mathrm{i} 0-\mathrm{C}$ |
|  |  | r, q | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $\begin{array}{llll}0 & 1 & 1\end{array}$ | r1 r0 q1 q0 | $\star \downarrow \downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r}-\mathrm{q}-\mathrm{C}$ |
|  | AND | r, i | 1 | $1 \begin{array}{llll}1 & 0 & 0\end{array}$ |  |  | 0 rl r 0 | i3 i2 i1 i0 | $\downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r} \wedge \mathrm{i} 3 \sim \mathrm{i} 0$ |
|  |  | r, q | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $1 \begin{array}{lll}1 & 0 & 0\end{array}$ | r1 r0 q1 q0 | $\downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r} \wedge \mathrm{q}$ |
|  | OR | r, i | 1 | $1 \begin{array}{llll}1 & 0 & 0\end{array}$ |  |  | $1 \mathrm{rl} \mathrm{r0}$ | i3 i2 i1 i0 | $\downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r} V \mathrm{i} 3 \sim \mathrm{i} 0$ |
|  |  | r, q | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $\begin{array}{llll}1 & 0 & 1\end{array}$ | r1 r0 q1 q0 | $\downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r} \vee \mathrm{q}$ |
|  | XOR | r, i | 1 | $\begin{array}{llll}1 & 0 & 1\end{array}$ |  |  | 0 rl r 0 | i3 i2 i1 i0 | $\downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r} \forall \mathrm{i} 3 \sim \mathrm{i} 0$ |
|  |  | r, q | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $\begin{array}{llll}1 & 1 & 0\end{array}$ | r1 r0 q1 q0 | $\downarrow$ | 7 | $\mathrm{r} \leftarrow \mathrm{r} \forall \mathrm{q}$ |
|  | CP | r, i | 1 | $\begin{array}{llll}1 & 0 & 1\end{array}$ |  |  | $1 \mathrm{rl} \mathrm{r0}$ | i3 i2 i1 i0 | $\downarrow \uparrow$ | 7 | r-i3~i0 |
|  |  | r, q | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}0 & 0 & 0\end{array}$ | r1 r0 q1 q0 | $\downarrow \downarrow$ | 7 | r-q |
|  | FAN | r, i | 1 | $\begin{array}{llll}1 & 0 & 1\end{array}$ |  |  | $0 \mathrm{rl} \mathrm{r0}$ | i3 i2 i1 i0 | $\downarrow$ | 7 | $\mathrm{r} \wedge \mathrm{i} 3 \sim \mathrm{i} 0$ |
|  |  | r, q | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}0 & 0 & 1\end{array}$ | r1 r0 q1 q0 | $\downarrow$ | 7 | $\mathrm{r} \wedge \mathrm{q}$ |
|  | RLC | r | 1 | $\begin{array}{llll}0 & 1 & 0\end{array}$ |  |  | $\begin{array}{llll}1 & 1 & 1\end{array}$ | r1 r0 r1 r0 | $\downarrow \downarrow$ | 7 | $\mathrm{d} 3 \leftarrow \mathrm{~d} 2, \mathrm{~d} 2 \leftarrow \mathrm{~d} 1, \mathrm{~d} 1 \leftarrow \mathrm{~d} 0, \mathrm{~d} 0 \leftarrow \mathrm{C}, \mathrm{C} \leftarrow \mathrm{d} 3$ |
|  | RRC | r | 1 | $\begin{array}{llll}1 & 1 & 0\end{array}$ |  |  | $\begin{array}{lll}0 & 0 & 0\end{array}$ | 11 rl r 0 | $\downarrow \downarrow$ | 5 | $\mathrm{d} 3 \leftarrow \mathrm{C}, \mathrm{d} 2 \leftarrow \mathrm{~d} 3, \mathrm{~d} 1 \leftarrow \mathrm{~d} 2, \mathrm{~d} 0 \leftarrow \mathrm{~d} 1, \mathrm{C} \leftarrow \mathrm{d} 0$ |
|  | INC | Mn | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}1 & 1 & 0 & \\ \end{array}$ | n 3 n 2 n 1 n 0 | $\downarrow \downarrow$ | 7 | $\mathrm{M}(\mathrm{n} 3 \sim \mathrm{n} 0) \leftarrow \mathrm{M}(\mathrm{n} 3 \sim \mathrm{n} 0)+1$ |
|  | DEC | Mn | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{lll}1 & 1 & 1\end{array}$ | n 3 n 2 n 1 n 0 | $\downarrow \downarrow$ | 7 | $\mathrm{M}(\mathrm{n} 3 \sim \mathrm{n} 0) \leftarrow \mathrm{M}(\mathrm{n} 3 \sim \mathrm{n} 0)-1$ |
|  | ACPX | MX, r | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}0 & 1 & 0\end{array}$ | $10 \mathrm{rl} \mathrm{r0}$ | $\star \downarrow \downarrow$ | 7 | $\mathrm{M}(\mathrm{X}) \leftarrow \mathrm{M}(\mathrm{X})+\mathrm{r}+\mathrm{C}, \mathrm{X} \leftarrow \mathrm{X}+1$ |
|  | ACPY | MY, r | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}0 & 1 & 0\end{array}$ | $11 \mathrm{rl} \mathrm{r0}$ | $\star \downarrow \downarrow$ | 7 | $\mathrm{M}(\mathrm{Y}) \leftarrow \mathrm{M}(\mathrm{Y})+\mathrm{r}+\mathrm{C}, \mathrm{Y} \leftarrow \mathrm{Y}+1$ |
|  | SCPX | MX, r | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}0 & 1 & 1\end{array}$ | $10 \mathrm{rl} \mathrm{r0}$ | $\star \downarrow \downarrow$ | 7 | $\mathrm{M}(\mathrm{X}) \leftarrow \mathrm{M}(\mathrm{X})$-r-C, $\mathrm{X} \leftarrow \mathrm{X}+1$ |
|  | SCPY | MY, r | 1 | $\begin{array}{llll}1 & 1 & 1\end{array}$ |  |  | $\begin{array}{llll}0 & 1 & 1\end{array}$ | $11 \mathrm{rl} \mathrm{r0}$ | $\star \downarrow \downarrow$ | 7 | $\mathrm{M}(\mathrm{Y}) \leftarrow \mathrm{M}(\mathrm{Y})$-r-C, $\mathrm{Y} \leftarrow \mathrm{Y}+1$ |
|  | NOT | r | 1 | $\begin{array}{llll}1 & 0 & 1\end{array}$ |  |  | $0 \mathrm{rl} \mathrm{r0}$ | $\left\lvert\, \begin{array}{llll}1 & 1 & 1 & 1\end{array}\right.$ | $\downarrow$ | 7 | $\mathrm{r} \leftarrow \overline{\mathrm{r}}$ |

### 2.2 Program Memory (ROM)

The built-in ROM, a mask ROM for loading the program, has a capacity of 4,096 steps $\times 12$ bits. The program area consists of $16(0-15)$ pages $\times 256(00 \mathrm{H}-\mathrm{FFH})$ steps. After initial reset, the program beginning address is set to bank 0 , page 1 , step 00 H . The interrupt vector is allocated to page 1 , steps $02 \mathrm{H}-0 \mathrm{CH}$.


Fig. 2.2.1 Configuration of the built-in ROM

### 2.3 Data Memory (RAM)

The E0C6007 built-in data memories are configured a general-purpose RAM, display data memory of the LCD, and I/O data memory which controls the peripheral circuit.
General-purpose RAM: 512 words $\times 4$ bits ( $000 \mathrm{H}-1 \mathrm{FFH}$ )
Display data memory: 160 words $\times 4$ bits (E00H-E4FH, E80H-ECFH)
I/O memory: $\quad 33$ words $\times 4$ bits (F00H-F7FH)
During programming, take note of the following:
(1) Since the stack area is taken from the RAM area, take care that destruction of stack data due to data writing does not occur. Sub-routine calls or interrupts consume 3 words of the stack area.
(2) RAM address $000 \mathrm{H}-00 \mathrm{FH}$ are memory register areas that are addressed with register pointer RP.

The memory map of the built-in data memory (RAM) and details of the I/O data memory map are shown in Figure 2.3.1 and Tables 2.3.1(a)-(c), respectively.

Note: Memory is not mounted in unused area within the memory map and in memory area not indicated in this chapter. For this reason, normal operation cannot be assured for programs that have been prepared with access to these areas.



Fig. 2.3.1 Memory map

Table 2.3.1(a) I/O data memory map (1)


[^0]Table 2.3.1(b) I/O data memory map (2)

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | \|nit *1 | 1 | 0 |  |
| F26H | R/W |  |  |  | $\begin{aligned} & \hline \text { RD3 } \\ & \text { RD2 } \\ & \text { RD1 } \\ & \text { RDO } \end{aligned}$ | $\begin{array}{ll} \hline X & * 5 \\ X & * 5 \\ X & * 5 \\ X & * 5 \\ \hline \end{array}$ |  |  | $]^{\mid} \begin{aligned} & \text { MSB } \\ & \begin{array}{l} \text { Programmable timer } \\ \text { reload data (low-order) } \end{array} \end{aligned}$ |
| F27H | RD7 | R/W |  | RD4 | $\begin{aligned} & \hline \text { RD7 } \\ & \text { RD6 } \\ & \text { RD5 } \\ & \text { RD4 } \end{aligned}$ | $\begin{array}{ll} X & * 5 \\ X & * 5 \\ X & * 5 \\ X & * 5 \\ \hline \end{array}$ |  |  | $\int_{\text {LSB }} \int_{\text {Programmable timer }}^{\text {MSB }} \begin{aligned} & \text { reload data (high-order) } \end{aligned}$ |
| F40H | K03 | R |  | K00 | $\begin{aligned} & \text { K03 } \\ & \text { K02 } \\ & \text { K01 } \\ & \text { K00 } \end{aligned}$ | $\begin{aligned} & \hline \mathbf{l}^{*} \\ & -*_{2} \\ & -*_{2} \\ & -*_{2} \\ & \hline \end{aligned}$ | High <br> High <br> High <br> High | Low <br> Low <br> Low <br> Low | $]$ Input port (K00-K03) |
| F53H | R33 | R32 | 0 | 0 | R33 | X *5 | High Off | $\begin{aligned} & \text { Low } \\ & \text { On } \end{aligned}$ | Output port (R33) <br> PTCLK output |
|  | R/W |  | R |  | $\begin{array}{r} \text { R32 } \\ 0 \\ 0 \\ 0 \end{array}$ | $\begin{gathered} \mathrm{x} \\ \hdashline-* 2 \\ -\quad * 2 \\ -\quad * 2 \end{gathered}$ | High | Low | Output port (R32) |
|  | R43 | R42 | R41 | R40 | R43 | 1 | $\begin{aligned} & \text { High } \\ & \text { Off } \end{aligned}$ | $\begin{gathered} \text { Low } \\ \text { On } \end{gathered}$ | Output port (R43) <br> Buzzer output (BZ) |
| F54H | RW |  |  |  | R42 | 1 | $\begin{gathered} \text { High } \\ \text { Off } \\ * 6 \end{gathered}$ | $\begin{gathered} \text { Low } \\ \text { On } \\ * \end{gathered}$ | Output port (R42) <br> Clock output (FOUT) <br> [Buzzer inverted output (\#BZ)] |
|  |  |  |  |  | R41 | 1 | High | Low | Output port (R41) |
|  |  |  |  |  | R40 | 1 | $\begin{aligned} & \text { High } \\ & \text { Off } \end{aligned}$ | $\begin{aligned} & \text { Low } \\ & \text { On } \end{aligned}$ | Output port (R40) <br> Clock inverted output (\#FOUT) |
| F60H | R/W |  |  |  | $\begin{aligned} & \hline \text { P03 } \\ & \text { P02 } \\ & \text { P01 } \\ & \text { P00 } \end{aligned}$ | $\begin{array}{ll} \text { X } & * 5 \\ X & * 5 \\ X & * 5 \\ X & * 5 \\ \hline \end{array}$ | High <br> High <br> High <br> High | Low <br> Low <br> Low <br> Low | $]$ I/O port (P00-P03) |
| F70H | CLKCHG | $\mathrm{OSCC}_{\text {O }}^{\text {R }}$ | VSC1 | vSCO | $\begin{array}{\|l\|} \hline \text { CLKCHG } \\ \text { OSCC } \\ \text { VSC1 } \\ \text { VSCO } \\ \hline \end{array}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { OSC3 } \\ \text { On } \end{gathered}$ | $\begin{gathered} \text { OSC1 } \\ \text { Off } \end{gathered}$ | CPU system clock switch OSC3 oscillation On/Off CPU operating voltage switch |
| F71H | R/W |  |  | HLMOD | $\begin{array}{\|l\|l\|} \hline \text { ALOFF } \\ \text { ALON } \\ \text { LDUTY } \\ \text { HLMOD } \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | All off <br> All on <br> 1/8 <br> HLMOD | Normal Normal 1/16 <br> Normal | All LCD dots fade out control All LCD dots displayed control LCD drive duty switch Heavy load protection mode |
| F72H | LC3 | $\mathrm{LC2}^{\text {L }}$ | LC1 W | LCO | $\begin{aligned} & \text { LC3 } \\ & \text { LC2 } \\ & \text { LC1 } \\ & \text { LC0 } \end{aligned}$ | $\begin{array}{ll} X & * 5 \\ X & * 5 \\ X & * 5 \\ X & * 5 \\ \hline \end{array}$ |  |  |  |
| F74H | SHOTPW | $\frac{\text { BZFQ2 }}{}$ | BZFQ1 <br> $W$ | BZFQ0 | $\begin{array}{\|c\|} \hline \text { SHOTPW } \\ \text { BZFQ2 } \\ \text { BZFQ1 } \\ \text { BZFQ0 } \\ \hline \end{array}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | 62.5 ms | 31.25 ms | 1-shot buzzer pulse width <br> Buzzer frequency selection |
| F75H | BZSHOT | ENVRST | ENVRT | ENVON | BZSHOT <br> ENVRST <br> ENVRT <br> ENVON | 0 <br> RESET <br> 0 <br> 0 | $\begin{gathered} \hline \text { Trigger } \\ \text { BUSY } \\ \text { Reset } \\ 1.0 \mathrm{sec} \\ \text { On } \\ \hline \end{gathered}$ | - READY - 0.5 sec Off | 1-shot buzzer trigger (W) <br> Status (R) <br> Envelope reset <br> Envelope cycle selection <br> Envelope On/Off |
| F76H | 0 | 0 | TMRST | WDRST | 0 ${ }^{* 4}$ <br> 0 ${ }^{*}$ <br> TMRST4  <br> WDRST  | $\begin{gathered} \hline{ }^{*}{ }^{*} \\ -{ }^{* 2} \\ \text { Reset } \\ \text { Reset } \\ \hline \end{gathered}$ | Reset <br> Reset | $-$ | Clock timer reset <br> Watchdog timer reset |
| F77H | 0 | 0 | SWRST W | SWRUN <br> RW | $\begin{array}{\|cc\|} \hline 0 & * 4 \\ 0 & * 4 \\ \text { SWRST } \\ \text { SWRUN } \\ \text { SWRU } \end{array}$ | $\begin{gathered} -*_{2} \\ -*_{2} \\ \text { Reset } \\ 0 \\ \hline \end{gathered}$ | Reset Run | Stop | Stopwatch timer reset <br> Stopwatch timer Run/Stop |

*3 Reset ( 0 ) immediately after being read $\quad * 4 \quad$ Always " 0 " when being read $\quad * 5$ Undefined
*6 When selecting options enclosed in brackets [ ] as output option, the output register will function as register only and will not affect the individual outputs.

Table 2.3.1(c) I/O data memory map (3)

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 |  |
| F78H | 0 | 0 | PTRST | PTRUN | $\begin{array}{\|cc\|} \hline 0 & { }^{* 4} \\ 0 & *_{4} \\ \text { PTRST } \\ \text { PTRUN } \end{array}$ | $\begin{gathered} \hline{ }^{*}{ }_{2} \\ -* 2 \\ \text { Reset } \\ 0 \end{gathered}$ | Reset <br> Run | Stop | Programmable timer reset <br> Programmable timer Run/Stop |
|  | R |  | W | R/W |  |  |  |  |  |
| F79H | PTCOUT | PTC2 | PTC1 | PTCO | $\begin{array}{\|c\|} \hline \text { PTCOUT } \\ \text { PTC2 } \\ \text { PTC1 } \\ \text { PTC0 } \\ \hline \end{array}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | On | Off | Programmable timer clock output <br> Programmable timer input clock selection |
|  | R/W |  |  |  |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |  |  |
| F7BH | HZR3 | 0 | 0 | 0 | $\begin{array}{\|cc\|} \hline \text { HZR3 } \\ 0 & * 4 \\ 0 & * 4 \\ 0 & * 4 \\ \hline \end{array}$ | $\begin{aligned} & 0 \\ & -\quad * 2 \end{aligned}$ | Output | High-Z | R32-R33 output high-impedance control |
|  | R/W | R |  |  |  | - ${ }^{*}$ <br> - ${ }^{2}$ |  |  |  |
| F7DH | 0 | 0 | 0 | IOCO | $\begin{array}{ll} 0 & { }^{*} 4 \\ 0 & * 4 \end{array}$ | $\begin{aligned} & -*_{2} \\ & - \\ & \hline \end{aligned}$ |  |  |  |
|  | R |  |  | R/W | $10 C 0$ | 0 | Output | Input | I/O control (P00-P03) |
| F7EH | 0 | 0 | 0 | PUP0 | $\begin{array}{ll} 0 & * 4 \\ 0 & * 4 \end{array}$ | $\begin{aligned} & -*_{2} \\ & -\quad * 2 \end{aligned}$ |  |  |  |
|  | R |  |  | R/W | PUPO | $\begin{aligned} & -{ }^{*} 2 \\ & 0 \\ & \hline \end{aligned}$ | Off | On | I/O pull up resistor On/Off (P00-P03) |
| F7FH | 0 | 0 | 0 | LCDOFF | $\begin{array}{ll}0 & * 4 \\ 0 & * 4\end{array}$ | $\begin{aligned} & -*_{2} \\ & - \end{aligned}$ |  |  |  |
|  | R |  |  | R/W | LCDOFF | 1 | Normal | Off | LCD display control |

*1 Initial value following initial reset
*3 Reset (0) immediately after being read
*5 Undefined
*2 Not set in the circuit
*4 Always "0" when being read

## Chapter 3 Power Source

### 3.1 Power Supply System

The E0C6007 operating power voltage is as follows:
2.2-5.5 V (Min. 1.8 V, when OSC3 oscillation circuit is not used)

The E0C6007 operates when a single power supply within the above range is applied between VDD and Vss. Even if the voltage is not within the above range necessary for the internal circuits, the ICitself can generate the following built-in power circuits.

Table 3.1.1 Power supply circuits

| Circuit | Power supply circuit | Output voltage |
| :--- | :---: | :---: |
| Oscillation circuit and internal circuits | Regulated voltage circuit | VS1 |
| LCD driver | LCD system voltage circuit | VL1-VL5 |

Notes: - VL3 is used only when the driving voltage of the LCD system will be supplied externally ( $1 / 5$ bias); when using the internal LCD system voltage circuit ( $1 / 4$ bias), it should be shorted with VL2.

- See "13 Electrical Characteristics" for voltage values.


Fig. 3.1.1 Configuration of power supply

### 3.2 Heavy Load Protection Mode

Because the load of the battery in the E0C6007 becomes heavy due to the buzzer, lamp, and other features, it has been equipped with heavy load protection function in case of power voltage drop. This functions works in the heavy load protection mode.
Based on the workings of the heavy load protection function, the E0C6007 realizes operation at 2.2 V (Min. 1.8 V, when OSC3 oscillation circuit is not used) source voltage.

When driving heavy loads, set the IC to heavy load protection mode.
At the normal mode, the LCD system regulated voltage is created with $\mathrm{V}_{\mathrm{L} 2}$; $\mathrm{V}_{\mathrm{L} 1}$ is $1 / 2$ reduced $\mathrm{V}_{\mathrm{L} 2}$ voltage while $V_{L 4}$ and $V_{L 5}$ are created by boosting to 1.5 and 2 times voltages, respectively. On the other hand, at the heavy load protection mode, the regulated voltage is $V_{L 1}$; $V_{L 2}$, VL4, and VL5 are created by boosting to 2, 3 and 4 times voltages. Because of this, the consumed current becomes greater than that in the normal mode, be careful not to set the heavy load protection unless necessary.
The LCD system voltage modes are shown in Table 3.2.1.
Table 3.2.1 LCD system voltage mode

| Terminal | Normal mode | Heavy load protection mode |
| :---: | :---: | :---: |
| VL1 | $1 / 2 V_{L 2}$ | VL1 regulated voltage |
| VL2 | VL2 regulated voltage | $2 \mathrm{~V}_{\mathrm{L} 1}$ |
| VL4 | $3 / 2 \mathrm{~V} 2$ | $3 \mathrm{VL1}$ |
| VL5 | $4 / 2 \mathrm{VL2}$ | $4 \mathrm{VL1}$ |

### 3.2.1 Control of heavy load protection mode

The control register for the heavy load protection mode are explained below.
Table 3.2.1.1 Control register for heavy load protection mode

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F71H | ALOFF | ALON | LDUTY | HLMOD | ALOFF <br> ALON | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | All off All on | Normal | All LCD dots fade out control All LCD dots displayed control |
|  |  |  |  |  |  |  |  | Normal |  |
|  |  |  |  |  | LDUTY | 0 | 1/8 | 1/16 | LCD drive duty switch |
|  |  |  |  |  | HLMOD | 0 | HLMOD | Normal | Heavy load protection mode |

## HLMOD (F71H [D0], R/W)

Controls the heavy load protection mode.
When "1" is written: Heavy load protection mode is set
When " 0 " is written: Heavy load protection mode is released Reading: Valid

Conversion to heavy load protection mode is done by writing "1" to HLMOD while cancellation of this mode is done by writing " 0 ".
At initial reset, the mode is set to " 0 " (heavy load protection mode cancellation).

### 3.2.2 Programming notes

(1) When driving heavy loads, set it to heavy load protection mode. Unless it is necessary, be careful not to set the heavy load protection mode with the software.
(2) Perform heavy load driving only after setting up at least 1 ms wait time through the software, after switching to the heavy load protection mode. (See Figure 3.2.2.1.)
(3) When the heavy load protection mode is to canceled after completion of heavy load driving, set up at least 2 seconds wait time through the software. (See Figure 3.2.2.1.)


Fig. 3.2.2.1 Control timing for heavy load protection mode

### 3.3 CPU Operating Voltage Change

During operation, E0C6007 can change OSC1 and OSC3 system clocks through the software, and operation at clock mode or high-speed mode is then possible. In this case, to obtain stable operating, operating voltage Vs1 of the internal circuit is changed through the software. For details, see Chapter 5, "Oscillation Circuit".

## CHAPTER 4 INITIAL RESET

### 4.1 Initial Reset Factors

The E0C6007 requires initial reset function to initialize the circuits.
There are three types of initial reset factors:
(1) Initial reset by power-on reset
(2) External reset through low level input to the \#RESET terminal
(3) External initial reset by simultaneous low level input of K00-K03 terminals (mask option)
(4) Initial reset by watchdog timer

Note: The E0C6007 must be reset after turning power on using the initial reset factor (1) or (2).
Figure 4.1.1 shows the configuration of the initial reset circuit.


Fig. 4.1.1 Configuration of initial reset circuit

### 4.1.1 Power-on reset circuit

The power-on reset circuit outputs the initial reset signal at power-on until the oscillation circuit starts oscillating.

Note: The power-on reset circuit may not work properly due to unstable or lower voltage input.
The following two initial reset method are recommended to generate the initial reset signal.

### 4.1.2 External initial reset by the \#RESET terminal

An initial reset can be executed externally by setting the reset terminal to high level. This high level must be maintained for at least 2 ms (in case oscillation frequency foscl $=32.768 \mathrm{kHz}$ ), because the initial reset circuit contains a noise rejector. When the reset terminal goes low, the CPU will start operating.

### 4.1.3 External initial reset by simultaneous low level input of K00-K03 terminals

Initial reset may be done by simultaneously providing low level input externally to the input port (K00-K03) selected by mask option. Because the initial reset circuit has time authorize circuit built-in, keep the specified input port terminal at Low level for at least 2 seconds (in case oscillation frequency foscl $=32.768 \mathrm{kHz}$ ). The input port combination which can be selected from the mask option are as follows:

- Not use
- K00*K01
- K00*K01*K02
- K $00 * \mathrm{~K} 01 * \mathrm{~K} 02 * \mathrm{~K} 03$


### 4.1.4 Initial reset by watchdog timer

If the CPU runs away for some reason, the watchdog timer will detect this situation and output an initial reset signal. See "4.2 Watchdog Timer" for details.

### 4.1.5 Internal register at initial resetting

The CPU is initialized by initial resetting as follows:
Table 4.1.5.1 Initial values

| CPU Core |  |  |  |
| :--- | :---: | :---: | :---: |
| Name | Symbol | Bit size | Initial value |
| Program counter step | PCS | 8 | 00 H |
| Program counter page | PCP | 4 | 1 H |
| Program counter bank | PCB | 1 | 0 |
| New page pointer | NPP | 4 | 1 H |
| New bank pointer | NBP | 1 | 0 |
| Stack pointer | SP | 8 | Undefined |
| Index register X | X | 12 | Undefined |
| Index register Y | Y | 12 | Undefined |
| Register pointer | RP | 4 | Undefined |
| General-purpose register A | A | 4 | Undefined |
| General-purpose register B | B | 4 | Undefined |
| Interrupt flag | I | 1 | 0 |
| Decimal flag | D | 1 | 0 |
| Zero flag | Z | 1 | Undefined |
| Carry flag | C | 1 | Undefined |


| Peripheral Circuits |  |  |
| :--- | :---: | :---: |
| Name | Bit size | Initial value |
| RAM | $512 \times 4$ | Undefined |
| Display memory | $160 \times 4$ | Undefined |
| Other peripheral circuits | - | $*$ |
| $*$ See Tables 2.3.1 (a)-(c). |  |  |

### 4.2 Watchdog Timer

### 4.2.1 Configuration of watchdog timer

E0C6007 has a built-in watchdog timer with OSC1 (clock timer 1 Hz signal) basic oscillation. The watchdog timer needs to be reset periodically through the software, and if not reset within 3-4 seconds, it automatically generates an initial reset signal to the CPU.
Figure 4.2.1.1 shows the configuration of the watchdog timer.


Fig. 4.2.1.1 Configuration of watchdog timer
By resetting the watchdog timer during the program's main routine, program runaways which do not pass the watchdog timer processing during main routine can be detected.
Note, however, that the watchdog timer operates even during HALT such that if the HALT condition continues for 3-4 seconds, it is re-initiated through initial resetting.

### 4.2.2 Control of watchdog timer

The control register of the watchdog timer is explained below.
Table 4.2.2.1 Control register of watchdog timer

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F76H | 0 | 0 | TMRST | WDRST | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |  |  |  |
|  | R |  | W |  | TMRST WDRST | Reset <br> Reset | Reset <br> Reset | - | Clock timer reset <br> Watchdog timer reset |

## WDRST (F76H [D0], W)

This bit resets the watchdog timer.
When " 1 " is written: Watchdog timer reset
When " 0 " is written: No operation
Reading: Always " 0 "
By writing "1" on WDRST, the watchdog timer is reset, after which it is immediately restarted. Writing "0" will mean no operation.
Because this bit is only for writing, it is always set to " 0 " during reading.

### 4.2.3 Programming notes

(1) The watchdog timer must reset within 3 -second cycles by the software.
(2) When the clock timer is reset (TMRST $\leftarrow " 1 ")$, the watchdog timer is counted up; reset the watchdog immediately after if necessary.

## CHAPTER 5 OSCILLATION CIRCUIT

### 5.1 Configuration of Oscillation Circuit

The E0C6007 has two oscillation circuits (OSC1 and OSC3). OSC1 is either a crystal or a CR oscillation circuit that supplies the operating clock to the CPU and peripheral circuits. OSC3 is either a CR or a ceramic oscillation circuit. When processing with the E0C6007 requires high-speed operation, the CPU operating clock can be switched from OSC1 to OSC3 by the software. To stabilize operation of the internal circuits, the operating voltage Vsı must be switched according to the oscillation circuit to be used. Figure 5.1.1 is the block diagram of this oscillation system.


Fig. 5.1.1 Oscillation system block diagram

### 5.2 OSC1 Oscillation Circuit

The OSC1 oscillation circuit generates the main clock for the CPU and the peripheral circuits. Either the crystal oscillation circuit or the CR oscillation circuit can be selected as the circuit type by mask option. Figure 5.2.1 shows the configuration of the OSC1 oscillation circuit.

(1) Crystal oscillation circuit

(2) CR oscillation circuit

Fig. 5.2.1 OSC1 oscillation circuit
As shown in Figure 5.2.1, the crystal oscillation circuit can be configured simply by connecting the crystal oscillator (X'tal) of 32.768 kHz (Typ.) and the feedback resistor Rfx ( $10 \mathrm{M} \Omega$ ) between the OSC1 and OSC2 terminals and the trimmer capacitor (CGx) between the OSC1 and Vdd terminals when crystal oscillation is selected.

When CR oscillation is selected by mask option, connect the resistor RcR1 between the OSC1 and OSC2 terminals. See "13 Electrical Characteristics" for resistance value of RCR1.

Notes: - The current consumption of CR oscillation is larger than crystal oscillation.

- Be aware that the CR oscillation frequency changes slightly.

Pay special attention to the circuits that use fosc1 as the source clock, such as the timer (time lag), the LCD frame frequency (display quality, flicker in low frequency) and the sound generator (sound quality).

### 5.3 OSC3 Oscillation Circuit

The E0C6007 has built-in the OSC3 oscillation circuit that generates the CPU's sub-clock (Max. 2 MHz ) for high speed operation. The mask option enables selection of either the CR or ceramic oscillation circuit. When CR oscillation is selected, only a resistance is required as an external element. When ceramic oscillation is selected, a ceramic oscillator and two capacitors (gate and drain capacitance) are required.
Figure 5.3.1 shows the configuration of the OSC3 oscillation circuit.

(1) CR oscillation circuit


Fig. 5.3.1 OSC3 oscillation circuit
As shown in Figure 5.3.1, the CR oscillation circuit can be configured simply by connecting the resistor RCR2 between the OSC3 and OSC4 terminals when CR oscillation is selected. See " 13 Electrical Characteristics" for resistance value of RCR2.
When ceramic oscillation is selected, the ceramic oscillation circuit can be configured by connecting the ceramic oscillator (Max. 2 MHz ) and feedback resistor Rfc (about $1 \mathrm{M} \Omega$ ) between the OSC3 and OSC4 terminals, capacitor CGC between the OSC3 and OSC4 terminals, and capacitor CDC between the OSC4 and Vdd terminals. For both Cgc and Cdc, connect capacitors that are about 100 pF . To reduce current consumption of the OSC3 oscillation circuit, oscillation can be stopped by the software (OSCC register).
When the OSC3 oscillation circuit is not used, connect the OSC3 terminal to Vsı.


Fig. 5.3.2 Connection diagram when the OSC3 oscillation circuit is unused

### 5.4 Operating Voltage Change

E0C6007 can change OSC1 and OSC3 system clocks through the software. In this case, to obtain stable operation, operating voltage Vsı of the internal circuit is changed through the software.
Likewise, when selecting OSC1 as the system clock, there is need to change operating voltage Vs1 according to the value of the power voltage (VdD-Vss).
Oscillation frequency and the corresponding operating voltage Vsı are shown in Table 5.4.1.
Table 5.4.1 Oscillation frequency and operating voltage

| Oscillation frequency | Oscillation circuit | Operating voltage Vs1 |
| :---: | :---: | :---: |
| 32.768 kHz | OSC1 | -1.2 V or -2.1 V |
| 1 MHz | OSC3 | -2.1 V |
| 2 MHz | OSC3 | -3.0 V |

The Vdd reference voltage is used as the operating voltage Vsi.
When OSC3 is to be used as the CPU system clock, change the operating voltage Vsı accordingly through the software and then turn the OSC3 oscillation ON and switch the clock frequency.
If the OSC3 oscillation frequency is to be fixed around 1 MHz , set the operating voltage to -2.1 V ; at 2 MHz , set the operating voltage to -3.0 V .
Moreover, when the CPU is to be operated with OSC1, set the operating voltage to -1.2 V if the power voltage is less than 3.1 V (VdD-Vss $<3.1 \mathrm{~V}$ ); set the operating voltage to -2.1 V if the voltage is 3.1 V or more ( $\mathrm{V}_{\mathrm{DD}}-\mathrm{Vss} \geq 3.1 \mathrm{~V}$ ). However, it can be used fixed at -1.2 V (at OSC1 operation) for power whose initial value is 3.6 V or less as in lithium batteries.

Note: Switching Vs1 when the power source voltage is lower than the set voltage may cause misoperation.

### 5.5 Clock Frequency and Instruction Execution Time

Table 5.5 .1 shows the instruction execution time according to each frequency of the system clock.
Table 5.5.1 Clock frequency and instruction execution time

| Clock frequency | Instruction execution time $(\mu \mathrm{s})$ |  |  |
| :--- | :---: | :---: | :---: |
|  | 5-clock instruction | 7-clock instruction | 12-clock instruction |
| 32.768 kHz | 152.6 | 213.6 | 366.2 |
| 1 MHz | 5.0 | 7.0 | 12.0 |
| 2 MHz | 2.5 | 3.5 | 6.0 |

### 5.6 Control of Oscillation Circuit

The control registers for the oscillation circuit are explained below.
Table 5.6.1 Control registers of oscillation circuit

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F70H | CLKCHG | OSCC | VSC1 | VSCO | $\begin{gathered} \hline \text { CLKCHG } \\ \text { OSCC } \end{gathered}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} \text { OSC3 } \\ \text { On } \end{gathered}$ | $\begin{gathered} \text { OSC1 } \\ \text { Off } \end{gathered}$ | CPU system clock switch OSC3 oscillation On/Off |
|  | R/W |  |  |  | $\begin{aligned} & \text { VSC1 } \\ & \text { VSC0 } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |  | CPU operating voltage switch |

## VSC0 and VSC1 (F70H [D0 and D1], R/W)

Switches the operating voltage of the internal circuit in accordance to the oscillation frequency and power source voltage.
The corresponding setting description is shown in Table 5.6.2.
Table 5.6.2 Corresponding between oscillation frequency, power source voltage, and operating voltage (Vs1)

| VSC1 | VSC0 | VS1 | Oscillation circuit | Oscillation frequency | Power source voltage (VDD-Vss) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | -1.2 V | OSC1 | 32.768 kHz | Under 3.1 V |
| 0 | 1 | -2.1 V | OSC1 | 32.768 kHz | 3.1 V or more $(*)$ |
| 0 | 1 | -2.1 V | OSC3 | 1 MHz | 2.2 V or more |
| 1 | $\times$ | -3.0 V | OSC3 | 2 MHz | 3.1 V or more |

The Vdd reference voltage is used as the operating voltage Vs1.
There is no need to set the $(*)$ state with regards to power whose initial value is 3.6 V or less as in lithium batteries.
VSC1 and VSC0 are set to " 0 " at initial reset.
Notes: - When switching Vs1 from -1.2 V (for OSC1 crystal oscillation circuit) to -3.0 V (for OSC3 oscillation circuit), or vice versa, be sure to hold the -2.1 V setting for more than 5 ms first for power voltage stabilization.

$$
\begin{aligned}
(\text { VSC1, VSCO }) & =(0,0) \rightarrow(0,1) \rightarrow 5 \mathrm{~ms} \text { WAIT } \rightarrow(1, x) \\
& =(1, \times) \rightarrow(0,1) \rightarrow 5 \mathrm{~ms} \text { WAIT } \rightarrow(0,0) \\
& =(0,0) \rightarrow(1, \times) \text { is prohibited } \\
& =(1, \times) \rightarrow(0,0) \text { is prohibited }
\end{aligned}
$$

- When CR oscillation has been selected by the mask option as OSC1, Vs1 becomes -2.1 V even when VSC1 = VSC0 $=0$ and will never become -1.2 V. In addition, since the current consumption is great for CR oscillation compared with the quartz crystal oscillation, when low power consumption is required, you should select quartz crystal oscillation as OSC1.


## OSCC (F70H [D2], R/W)

Controls the oscillation of the OSC3 oscillation circuit.
When " 1 " is written: OSC3 oscillation ON
When " 0 " is written: OSC3 oscillation OFF Reading: Valid
When high-speed operation of the CPU is required, OSCC is set to " 1 "; otherwise, set it to " 0 " to minimize power current consumption.
At initial reset, OSCC is set to " 0 ".
Note: It takes 5 ms for the OSC3 oscillation circuit to stabilize after oscillation turns ON. Since oscillation stabilization time differs according to external oscillation terminal and usage conditions, set the stand-by time with enough allowance when switching the clock frequency.

## CLKCHG (F70H [D3], R/W)

Selects the CPU operating clock.
When "1" is written: OSC3 clock is selected
When " 0 " is written: OSC1 clock is selected

> Reading: Valid

When assigning OSC3 as the CPU operating clock, set CLKCHG to "1"; when assigning OSC1, set it to "0".
At initial reset, CLKCHG is set to "0".
Note: When switching the CPU operating clock from OSC1 to OSC3, follow the flow chart shown in Figure 5.6.1 and then proceed with software processing.


Condition:
$\mathrm{V}_{\mathrm{s} 1}=-2.1 \mathrm{~V}, \mathrm{OSC} 3=1 \mathrm{MHz}$ (stabilized)
$\mathrm{Vs} 1=-3.0 \mathrm{~V}, \mathrm{OSC} 3=2 \mathrm{MHz}$ (stabilized)


Fig. 5.6.1 CPU operating clock control flow

### 5.7 Programming Notes

(1) When high-speed operation of the CPU is not required, observe the following reminders to minimize power current consumption.
Set the CPU operating clock to OSC1.
Turn the OSC3 oscillation OFF.
Set the internal operating voltage ( V sı ) to -1.2 V or -2.1 V .
(2) When the CPU is to be operated with OSC1, set the operating voltage to -1.2 V if the power voltage is less than $3.1 \mathrm{~V}(\mathrm{~V} D \mathrm{D}-\mathrm{Vss}<3.1 \mathrm{~V})$; set the operating voltage to -2.1 V if the voltage is 3.1 V ormore (Vdd-Vss $\geq 3.1 \mathrm{~V}$ ). Moreover, because -1.2 V will be set during initial reset, be sure to execute the previous process at the beginning of the initial routine. Note, however, that it can be used fixed at 1.2 V (at OSC1 operation) for power whose initial value is 3.6 V or less as in lithium batteries.
(3) When switching Vs1 from -1.2 V (for OSC1 crystal oscillation circuit) to -3.0 V (for OSC3 oscillation circuit), or vice versa, be sure to hold the -2.1 V setting for more than 5 ms first for power voltage stabilization.

$$
\begin{aligned}
(\mathrm{VSC} 1, \mathrm{VSC} 0) & =(0,0) \rightarrow(0,1) \rightarrow 5 \mathrm{~ms} \text { WAIT } \rightarrow(1, \times) \\
& =(1, \times) \rightarrow(0,1) \rightarrow 5 \mathrm{~ms} \text { WAIT } \rightarrow(0,0) \\
& =(0,0) \rightarrow(1, \times) \text { is prohibited } \\
& =(1, \times) \rightarrow(0,0) \text { is prohibited }
\end{aligned}
$$

(4) When switching the CPU operating clock from OSC1 to OSC3, follow the flow chart shown in Figure 5.6.1 and then proceed with software processing.
(5) Use separate instructions to switch the clock from OSC3 to OSC1 and turn the OSC3 oscillation OFF. Simultaneous processing with a single instruction may cause malfunction of the CPU.

## CHAPTER 6 InPuT/OUTPUT PORTS

### 6.1 Input Port (Kxx)

### 6.1.1 Configuration of input ports

The E0C6007 has 4 bits of general input ports (K00-K03) built-in.
Figure 6.1.1.1 shows the configuration of the input port.


Fig. 6.1.1.1 Configuration of input port
The input port pin K03 is used as the clock input pins for the programmable timer. See " 8.3
Programmable Timer" for details.

### 6.1.2 Mask option

The input ports (K00-K03) are provided with built-in pull up resistor the use of which may be selected for every bit with the mask option.
Selection of "Pull up resistor enable" with the mask option suits input from the pushswitch, key matrix, and so forth. When changing the input port from low level to high level with a pull up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull up resistor and input gate capacity. Hence, when reading data from the input port, set an appropriate waiting time. Care is particularly required for key matrix configuration scanning. For reference, approximately $500 \mu \mathrm{~s}$ waiting time is required.
When "Pull up resistor disabled" is selected, the port can be used for slide switch input and interfacing with other LSIs. In this case, take care that floating state does not occur.

### 6.1.3 Interrupt function

All four bits of the input ports K00-K03 provide the interrupt function.
Whether to mask the interrupt function can be selected individually for all four bits by the software.
Figure 6.1.3.1 shows the configuration of the input (K00-K03) interrupt circuit.


Fig. 6.1.3.1 Configuration of input (K00-K03) interrupt circuit
The interrupt mask registers (EIK00-EIK03) enable or mask the interrupt generation of the corresponding input port $\mathrm{K} 00-\mathrm{K} 03$. When an input signal which is not masked goes low, the interrupt factor flag (IK0) is set to " 1 " and an interrupt occurs at the falling edge of the input signal.

### 6.1.4 Control of input ports

The control registers for the input ports are explained below.
Table 6.1.4.1 Control registers of input ports

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F04H | 0 | 0 | 0 | IKO | $\begin{gathered} \hline 0 \\ 0 \\ 0 \\ \text { IK0 } \end{gathered}$ |  | Yes | No | Interrupt factor flag (K00-K03) |
|  | R |  |  |  |  | 0 |  |  |  |
| F14H | EIK03 | EIK02 | EIK01 | EIK00 | EIK03 | 0 | Enable | Mask | Interrupt mask register (K03) |
|  |  |  |  |  | EIK02 | 0 | Enable | Mask | Interrupt mask register (K02) |
|  | R/W |  |  |  | EIK01 | 0 | Enable | Mask | Interrupt mask register (K01) |
|  |  |  |  |  | EIK00 | 0 | Enable | Mask | Interrupt mask register (K00) |
| F 40 H | K03 | K02 | K01 | K00 | K03 | - | High | Low | $\square$ |
|  |  |  |  |  | K02 | - | High | Low |  |
|  | R |  |  |  | K01 | - | High | Low |  |
|  |  |  |  |  | K00 | - | High | Low | - |

## K00-K03 (F40H, R)

Input data of the input port terminal may be read out with these registers.
When " 1 " is read: High level
When " 0 " is read: Low level
Writing: Invalid
The terminal voltage of 4 bits input ports (K00-K03) are each reading as " 1 " and " 0 " at high (VdD) level and low (Vss) level, respectively.
When these bits are used for reading only, writing operation becomes invalid.

## EIK00-EIK03 (F14H, R/W)

This is the interrupt mask register of the input ports.
When " 1 " is written: Enable
When " 0 " is written: Mask

> Reading: Valid

EIK0x corresponds to input port K0x. Whether to mask the interrupt function can be set in units of 1 bit. Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
At initial reset, this register is set to " 0 " (mask).

## IK0 (F04H [D0], R)

This is the interrupt factor flag of the input ports.
When " 1 " is read: Interrupt has occurred
When " 0 " is read: Interrupt has not occurred Writing: Invalid

The interrupt factor flags IK0 is associated with K00-K03. From the status of this flag, the software can decide whether an input interrupt has occurred.
The flag will not be set even if an input port status changes when the interrupt mask register (EIK0x) is set to " 0 ".
Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.
At initial reset, this flag is set to " 0 ".

### 6.1.5 Programming notes

(1) When changing the input port from low level to high level with a pull up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull up resistor and input gate capacity. Hence, when reading data from the input port, set an appropriate waiting time. Care is particularly required for key matrix configuration scanning. For reference, approximately $500 \mu \mathrm{~s}$ waiting time is required.
(2) Input interrupt programming related precautions


When the content of the mask register is rewritten, while the port K input is in the active status, the input interrupt factor flag is set at $(1$.

Fig. 6.1.5.1 Input interrupt timing
When using an input interrupt, if you rewrite the content of the mask register, when the value of the input terminal which becomes the interrupt input is in the active status (input terminal = low status), the factor flag for input interrupt may be set.
For example, a factor flag is set with the timing of $(1)$ shown in Figure 6.1.5.1. However, when clearing the content of the mask register with the input terminal kept in the low status and then setting it, the factor flag of the input interrupt is again set at the timing that has been set.
Consequently, when the input terminal is in the active status (low status), do not rewrite the mask register (clearing, then setting the mask register), so that a factor flag will only set at the rising edge in this case. When clearing, then setting the mask register, set the mask register, when the input terminal is not in the active status (high status).
(3) Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
(4) Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.

### 6.2 Output Port (Rxx)

### 6.2.1 Configuration of output ports

The E0C6007 has 6 bits (R32, R33, and R40-R43) of general output ports built-in.
Figure 6.2.1.1 shows the configuration of the output port.


Fig. 6.2.1.1 Configuration of output port

### 6.2.2 Mask option

The output ports may be selected for the following by mask option.
(1) Output specification of output ports

The output specification of each output port may be selected (in 1-bit units). Two types of output specification may be selected: complementary output and N channel (Nch) open drain output.
However, even if Nch open drain is selected, application on the terminal of voltage exceeding the power current voltage is not permitted.

## (2) Special output

Output ports R33, R40, R42 and R43 may be selected, in addition to DC output, as special output port as follows:

R33: Programmable timer operating clock output (PTCLK)
R40: Clock inverted output (\#FOUT)
R42: Buzzer inverted output (\#BZ) or clock output (FOUT)
R43: Buzzer output (BZ)

## Buzzer outputs BZ (R43) and \#BZ (R42)

Through mask option selection, R43 and R42 may be assigned as buzzer outputs. BZ and \#BZ are buzzer signal outputs for driving piezo-electric buzzers, the buzzer signal being created by the division of foscı. Moreover, digital envelope may be added to the buzzer signal.
See Chapter 9, "Sound Generator" for details.
Buzzer output BZ and \#BZ can be controlled simultaneously by register R43. Note, however, that register R42 at \#BZ output selection may be used as a 1-bit general register in which Read/Write operation is possible, and the data of said register will not affect \#BZ (output from the R42 terminal).

Notes: - The BZ and \#BZ output signals could generate hazards during ON/OFF switching.

- When output port R43 is set to DC output, output port R42 may not be set to \#BZ output.

Figure 6.2.2.1 shows the output waveform of BZ and \#BZ.


Fig. 6.2.2.1 Output waveform of BZ and \#BZ

## PTCLK (R33)

The operating clock for the programmable timer is output externally from this port. In this case, the clock output ON or OFF may be controlled from the R33 register by setting PTCOUT(F79H [D3]) to " 1 ". The clock frequency is selected by the 3-bit register PTC0-PTC2.
Moreover, when PTCOUT is set to " 0 ", output port R33 becomes DC output.
Because of the above functions, PTCLK output and DC output belong to a common option selection item. Refer to "8.3 Programmable Timer" regarding selection of clock frequency.

## Clock outputs FOUT (R42), \#FOUT (R40)

When R40 and R42 are selected to clock output, it outputs the clock of fosc3, fosc1 or the demultiplied foscı. R40 (\#FOUT) output generates an antiphase clock in relation to R42 (FOUT).
Figure 6.2.2.2 shows the output waveform of FOUT and \#FOUT. The clock frequency is selectable with the mask options, from the frequencies listed in Table 6.2.2.1.


Fig. 6.2.2.2 Output waveform of FOUT and \#FOUT
Note: Clock output signal could generate hazards during ON/OFF switching.
Table 6.2.2.1 FOUT clock frequency

| Setting | Clock frequency $(\mathrm{Hz})$ |
| :--- | :---: |
| fosc3 | OSC3 oscillation frequency |
| fosc $1 / 1$ | 32,768 |
| fosc $1 / 2$ | 16,384 |
| fosc $1 / 4$ | 8,192 |
| $\mathrm{fosc}_{1} / 8$ | 4,096 |
| fosc $1 / 16$ | 2,048 |
| fosc $1 / 32$ | 1,024 |
| fosc $1 / 64$ | 512 |
| fosc $1 / 128$ | 256 |

### 6.2.3 High impedance control

The terminal output state of output ports R32 and R33 may be selected for high impedance state using the high impedance control register HZR3.

### 6.2.4 Control of output ports

The control registers for the output ports are explained below.
Table 6.2.4.1 Control registers of output ports

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F53H | R33 | R32 | 0 | 0 | R33 | X | High Off | $\begin{gathered} \text { Low } \\ \text { On } \end{gathered}$ | Output port (R33) PTCLK output |
|  | R/W |  | R |  | $\begin{gathered} \mathrm{R} 32 \\ - \\ 0 \\ 0 \end{gathered}$ | x | High | Low | Output port (R32) |
| F54H | R43 | R42 | R41 | R40 | R43 | 1 | High <br> Off | $\begin{gathered} \text { Low } \\ \text { On } \end{gathered}$ | Output port (R43) <br> Buzzer output (BZ) |
|  | R/W |  |  |  | R42 | 1 | High Off | $\begin{gathered} \text { Low } \\ \text { On } \end{gathered}$ | Output port (R42) <br> Clock output (FOUT) <br> [Buzzer inverted output (\#BZ)] |
|  |  |  |  |  | R41 | 1 | High | Low | Output port (R41) |
|  |  |  |  |  | R40 | 1 | High Off | $\begin{aligned} & \text { Low } \\ & \text { On } \end{aligned}$ | Output port (R40) <br> Clock inverted output (\#FOUT) |
| F7BH | HZR3 | 0 | 0 | 0 | $\begin{gathered} \text { HZR3 } \\ 0 \end{gathered}$ | $0$ | Output | High-Z | R32-R33 output high-impedance control |
|  | R/W | R |  |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | - |  |  |  |

## HZR3 (F7BH [D3], R/W)

Controls high impedance loading to output ports R32 and R33.
When "1" is written: Data output
When " 0 " is written: High impedance Reading: Valid
By writing "1" in the control register HZR3, the output register data (R32 and R33) is generated in the terminal; writing " 0 " will generate high impedance state.
During initial reset, this register is set to " 0 " and the ports acquire high impedance state.

## When DC output is selected

## R32, R33, R40-R43 (F53H [D2] and [D3], F54H, R/W)

Sets the output data for the output ports.
When " 1 " is written: High level
When " 0 " is written: Low level

## Reading: Valid

Output port terminals will generate the data written into the corresponding registers (R32, R33, R40R43) as it is. The output port terminal goes high (VDD) when "1" is written to the register, and goes low (Vss) when " 0 " is written.
At initial reset, only R40-R43 are set to "1" and the other output registers become undefined.

## When special output is selected

## R43 (F54H [D3], R/W) when BZ and \#BZ output is selected

Performs the output control of buzzer signal (BZ, \#BZ).
When " 0 " is written: Buzzer signal output
When " 1 " is written: Low level (DC)
Reading: Valid

When " 0 " is set on R 43 , BZ signal is generated from R 43 terminal; at the same time, \#BZ signal (BZ inverted signal) is generated from R42 terminal if R42 is set to \#BZ output.
When "1" is set on R43, R43 terminal (and R42 terminal too, when \#BZ output is selected) output goes low (Vss).
Note, however, that R42 at \#BZ output selection may be used as a 1-bit general register in which
Read/Write operation is possible, and the data of said register will not affect \#BZ (R42 terminal output).
At initial reset, R43 and R42 are set to "1".

## R33 (F53H [D3], R/W) when PTCLK (DC) output is selected

Controls the output of the programmable timer operating clock (PTCLK).
When " 0 " is written: Clock output
When " 1 " is written: High level (DC)
Reading: Valid
With "1" written on PTCOUT (F79H [D3]), the operating clock of the programmable timer may be generated externally by writing " 0 " on R33 register. Moreover, the output will go high (VDD) by writing "1".
However, when PTCOUT is " 0 ", the output becomes regular DC output.

## R40, R42 (F54H [D0, D2], R/W) when FOUT and \#FOUT output is selected

Controls the \#FOUT and FOUT (clock) output.
When " 0 " is written: Clock output
When " 1 " is written: High level (DC)
Reading: Valid
When R42 is set to FOUT output, clock with the specified frequency is generated from R42 terminal by writing " 0 " on R42 register.
By writing " 1 ", the R42 terminal will go high (VDD).
The same applies to R40. The clock phase when \#FOUT signal is output from R40 is antiphase to that of R42.
At initial reset, R40 and R42 are set to "1".

### 6.2.5 Programming notes

(1) When BZ, \#BZ, FOUT, \#FOUT, and PTCLK (DC) are selected by mask option, a hazard may be observed in the output waveform when the data of the output register changes.
(2) Because the R32 and R33 ports gain high impedance during initial reset, be careful when using them as interface with external devices and the like.

### 6.3 I/O Port (Pxx)

### 6.3.1 Configuration of I/O ports

The E0C6007 has 4 bits of general I/O ports (P00-P03) built-in.
Figure 6.3.1.1 shows the configuration of the I/O port.


Fig. 6.3.1.1 Configuration of I/O port

### 6.3.2 Mask option

Output specification (during output) for the I/O port may be selected by mask option (selected with the 4 bits group). Two types of output specification may be selected: complementary output and N channel (Nch) open drain output. However, even if Nch open drain is selected, application on the terminal of voltage exceeding the power current voltage is not permitted.

### 6.3.3 I/O control register and input/output mode

Input or output mode can be set for the four bits of I/O port P00-P03 by writing data to the I/O control register IOC0.

To set the input mode, " 0 " is written to the I/O control register. When an I/O port is set to input mode, it becomes high impedance state and works as an input port.

The output mode is set when " 1 " is written to the I/O control register. When an I/O port set to output mode works as an output port, it outputs a high level (VDD) when the data of output register is " 1 ", and a low level (Vss) when the data of output register is " 0 ".

### 6.3.4 Pull up resistor

Pull up resistors can be added to four bits of I/O ports by writing data to the pull up control register PUPO. When " 0 " is written to the pull up control register, the I/O port terminals are pulled up. When " 1 " is written, the pull up resistors are disconnected.

### 6.3.5 Control of I/O ports

The control registers for the I/O ports are explained below.
Table 6.3.5.1 Control register of I/O ports

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F 60 H | P03 | P02 | P01 | P00 | $\begin{aligned} & \hline \text { P03 } \\ & \text { P02 } \\ & \text { P01 } \\ & \text { P00 } \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ | High <br> High <br> High <br> High | Low <br> Low <br> Low <br> Low | $]$ I/O port (P00-P03) |
|  |  |  |  |  |  |  |  |  |  |
|  | R/W |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
| F7DH | 0 | 0 | 0 | IOCO | 0 | - |  |  |  |
|  |  |  |  |  | 0 | - |  |  |  |
|  | R |  |  | R/W | $\begin{gathered} 0 \\ \text { IOCO } \end{gathered}$ | - | Output | Input | I/O control (P00-P03) |
| F7EH | 0 | 0 | 0 | PUPO | 0 | - |  |  |  |
|  |  |  |  |  | 0 | - |  |  |  |
|  | R |  |  | R/W | 0 | - |  |  |  |
|  |  |  |  |  | PUPO | 0 | Off | On | I/O pull up resistor On/Off (P00-P03) |

## IOCO (F7DH [D0], R/W)

Input/output direction of I/O ports are set in units of 4 bits.
When " 1 " is written: Output mode
When " 0 " is written: Input mode
Reading: Valid
By writing " 1 " to IOC 0 , the I/O ports enter the output mode, while writing " 0 " they enter the input mode. At initial reset, IOC0 is set to " 0 " and the I/O ports are all in the input mode.

## PUPO (F7EH [D0], R/W)

Whether the I/O ports will be pulled up or not is set in units of 4 bits.
When " 0 " is written: Pull up ON
When "1" is written: Pull up OFF
Reading: Valid
By writing " 0 " to PUP0, the I/O ports are pulled up, while writing " 1 " turns the pull up function OFF. At initial reset, PUP0 is set at " 0 ", and all I/O ports are pulled up.

## P00-P03 (F60H, R/W)

## - During writing operation

When "1" is written: High level
When " 0 " is written: Low level
When the I/O port is set at output port, the data written is generated on the I/O port terminal as it is. When " 1 " is written as port data, the port terminal goes high (VDD) and goes low (Vss) when " 0 " is written.
Note, however, that even at input mode, port data writing is also possible.

## - During reading operation

When " 1 " is read: High level
When " 0 " is read: Low level
Reading the I/O port terminal voltage level. When the I/O port is at input mode, voltage level input of the port terminal is read; when set at output mode, output voltage level is read. When the terminal voltage is at high (VmD) level, port data reading is " 1 "; at low (Vss) level, it is " 0 ".

### 6.3.6 Programming notes

(1) When the I/O port is set at output mode, and low impedance load is connected to the port terminal, the data written and read may differ.
(2) If the state of the I/O port meets all of the following 4 conditions, the reading data will be undefined:

- The input/output mode is set at output mode
- Output specification is set at Nch open drain
- The content of the data register is "1"
- The pull up resistor turned is OFF


## CHAPTER 7 LCD DRIVER

The E0C6007 has 16 common terminals and 40 segment terminals and can drive a maximum of $640(40 \times 16)$ dots ( 8 characters $\times 2$ lines) LCD.
This LCD driver performs the following control through the software.

- Drive duty can be set to $1 / 16$ or $1 / 8$ duty.
- LCD contrast can be adjusted through a 16 steps range.
- All dots of the LCD panel can be switched ON and OFF.


### 7.1 Drive Duty

Because the power for LCD driving is generated by the internal circuit of the CPU, there is no need to provide for it externally. Driving is done by $1 / 16$ duty or $1 / 8$ duty dynamic drive through 4 electric potentials ( $1 / 4$ bias) : Vl1, VL2, Vl4, and VL5. The 5 electric potentials are entered in VL1, VL2, Vl3, VL4 and VL5 terminals and $1 / 5$ bias driving may then be set.
Drive duty may be selected from the software. Dotnumber differences due to the selected duty are shown in Table 7.1.1.

Table 7.1.1 Differences due to selected duty

| Duty | Common terminal in use | Maximum dot number | Frame frequency $*$ |
| :---: | :---: | :---: | :---: |
| $1 / 16$ | COM0-15 | 640 dots | 32 Hz |
| $1 / 8$ | COM0-7 | 320 dots | 32 Hz |
| $*$ * Frame frequency $=$ fosc $1 / 1,024$ |  |  |  |

Figure 7.1.1 shows the drive waveform for $1 / 16$ duty ( $1 / 5$ bias), and Figure 7.1.2 shows the drive waveform for $1 / 8$ duty ( $1 / 4$ bias).


Fig. 7.1.1 Drive waveform for $1 / 16$ duty ( $1 / 5$ bias)
Note: $1 / 5$ bias may only be utilized when power for LCD driving is supplied externally; when internal power circuit is used, $1 / 4$ bias is utilized.


Fig. 7.1.2 Drive waveform for $1 / 8$ duty ( $1 / 4$ bias)

### 7.2 Mask Option

Disconnecting the internal power for LCD driving will enable electric potentials to be supplied externally. In such case, the 5 electric potentials are entered in VL1, VL2, VL3, VL4 and VL5 terminals and $1 / 5$ bias driving may then be set. Since $1 / 5$ bias driving provides better display quality, when low power current consumption is not required (i.e., when power is supplied from AC outlet), selectexternal power mode. However, note that in order to maintain a stable display, power source must be one which will remain stable even when heavy load such as buzzer, etc. is driven.
Moreover, in the external power mode, the contrast adjustment function cannot be used. Accommodate this limitation by utilizing the external circuit as necessary.
A sample circuit of external power for LCD driving when power is supplied externally is shown in Figure 7.2.1.


Fig. 7.2.1 Sample circuit of external power for LCD driving when power is supplied externally

### 7.3 Display Data Memory

The display data memory of the E0C6007 is allocated to the built-in RAM addresses E00H-E4FH and E80H-ECFH.
Figure 7.3.1 shows the correspondence between the display data memory and the LCD dot matrix.


Fig. 7.3.1 LCD dot matrix and segment memory correspondence
When the segment memory bit is assigned as " 1 ", the corresponding LCD dot lights up, and when assigned as " 0 ", the dot dies out.
At $1 / 16$ duty drive and $1 / 8$ duty drive, COM0 to COM15 lines and COM0 to COM7 lines light up, respectively.
At initial reset, the display data memory content becomes undefined and hence, there is needto initialize by software.

### 7.4 Control of LCD Driver

The control registers for the LCD driver are explained below.
Table 7.4.1 Control registers of LCD driver

| Address | Register |  |  |  | Name | Init | 1 | 0 | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 |  |  |  |  |  |
| F71H | ALOFF | ALON | LDUTY | HLMOD | ALOFF <br> ALON | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | All off All on | Normal <br> Normal | All LCD dots fade out control All LCD dots displayed control |
|  | R/W |  |  |  | LDUTY HLMOD | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 / 8 \\ \text { HLMOD } \end{gathered}$ | 1/16 <br> Normal | LCD drive duty switch Heavy load protection mode |
| F 72 H | LC3 | LC2 | LC1 | LCO | $\begin{aligned} & \text { LC3 } \\ & \text { LC2 } \end{aligned}$ | $\begin{aligned} & X \\ & X \end{aligned}$ |  |  | LCD contrast adjustment LC3-LC0 $=0$ light |
|  | R/W |  |  |  | $\begin{aligned} & \text { LC1 } \\ & \text { LC0 } \end{aligned}$ | $\begin{aligned} & X \\ & X \end{aligned}$ |  |  | - LC3-LC $0=15$ dark |
| F7FH | 0 | 0 | 0 | LCDOFF | $\begin{array}{ll} 0 & { }^{*} 4 \\ 0 & { }^{*} 4 \end{array}$ | - *2 |  |  |  |
|  | R |  |  | R/W | LCDOFF | $1$ | Normal | Off | LCD display control |

## LDUTY (F71H [D1], R/W)

Sets the LCD drive duty.
When " 1 " is written: $1 / 8$ duty
When " 0 " is written: $1 / 16$ duty
Reading: Valid
Writing " 1 " or " 0 " on LDUTY will set is to $1 / 8$ duty or $1 / 16$ duty, respectively.
At initial reset, LDUTY is set at " 0 ".

## ALON (F71H [D2], R/W)

Displays the all LCD dots on.
When " 1 " is written: All LCD dots displayed
When " 0 " is written: Normal operation

## Reading: Valid

Writing " 1 " to ALON will display all the LCD dots on; writing " 0 " will set the LCD display back to normal. LCD panel testing may be conducted with this function.
Total LCD displaying at ALON $=" 1 "$ is a static operation and does not affect the content of the display data memory.
ALON precedes ALOFF.
At initial reset, ALON is set at " 0 ".

## ALOFF (F71H [D3], R/W)

Fade outs the all LCD dots.
When " 1 " is written: All LCD dots fade out
When " 0 " is written: Normal operation
Reading: Valid
When " 1 " is written on ALOFF, all LCD dots will fade out; writing " 0 " will set it back to normal.
All fading out of LCD at ALOFF $=" 1 "$ is due to light out signals and does not affect the content of the display data memory.
Flashing of the entire LCD panel is performed by this function.
At initial reset, ALOFF is set to "1".

LC0, LC1, LC2, LC3 (F72H, R/W)
Will adjust the LCD contrast.
Contrast may be adjusted to 16 levels as shown in Table 7.4.2.
Table 7.4.2 LCD contrast

|  | LC3 | LC2 | LC1 | LC0 | Contrast |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | light $\uparrow$ |
| 1 | 0 | 0 | 0 | 1 |  |
| 2 | 0 | 0 | 1 | 0 |  |
| 3 | 0 | 0 | 1 | 1 |  |
| 4 | 0 | 1 | 0 | 0 |  |
| 5 | 0 | 1 | 0 | 1 |  |
| 6 | 0 | 1 | 1 | 0 |  |
| 7 | 0 | 1 | 1 | 1 |  |
| 8 | 1 | 0 | 0 | 0 |  |
| 9 | 1 | 0 | 0 | 1 |  |
| A | 1 | 0 | 1 | 0 |  |
| B | 1 | 0 | 1 | 1 |  |
| C | 1 | 1 | 0 | 0 |  |
| D | 1 | 1 | 0 | 1 |  |
| E | 1 | 1 | 1 | 0 | $\stackrel{\downarrow}{\downarrow}$ |
| F | 1 | 1 | 1 | 1 |  |

At room temperature, use setting number 7 or 8 as standard.
The voltage of the LCD system power terminals $V_{L 1}, \mathrm{~V}_{\mathrm{L} 2}, \mathrm{~V}_{\mathrm{L} 4}$ and $\mathrm{V}_{\mathrm{L} 5}$ changes through this function.
Because at initial reset, the contents of LC0-LC3 are undefined, initialize it by the software.

## LCDOFF (F7FH [D0], R/W)

Control the LCD system voltage circuit ON and OFF.
When " 1 " is written: Normal operation
When " 0 " is written: Display OFF

> Reading: Valid

When " 1 " is written to LCDOFF, the LCD system voltage circuit turns ON and generate the LCD drive volatges. When " 0 " is written, all the drive voltages go to Vss level and the display turns OFF.
At initial reset, this register is set to " 1 ".

### 7.5 Programming Note

Because at initial reset, the contents of display data memory and LC0-LC3 are undefined, there is need to initialize by software.

## CHAPTER 8 TIMERS

### 8.1 Clock Timer

### 8.1.1 Configuration of clock timer

The E0C6007 has a clock timer with OSC1 (crystal oscillation) as basic oscillation built-in. The clock timer is configured with an 8 bits binary counter with 256 Hz signal divided from OSC1 as input clock, allowing $128 \mathrm{~Hz}-1 \mathrm{~Hz}$ of data to be read by the software.
Figure 8.1.1.1 shows the configuration of the clock timer.


Fig. 8.1.1.1 Configuration of clock timer

### 8.1.2 Interrupt function

The clock timer has interrupt capability, and interrupt is generated by the falling edge of $32 \mathrm{~Hz}, 8 \mathrm{~Hz}, 2 \mathrm{~Hz}$, and 1 Hz signals. Figure 8.1.2.1 shows the timing chart of the clock timer.


Fig. 8.1.2.1 Timing chart of clock timer
The clock timer interrupt is generated at the falling edge of the frequencies ( $32 \mathrm{~Hz}, 8 \mathrm{~Hz}, 2 \mathrm{~Hz}$, and 1 Hz ). At this time, the corresponding interrupt factor flag (IT32, IT8, IT2, and IT1) is set to "1".
Selection of whether to mask the separate interrupts can be made with the interrupt mask registers (EIT32, EIT8, EIT2, and EIT1). However, regardless of the interrupt mask register setting, the interrupt factorflag is set to "1" at the falling edge of the corresponding signal.

### 8.1.3 Control of clock timer

The control registers for the clock timer are explained below.
Table 8.1.3.1 Control registers of clock timer

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| FOOH | IT1 | IT2 | IT8 | IT32 | $\begin{aligned} & \mathrm{IT} 1 \\ & \mathrm{IT} 2 \\ & \mathrm{IT} 8 \\ & \text { IT32 } \\ & \hline \end{aligned}$ | 0 | Yes | No | Interrupt factor flag (clock timer 1 Hz ) |
|  |  |  |  |  |  | 0 | Yes | No | Interrupt factor flag (clock timer 2 Hz ) |
|  | R |  |  |  |  | 0 | Yes | No | Interrupt factor flag (clock timer 8 Hz ) |
|  |  |  |  |  | 0 | Yes | No | Interrupt factor flag (clock timer 32 Hz ) |  |
| F 10 H | EIT1 | EIT2 | EIT8 | EIT32 |  | EIT1 <br> EIT2 <br> EIT8 <br> EIT32 | 0 | Enable | Mask | Interrupt mask register (clock timer 1 Hz ) |
|  |  |  |  |  | 0 |  | Enable | Mask | Interrupt mask register (clock timer 2 Hz ) |
|  | R/W |  |  |  | 0 |  | Enable | Mask | Interrupt mask register (clock timer 8 Hz ) |
|  |  |  |  |  | 0 |  | Enable | Mask | Interrupt mask register (clock timer 32 Hz ) |
| F 20 H | TM3 | TM2 | TM1 | TM0 | TM3 <br> TM2 <br> TM1 <br> TM0 | 0 |  |  | Clock timer data ( 16 Hz ) |
|  |  |  |  |  |  | 0 |  |  | Clock timer data ( 32 Hz ) |
|  | R |  |  |  |  | 0 |  |  | Clock timer data ( 64 Hz ) |
|  |  |  |  |  | 0 |  |  | Clock timer data (128 Hz) |  |
| F21H | TM7 | TM6 | TM5 | TM4 |  | $\begin{aligned} & \text { TM7 } \\ & \text { TM6 } \\ & \text { TM5 } \\ & \text { TM4 } \end{aligned}$ | 0 |  |  | Clock timer data ( 1 Hz ) |
|  |  |  |  |  | 0 |  |  |  | Clock timer data ( 2 Hz ) |
|  | R |  |  |  | 0 |  |  |  | Clock timer data ( 4 Hz ) |
|  |  |  |  |  | 0 |  |  |  | Clock timer data (8 Hz) |
| F 76 H | 0 | 0 | TMRST | WDRST | 0 | - |  |  |  |
|  |  |  |  |  | 0 | - |  |  |  |
|  |  |  |  |  | TMRST | Reset | Reset | - | Clock timer reset |
|  |  |  |  |  | WDRST | Reset | Reset | - | Watchdog timer reset |

## TMRST (F76H [D1], W)

This bit resets the clock timer.
When "1" is written: Clock timer reset
When " 0 " is written: No operation
Reading: Always " 0 "
By writing " 1 " on TMRST, the clock timer is reset and all timer data are set to " 0 ".
Because this bit is only for writing, it is always " 0 " during reading.
TM0-TM7 (F20H, F21H, R)
Will read the data of the clock timer.
TMx ( $\mathrm{x}=0-7$ ) and frequency correspondence are as follows:

| F20H |  |
| :--- | :--- |
|  | F21H |
| TM0: 128 Hz | TM4: 84 Hz |
| TM $: 64 \mathrm{~Hz}$ | TM5: 4 Hz |
| TM2: 32 Hz | TM6: 2 Hz |
| TM3: 16 Hz |  |
| TM7: 1 Hz |  |

The above 8 bits are only for reading and render writing operation invalid.
At initial reset, timer data is initialized to " 0 ".

## EIT32, EIT8, EIT2, EIT1 (F10H, R/W)

These are the interrupt mask registers of the clock timer.
When " 1 " is written: Enabled
When " 0 " is written: Masked
Reading: Valid
EIT32, EIT8, EIT2, and EIT1 correspond to $32 \mathrm{~Hz}, 8 \mathrm{~Hz}, 2 \mathrm{~Hz}$, and 1 Hz timer interrupts, respectively.
Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI).
Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
At initial reset, these registers are all set to " 0 " (mask).

## IT32, IT8, IT2, IT1 (F00H, R)

These are the interrupt factor flags of the clock timer.
When " 1 " is read: Interrupt has occurred
When " 0 " is read: Interrupt has not occurred Writing: Invalid

IT32, IT8, IT2, and IT1 correspond to $32 \mathrm{~Hz}, 8 \mathrm{~Hz}, 2 \mathrm{~Hz}$, and 1 Hz timer interrupts, respectively. The occurrence of clock timer interrupt can be determined by the software through these flags. However, regardless of interrupt masking, these flags are set to "1" due to the falling edge of the corresponding signal.
Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction. At initial reset, these flags are set to " 0 ".

### 8.1.4 Programming notes

(1) When the clock timer has been reset, the interrupt factor flag (IT) may sometimes be set to "1". Consequently, perform flag read (reset the flag) as necessary at reset.
(2) Because the watchdog timer counts up during reset as in the above (1), reset the watchdog timer as necessary.
(3) When the low-order digits (TM0-TM3) and high-order digits (TM4-TM7) are consecutively read, proper reading may not be obtained due to the carry from the low-order digits into thehigh-orderdigits (when the reading of the low-order digits and high-order digits span the timing of the carry). Forthis reason, perform multiple reading of timer data, make comparisons and use matching data as result.
(4) Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
(5) Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.

### 8.2 Stopwatch Timer

### 8.2.1 Configuration of stopwatch timer

The E0C6007 has $1 / 100 \mathrm{sec}$ unit (SWL) and $1 / 10 \mathrm{sec}$ unit (SWH) stopwatch timer built-in. The stopwatch timer is configured with a 2 levels 4 bits BCD counter which has an input clock approximating 100 Hz signal (signal divided from OSC1 to the closest 100 Hz ) and data can be read in units of 4 bits by software.
Figure 8.2.1.1 shows the configuration of the stopwatch timer.


Fig. 8.2.1.1 Configuration of stopwatch timer
The stopwatch timer can be used as a separate timer from the clock timer. In particular, digital watch stopwatch functions can be realized easily with software.

### 8.2.2 Count-up pattern

The stopwatch timer is configured of 4 bits BCD counters SWL and SWH.
The counter SWL, at the stage preceding the stopwatch timer, has an approximated 100 Hzsignal for the input clock. It counts up every $1 / 100 \mathrm{sec}$, and generates an approximated 10 Hz signal. The counter SWH has an approximated 10 Hz signal generated by the counter SWL for the input clock. In count-up every $1 / 10 \mathrm{sec}$, and generated 1 Hz signal.
Figure 8.2.2.1 shows the count-up pattern of the stopwatch timer.


Fig. 8.2.2.1 Count-up pattern of stopwatch timer
SWL generates an approximated 10 Hz signal from the basic 256 Hz signal. The count-up intervals are $2 / 256 \mathrm{sec}$ and $3 / 256 \mathrm{sec}$, so that finally two patterns are generated: $25 / 256 \mathrm{sec}$ and $26 / 256 \mathrm{sec}$ intervals. Consequently, these patterns do not amount to an accurate $1 / 100 \mathrm{sec}$.
SWH counts the approximated 10 Hz signals generated by the $25 / 256 \mathrm{sec}$ and $26 / 256 \mathrm{sec}$ intervals in the ratio of $4: 6$, to generate a 1 Hz signal. The count-up intervals are $25 / 256 \mathrm{sec}$ and $26 / 256 \mathrm{sec}$, which do not amount to an accurate $1 / 10 \mathrm{sec}$.

### 8.2.3 Interrupt function

Stopwatch timers SWL and SWH, through their respective overflows, can generate 10 Hz (approximate 10 Hz ) and 1 Hz interrupts.
Figure 8.2.3.1 shows the timing chart for the stopwatch timer.


Fig. 8.2.3.1 Timing chart for stopwatch timer
The stopwatch interrupts are generated by the overflow of their respective counters SWL and SWH (changing "9" to "0"). At this time, the corresponding interrupt factor flags (ISW0 and ISW1) are set to "1".
The respective interrupts can be masked separately through the interrupt mask registers (EISW0 and EISW1). However, regardless of the setting of the interrupt mask registers, the interrupt factor flags are set to " 1 " by the overflow of their corresponding counters.

### 8.2.4 Control of stopwatch timer

The control registers for the stopwatch timer are explained below.
Table 8.2.4.1 Control registers of stopwatch timer


## SWRST (F77H [D1], W)

This bit resets the stopwatch timer.
When "1" is written: Stopwatch timer reset
When " 0 " is written: No operation
Reading: Always " 0 "
By writing " 1 " on SWRST, the stopwatch timer is reset. All timer data is set to " 0 ".
When the stopwatch timer is reset in the RUN mode, it will re-start counting immediately after the reset and at STOP mode, the reset data is maintained.
Because this bit is for writing only, it is always " 0 " during reading.

## SWRUN (F77H [D0], R/W)

This register controls RUN/STOP of the stopwatch timer.
When " 1 " is written: RUN
When "0" is written: STOP

## Reading: Valid

By writing "1" on SWRUN, the stopwatch timer performs counting operation. Writing " 0 " will make the stopwatch stop counting.
Even if the stopwatch is stopped, the timer data at that point is kept.
When data of the counter is read at run mode, proper reading may not be obtained due to the carry from low-order digits (SWL) into high-order digits (SWH) (i.e., in case SWL and SWH reading span the timing of the carry). To avoid this occurrence, perform the reading after suspending the counter once and then set the SWRUN to "1" again.
Moreover, it is required that the suspension period not exceed $976 \mu \mathrm{~s}(1 / 4$ cycle of 256 Hz$)$.
At initial reset, SWRUN is set to "0".

## SWLO-SWL3 (F22H, R)

Will read the stopwatch timer data to the $1 / 100 \mathrm{sec}$ digits (BCD).
Since these bits are for reading only, writing operation is invalidated.
At initial reset, timer data is set to " 0 ".

## SWH0-SWH3 (F23H, R)

Will read the stopwatch timer data to the $1 / 10$ sec digits (BCD).
Since these bits are for reading only, writing operation is invalidated.
At initial reset, timer data is set to " 0 ".

## EISW0, EISW1 (F11H [D0, D1], R/W)

These are the interrupt mask registers of the stopwatch timer.
When " 1 " is written: Enabled
When " 0 " is written: Masked
Reading: Valid
EISW0 and EISW1 correspond to 10 Hz and 1 Hz stopwatch timer interrupts, respectively.
Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
At initial reset, these registers are all set to " 0 " (mask).
ISW0, ISW1 (F01H [D0, D1], R)
These are the interrupt factor flags of the stopwatch timer.
When " 1 " is read: Interrupt has occurred
When " 0 " is read: Interrupt has not occurred Writing: Invalid

ISW0 and ISW1 correspond to 10 Hz and 1 Hz stopwatch timer interrupts, respectively.
The occurrence of stopwatch timer interrupt can be determined by the software through these flags. However, regardless of interrupt masking, these flags are set to "1" by the overflow of the corresponding counters.
Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.
At initial reset, these flags are set to " 0 ".

### 8.2.5 Programming notes

(1) When data of the counter is read at run mode, perform the reading after suspending the counteronce and then set SWRUN to "1" again. Moreover, it is required that the suspension period not exceed 976 $\mu \mathrm{s}(1 / 4$ cycle of 256 Hz ).
(2) Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
(3) Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.

### 8.3 Programmable Timer

### 8.3.1 Configuration of programmable timer

The E0C6007 has a programmable timer with OSC1 (crystal oscillation) as basic oscillation built-in. The programmable timer is configured with an 8 bits pre-settable down counter and it has been downcount at initial value by $256 \mathrm{~Hz}-8,192 \mathrm{~Hz}$ signal or by the input signal of input port K03.
The initial value of count data can be set by software to the reload register; at the point where the down-counter value is " 0 ", the programmable timer reloads the initial value and continues to downcount.
The down-counter data may be read through the software. Moreover, the input clock being selected may be generated to output port R33.
Figure 8.3.1.1 shows the configuration of the programmable timer.


Fig. 8.3.1.1 Configuration of programmable timer
One input clock may be selected by software from any of the following 8 types:
(1) K03 input (with noise rejector)
(2) K03 input (direct)
(3) 256 Hz
(4) 512 Hz
(5) $1,024 \mathrm{~Hz}$
(6) $2,048 \mathrm{~Hz}$
(7) $4,096 \mathrm{~Hz}$
(8) $8,192 \mathrm{~Hz}$

Note, however, that down-count is done at falling edges of the input signal as shown in Figure 8.3.1.2.


Fig. 8.3.1.2 Timing of down-counts

Type (1) K03 input (with noise rejector) is for counting by key entry, the input signal from which passes the 256 Hz sampling noise reject circuit. With this, no more than 2 ms of chattering is purged, and at least 4 ms signal is received.

### 8.3.2 Interrupt function

The programmable timer generates interrupt after the down-count from the initial setting is completed and the content of the down-counter indicates 00 H .
After interrupt generation, the programmable timer reloads the initial count value into the down-counter and resumes counting.
Figure 8.3.2.1 shows the timing chart of the programmable timer.


Fig. 8.3.2.1 Timing chart of programmable timer
When the down-counter values PT0-PT7 have become 00 H the interrupt factor flag IPT is set to " 1 " and an interrupt is generated. The interrupt can be masked through the interrupt mask register EIPT. However, regardless of the setting of the interrupt mask register, the interrupt factor flag is set to " 1 " when the down-counter equals 00 H .

### 8.3.3 Control of programmable timer

The control registers for the programmable timer are explained below.
Table 8.3.3.1 Control registers of programmable timer

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F 02 H | 0 | 0 | 0 | IPT | $\begin{gathered} \hline 0 \\ 0 \\ 0 \\ \text { IPT } \end{gathered}$ | $\begin{aligned} & - \\ & - \\ & - \\ & 0 \end{aligned}$ | Yes | No | Interrupt factor flag (programmable timer) |
|  | R |  |  |  |  |  |  |  |  |
| F 12 H | 0 | 0 | 0 | EIPT | $\begin{gathered} 0 \\ 0 \\ 0 \\ \text { EIPT } \end{gathered}$ | $\begin{aligned} & - \\ & - \\ & - \\ & 0 \end{aligned}$ | Enable | Mask | Interrupt mask register (programmble timer) |
|  | R |  |  | R/W |  |  |  |  |  |
| F24H | PT3 | PT2 | PT1 | PTO | $\begin{aligned} & \text { PT3 } \\ & \text { PT2 } \\ & \text { PT1 } \\ & \text { PT0 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ |  |  | $\int_{\text {LSB }}^{\text {Mrogrammable timer data (low-order) }}$ |
|  | R |  |  |  |  |  |  |  |  |
| F25H | PT7 | PT6 | PT5 | PT4 | $\begin{aligned} & \text { PT7 } \\ & \text { PT6 } \\ & \text { PT5 } \\ & \text { PT4 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ |  |  |  |
|  | R |  |  |  |  |  |  |  |  |
| F26H | RD3 | RD2 | RD1 | RD0 | $\begin{aligned} & \hline \text { RD3 } \\ & \text { RD2 } \\ & \text { RD1 } \\ & \text { RD0 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ |  |  | $\begin{aligned} & -\int_{\text {LSB }}^{\text {MSB }} \begin{array}{l} \text { Programmable timer } \\ \text { reload data (low-order) } \end{array} \\ & \hline \end{aligned}$ |
|  | R/W |  |  |  |  |  |  |  |  |
| F27H | RD7 | RD6 | RD5 | RD4 | $\begin{aligned} & \text { RD7 } \\ & \text { RD6 } \\ & \text { RD5 } \\ & \text { RD4 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ | Reset <br> Run |  | $\int_{\text {LSB }} \begin{aligned} & \text { MSB } \\ & \text { Programmable timer } \\ & \text { reload data (high-order) } \end{aligned}$ |
|  | R/W |  |  |  |  |  |  |  |  |
| F78H | 0 | 0 | PTRST | PTRUN | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |  |  |  |
|  | R |  | W | R/W | PTRST PTRUN | Reset <br> 0 |  | Stop | Programmable timer reset <br> Programmable timer Run/Stop |
|  | PTCOUT | PTC2 | PTC1 | PTC0 | $\begin{array}{\|c\|} \hline \text { PTCOUT } \\ \text { PTC2 } \\ \text { PTC1 } \\ \text { PTCO } \end{array}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | On | Off | Programmable timer clock output <br> Programmable timer input clock selection |
|  | R/W |  |  |  |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |  |  |

## PTC0, PTC1, PTC2 (F79H [D0-D2], R/W)

Selects the input clock.
The PTC0-PTC2 setting and input clock correspondence is shown in Table 8.3.3.2.
Table 8.3.3.2 Input clock setting

| PTC2 | PTC1 | PTC0 | Input clock |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | K03 input (with noise rejector) |
| 0 | 0 | 1 | K03 input (direct) |
| 0 | 1 | 0 | 256 Hz |
| 0 | 1 | 1 | 512 Hz |
| 1 | 0 | 0 | $1,024 \mathrm{~Hz}$ |
| 1 | 0 | 1 | $2,048 \mathrm{~Hz}$ |
| 1 | 1 | 0 | $4,096 \mathrm{~Hz}$ |
| 1 | 1 | 1 | $8,192 \mathrm{~Hz}$ |

## PTCOUT (F79H [D3], R/W)

Generates the input clock being selected to output port R33.
Refer to Section 6.2, "Output Port" regarding control methods.

## RD0-RD3, RD4-RD7 (F26H, F27H, R/W)

These are reload registers for setting the initial value of the timer.
Sets the low-order 4 bits of the 8 bits timer data to RD0-RD3, and the high-order 4 bits to RD4-RD7. The set timer data is loaded to the down-counter when the programmable timer is reset or when the content of the down-counter is 00 H .
When data of reload registers is set at " 00 H ", the down-counter becomes a 256 -value counter.
At initial reset, this register will be undefined.

## PTRST (F78H [D1], W)

This bit resets the programmable timer.
When "1" is written: Programmable timer reset
When " 0 " is written: No operation
Reading: Always " 0 "
By writing "1" on PTRST, the programmable timer is reset.
The contents set in RD0-RD7 are loaded into the down-counter.
When the programmable timer is reset in the RUN mode, it will re-start counting immediately after loading and at STOP mode, the load data is maintained.
Because this bit is only for writing, it is always " 0 " during reading.

## PTRUN (F78H [D0], R/W)

This register controls RUN/STOP of the programmable timer.

> When " 1 " is written: RUN
> When " 0 " is written: STOP Reading: Valid

By writing "1" on PTRUN, the programmable timer performs counting operation. Writing " 0 " will make the programmable timer stop counting.
Even if the programmable timer is stopped, the timer data at that point is kept.
When data of the counter is read at the RUN mode, proper reading may not be obtained due to the carry from the low-order digits (PT0-PT3) into the high-order digits (PT4-PT7) (when the reading of the low-order digits and high-order digits span the timing of the carry). To avoid this occurrence, perform the reading after suspending the programmable timer once, and set the PTRUN to "1" again. Moreover, it is required that the suspension period be within $1 / 4$ cycle of the input clock (in case of $1 / 2$ duty).
At initial reset, PTRUN is set to " 0 ".

## PT0-PT3, PT4-PT7 (F24H, F25H, R)

Will read the data from the down-counter of the programmable timer.
Will read the low-order 4 bits of the 8 bits counter data PT0-PT3, and the high-order 4 bits PT4-PT7.
Because these 8 bits are only for reading, writing operation is rendered invalid.
At initial reset, timer data will be undefined.

## EIPT (F12H [D0], R/W)

This is the interrupt mask register of the programmable timer.
When " 1 " is written: Enabled
When " 0 " is written: Masked
Reading: Valid
Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
At initial reset, this register is set to " 0 " (mask).

## IPT (F02H [D0], R)

This is the interrupt factor flag of the programmable timer.
When " 1 " is read: Interrupt has occurred
When " 0 " is read: Interrupt has not occurred Writing: Invalid

From the status of this flag, the software can decide whether the programmable timer interrupt. Note, however, that even if the interrupt is masked, this flag will be set to " 1 " by the counter value will become "00H".
Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction. At initial reset, this flag is set to " 0 ".

### 8.3.4 Programming notes

(1) When initiating programmable timer count, perform programming by the following steps:

1. Set the initial data to RD0-RD7.
2. Reset the programmable timer by writing "1" to PTRST.
3. Start the down-count by writing "1" to PTRUN.
(2) When the reload register (RD0-RD7) value is set at " 00 H ", the down-counter becomes a 256 -value counter.
(3) When data of the timer is read consecutively in 8 bits in the RUN mode, perform the reading after suspending the timer once and then set the PTRUN to " 1 " again. Moreover, it is required that the suspension period be within $1 / 4$ cycle of the input clock (in case of $1 / 2$ duty). Accordingly, when the input clock is a fast clock faster than a 256 Hz , high speed processing by OSC3 is required.
(4) Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
(5) Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.

## Chapter 9 Sound Generator

### 9.1 Configuration of Sound Generator

The E0C6007 is capable of generating buzzer signals ( BZ and \#BZ) to drive a piezo-electric buzzer.
The buzzer signal frequency may be selected by software from 8 types of signal divided from foscı ( 32.768 kHz ). Also, digital envelope which is duty ratio controlled may be added to the buzzer signal. In addition, 1 -shot output circuit is built-in to output key operation check sound, and the like.
Figure 9.1.1 shows the sound generator configuration. Figure 9.1 . 2 shows the sound generator timing chart.


Fig. 9.1.1 Configuration of sound generator


Fig. 9.1.2 Timing chart of sound generator

### 9.2 Mask Option

(1) Selection can be made whether to output the BZ signal from the R43 terminal.
(2) Selection can be made whether to output the \#BZ signal from the R42 terminal. However, if the BZ signal is not output the \#BZ signal cannot be output.

See Section 6.2, "Output Port" for details of the above mask option.

### 9.3 Frequency Setting

The frequencies of the buzzer signals (BZ, \#BZ) are set by writing data to registers BZFQ0-BZFQ2. Table 9.3.1 lists the register setting values and the frequencies that can be set.

Table 9.3.1 Setting of frequencies of buzzer signals

| BZFQ2 | BZFQ1 | BZFQ0 | Buzzer frequency (Hz) |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $4,096.0$ |
| 0 | 0 | 1 | $3,276.8$ |
| 0 | 1 | 0 | $2,730.7$ |
| 0 | 1 | 1 | $2,340.6$ |
| 1 | 0 | 0 | $2,048.0$ |
| 1 | 0 | 1 | $1,638.4$ |
| 1 | 1 | 0 | $1,365.3$ |
| 1 | 1 | 1 | $1,170.3$ |

Note: A hazard may be observed in the output waveform of the BZ and \#BZ signals when switches the buzzer frequency while the $B Z$ and \#BZ signals being output.

### 9.4 Digital Envelope

A duty ratio control data envelope (with duty ratio change in 8 steps) can be added to the buzzer signal (BZ, \#BZ).
Duty ratio refers to the ratio of pulse width to the pulse cycle; given that high level output time is TH, and low level output time is TL, BZ output becomes $\mathrm{TH} /(\mathrm{TH}+\mathrm{TL})$.
\#BZ output becomes $\mathrm{TL} /(\mathrm{TH}+\mathrm{TL})$ owing to the inverted output of the BZ output. Moreover, care is necessary as the duty ratio differs according to the buzzer frequency.
Envelope addition is performed by writing " 1 " to ENVON; when " 0 " is written, the duty ratio is fixed at the maximum ( $1 / 2$ duty). Moreover, when envelope is added, writing " 1 " to ENVRST will cause the BZ signal duty ratio to be returned to maximum.
The decay time of the envelope (time for the duty ratio to change) can be selected with the register ENVRT. This time is $62.5 \mathrm{~ms}(16 \mathrm{~Hz})$ when " 0 " is written, and $125 \mathrm{~ms}(8 \mathrm{~Hz})$ when " 1 " is written.
However, a maximum difference of 4 ms is taken from envelope-ON until the first change.
Table 9.4.1 lists the duty ratio and buzzer frequencies.
Figure 9.4.1 shows the digital envelope timing chart.
Table 9.4.1 Duty ratio and buzzer frequencies

| Duty ratio | Buzzer frequencies |  |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $4,096.6$ | $3,276.8$ | $2,730.7$ | $2,340.6$ |
|  | $2,048.0$ | $1,638.4$ | $1,365.3$ | $1,170.3$ |
| Level 1 (max.) | $8 / 16$ | $8 / 20$ | $12 / 24$ | $12 / 28$ |
| Level 2 | $7 / 16$ | $7 / 20$ | $11 / 24$ | $11 / 28$ |
| Level 3 | $6 / 16$ | $6 / 20$ | $10 / 24$ | $10 / 28$ |
| Level 4 | $5 / 16$ | $5 / 20$ | $9 / 24$ | $9 / 28$ |
| Level 5 | $4 / 16$ | $4 / 20$ | $8 / 24$ | $8 / 28$ |
| Level 6 | $3 / 16$ | $3 / 20$ | $7 / 24$ | $7 / 28$ |
| Level 7 | $2 / 16$ | $2 / 20$ | $6 / 24$ | $6 / 28$ |
| Level 8 (min.) | $1 / 16$ | $1 / 20$ | $5 / 24$ | $5 / 28$ |



Fig. 9.4.1 Digital envelope timing chart

### 9.5 1-shot Output

In order to cause the buzzer to ring in a short period of time as in the case of key operation check sound, 1 -shot output function is built-in. The time duration for buzzer signal to be output ( BZ and $\# \mathrm{BZ}$ ) may be selected by SHOTPW; when "0" is written on SHOTPW, it is set to 31.25 ms and to 62.5 ms when "1" written.
Actual output operation is performed by writing "1" on BZSHOT; after performing the previously described writing operation, it synchronizes with the internal 256 Hz signal and buzzer signal is output in output port R43 (R42).
Moreover, after the set time has lapsed, it synchronizes with the same 256 Hz previously described and the buzzer signal is automatically turned off. Also, by reading BZSHOT, whether the 1 -shot circuit is in operation or not may be determined with the software.
Figure 9.5.1 shows the timing chart of the 1 -shot output.


Fig. 9.5.1 Timing chart of 1 -shot output

### 9.6 Control of Sound Generator

The control registers for the sound generator are explained below.
Table 9.6.1 Control registers of sound generator

| Address | Register |  |  |  |  |  |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D3 | D2 | D1 | D0 | Name | Init | 1 | 0 |  |
| F54H | R43 | R42 | R41 | R40 | R43 | 1 | $\begin{gathered} \hline \text { High } \\ \text { Off } \end{gathered}$ | $\begin{gathered} \text { Low } \\ \text { On } \end{gathered}$ | Output port (R43) <br> Buzzer output (BZ) |
|  | R/W |  |  |  | R42 | 1 | $\begin{aligned} & \text { High } \\ & \text { Off } \end{aligned}$ | $\begin{aligned} & \text { Low } \\ & \text { On } \end{aligned}$ | Output port (R42) <br> Clock output (FOUT) <br> [Buzzer inverted output (\#BZ)] |
|  |  |  |  |  | R41 | 1 | High | Low | Output port (R41) |
|  |  |  |  |  | R40 | 1 | High Off | $\begin{aligned} & \text { Low } \\ & \text { On } \end{aligned}$ | Output port (R40) <br> Clock inverted output (\#FOUT) |
| F74H | SHOTPW | BZFQ2 | BZFQ1 | BZFQ0 | $\begin{array}{\|c\|} \hline \text { SHOTPW } \\ \text { BZFQ2 } \\ \text { BZFQ1 } \\ \text { BZFQ0 } \\ \hline \end{array}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | 62.5 ms | 31.25 ms | 1-shot buzzer pulse width <br> Buzzer frequency selection |
|  | R/W |  |  |  |  |  |  |  |  |
| F75H | BZSHOT | ENVRST | ENVRT | ENVON | BZSHOT | 0 | Trigger BUSY | READY | 1-shot buzzer trigger (W) Status (R) |
|  |  | W |  |  | ENVRST | RESET | Reset | - | Envelope reset |
|  | W |  | R/W |  | ENVRT | 0 | 1.0 sec | 0.5 sec | Envelope cycle selection |
|  | R |  |  |  | ENVON | 0 | On | Off | Envelope On/Off |

## BZFQ0-BZFQ2 (F74H [D0-D2], R/W)

Will select the buzzer signal frequency.
Table 9.6.2 Setting of frequencies of buzzer signals

| BZFQ2 | BZFQ1 | BZFQ0 | Buzzer frequency (Hz) |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $4,096.0$ |
| 0 | 0 | 1 | $3,276.8$ |
| 0 | 1 | 0 | $2,730.7$ |
| 0 | 1 | 1 | $2,340.6$ |
| 1 | 0 | 0 | $2,048.0$ |
| 1 | 0 | 1 | $1,638.4$ |
| 1 | 1 | 0 | $1,365.3$ |
| 1 | 1 | 1 | $1,170.3$ |

At initial reset, $4,096 \mathrm{~Hz}$ is selected.

## ENVRST (F75H [D2], W)

This is the reset input to make the duty ratio of the buzzer signal the maximum.
When "1" is written: Reset input
When " 0 " is written: No operation
Reading: Always " 0 "
When envelope is added to the buzzer signal, by writing " 1 " on ENVRST, the envelope is reset and duty ratio becomes maximum. When envelope is not added, or when buzzer signal is not being output, reset operation is ineffective.

## ENVON (F75H [D0], R/W)

This controls adding the envelope to the buzzer signal.
When " 1 " is written: Envelope added (ON)
When " 0 " is written: No envelope (OFF)
Reading: Valid
By writing "1" on ENVON, envelope is added to the buzzer signal. Writing "0" means envelope will not be added.
At initial reset, ENVON is set to "0" and envelope OFF will be selected.

## ENVRT (F75H [D1], R/W)

Selects the attenuation time of the envelope added to the buzzer signal.
When " 1 " is written: $1.0 \mathrm{sec}(125 \mathrm{~ms} \times 7=875 \mathrm{~ms})$
When " 0 " is written: $0.5 \mathrm{sec}(62.5 \mathrm{~ms} \times 7=437.5 \mathrm{~ms}$ )

## Reading: Valid

The attenuation time of digital envelopes is determined by the time change for duty ratio. When "1" is written on ENVRT, attenuation time is set in 125 ms ( 8 Hz ) units ( $125 \mathrm{~ms} \times 7=875 \mathrm{~ms}$ ), and in 62.5 ms ( 16 Hz ) unit ( $62.5 \mathrm{~ms} \times 7=437.5 \mathrm{~ms}$ ) when " 0 " is written.
However, there is a maximum error of 4 ms from envelope ON to the first change in both cases.
At initial reset, ENVRT is set to " 0 ".

## R43, R42 (F54H [D3, D2], R/W)

Controls the output of the buzzer signals (BZ, \#BZ).
When " 0 " is written: Buzzer signal output
When " 1 " is written: Low level (DC)
Reading: Valid
When " 0 " is set on R43, BZ signal is generated from R43 terminal, and if R42 is set to \#BZ output, \#BZ signal (inverted signal of $B Z$ ) is generated at the same time.
When "1" is set on R43, R43 terminal (R42 too, if \#BZ output is selected) becomes of low (Vss) level output.
However, R42 with \#BZ output selected, may be used as a 1-bit general register capable of read/write function, the data of which register does not affect \#BZ (R42 terminal output).
At initial reset, both R43 and R42 are set to "1".
Note: BZ and \#BZ output signals may produce hazards during ON/OFF switching.

## SHOTPW (F74H [D3], R/W)

Sets the output time duration of the 1 -shot buzzer.
When " 1 " is written: 62.5 ms
When " 0 " is written: 31.25 ms
Reading: Valid
Output time duration is set to 62.5 ms or 31.25 ms by writing " 1 " or " 0 ", respectively, on SHOTPW. At initial reset, SHOTPW is set to " 0 ".

## BZSHOT (F75H [D3], W, R)

Controls the output of the 1 -shot buzzer.

## - During writing operation

When " 1 " is written: Trigger
When " 0 " is written: No operation
When "1" is written on BZSHOT, the 1 -shot circuit operates and the buzzer signal (BZ and \#BZ) is output.
The 1 -shot buzzer operates only when the regular buzzer output is in the OFF ( $\mathrm{R} 43=$ " 0 ") state and writing to BZSHOT becomes invalid in the ON (R43 = "1") state.

## - During reading operation

When " 1 " is read: Busy
When " 0 " is read: Ready
The BZSHOT reads " 1 " when the 1 -shot buzzer is ringing and " 0 " when it is not ringing. The period of " 1 " is from the time of the trigger until the buzzer output is turned OFF.
At initial reset, " 0 " is read.

### 9.7 Programming Notes

(1) The BZ and \#BZ signals may generate hazards in the following cases:

- When the content of R43 register is changed, BZ and \#BZ signals are switched ON or OFF.
- When the contents of buzzer frequency selection registers (BZFQ0-BZFQ2) while the buzzer signal ( $B Z$ and \#BZ) is being output.
(2) The 1 -shot buzzer operates only when the regular buzzer output is in the OFF $(\mathrm{R} 43=" 0$ ") state and writing to BZSHOT becomes invalid in the ON (R43 = "1") state.


## CHAPTER 10 Interrupt and HALT

The E0C6007 has the following interrupt functions built-in, and masking is possible for each one.

$$
\begin{array}{ll}
\text { External interrupt } & \text { - Input interrupt (1 system) } \\
\text { Internal interrupt } & \text { • Clock timer interrupt (3 systems) } \\
& \text { • Stopwatch timer interrupt }(2 \text { systems }) \\
& \text { • Programmable timer interrupt (1 system) }
\end{array}
$$

To allow the interrupt to function, it is necessary that the interrupt mask register of the required systembe set to "1" (enable) and, at the same time, the interrupt flag be set to "1" (EI).
When interrupt occurs, the interrupt flag is automatically reset to "0" (DI), prohibiting the any consequent interrupts.

The CPU stops the operating clock when a HALT instruction is executed and then enters the HALT state.
Re-running the CPU from the HALT state requires issuance of interrupt request.
If return through interrupt request is not effective, return is effected from initial reset by the watchdog timer.

Figure 10.1 shows the configuration of the interrupt circuit.
See the explanations of the relevant circuits for interrupt details.


Fig. 10.1 Configuration of interrupt circuit

### 10.1 Interrupt Factor Flag and Interrupt Mask

The corresponding interrupt factor flag is set to " 1 " with the individual interrupt element.
If the following conditions exist, interrupt for the CPU occurs when the interrupt factor flag is set to " 1 ".

- The corresponding interrupt mask register is set at "1" (enable).
- The interrupt flag is set at "1" (EI).

The interrupt factor flag is reset to " 0 " at the read-only register by reading the data.
Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI).
Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.
At initial reset, the interrupt factor flag is reset to " 0 ".
The interrupt can be masked by the corresponding interrupt mask register.
The interrupt mask register is a register capable of read/write operation; by writing " 1 ", it is enabled (interrupt is allowed) and by writing " 0 ", it is masked (interrupt is prohibited).
Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction. At initial reset, the interrupt mask register is set to " 0 ".
The interrupt factor flag is set to "1" by interrupt factor even if the interrupt is masked. (The input interrupt factor flag IK0 will be eliminated.)
Table 10.1.1 shows the correspondence between interrupt factor flags and interrupt mask registers.
Table 10.1.1 Interrupt factor flags and interrupt mask registers

| Interrupt factor | Interrupt factor flag | Interrupt mask register |
| :--- | :--- | :--- |
| Falling edge of clock timer (1 Hz) | IT1 (F00H [D3]) | EIT1 (F10H [D3]) |
| Falling edge of clock timer $(2 \mathrm{~Hz})$ | IT2 (F00H [D2]) | EIT2 (F10H [D2]) |
| Falling edge of clock timer $(8 \mathrm{~Hz})$ | IT8 (F00H [D1]) | EIT8 (F10H [D1]) |
| Falling edge of clock timer $(32 \mathrm{~Hz})$ | IT32 (F00H [D0]) | EIT32 (F10H [D0]) |
| Overflow of stopwatch timer (SWH) (1 Hz) | ISW1 (F01H [D1]) | EISW1 (F11H [D1]) |
| Overflow of stopwatch timer (SWL) (10 Hz) | ISW0 (F01H [D0]) | EISW0 (F11H [D0]) |
| Changing of input (K00-K03) status | IK0 (F04H [D0]) | EIK03 (F14H [D3]) |
|  | EIK02 (F14H [D2]) |  |
|  |  | EIK01 (F14H [D1]) |
| Counter value of programmable timer $=00 \mathrm{H}$ | IPT (F02H [D0]) | EIP00 (F14H [D0]) |

### 10.2 Interrupt Vector

When an interrupt request is issued to the CPU, the CPU starts interrupt processing.
Interrupt processing is accomplished by the following steps after the instruction being executed is completed.

1. The address (value of the program counter) of the program which should be run next is saved in the stack area (RAM).
2. The vector address ( 1 page $02 \mathrm{H}-0 \mathrm{CH}$ ) for each interrupt request is set to the program counter.
3. Branch instruction written to the vector is effected (branch to software interrupt processing routine).

Note: Time equivalent to 12 cycles of CPU system clock is required for steps 1 and 2.
The interrupt request and interrupt vector correspondence is shown in Table 10.2.1.
Table 10.2.1 Interrupt request and interrupt vectors

| Interrupt vector <br> (PCP and PCS) | Interrupt request | Priority |
| :---: | :--- | :---: |
| 102 H | Clock timer interrupt | Low |
| 104 H | Stopwatch timer interrupt | $\uparrow$ |
| 106 H | Input (K00-K03) interrupt | $\downarrow$ |
| 10 CH | Programmable timer interrupt | High |

When multiple interrupts simultaneously occur, the high priority vector address is set to the program counter.

### 10.3 Programming Notes

(1) The interrupt factor flag is set when the interrupt conditions are established, regardless of the setting of the interrupt mask register. Note, however, that the input interrupt factor flag (IK0) will be eliminated.
(2) When an interrupt occurs, the interrupt flag will be reset by the hardware and it will become DI status. After completion of the interrupt processing, set to the EI status through the software as needed. Moreover, the nesting level may be set to be programmable by setting to the EI state at the beginning of the interrupt processing routine.
(3) The interrupt factor flags must always be reset before setting the EI status. When the interrupt mask register has been set to " 1 ", the same interrupt will occur again if the EI status is set unless of resetting the interrupt factor flag.
(4) The interrupt factor flag will be reset by reading through the software. Because of this, when multiple interrupt factor flags are to be assigned to the same address, perform the flag check after the contents of the address has been stored in the RAM. Direct checking with the FAN instruction will cause all the interrupt factor flag to be reset.
(5) Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.
(6) Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
(7) When multiple interrupts simultaneously occur, the high priority vector address is set to the program counter.
(8) If an interrupt occurs while the CPU is processing some other interrupt request of which the priority is lower than the new one but the CPU has not fetched the interrupt vector, the CPU may shift to a vector address (one of among $102 \mathrm{H}, 104 \mathrm{H}, 106 \mathrm{H}$ and 10 CH ) that is different from the new interrupt. Therefore, make sure the interrupt factor flag has been set immediately after the branch instruction stored in the vector address is executed and quit the interrupt processing if it has not been set. Furthermore, place a branch instruction for executing the interrupt processing routine in the vector address 10 CH because the CPU may shift to that address. By setting the start address of the programmable timer interrupt processing routine as the branch destination, the priority level by hardware can be maintained.
If the program does not have the individual processing routine for each interrupt (for example, in the case of all interrupts using the same processing routine in which the type of interrupt is judged by reading the interrupt flags, or in the case of the main routine checking all the interrupt flags by branching the flow the RET instruction stored in all the vector address), place the instruction the same as the other interrupt vectors in address 10 CH .
When the interrupt function is not used, it is not necessary to pay attention to the above mentioned precautions.

## Chapter 11 Summary of Notes

### 11.1 Notes for Low Current Consumption

The E0C6007 contains control registers for each of the circuits so that current consumption can be lowered. These control registers lower the current consumption through programs that operate the circuits at the minimum levels.
The following text explains the circuits that can control operation and their control registers. Refer to these when putting programs together.

Table 11.1.1 Circuits and control registers

| Circuits (and Items) | Control registers | Order of consumed current |
| :--- | :--- | :--- |
| CPU | HALT instruction | See electrical characteristics (Chapter 13) |
| CPU operation frequency | CLKCHG, OSCC | See electrical characteristics (Chapter 13) |
| Internal regulated voltage | VSCO, VSC1 | See electrical characteristics (Chapter 13) |
| Heavy load protection mode | HLMOD | See electrical characteristics (Chapter 13) |

Below are the circuit status at initial reset.

CPU:
CPU operating frequency:
Internal regulated voltage:

Operating
OSC1 side (CLKCHG = "0"),
OSC3 oscillation circuit is stopped ( $\mathrm{OSCC}=" 0$ ")
-1.2 V (VSC0, VSC1 = "0")
When CR oscillation is selected by mask option, the internal regulated voltage becomes - 2.1 V .
Heavy load protection mode: Normal operating mode (HLMOD = "0")
Also, be careful about panel selection because the current consumption can differ by the order of several $\mu \mathrm{A}$ on account of the LCD panel characteristics.

### 11.2 Summary of Notes by Function

Here, the cautionary notes are summed up by function category. Keep these notes well in mined when programming.

## Memory

Memory is not mounted in unused area within the memory map and in memory area not indicated in this manual. For this reason, normal operation cannot be assured for programs that have been prepared with access to these areas.

## Heavy load protection mode

(1) When driving heavy loads, set it to heavy load protection mode. Unless it is necessary, be careful not to set the heavy load protection mode with the software.
(2) Perform heavy load driving only after setting up at least 1 ms wait time through the software, after switching to the heavy load protection mode. (See Figure 3.2.2.1.)
(3) When the heavy load protection mode is to canceled after completion of heavy load driving, set up at least 2 seconds wait time through the software. (See Figure 3.2.2.1.)

## Watchdog timer

(1) The watchdog timer must reset within 3-second cycles by the software.
(2) When the clock timer is reset (TMRST $\leftarrow " 1 "$ ), the watchdog timer is counted up; reset the watchdog immediately after if necessary.

## Oscillation circuit

(1) When high-speed operation of the CPU is not required, observe the following remindersto minimize power current consumption.

Set the CPU operating clock to OSC1.
Turn the OSC3 oscillation OFF.
Set the internal operating voltage ( V sı ) to -1.2 V or -2.1 V .
(2) When the CPU is to be operated with OSC1, set the operating voltage to -1.2 V if the power voltage is less than $3.1 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{DD}}-\mathrm{Vss}<3.1 \mathrm{~V}\right)$; set the operating voltage to -2.1 V if the voltage is 3.1 Vormore (Vdd-Vss $\geq 3.1 \mathrm{~V}$ ). Moreover, because -1.2 V will be set during initial reset, be sure to execute the previous process at the beginning of the initial routine. Note, however, that it can be used fixed at 1.2 V (at OSC1 operation) for power whose initial value is 3.6 V or less as in lithium batteries.
(3) When switching Vs1 from -1.2 V (for OSC 1 crystal oscillation circuit) to -3.0 V (for OSC3 oscillation circuit), or vice versa, be sure to hold the -2.1 V setting for more than 5 ms first for power voltage stabilization.

$$
\begin{aligned}
(\mathrm{VSC} 1, \mathrm{VSC} 0) & =(0,0) \rightarrow(0,1) \rightarrow 5 \mathrm{~ms} \text { WAIT } \rightarrow(1, \times) \\
& =(1, \times) \rightarrow(0,1) \rightarrow 5 \mathrm{~ms} \text { WAIT } \rightarrow(0,0) \\
& =(0,0) \rightarrow(1, \times) \text { is prohibited } \\
& =(1, \times) \rightarrow(0,0) \text { is prohibited }
\end{aligned}
$$

(4) When switching the CPU operating clock from OSC1 to OSC3, follow the flow chart shown in Figure 5.6.1 and then proceed with software processing.
(5) Use separate instructions to switch the clock from OSC3 to OSC1 and turn the OSC3 oscillation OFF. Simultaneous processing with a single instruction may cause malfunction of the CPU.
(6) When CR oscillation has been selected by the mask option, internal regulated voltage becomes - 2.1 V and will never become -1.2 V .

## Input port (Kxx)

(1) When changing the input port from low level to high level with a pull up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull up resistor and input gate capacity. Hence, when reading data from the input port, set an appropriate waiting time. Care is particularly required for key matrix configuration scanning. For reference, approximately $500 \mu \mathrm{~s}$ waiting time is required.
(2) Input interrupt programming related precautions


When the content of the mask register is rewritten, while the port K input is in the active status, the input interrupt factor flag is set at $(1)$.

Fig. 11.2.1 Input interrupt timing
When using an input interrupt, if you rewrite the content of the mask register, when the value of the input terminal which becomes the interrupt input is in the active status (input terminal = low status), the factor flag for input interrupt may be set.
For example, a factor flag is set with the timing of $(1)$ shown in Figure 11.2.1. However, when clearing the content of the mask register with the input terminal kept in the low status and then setting it, the factor flag of the input interrupt is again set at the timing that has been set.
Consequently, when the input terminal is in the active status (low status), do not rewrite the mask register (clearing, then setting the mask register), so that a factor flag will only set at the rising edge in this case. When clearing, then setting the mask register, set the mask register, when the input terminal is not in the active status (high status).

## Output port (Rxx)

(1) When BZ, \#BZ, FOUT, \#FOUT, and PTCLK (DC) are selected by mask option, a hazard may be observed in the output waveform when the data of the output register changes.
(2) Because the R32 and R33 ports gain high impedance during initial reset, be careful when using them as interface with external devices and the like.

## I/O port (Pxx)

(1) When the I/O port is set at output mode, and low impedance load is connected to the port terminal, the data written and read may differ.
(2) If the state of the I/O port meets all of the following 4 conditions, the reading data will be undefined:

- The input/output mode is set at output mode
- Output specification is set at Nch open drain
- The content of the data register is " 1 "
- The pull up resistor turned is OFF


## LCD driver

Because at initial reset, the contents of segment data memory and LC0-LC3 are undefined, there is need to initialize by software.

## Clock timer

(1) When the clock timer has been reset, the interrupt factor flag (IT) may sometimes be set to "1". Consequently, perform flag read (reset the flag) as necessary at reset.
(2) Because the watchdog timer counts up during reset as in the above (1), reset the watchdog timer as necessary.
(3) When the low-order digits (TM0-TM3) and high-order digits (TM4-TM7) are consecutively read, proper reading may not be obtained due to the carry from the low-order digits into the high-order digits (when the reading of the low-order digits and high-order digits span the timing of the carry). For this reason, perform multiple reading of timer data, make comparisons and use matching data as result.

## Stopwatch timer

When data of the counter is read at run mode, perform the reading after suspending the counteronce and then set SWRUN to "1" again. Moreover, it is required that the suspension period notexceed $976 \mu \mathrm{~s}$ ( $1 / 4$ cycle of 256 Hz ).

## Programmable timer

(1) When initiating programmable timer count, perform programming by the following steps:

1. Set the initial data to RD0-RD7.
2. Reset the programmable timer by writing "1" to PTRST.
3. Start the down-count by writing " 1 " to PTRUN.
(2) When the reload register (RD0-RD7) value is set at " 00 H ", the down-counter becomes a 256 -value counter.
(3) When data of the timer is read consecutively in 8 bits in the RUN mode, perform the reading after suspending the timer once and then set the PTRUN to "1" again. Moreover, it is required that the suspension period be within $1 / 4$ cycle of the input clock (in case of $1 / 2$ duty). Accordingly, when the input clock is a fast clock faster than 256 Hz , high speed processing by OSC3 is required.

## Sound generator

(1) The BZ and \#BZ signals may generate hazards in the following cases:

- When the content of R43 register is changed, BZ and \#BZ signals are switched ON or OFF.
- When the contents of buzzer frequency selection registers (BZFQ0-BZFQ2) while the buzzer signal ( $B Z$ and \#BZ) is being output.
(2) The 1 -shot buzzer operates only when the regular buzzer output is in the OFF ( $\mathrm{R} 43=00$ ") state and writing to BZSHOT becomes invalid in the ON $(\mathrm{R} 43=11 ")$ state.


## Interrupt

(1) The interrupt factor flag is set when the interrupt conditions are established, regardless of the setting of the interrupt mask register. Note, however, that the input interrupt factor flag (IK0) will be eliminated.
(2) When an interrupt occurs, the interrupt flag will be reset by the hardware and it will become DI status. After completion of the interrupt processing, set to the EI status through the software as needed. Moreover, the nesting level may be set to be programmable by setting to the EI state at the beginning of the interrupt processing routine.
(3) The interrupt factor flags must always be reset before setting the EI status. When the interrupt mask register has been set to "1", the same interrupt will occur again if the EI status is set unless of resetting the interrupt factor flag.
(4) The interrupt factor flag will be reset by reading through the software. Because of this, when multiple interrupt factor flags are to be assigned to the same address, perform the flag check after the contents of the address has been stored in the RAM. Direct checking with the FAN instruction will cause all the interrupt factor flag to be reset.
(5) Be sure that the interrupt factor flag reading is done with the interrupt in the DISABLE state (DI). Reading the interrupt factor flag while in the ENABLE state (EI) may cause malfunction.
(6) Be sure that writing to the interrupt mask register is done with the interrupt in the DISABLE state (DI). Writing to the interrupt mask register while in the ENABLE state (EI) may cause malfunction.
(7) When multiple interrupts simultaneously occur, the high priority vector address is set to the program counter.
(8) If an interrupt occurs while the CPU is processing some other interrupt request of which the priority is lower than the new one but the CPU has not fetched the interrupt vector, the CPU may shift to a vector address (one of among $102 \mathrm{H}, 104 \mathrm{H}, 106 \mathrm{H}$ and 10 CH ) that is different from the new interrupt. Therefore, make sure the interrupt factor flag has been set immediately after the branch instruction stored in the vector address is executed and quit the interrupt processing if it has not been set. Furthermore, place a branch instruction for executing the interrupt processing routine in the vector address 10 CH because the CPU may shift to that address. By setting the start address of the programmable timer interrupt processing routine as the branch destination, the priority level by hardware can be maintained.
If the program does not have the individual processing routine for each interrupt (for example, in the case of all interrupts using the same processing routine in which the type of interrupt is judged by reading the interrupt flags, or in the case of the main routine checking all the interrupt flags by branching the flow the RET instruction stored in all the vector address), place the instruction the same as the other interrupt vectors in address 10 CH .
When the interrupt function is not used, it is not necessary to pay attention to the above mentioned precautions.

### 11.3 Precautions on Mounting

## Oscillation Circuit

- Oscillation characteristics change depending on conditions (board pattern, components used, etc.). In particular, when a ceramic oscillator or crystal oscillator is used, use the oscillator manufacturer's recommended values for constants such as capacitance and resistance.
- Disturbances of the oscillation clock due to noise may cause a malfunction. Consider the following points to prevent this:
(1) Components which are connected to the OSC1 (OSC3) and OSC2 (OSC4) terminals, such as oscillators, resistors and capacitors, should be connected in the shortest line.
(2) As shown in the figure, make a VdD pattern as large as possible at circumscription of the OSC1 (OSC3) and OSC2 (OSC4) terminals and the components connected to these terminals.
Furthermore, do not use this VdD pattern for any purpose other than the oscillation system.

- In order to prevent unstable operation of the oscillation circuit due to current leak between OSC1 (OSC3) and Vss, please keep enough distance between OSC3 and Vss or other signals on the board pattern.


## Reset Circuit

- The power-on reset signal which is input to the \#RESET terminal changes depending on conditions (power rise time, components used, board pattern, etc.).
Decide the time constant of the capacitor and resistor after enough tests have been completed with the application product.
When using the built-in pull-up resistor of the \#RESET terminal, take into consideration dispersion of the resistance for setting the constant.
- In order to prevent any occurrences of unnecessary resetting caused by noise during operating, components such as capacitors and resistors should be connected to the \#RESET terminal in the shortest line.


## Power Supply Circuit

- Sudden power supply variation due to noise may cause malfunction. Consider the following points to prevent this:
(1) The power supply should be connected to the VDD and Vss terminal with patterns as short and large as possible.
Furthermore, similar consideration is necessary when VL1-VL5 are supplied from outside the IC.
(2) When connecting between the VDD and Vss terminals with a bypass capacitor, theterminals should be connected as short as possible.

(3) Components which are connected to the Vs1, VL1-VL5 terminals, such as capacitors and resistors, should be connected in the shortest line.
In particular, the $V_{L 1}-V_{L 5}$ voltages affect the display quality.
- Do not connect anything to the VL1-VL5 terminals when the LCD driver is not used.


## Arrangement of Signal Lines

- In order to prevent generation of electromagnetic induction noise caused by mutual inductance, do not arrange a large current signal line near the circuits that are sensitive to noise such as the oscillation unit.
- When a signal line is parallel with a high-speed line in long distance or intersects a high-speed line, noise may generated by mutual interference between the signals and it may cause a malfunction. Do not arrange a high-speed signal line especially near circuits that are sensitive to noise such as the oscillation unit.



## Precautions for Visible Radiation (when bare chip is mounted)

- Visible radiation causes semiconductor devices to change the electrical characteristics. It may cause this IC to malfunction. When developing products which use this IC, consider the following precautions to prevent malfunctions caused by visible radiation.
(1) Design the product and implement the IC on the board so that it is shielded from visible radiation in actual use.
(2) The inspection process of the product needs an environment that shields the IC from visible radiation.
(3) As well as the face of the IC, shield the back and side too.


## Chapter 12 Basic External Connection Diagram


*1 When the load on the liquid crystal system is large, increase the capacitance of the voltage booster capacitors $\left(\mathrm{C}_{1}-\mathrm{C}_{3}\right)$ and the capacitors between VDD and liquid crystal system power $\left(\mathrm{C}_{4}-\mathrm{C}_{7}\right)$.

Note: The above table is simply an example. Refer to Chapter 13, "Electrical Characteristics", for detailed characteristics.

## chapter 13 Electrical Characteristics

13.1 Absolute Maximum Rating

| (Vdd=0V) |  |  |  |
| :---: | :---: | :---: | :---: |
| Item | Symbol | Rated value | Unit |
| Supply voltage | Vss | -7.0 to 0.5 | V |
| Input voltage (1) | VI | Vss - 0.3 to 0.5 | V |
| Input voltage (2) | Viosc | Vs1-0.3 to 0.5 | V |
| Permissible total output current *1 | EIvss | 10 | mA |
| Operating temperature | Topr | -20 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature | Tstg | -65 to 150 | ${ }^{\circ} \mathrm{C}$ |
| Soldering temperature / time | Tsol | $260^{\circ} \mathrm{C}, 10 \mathrm{sec}$ (lead section) | - |
| Permissible dissipation *2 | PD | 250 | mW |

*1 The permissible total output current is the sum total of the current (average current) that simultaneously flows from the output pin (or is drawn in).
*2 In case of plastic package.

### 13.2 Recommended Operating Conditions



### 13.3 DC Characteristics

Conditions unless otherwise specified:


| Item | Symbol | Condition |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| High-level input voltage (1) | VIH1 | Vss $=-2.2$ to -5.5V | K00-03, P00-03 | 0.2-Vss |  | 0 | V |
| Low-level input voltage (1) | VIL1 | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ |  | Vss |  | 0.8.Vss | V |
| High-level input voltage (2) | VIH2 | $\begin{aligned} & \text { Vss }=-2.2 \text { to }-5.5 \mathrm{~V} \\ & \mathrm{Ta}=25^{\circ} \mathrm{C} \end{aligned}$ | \#RESET | -0.2 |  | 0 | V |
| Low-level input voltage (2) | VIL2 |  |  | Vss |  | Vss+0.2 | V |
| High-level input current | IIH | VsS $=-3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=0 \mathrm{~V}$ | K00-03, P00-03, \#RESET | 0 |  | 0.5 | $\mu \mathrm{A}$ |
| Low-level input current (1) | ILL1 | $\text { Vss }=-3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL} 1}=\mathrm{Vss}$ <br> With Pull-up resistor |  | -45 |  | -15 | $\mu \mathrm{A}$ |
| Low-level input current (2) | ILL2 | VSS=-3.0V, VIL2=VSS <br> No Pull-up resistor |  | -0.5 |  | 0 | $\mu \mathrm{A}$ |
| High-level output current (1) | IoH1 | $\begin{aligned} & \text { Vss }=-2.2 \mathrm{~V} \\ & \text { VoHI }=-0.5 \mathrm{~V} \end{aligned}$ | P00-03, R32, R33, R40, R41 |  |  | -1.0 | mA |
| Low-level output current (1) | IoL1 | $\begin{aligned} & \text { VSS=-2.2V, } \\ & \text { VoL1=Vss }+0.5 \mathrm{~V} \end{aligned}$ |  | 4.0 |  |  | mA |
| High-level output current (2) | IoH2 | $\begin{aligned} & \text { Vss }=-2.2 \mathrm{~V} \\ & \text { VoH } 2=-0.5 \mathrm{~V} \end{aligned}$ | R42, R43 |  |  | -2.0 | mA |
| Low-level output current (2) | IoL2 | $\begin{aligned} & \text { Vss=-2.2V, } \\ & \text { VoL2=Vss }+0.5 \mathrm{~V} \end{aligned}$ |  | 8.0 |  |  | mA |
| Common output current | Ioн3 | VOH3=-0.05V | COM0-15 |  |  | -30 | $\mu \mathrm{A}$ |
|  | IoL3 | VoL3 $=$ VL5 +0.05 V |  | 30 |  |  | $\mu \mathrm{A}$ |
| Segment output current | Iон4 | VOH4=-0.05V | SEG0-39 |  |  | -10 | $\mu \mathrm{A}$ |
|  | IoL4 | Vol4=VL5+0.05V |  | 10 |  |  | $\mu \mathrm{A}$ |

### 13.4 Analog Circuit Characteristics and Consumed Current

Conditions unless otherwise specified:
VDD $=0 \mathrm{~V}, \mathrm{VSS}=-3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{L} 1}=-1.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{L} 2}=-2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{L}} 4=-3.0 \mathrm{~V}, \mathrm{VL} 5=-4.0 \mathrm{~V}$, foscl $=32.768 \mathrm{kHz}$, fosc3 $=1 \mathrm{MHz}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{C} 1 \sim \mathrm{C} 8=0.047 \mu \mathrm{~F}$

| Item | Symbol | Condition |  | Min. | Typ. | Max. | $\begin{array}{\|c} \hline \text { Unit } \\ \hline \mathrm{V} \\ \hline \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LCD drive voltage (Normal mode) | VL1 | Connects a $1 \mathrm{M} \Omega$ load resistance between VdD and VL1 (No panel load) |  | $\begin{gathered} \hline 1 / 2 \cdot \mathrm{~V}_{\mathrm{L} 2} \\ -0.1 \\ \hline \end{gathered}$ |  | $\begin{gathered} 1 / 2 \cdot \mathrm{VL}^{2} 2 \\ \times 0.95 \end{gathered}$ |  |
|  | VL2 | Connects a $1 \mathrm{M} \Omega$ load resistance between VDD and $V_{L 2}$ (No panel load) | LC="0" | $\begin{gathered} \text { Typ. } \\ \times 1.12 \end{gathered}$ | -2.06 | $\begin{gathered} \text { Typ. } \\ \times 0.88 \end{gathered}$ | V |
|  |  |  | LC="1" |  | -2.11 |  |  |
|  |  |  | LC="2" |  | -2.17 |  |  |
|  |  |  | LC="3" |  | -2.22 |  |  |
|  |  |  | LC="4" |  | -2.27 |  |  |
|  |  |  | LC="5" |  | -2.32 |  |  |
|  |  |  | LC="6" |  | -2.38 |  |  |
|  |  |  | LC="7" |  | -2.43 |  |  |
|  |  |  | LC="8" |  | -2.48 |  |  |
|  |  |  | LC="9" |  | -2.53 |  |  |
|  |  |  | LC="10" |  | -2.59 |  |  |
|  |  |  | LC="11" |  | -2.64 |  |  |
|  |  |  | LC="12" |  | -2.69 |  |  |
|  |  |  | LC="13" |  | -2.74 |  |  |
|  |  |  | LC="14" |  | -2.80 |  |  |
|  |  |  | LC="15" |  | -2.85 |  |  |
|  | VL4 | Connects a $1 \mathrm{M} \Omega$ load resistance betwe VL4 (No panel load) | en VDD and | 3/2.VL2 |  | $\begin{gathered} 3 / 2 \cdot \mathrm{VL} 2 \\ \times 0.95 \\ \hline \end{gathered}$ | V |
|  | VL5 | Connects a $1 \mathrm{M} \Omega$ load resistance betwe VL5 (No panel load) | en VDD and | 2.VL2 |  | $\begin{aligned} & \hline 2 \cdot V_{\mathrm{L} 2} \\ & \times 0.95 \end{aligned}$ | V |
| LCD drive voltage | $\mathrm{V}_{\mathrm{L} 1}$ | Connects a $1 \mathrm{M} \Omega$ load resistance | LC="0" |  | -1.05 |  |  |
| (Heavy load protection mode) |  | between VDD and VL1 (No panel load) | LC="1" |  | -1.08 |  |  |
|  |  |  | LC="2" |  | -1.11 |  |  |
|  |  |  | LC="3" |  | -1.13 |  |  |
|  |  |  | LC="4" |  | -1.16 |  |  |
|  |  |  | LC="5" |  | -1.19 |  |  |
|  |  |  | LC="6" |  | -1.21 |  |  |
|  |  |  | LC="7" | Typ. | -1.24 | Typ. | V |
|  |  |  | LC="8" | $\times 1.12$ | -1.26 | $\times 0.88$ | $v$ |
|  |  |  | LC="9" |  | -1.29 |  |  |
|  |  |  | LC="10" |  | -1.32 |  |  |
|  |  |  | LC="11" |  | -1.34 |  |  |
|  |  |  | LC="12" |  | -1.37 |  |  |
|  |  |  | LC="13" |  | -1.40 |  |  |
|  |  |  | LC="14" |  | -1.42 |  |  |
|  |  |  | LC="15" |  | -1.45 |  |  |
|  | VL2 | Connects a $1 \mathrm{M} \Omega$ load resistance betwe $\mathrm{V}_{\mathrm{L} 2}$ (No panel load) | en VDD and | 2.VL1 |  | $\begin{gathered} \hline 2 \cdot V_{L 1} \\ \times 0.90 \end{gathered}$ | V |
|  | VL4 | Connects a $1 \mathrm{M} \Omega$ load resistance betwe VL4 (No panel load) | en VDD and | 3.VL1 |  | $\begin{array}{r} 3 \cdot V_{\mathrm{L} 1} \\ \times 0.90 \\ \hline \end{array}$ | V |
|  | VL5 | Connects a $1 \mathrm{M} \Omega$ load resistance betwe VL5 (No panel load) | en VDD and | 4.VL1 |  | $\begin{array}{r} 4 . V_{\mathrm{L} 1} \\ \times 0.90 \\ \hline \end{array}$ | V |
| Current consumption *1 | Ihlt | During HALT (VSC="0", OSCC="0") |  |  | 2.5 | 5.0 | $\mu \mathrm{A}$ |
| (OSC1/crystal oscillation) | IEX1 | During operation at $32 \mathrm{kHz}(\mathrm{VSC}=$ " 0 ", | OSCC="0") |  | 6.5 | 9.0 | $\mu \mathrm{A}$ |
|  | IEX2 | During operation at 1 MHz (VSC= ${ }^{\text {c }}$ ") |  |  | 400 | 600 | $\mu \mathrm{A}$ |
|  | IEX3 | During operation at 2 MHz (VSC="2", | Vss=-5.0V) |  | 1,000 | 1,500 | $\mu \mathrm{A}$ |
| Current consumption *1 | Ihlt | During HALT (VSC="0"or"1", OSCC | "0") |  | 20 | 70 | $\mu \mathrm{A}$ |
| (OSC1/CR oscillation) | IEX1 | During operation at foscl ( $\mathrm{VSC}=$ "0"or" | 1 ", OSCC="0") |  | 25 | 80 | $\mu \mathrm{A}$ |
|  | IEX2 | During operation at $1 \mathrm{MHz}(\mathrm{VSC}=11$ ") |  |  | 420 | 600 | $\mu \mathrm{A}$ |
|  | IEX3 | During operation at 2 MHz (VSC="2", | Vss=-5.0V) |  | 1,000 | 1,500 | $\mu \mathrm{A}$ |

[^1]
### 13.5 AC Characteristics

## \#RESET input

Condition: VDD $=0 \mathrm{~V}, \mathrm{VSS}=-3.0 \mathrm{~V}$, fosc $1=32.768 \mathrm{kHz}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{IH}}=0.5 \mathrm{Vss}, \mathrm{V}_{\mathrm{IL}}=0.9 \mathrm{Vss}$

| Item | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \#RESET input time | tsr | 2.0 |  |  | ms |
| \#RESET |  |  |  |  |  |

### 13.6 Oscillation Characteristics

The oscillation characteristics change depending on the conditions (components used, board pattern, etc.). Use the following characteristics as reference values.

## OSC1 crystal oscillation characteristics

Conditions unless otherwise specified:
Vdd $=0 \mathrm{~V}$, Vss $=-3.0 \mathrm{~V}$, Crystal: $\mathrm{C}-002 \mathrm{R}(\mathrm{CI}=35 \mathrm{k} \Omega), \mathrm{CGX}=25 \mathrm{pF}, \mathrm{Cdx}=\mathrm{built}-\mathrm{in}, \mathrm{Rfx}=10 \mathrm{M} \Omega, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{VSC}=" 0 "$

| Item | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Oscillation start time | tsta | Vss=-2.2 to -5.5 V |  |  | 5 | S |
| Built-in drain capacitance | CD | Package as assembled |  | 22 |  | pF |
|  |  | Bare chip |  | 21 |  | pF |
| Frequency/voltage deviation | $\partial \mathrm{f} / \partial \mathrm{V}$ | Vss $=-2.2$ to -5.5 V |  |  | 5 | ppm |
| Frequency/IC deviation | $\partial \mathrm{f} / \partial \mathrm{IC}$ |  | -10 |  | +10 | ppm |
| Frequency adjustable range | $\partial \mathrm{f} / \partial \mathrm{CG}$ | $\mathrm{CG}=5$ to 25 pF | 35 | 45 |  | ppm |
| Harmonic oscillation start voltage | Vhho | $\mathrm{CG}=5 \mathrm{pF}$ (Vss) |  |  | -5.5 | V |
| Permitted leak resistance | Rleak | Between OSC1 and Vdd, Vs1 | 200 |  |  | $\mathrm{M} \Omega$ |

## OSC1 CR oscillation characteristics

Conditions unless otherwise specified:
$V_{D D}=0 \mathrm{~V}, \mathrm{VSS}=-3.0 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{VSC}=" 0$ " or " 1 "

| Item | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| Oscillation frequency | fosc1 | RCR1 $=1.6 \mathrm{M} \Omega$ | Typ. <br> $\times 70 \%$ | 32 | Typ. <br> $\times 130 \%$ | kHz |
| Oscillation start time | tsta | Vss=-2.2 to -5.5 V |  |  | 3 | ms |
| Frequency/voltage deviation | $\partial \mathrm{f} / \partial \mathrm{V}$ | Vss $=-2.2$ to -5.5 V | -5 |  | +5 | $\%$ |

## OSC3 CR oscillation characteristics 1

Conditions unless otherwise specified:
VDD $=0 \mathrm{~V}, \mathrm{VSS}=-3.0 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{VSC}=1{ }^{1 "}$

| Item | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| Oscillation frequency | fosc3 | RCR2 $=40 \mathrm{k} \Omega$ | Typ. <br> $\times 70 \%$ | 860 | Typ. <br> $\times 130 \%$ | kHz <br> Oscillation start time |
| tsta | Vss $=-2.2$ to -5.5 V |  |  | 3 | ms |  |
| Frequency/voltage deviation | $\partial \mathrm{f} / \partial \mathrm{V}$ | Vss $=-2.2$ to -5.5 V | -5 |  | +5 | $\%$ |

## OSC3 CR oscillation characteristics 2

Conditions unless otherwise specified:
VDD $=0 \mathrm{~V}, \mathrm{VSS}=-5.0 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{VSC}=" 2 "$

| Item | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| Oscillation frequency | fosc3 | RCR2 $=20 \mathrm{k} \Omega$ | Typ. <br> $\times 70 \%$ | 1.7 | Typ. <br> $\times 130 \%$ | MHz |
| Oscillation start time | tsta | Vss=-3.5 to -5.5 V |  |  | 3 | ms |
| Frequency/voltage deviation | $\partial \mathrm{f} / \partial \mathrm{V}$ | Vss $=-3.5$ to -5.5 V | -5 |  | +5 | $\%$ |

## OSC3 ceramic oscillation characteristics 1

Conditions unless otherwise specified:
VDD $=0 \mathrm{~V}, \mathrm{VsS}=-3.0 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{VSC}=" 1$ ", Ceramic oscillator: CSB 1000 J *1 ( 1 MHz ), $\mathrm{CGC}=\mathrm{CdC}=100 \mathrm{pF}, \mathrm{Rfc}=1 \mathrm{M} \Omega$

| Item | Symbol | Condition | Min. | Typ. | Max. |
| :--- | :--- | :--- | :---: | :---: | :---: | Unit 

*1 Made by Murata Mfg. Co.

## OSC3 ceramic oscillation characteristics 2

Conditions unless otherwise specified:
$V_{D D}=0 \mathrm{~V}, \mathrm{VSS}=-5.0 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{VSC}=$ " 2 ", Ceramic oscillator: $\mathrm{CSA} 2.00 \mathrm{MG}{ }^{* 1}$ ( 2 MHz ), $\mathrm{CGC}=\mathrm{CDC}=100 \mathrm{pF}, \mathrm{Rfc}=1 \mathrm{M} \Omega$

| Item | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| Oscillation start time | tsta | Vss $=-3.5$ to -5.5 V |  |  | 3 | ms |
| Frequency/voltage deviation | 子f $/ \partial \mathrm{V}$ | Vss $=-3.5$ to -5.5 V | -3 |  | +3 | $\%$ |

*1 Made by Murata Mfg. Co.

OSC3 CR oscillation frequency - resistance characteristic


## Chapter 14 PaCKAGE

### 14.1 Plastic Package

## QFP15-100pin

(Unit: mm)


E0C6007 Technical Hardware

### 14.2 Ceramic Package for Test Samples

## QFP15-100pin

(Unit: mm)


## CHAPTER 15 Pad LAyout

15.1 Diagram of Pad Layout


### 15.2 Pad Coordinates

(unit: $\mu \mathrm{m}$ )

| Pad |  | Coordinate |  | Pad |  | Coordinate |  | Pad |  | Coordinate |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| No. | Name | X | Y | No. | Name | X | Y | No. | Name | X | Y |
| 1 | SEG39 | 1,402 | 1,768 | 32 | SEG8 | -1,768 | 427 | 63 | VDD | 741 | -1,768 |
| 2 | SEG38 | 1,272 | 1,768 | 33 | SEG7 | -1,768 | 297 | 64 | Vref | 871 | -1,768 |
| 3 | SEG37 | 1,142 | 1,768 | 34 | SEG6 | -1,768 | 167 | 65 | VL1 | 1,034 | -1,768 |
| 4 | SEG36 | 1,012 | 1,768 | 35 | SEG5 | -1,768 | 37 | 66 | VL2 | 1,164 | -1,768 |
| 5 | SEG35 | 882 | 1,768 | 36 | SEG4 | -1,768 | -93 | 67 | VL3 | 1,294 | -1,768 |
| 6 | SEG34 | 752 | 1,768 | 37 | SEG3 | -1,768 | -223 | 68 | VL4 | 1,768 | -1,476 |
| 7 | SEG33 | 622 | 1,768 | 38 | SEG2 | -1,768 | -353 | 69 | VL5 | 1,768 | -1,346 |
| 8 | SEG32 | 492 | 1,768 | 39 | SEG1 | -1,768 | -483 | 70 | CF | 1,768 | -1,216 |
| 9 | SEG31 | 362 | 1,768 | 40 | SEG0 | -1,768 | -613 | 71 | CE | 1,768 | -1,086 |
| 10 | SEG30 | 232 | 1,768 | 41 | K03 | -1,768 | -773 | 72 | CD | 1,768 | -956 |
| 11 | SEG29 | 102 | 1,768 | 42 | K02 | -1,768 | -903 | 73 | CC | 1,768 | -826 |
| 12 | SEG28 | -28 | 1,768 | 43 | K01 | -1,768 | -1,033 | 74 | CB | 1,768 | -696 |
| 13 | SEG27 | -158 | 1,768 | 44 | K00 | -1,768 | -1,163 | 75 | CA | 1,768 | -566 |
| 14 | SEG26 | -288 | 1,768 | 45 | P03 | -1,768 | -1,307 | 76 | COM0 | 1,768 | -436 |
| 15 | SEG25 | -418 | 1,768 | 46 | P02 | -1,768 | -1,437 | 77 | COM1 | 1,768 | -306 |
| 16 | SEG24 | -548 | 1,768 | 47 | P01 | -1,768 | -1,568 | 78 | COM2 | 1,768 | -176 |
| 17 | SEG23 | -678 | 1,768 | 48 | P00 | -1,768 | -1,698 | 79 | COM3 | 1,768 | -46 |
| 18 | SEG22 | -808 | 1,768 | 49 | R43 | -1,283 | -1,768 | 80 | COM4 | 1,768 | 84 |
| 19 | SEG21 | -938 | 1,768 | 50 | R42 | -1,153 | -1,768 | 81 | COM5 | 1,768 | 214 |
| 20 | SEG20 | -1,068 | 1,768 | 51 | R41 | -927 | -1,768 | 82 | COM6 | 1,768 | 344 |
| 21 | SEG19 | -1,198 | 1,768 | 52 | R40 | -797 | -1,768 | 83 | COM7 | 1,768 | 474 |
| 22 | SEG18 | -1,328 | 1,768 | 53 | R33 | -658 | -1,768 | 84 | COM8 | 1,768 | 604 |
| 23 | SEG17 | -1,458 | 1,768 | 54 | R32 | -528 | -1,768 | 85 | COM9 | 1,768 | 734 |
| 24 | SEG16 | -1,588 | 1,768 | 55 | \#RESET | -383 | -1,768 | 86 | COM10 | 1,768 | 864 |
| 25 | SEG15 | -1,768 | 1,337 | 56 | \#TEST | -253 | -1,768 | 87 | COM11 | 1,768 | 994 |
| 26 | SEG14 | -1,768 | 1,207 | 57 | Vss | -39 | -1,768 | 88 | COM12 | 1,768 | 1,124 |
| 27 | SEG13 | -1,768 | 1,077 | 58 | OSC4 | 91 | -1,768 | 89 | COM13 | 1,768 | 1,254 |
| 28 | SEG12 | -1,768 | 947 | 59 | OSC3 | 221 | -1,768 | 90 | COM14 | 1,768 | 1,384 |
| 29 | SEG11 | -1,768 | 817 | 60 | Vs1 | 351 | -1,768 | 91 | COM15 | 1,768 | 1,545 |
| 30 | SEG10 | -1,768 | 687 | 61 | OSC2 | 481 | -1,768 | - | - | - | - |
| 31 | SEG9 | -1,768 | 557 | 62 | OSC1 | 611 | -1,768 | - | - | - | - |

## EPSON International Sales Operations

## AMERICA <br> S-MOS SYSTEMS, INC. <br> 150 River Oaks Parkway <br> San Jose, CA 95134, U.S.A. <br> Phone: $+1-408-922-0200 \quad$ Fax: $+1-408-922-0238$ <br> Telex: 176079 SMOS SNJUD <br> S-MOS SYSTEMS, INC. <br> EASTERN AREA SALES AND TECHNOLOGY CENTER <br> 301 Edgewater Place, Suite 120 <br> Wakefield, MA 01880, U.S.A. <br> Phone: +1-617-246-3600 Fax: +1-617-246-5443 <br> S-MOS SYSTEMS, INC. <br> SOUTH EASTERN AREA SALES AND TECHNOLOGY CENTER 4300 Six Forks Road, Suite 430 <br> Raleigh, NC 27609, U.S.A. <br> Phone: +1-919-781-7667 Fax: +1-919-781-6778 <br> S-MOS SYSTEMS, INC. <br> CENTRAL AREA SALES AND TECHNOLOGY CENTER <br> 1450 E.American Lane, Suite 1550 <br> Schaumburg, IL 60173, U.S.A. <br> Phone: +1-847-517-7667 Fax: +1-847-517-7601

## EUROPE

## - HEADQUARTERS -

## EPSON EUROPE ELECTRONICS GmbH

Riesstrasse 15
80992 Muenchen, GERMANY
Phone: +49-(0)89-14005-0 Fax: +49-(0)89-14005-110

- GERMANY -

EPSON EUROPE ELECTRONICS GmbH

## SALES OFFICE

Breidenbachstrasse 46
D-51373 Leverkusen, GERMANY
Phone: +49-(0)214-83070-0 Fax: +49-(0)214-83070-10

- UNITED KINGDOM -

EPSON EUROPE ELECTRONICS GmbH
UK BRANCH OFFICE
G6 Doncastle House, Doncastle Road
Bracknell, Berkshire RG12 8PE, ENGLAND
Phone: +44-(0)1344-381700 Fax: +44-(0)1344-381701

- FRANCE -

EPSON EUROPE ELECTRONICS GmbH FRENCH BRANCH OFFICE
1 Avenue de I' Atlantique, LP 915 Les Conquerants
Z.A. de Courtaboeuf 2, F-91976 Les Ulis Cedex, FRANCE

Phone: +33-(0)1-64862350 Fax: +33-(0)1-64862355

## ASIA <br> - HONG KONG, CHINA -

EPSON HONG KONG LTD.
20/F., Harbour Centre, 25 Harbour Road
Wanchai, HONG KONG
Phone: +852-2585-4600 Fax: +852-2827-4346
Telex: 65542 EPSCO HX

- CHINA -

SHANGHAI EPSON ELECTRONICS CO., LTD.
4F, Bldg., 27, No. 69, Gui Jing Road
Caohejing, Shanghai, CHINA
Phone: 21-6485-5552 Fax: 21-6485-0775

- TAIWAN, R.O.C. -

EPSON TAIWAN TECHNOLOGY \& TRADING LTD.
10F, No. 287, Nanking East Road, Sec. 3
Taipei, TAIWAN, R.O.C.
Phone: 02-2717-7360 Fax: 02-2712-9164
Telex: 24444 EPSONTB
EPSON TAIWAN TECHNOLOGY \& TRADING LTD. HSINCHU OFFICE
13F-3, No. 295, Kuang-Fu Road, Sec. 2
HsinChu 300, TAIWAN, R.O.C.
Phone: 03-573-9900 Fax: 03-573-9169

- SINGAPORE -

EPSON SINGAPORE PTE., LTD.
No. 1 Temasek Avenue, \#36-00
Millenia Tower, SINGAPORE 039192
Phone: +65-337-7911 Fax: $+65-334-2716$

- KOREA -

SEIKO EPSON CORPORATION
KOREA OFFICE
10F, KLI 63 Bldg., 60 Yoido-Dong
Youngdeungpo-Ku, Seoul, 150-010, KOREA
Phone: 02-784-6027 Fax: 02-767-3677

- JAPAN -

SEIKO EPSON CORPORATION
ELECTRONIC DEVICES MARKETING DIVISION
Electronic Device Marketing Department
IC Marketing \& Engineering Group
421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN
Phone: +81-(0)42-587-5816 Fax: +81-(0)42-587-5624
ED International Marketing Department I

## (Europe \& U.S.A.)

421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN
Phone: +81-(0)42-587-5812 Fax: +81-(0)42-587-5564
ED International Marketing Department II (Asia)
421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN
Phone: +81-(0)42-587-5814 Fax: +81-(0)42-587-5110


In pursuit of "Saving" Technology, Epson electronic devices. Our lineup of semiconductors, liquid crystal displays and quartz devices assists in creating the products of our customers' dreams.

Epson IS energy savings.

## EPSON

## SEIKO EPSON CORPORATION

ELECTRONIC DEVICES MARKETING DIVISION
Electronic devices information on the Epson WWW server


[^0]:    *1 Initial value following initial reset
    *3 Reset (0) immediately after being read
    *5 Undefined

[^1]:    *1 No panel loard.

