

Patent Number : 61007 (R.O.C)
Patent Pending : 83216083 (R.O.C)

#### GENERAL DESCRIPTION

EM73862 is an advanced single chip CMOS 4-bit micro-controller. It contains 8K-byte ROM, 372-nibble RAM, 4-bit ALU, 13-level subroutine nesting, 22-stage time base, two 12-bit timer/counters for the kernel function. EM73862 also contains 5 interrupt sources, 3 I/O ports (including 1 input port and 2 bidirection ports), LCD display (40x8), built-in sound generator.

Except low-power consumption and high speed, EM73862 also have a sleep mode for power saving function. EM73862 is suitable for appliaction in many fields, for example : family appliance, consumer products, hand held games and the toy controller ... etc.

#### **FEATURES**

• Operation voltage : 2.4V to 3.3V.

• Clock source : Single clock system for both RC and Crystal is available by mask option.

• Oscillation frequency: 1M, 2M and 4M Hz is available by mask option.

• Instruction set : 107 powerful instructions for EM73862.

• Instruction cycle time: Up to 2us for 4 MHz.

• ROM capacity : 8192 X 8 bits for EM73862.

• RAM capacity : 372 X 4 bits.

• Input port : 1 port (P0.0-P0.3) and sleep/hold releasing function are available by mask option.

(each input pin is pull-up and pull-down resistor available by mask option).

• Bidirection port : 2 ports (P4, P8). P4 is the high current source (typ. 5mA). P4.0 and SOUND is

available by mask option. P8(0..3) and sleep/hold releasing function are available by mask option. (each I/O pin is puah-pull and open-drain available by mask option).

• 12-bit timer/counter : Two 12-bit timer/counters are programmable for timer, event counter and pulse width

measurement.

Built-in time base counter: 22 stages.
Subroutine nesting: Up to 13 levels.

• Interrupt : External . . . . 2 input interrupt sources.

Internal . . . . . 2 Timer overflow interrupts.

1 Time base interrupt.

• LCD driver : 40 X 8 dots, 1/8 duty, LCD bias is 1/4 and 1/5 available by mask option.

• Sound effect : Tone generator and random generator.

• Power saving function : Sleep mode and Hold mode.

• Package type: EM73862H Chip form 65 pins.

## **FUNCTION BLOCK DIAGRAM**



## PIN DESCRIPTIONS

| Symbol             | Pin-type    |                       | Function                                             |
|--------------------|-------------|-----------------------|------------------------------------------------------|
| $V_{DD}$           |             | Power supply (+)      |                                                      |
| V <sub>SS</sub>    |             | Power supply (-)      |                                                      |
| RESET              | RESET-A     | System reset input si | ignal, low active                                    |
|                    |             | mask option :         | none                                                 |
|                    |             |                       | pull-up                                              |
| XIN/CLK            | OSC-A/OSC-C | Crystal/RC or extern  | nal clock source connecting pin                      |
| XOUT/NC            | OSC-A/OSC-C | Crystal/RC connecti   | ng pin                                               |
| P0.(03)/WAKEUP03   | INPUT-B     | 4-bit input port with | Sleep/Hold function                                  |
|                    |             | mask option :         | wakeup enable, pull-up                               |
|                    |             |                       | wakeup enable, none                                  |
|                    |             |                       | wakeup disable, pull-up                              |
|                    |             |                       | wakeup disable, pull-down                            |
|                    |             |                       | wakeup disable, none                                 |
| P4.0/SOUND         | I/O-I       | 1-bit bidirection I/O | port or inverse sound effect output                  |
|                    |             | mask option :         | SOUND enable, push-pull                              |
|                    |             |                       | SOUND disable, open-drain                            |
|                    |             |                       | SOUND disable, push-pull                             |
| P8.0(INT1)/WAKEUPA | I/O-L       |                       | port with external interrupt sources input and Sleep |
| P8.2(INT0)/WAKEUPC |             | /Hold releasing func  |                                                      |
|                    |             | mask option :         | wakeup enable, push-pull                             |
|                    |             |                       | wakeup disable, push-pull                            |
|                    |             |                       | wakeup disable, open-drain                           |
| P8.1(TRGB)/WAKEUPB |             |                       | port with time/counter A,B external input and Sleep  |
| P8.3(TRGA)/WAKEUPD |             | /Hold releasing func  |                                                      |
|                    |             | mask option :         | wakeup enable, push-pull                             |
|                    |             |                       | wakeup disable, push-pull                            |
|                    |             |                       | wakeup disable, open-drain                           |

<sup>\*</sup> This specification are subject to be changed without notice.



| Symbol     | Pin-type | Function                                      |
|------------|----------|-----------------------------------------------|
| SOUND      |          | Built-in sound effect output                  |
| VRLC       |          | LCD regulator voltage input                   |
| COM0~COM7  |          | LCD common output pins                        |
| SEG0~SEG39 |          | LCD segment output pins                       |
| TEST       |          | Test pin must be connected to V <sub>ss</sub> |

#### **FUNCTION DESCRIPTIONS**

## PROGRAM ROM (8K X 8 bits)

8 K x 8 bits program ROM contains user's program and some fixed data.

The basic structure of program ROM can be divided into 4 parts.

- 1. Address 0000h: Reset start address.
- 2. Address 0002h 000Ch : 5 kinds of interrupt service routine entry addresses .
- 3. Address 000Eh-0086h : SCALL subroutine entry address, only available at 000Eh,0016h,001Eh,0026h, 002Eh, 0036h, 003Eh, 0046h, 004Eh, 0056h, 005Eh, 0066h, 006Eh, 0076h, 007Eh, 0086h .
- 4. Address 0000h 07FFh: LCALL subroutine entry address.
- 5. Address 0000h 1FFFh: Except used as above function, the other region can be used as user's program region.

| address | 8192 x 8 bits                                                 |    |                 |
|---------|---------------------------------------------------------------|----|-----------------|
| 0000h   | Reset start address                                           | _\ | <b>\</b>        |
| 0002h   | INTO; External interrupt service routine entry address        |    |                 |
| 0004h   |                                                               | _  |                 |
| 0006h   | TRGA; Timer/counterA interrupt service routine entry address  |    |                 |
| 0008h   | TRGB; Timer/counter B interrupt service routine entry address |    | Subroutine call |
| 000Ah   | TBI; Time base interrupt service routine entry address        |    | \entry address  |
| 000Ch   | INT1; External interrupt service routine entry address        |    | designated by   |
| 000Eh   | CCALL submouting call anter; address                          |    | [LCALL a] in-   |
| 0086h   | SCALL, subroutine call entry address                          |    | struction       |
|         |                                                               |    |                 |
| •       |                                                               |    |                 |
| 07FFh   |                                                               |    | )               |
| 0800h   |                                                               | [  |                 |
|         |                                                               |    |                 |
| 0FFFh   |                                                               |    | Data table for  |
| 1000h   |                                                               |    | Data table for  |
|         |                                                               |    | [LDAX],[LDAXI]  |
| 1FFFh   |                                                               |    | instruction     |

User's program and fixed data are stored in the program ROM. User's program is according the PC value to send next executed instruction code .

The program counter is a 13-bit binary counter. The PC is initialized to "0" during reset.

Fixed data can be read out by table-look-up instruction. Table-look-up instruction is depended on the Data Pointer (DP) to ROM address, then to get the ROM code data :

 $\label{eq:loss_loss} \begin{array}{ll} LDAX & Acc \leftarrow ROM[DP]_L \\ LDAXI & Acc \leftarrow ROM[DP]_H, DP+1 \end{array}$ 

DP is a 12-bit data register which can store the program ROM address to be the pointer for the ROM code data. First, user load ROM address into DP by instruction "LDADPL, LDADPM, LDADPH", then user can get the



lower nibble of ROM code data by instruction "LDAX" and higher nibble by instruction "LDAXI" PROGRAM EXAMPLE: Read out the ROM code of address 1777h by table-look-up instruction.

```
LDIA #07h;
              ; [DP]_L \leftarrow 07h
STADPL
              ; [DP]_{M}^{2} \leftarrow 07h
STADPM
              ; [DP]_{H}^{-} \leftarrow 07h, Load DP=777h
STADPH
LDL #00h;
LDH #03h;
LDAX
              ; ACC \leftarrow 6h
STAMI
              ; RAM[30] \leftarrow 6h
LDAXI
              ; ACC \leftarrow 5h
STAM
              ; RAM[31] \leftarrow 5h
ORG 1777h
DATA 56h;
```

#### DATA RAM (372-nibble)

There is total 372 - nibble data RAM from address 000 to 17Fh Data RAM includes 3 parts: zero page region, stacks and data area.





#### ZERO- PAGE:

From 000h to 00Fh is the location of zero-page. It is used as the pointer in zero-page addressing mode for the instruction of "STD #k,y; ADD #k,y; CLR y,b; CMP y,b".

PROGRAM EXAMPLE: To wirte immediate data "07h" to address "003h" of RAM and to clear bit 2 of RAM.

STD #07h, 03h; RAM[03]  $\leftarrow$  07h CLR 0Eh,2; RAM[0Eh],  $\leftarrow$  0

#### STACK:

There are 13 - level (maximum) stack for user using for subroutine (including interrupt and CALL). User can assign any level be the starting stack by giving the level number to stack pointer (SP).

When user using any instruction of CALL or subroutine, before entry the subroutine, the previous PC address will be saved into stack until return from those subroutines, the PC value will be restored by the data saved in stack.

#### DATA AREA:

Except the special area used by user, the whole RAM can be used as data area for storing and loading general data.

#### ADDRESSING MODE

The 372 nibble data memory consists of two banks (bank 0 and bank 1). There are 244x4 bits (address 000h~0F3h) on bank 0 and 128x4 bits (address 100h~17Fh) on bank 1.

There are three addressing modes in the data memory:

## (1) Indirect addressing mode:

The bank is selected by P9.3. When P9.3 is cleared to "0", the bank 0 is selected.

When P9.3 is set to "1", the bank 1 is selected. The address in the bank are specified by the HL registers.



PROGRAM EXAMPLE: Load the data of RAM address "143h" to RAM address "023h".

SEP P9,3 ; P9.3 $\leftarrow$  1 LDL #3h ; LR $\leftarrow$  3 LDH #4h ; HR $\leftarrow$  4

LDAM ;  $Acc \leftarrow RAM[134h]$ 

CLP P9,3 ; P9.3 $\leftarrow$  0 LDL #2h ; LR $\leftarrow$  2 LDH #3h ; HR $\leftarrow$  3

STAM ;  $RAM[023h] \leftarrow Acc$ 

#### (2) Direct addressing mode:

The bank is selected by P9.3. When P9.3 is cleared to "0", the bank 0 is selected.

When P9.3 is set to "1", the bank 1 is selected. The address in the bank are directly specified by 8 bits of the second byte in the instruction field.





PROGRAM EXAMPLE: Load the data of RAM address "143h" to RAM address "023h".

SEP P9,3 ; P9.3←1

LDA 43h;  $Acc \leftarrow RAM[134h]$ 

CLP P9,3 ; P9.3 $\leftarrow$  0

STA 23h ;  $RAM[023h] \leftarrow Acc$ 

(3) Zero-page addressing mode:

The zero-page is the bank 0 (address 000h~00Fh). The address are the lower 4 bits of the second byte in the instruction field.



PROGRAM EXAMPLE: Write immediate "0Fh" to RAM address "005h".

STD #0Fh, 05h; RAM[05h]  $\leftarrow$  0Fh

### PROGRAM COUNTER (8K ROM)

Program counter (PC) is composed by a 13-bit counter, which indicates the next executed address for the instruction of program ROM.

For a 8K - byte size ROM, PC can indicate address form 0000h - 1FFFh, for BRANCH and CALL instrcutions, PC is changed by instruction indicating.

#### (1) Branch instruction:

#### SBR a

Object code: 00aa aaaa

Condition: SF=1; PC  $\leftarrow$  PC  $_{12-6.a}$  (branch condition satisified)

SF=0; PC $\leftarrow$  PC +1( branch condition not satisified)

| PC | Ori | gina | ıl PC | c val | ue + | - 1 | ı | 1 | ı | ı |
|----|-----|------|-------|-------|------|-----|---|---|---|---|

#### LBR a

Object code: 1100 aaaa aaaa aaaa

Condition: SF=1; PC  $\leftarrow$  PC  $_{12.a}$  ( branch condition satisified )

SF=0; PC← PC +2( branch condition not satisified)

| PC | · | Ori | gina | 1 PC | val | ue + | 2 | I | l | 1 | l |
|----|---|-----|------|------|-----|------|---|---|---|---|---|



## SLBR a

Object code: 0101 0101 1100 aaaa aaaa aaaa (a:1000h~1FFFh)

0101 0111 1100 aaaa aaaa aaaa (a:0000h~0FFFh)

Condition: SF=1; PC  $\leftarrow$  a (branch condition satisfied)



SF=0; PC  $\leftarrow$  PC + 3 (branch condition not satisified)



#### (2) Subroutine instruction:

#### SCALL a

Object code: 1110 nnnn

Condition:  $PC \leftarrow a$ ; a=8n+6; n=1..Fh; a=86h, n=0

#### LCALL a

Object code: 0100 0aaa aaaa aaaa

Condition:  $PC \leftarrow a$ 

### RET

Object code: 0100 1111

Condition:  $PC \leftarrow STACK[SP]$ ; SP + 1

| PC | <sup>'</sup> Th | e retur | n addı | ess | store | d in | sta | ck |   |   |  |
|----|-----------------|---------|--------|-----|-------|------|-----|----|---|---|--|
|    |                 |         |        | 1   |       | l    | 1   | 1  | ĺ | l |  |

#### RT I

Object code: 0100 1101

Condition : FLAG. PC  $\leftarrow$  STACK[SP]; EI  $\leftarrow$  1; SP + 1

PC The return address stored in stack

## (3) Interrupt acceptance operation:

When an interrupt is accepted, the original PC is pushed into stack and interrupt vector will be loaded into PC,The interrupt vectors are as following:

**INTO** (External interrupt from P8.2)

**TRGA** (Timer A overflow interrupt)

**TRGB** (Time B overflow interrupt)



**TBI** (Time base interrupt)

**INT1** (External interrupt from P8.0)

### (4) Reset operation:

## (5) Other operations:

For 1-byte instruction execution: PC + 1

For 2-byte instruction execution: PC + 2

For 3-byte instruction execution: PC + 3

#### **ACCUMULATOR**

Accumulator is a 4-bit data register for temporary data . For the arithematic, logic and comparative opertion ..., ACC plays a role which holds the source data and result .

#### **FLAGS**

There are three kinds of flag, CF ( Carry flag ), ZF ( Zero flag ), SF ( Status flag ), these 3 1-bit flags are affected by the arithmeatic, logic and comparative .... operation .

All flags will be put into stack when an interrupt subroutine is served, and the flags will be restored after RTI instruction executed.

#### (1) Carry Flag (CF)

The carry flag is affected by following operation:

- a. Addition: CF as a carry out indicator, when the addition operation has a carry-out, CF will be "1", in another word, if the operation has no carry-out, CF will be "0".
- b. Subtraction: CF as a borrow-in indicator, when the subtraction operation must has a borrow, in the CF will be "0", in another word, if no borrow-in, CF will be "1".
- c. Comparision: CF is as a borrow-in indicator for Comparision operation as the same as subtraction operation.
- d. Rotation: CF shifts into the empty bit of accumulator for the rotation and holds the shift out data after rotation.
- e. CF test instruction: For TFCFC instruction, the content of CF sends into SF then clear itself "0". For TTSFC instruction, the content of CF sends into SF then set itself "1".



## (2) Zero Flag (ZF)

ZF is affected by the result of ALU, if the ALU operation generate a "0" result, the ZF will be "1", otherwise, the ZF will be "0".

#### (3) Status Flag (SF)

The SF is affected by instruction operation and system status.

- a. SF is initiated to "1" for reset condition.
- b. Branch instruction is decided by SF, when SF=1, branch condition will be satisified, otherwise, branch condition will not be satisified by SF = 0.

#### PROGRAM EXAMPLE:

Check following arithematic operation for CF, ZF, SF

|            | CF | ZF | SF |
|------------|----|----|----|
| LDIA #00h; | -  | 1  | 1  |
| LDIA #03h; | -  | 0  | 1  |
| ADDA #05h; | -  | 0  | 1  |
| ADDA #0Dh; | -  | 0  | 0  |
| ADDA #0Eh; | -  | 0  | 0  |

#### **ALU**

The arithematic operation of 4 - bit data is performed in ALU unit. There are 2 flags can be affected by the result of ALU operation, ZF and SF. The operation of ALU can be affected by CF only.

#### **ALU STRUCTURE**

ALU supported user arithematic operation function, including: addition, subtraction and rotaion.



#### **ALU FUNCTION**

#### (1) Addition:

For instruction ADDAM, ADCAM, ADDM #k, ADD #k,y .... ALU supports addition function. The addition operation can affect CF and ZF. For addition operation, if the result is "0", ZF will be "1", otherwise, not equal "0", ZF will be "0", When the addition operation has a carry-out. CF will be "1", otherwise, CF will be "0".



#### **EXAMPLE:**

| Operation | Carry | Zero |
|-----------|-------|------|
| 3+4=7     | 0     | 0    |
| 7+F=6     | 1     | 0    |
| 0+0=0     | 0     | 1    |
| 8+8=0     | 1     | 1    |

### (2) Subtraction:

For instruction SUBM #k, SUBA #k, SBCAM, DECM... ALU supports user subtraction function. The subtraction operation can affect CF and ZF, For subtraction operation, if the result is negative, CF will be "0", it means a borrow out, otherwise, if the result is positive, CF will be "1". For ZF, if the result of subtraction operation is "0", the ZF will be "1", otherwise, ZF will be "1".

#### **EXAMPLE:**

| Operation      | Carry | Zero |
|----------------|-------|------|
| 8-4=4          | 1     | 0    |
| 7-F = -8(1000) | 0     | 0    |
| 9-9=0          | 1     | 1    |

#### (3) Rotation:

There are two kinds of rotation operation, one is rotation left, the other is rotation right. RLCA instruction rotates Acc value to left, shift the CF value into the LSB bit of Acc and the shift out data will be hold in CF.



RRCA instruction operation rotates Acc value to right, shift the CF value into the MSB bit of Acc and the shift out data will be hold in CF.



PROGRAM EXAMPLE: To rotate Acc right and shift a "1" into the MSB bit of Acc.

TTCFS;  $CF \leftarrow 1$ 

RRCA; rotate Acc right and shift CF=1 into MSB.

#### **HL REGISTER**

HL register are two 4-bit registers, they are used as a pair of pointer for the address of RAM memory and also 2 independent temporary 4-bit data registers. For some instruction, L register can be a pointer to indicate the pin number ( Port4 ).



#### HL REGISTER STRUCTURE



#### **HL REGISTER FUNCTION**

(1) For instruction: LDL #k, LDH #k, THA, THL, INCL, DECL, EXAL, EXAH, HL register used as a temporary register.

PROGRAM EXAMPLE: Load immediate data "5h" into L register, "Dh" into H register. LDL #05h; LDH #0Dh;

(2) For instruction LDAM, STAM, STAMI .., HL register used as a pointer for the address of RAM memory.

PROGRAM EXAMPLE: Store immediate data #Ah into RAM of address 35h. LDL #5h; LDH #3h; STDMI #0Ah; RAM[35] ← Ah

(3) For instruction: SELP, CLPL, TFPL, L regieter be a pointer to indicate the bit of I/O port.

When LR = 0 indicate P4.0

PROGRAM EXAMPLE: To set bit 0 of Port4 to "1" LDL #00h; SEPL ;  $P4.0 \leftarrow 1$ 

#### **STACK POINTER (SP)**

Stack pointer is a 4-bit register which stores the present stack level number.

Before using stack, user must set the SP value first, CPU will not initiate the SP value after reset condition . When a new subroutine is accepted, the SP will be decreased one automatically, in another word, if returning from a subroutine, the SP will be increased one .

The data transfer between ACC and SP is by instruction of "LDASP" and "STASP".

### **DATA POINTER (DP)**

Data pointer is a 12-bit register which stores the address of ROM can indicate the ROM code data specified by user (refer to data ROM).

#### **CLOCK AND TIMING GENERATOR**

The clock generator is supported by a single clock system, the clock source comes from crystal (resonator) or RC oscillation is decided by mask option, the working frequency range is 480 K Hz to 4 MHz depending on the working voltage.



#### CLOCK AND TIMING GENERATOR STRUCTURE

The clock generator connects outside components (crystal or resonator by XIN and XOUT pin for crystal osc. type, Resistor and capacitor by CLK pin for RC osc type, these two type is decided by mask option). The clock generator generates a basic system clock "fc".

When CPU sleeping, the clock generator will be stoped until the sleep condition released. The system clock control generates 4 basic phase signals (S1, S2, S3, S4) and system clock.



#### **CLOCK AND TIMING GENERATOR FUNCTION**

The frequency of fc is the oscillation frequency for XIN, XOUT by crystal (resonator) or for CLK by RC osc. When CPU sleeps, the XOUT pin will be in "high" state. When user choose RC osc, XOUT pin is no used. The instruction cycle equal 8 basic clock fc.

1 instructure cycle = 8 / fc

#### TIMING GENERATOR AND TIME BASE

The timing generator produces the system clock from basic clock pulse which can be normal mode or slow mode clock.

1 instruction cycle = 8 basic clock pulses

There are 22 stages time base.



When working in the single clock mode, the timebase clock source is come from fc.

Time base provides basic frequency for following function:

- 1. TBI (time base interrupt).
- 2. Timer/counter, internal clock source.
- 3. Warm-up time for sleep mode releasing.

## TIME BASE INTERRUPT (TBI)

The time base can be used to generate a fixed frequency interrupt . There are 8 kinds of frequencies can be selected by setting "P25"

Single clock mode



| P25 | 3 2 1 0                                               |
|-----|-------------------------------------------------------|
|     | ( initial value 0000 )                                |
|     | 0 0 x x: Interrupt disable                            |
|     | 0 1 0 0: Interrupt frequency XIN / $2^{10}$ Hz        |
|     | 0 1 0 1: Interrupt frequency XIN / $2^{11}$ Hz        |
|     | 0 1 1 0: Interrupt frequency XIN / 2 <sup>12</sup> Hz |
|     | 0 1 1 1: Interrupt frequency XIN / 2 <sup>13</sup> Hz |
|     | 1 1 0 0: Interrupt frequency XIN / 2°Hz               |
|     | 1 1 0 1: Interrupt frequency XIN / 28 Hz              |
|     | 1 1 1 0: Interrupt frequency XIN / 2 <sup>15</sup> Hz |
|     | 1 1 1 1: Interrupt frequency XIN / 2 <sup>17</sup> Hz |
|     | 1 0 x x: Reserved                                     |

#### TIMER / COUNTER (TIMERA, TIMERB)

Timer/counters can support user three special functions:

- 1. Even counter
- 2. Timer.
- 3. Pulse-width measurement.

These three functions can be executed by 2 timer/counter independently.

For timerA, the counter data is saved in timer register TAH, TAM, TAL, which user can set counter initial value and read the counter value by instruction "LDATAH(M,L), STATAH(M,L)" and timer register is TBH, TBM, TBL and W/R instruction "LDATBH (M,L), STATBH (M,L)".

The basic structure of timer/counter is composed by two same structure counter, these two counters can be set initial value and send counter value to timer register, P28 and P29 are the command ports for timerA and timer B, user can choose different operation mode and different internal clock rate by setting these two ports. When timer/counter overflow, it will generate a TRGA(B) interrupt request to interrupt control unit.



#### TIMER/COUNTER CONTROL

P8.1/TRGB, P8.3/TRGA are the external timer inputs for timerB and timerA, they are used in event counter and pulse-width measurement mode.

Timer/counter command port: P28 is the command port for timer/counterA and P29 is for the timer/counterB.





| Port 29 | 3  | 2      | 1     | 0     |   |
|---------|----|--------|-------|-------|---|
|         | TM | ISB    | I     | PSB   |   |
|         | Ir | nitial | state | . 000 | n |

| TIMER/COUNTER MODE SELECTION |                              |  |  |  |
|------------------------------|------------------------------|--|--|--|
| TMSA (B)                     | Function description         |  |  |  |
| 0 0                          | Stop                         |  |  |  |
| 0 1                          | Event counter mode           |  |  |  |
| 1 0                          | Timer mode                   |  |  |  |
| 11                           | Pulse width measurement mode |  |  |  |
|                              |                              |  |  |  |

| INTERNAL PULSE-RATE SELECTION |                        |  |  |  |  |  |  |  |
|-------------------------------|------------------------|--|--|--|--|--|--|--|
| IPSA(B)                       | Function description   |  |  |  |  |  |  |  |
| 0.0                           | XIN/2 <sup>10</sup> Hz |  |  |  |  |  |  |  |
| 0 1                           | XIN/2 <sup>14</sup> Hz |  |  |  |  |  |  |  |
| 1 0                           | XIN/2 <sup>18</sup> Hz |  |  |  |  |  |  |  |
| 11                            | XIN/2 <sup>22</sup> Hz |  |  |  |  |  |  |  |

#### TIMER/COUNTER FUNCTION

Timer/counterA can be programmable for timer, event counter and pulse width measurement. Each timer/counter can execute any one of these functions independly.

#### **EVENT COUNTER MODE**

For event counter mode, timer/counter increases one at any rising edge of P8.1/TRGB for timerB (P8.3/TRGA for timer A). When timerB (timerA) counts overflow, it will give interrupt control an interrupt request TRGB (TRGA).



PROGRAM EXAMPLE: Enable timerA with P28

LDIA #0100B;

OUTA P28; Enable timerA with event counter mode

#### TIMER MODE

For timer mode ,timer/counter increase one at any rising edge of internal pulse . User can choose 4 kinds of internal pulse rate by setting IPSB for timerB (IPSA for timerA).

When timer/counter counts overflow, TRGB (TRGA) will be generated to interrupt control unit.





 $PROGRAM\ EXAMPLE:\ To\ generate\ TRGA\ interrupt\ request\ after\ 60\ ms\ with\ system\ clock\ XIN=4MHz$ 

LDIA #0100B;

EXAE; enable mask 2

EICIL 110111B; interrupt latch  $\leftarrow$ 0, enable EI

LDIA #06H;

STATAL; LDIA #01H; STATAM; LDIA #0FH; STATAH; LDIA #1000B;

OUTA P28; enable timerA with internal pulse rate: XIN/2<sup>10</sup> Hz

NOTE: The preset value of timer/counter register is calculated as following procedure.

Internal pulse rate:  $XIN/2^{10}$ ; XIN = 4MHz

The time of timer counter count one =  $2^{10}$  /XIN = 1024/4000=0.256ms

The number of internal pulse to get timer overflow = 60 ms / 0.256 ms = 234.375 = 0 EAH

The preset value of timer/counter register = 1000H - 0EAH = 0F16H

### PULSE WIDTH MEASUREMENT MODE

For the pulse width measurement mode, the counter only incresed by the rising edge of internal pulse rate as external timer/counter input (P8.1/TRGB, P8.3/TRGA), interrupt request will be generated as soon as timer/counter count overflow.



PROGRAM EXAMPLE: Enable timerA by pulse width measurement mode .

LDIA #1100B;

OUTA P28; Enable timerA with pulse width measurement mode.

#### INTERRUPT FUNCTION

There are 5 interrupt sources, 2 external interrupt sources, 3 internal interrupt sources . Multiple interrupts are admitted according the priority .



| Туре     | Interrupt source                 | Priority | Interrupt<br>Latch | Interrupt<br>Enable condition | Program ROM entry address |
|----------|----------------------------------|----------|--------------------|-------------------------------|---------------------------|
| External | External interrupt(INT0)         | 1        | IL5                | EI=1                          | 002H                      |
| Internal | Reserved                         | 2        | IL4                | EI=1, MASK3=1                 | 004H                      |
| Internal | TimerA overflow interrupt (TRGA) | 3        | IL3                | EI=1, MASK2=1                 | 006H                      |
| Internal | TimerB overflow interrupt (TRGB) | 4        | IL2                | EI=1, MASK1=1                 | 008H                      |
| Internal | Time base interrupt(TBI)         | 5        | IL1                |                               | 00AH                      |
| External | External interrupt(INT1)         | 6        | IL0                | EI=1,MASK0=1                  | 00CH                      |

#### INTERRUPT STRUCTURE



#### Interrupt controller:

ILO-IL5 : Interrupt latch . Hold all interrupt requests from all interrupt sources. ILr can not be

set by program, but can be reset by program or system reset, so IL only can decide

which interrupt source can be accepted.

MASK0-MASK3 : Except INTO, MASK register can promit or inhibit all interrupt sources.

EI : Enable interrupt Flip-Flop can promit or inhibit all interrupt sources, when inter-

rupt happened, EI is cleared to "0" automatically, after RTI instruction happened,

EI will be set to "1" again.

Priority checker: Check interrupt priority when multiple interrupts happened.

## INTERRUPT FUNCTION

The procedure of interrupt operation:

- 1. Push PC and all flags to stack.
- 2. Set interrupt entry address into PC.
- 3. Set SF=1.
- 4. Clear EI to inhibit other interrupts happened.
- 5. Clear the IL for which interrupt source has already be accepted.
- 6. To excute interrupt subroutine from the interrupt entry address.
- 7. CPU accept RTI, restore PC and flags from stack . Set EI to accept other interrupt requests.



PROGRAM EXAMPLE: To enable interrupt of "INTO, TRGA"

LDIA #1100B;

EXAE; set mask register "1100B" EICIL 111111B; enable interrupt F.F.

## POWER SAVING FUNCTION (Sleep / Hold function)

During sleep and hold condition, CPU holds the system's internal status with a low power consumption, for the sleep mode, the system clock will be stoped in the sleep condition and system need a warm up time for the stability of system clock running after wakeup. In the other way, for the hold mode, the system clock

does not stop at all and it does not need a warm-up time any way.

The sleep and hold mode is controlled by Port 16 and released by P0(0..3)/WAKEUP0..3 or P8(0..3)/WAKEUPA..D.



| SWWT | Set wake-up | warm-up time |
|------|-------------|--------------|
| 0 0  | 2 18 /XIN   |              |
| 0.1  | 2 14 /XIN   |              |
| 10   | 2 16 /XIN   |              |
| 1 1  | Hold mode   |              |

| WN | Set wake-up release mode      |
|----|-------------------------------|
| 0  | Wake-up in edge release mode  |
| 1  | Wake-up in level release mode |

| SE | Enable sleep/hold         |
|----|---------------------------|
| 0  | Reserved                  |
| 1  | Enable sleep / hold rnode |

Sleep and hold condition:

- 1. Osc stop ( sleep only ) and CPU internal status held .
- 2. Internal time base clear to "0".
- 3. CPU internal memory ,flags, register, I/O held original states.
- 4. Program counter hold the executed address after sleep release.

#### Release condition:

- 1. Osc start to oscillating.(sleep only).
- 2. Warm-up time passing ( sleep only ).
- 3. According PC to execute the following program.

There is one kind of sleep/hold release mode.

1. Edge release mode:

Release sleep/hold condition by the falling edge of any one of P0(0..3)/WAKEUP0..3 or P8(0..3)/WAKEUPA..D.

Note: There are 8 independent mask options for wakeup function in EM73862. So, the wakeup function of P0(0..3)/WAKEUP0..3 and P8(0..3)/WAKEUPA..D are enabled or disabled independently.

#### LCD DRIVER

It can directly drive the liquid crystal display ( LCD ) and has 40 segments , 8 commons output pins. There are total 40x8 dots can be display. The VRLC pin is the LCD driver power input, there is the voltage of ( Vcc - VRLC ) to LCD .

(1) LCD driver control command register:



| POI(2/3) | . 1 | U | Initial value: 0h |
|----------|-----|---|-------------------|
| LDC      | *   | * |                   |

| LCD DI | LCD DISPLAY CONTROL                |  |  |  |  |  |  |
|--------|------------------------------------|--|--|--|--|--|--|
| LDC    | Function description               |  |  |  |  |  |  |
| 0 0    | LCD display disable                |  |  |  |  |  |  |
| 0 1    | Blanking, change COMMON pin output |  |  |  |  |  |  |
| 1 0    | Reserved                           |  |  |  |  |  |  |
| 1 1    | LCD display enable                 |  |  |  |  |  |  |

<sup>\* :</sup> Don't care .

P27 is the LDC driver control command register. The initial value is 0000.

When LDC (bit2 and bit3 of P27) is set to "00", the LCD display is disabled.

When LDC is set to "01", the LCD is blanking, the COM pins are inactive and the SEG pins continuously output the display data .

The power switch of LCD driver is turned off when the CPU is reseted.

When LDC is set to "11", the LCD display is enabled, the power switch is turned on and it can not be turned off forever except the CPU is reseted again .

The power switch is also turned off during the sleep operation . Users must enable the LCD display again by self when the CPU is waked up .

### (2) LCD display data area:

The LCD display data is stored in the display data area of the data memory (RAM).

The display data area begins with address 20H during reset. The LCD display data area is as below:

| RAM        | 0    | 1      | 2                      | 3            | 4            | 5                                         | 6            | 7                    | 8            | 9                             | A      | В | C | D | E | F                                  |
|------------|------|--------|------------------------|--------------|--------------|-------------------------------------------|--------------|----------------------|--------------|-------------------------------|--------|---|---|---|---|------------------------------------|
| 20H        |      |        |                        | C            | O            | M                                         | 0            |                      |              |                               |        |   |   |   |   |                                    |
| 30H        |      |        |                        | C            | 0            | M                                         | 1            |                      |              |                               |        |   |   |   |   |                                    |
| <b>40H</b> |      |        |                        | C            | 0            | M                                         | 2            |                      |              |                               |        |   |   |   |   |                                    |
| 50H        |      |        |                        | C            | O            | M                                         | 3            |                      |              |                               |        |   |   |   |   |                                    |
| 60H        |      |        |                        | C            | O            | M                                         | 4            |                      |              |                               |        |   |   |   |   |                                    |
| <b>70H</b> |      |        |                        | C            | O            | M                                         | 5            |                      |              |                               |        |   |   |   |   |                                    |
| 80H        |      |        |                        | C            | 0            | M                                         | 6            |                      |              |                               |        |   |   |   |   |                                    |
| 90H        |      |        |                        | C            | 0            | M                                         | 7            |                      |              |                               |        |   |   |   |   |                                    |
|            | GGGG | E EEEE | EEEEE<br>GGGGG<br>8911 | EEEE<br>GGGG | EEEE<br>GGGG | SSS S<br>EEE E<br>GGG G<br>222 2<br>012 3 | EEEE<br>GGGC | EEEE<br>GGGG<br>2233 | EEEI<br>GGGG | E EEEE<br>G GGGC<br>3 3 3 3 3 | }<br>} |   |   |   |   | bbbb<br>i i i i<br>t t t t<br>0123 |

Read automatically the display data from the display data area and send to the LCD driver by the hardware . Therefore, the display patterns can be changed only by overwritting the contents of the display data area with the software .

The data memory which is not used to store the LCD display data and the addresses are not connected to the LCD can be used to store the ordinary user's processing data .

#### PROGRAM EXAMPLE:

LDIA #1100B ; LCD display enable OUTA P27

LDIA #1010B STA 24H



## (3) LCD waveform: (1/5 bias)





#### **SOUND EFFECT**

EM73862/EM73462 has a built-in sound generator. It includes the tone generator and random generator. The tone generator is a binary down counter and the random generator is a 9-bit linear feedback shift register. When the CPU is resetted or sleeping, the sound generator is disabled and the output (P4.0/SOUND) is high.



Sound generator command register

There are 3 kinds of basic frequency for sound generator which can be selected by P30. The output of sound effect is tone and random combination.

Initial value: 0000

| Port30 | 3 2 |     | 1  | 0    |
|--------|-----|-----|----|------|
|        | BFF | REQ | SM | 1ODE |

| BFI | REQ | Basic frequency (f1) select |
|-----|-----|-----------------------------|
| 0   | 0   | 240 KHz                     |
| 0   | 1   | 120 KHz                     |
| 1   | 0   | 60 KHz                      |
|     |     |                             |

| SMODE | Sound generator mode |
|-------|----------------------|
| 0 0   | Disable              |
| 0 1   | Tone output          |
| 1 0   | Random output        |
| 1 1   | Tone+random output   |

Tone frequency register

don't care

The 8-bit tone frequency register is P24 and P23. The tone frequency will be changed when user output the different data to P23. Thus, the data must be output to P24 before P23 when user want to change the 8-bit tone frequency (TF).

| Port24                 |   |   |   |   | Po | rt23  |       |          |                          |
|------------------------|---|---|---|---|----|-------|-------|----------|--------------------------|
| 3                      | 2 | 1 | 0 | _ | 3  | 2     | 1     | 0        | Initial value: 1111 1111 |
| Higher nibble register |   |   |   |   | Lo | wer n | ibble | register |                          |

\*\*  $f1=240K/2^{X}$ , f2=f1/(TF+1)/2,  $TF=1\sim255$ ,  $TF\neq0$ 

\*\* Example : BFREQ=10, TF=00110001B. ⇒ f1=60K Hz, f2=60K Hz/50/2=600 Hz

Random generator

$$f(x)=x^9+x^4+1$$





#### PROGRAM EXAMPLE:

LDIA #1001B; basic frequency: 60 KHz tone output

OUTA P30

LDIA #0011B; 600 Hz tone output

OUTA P24 LDIA #0001B OUTA P23

#### **RESETTING FUNCTION**

When CPU in normal working condition and RESET pin holds in low level for three instruction cycles at least, then CPU begins to initialize the whole internal states, and when RESET pin changes to high level, CPU begins to work in normal condition.

The CPU internal state during reset condition is as following table:

| Hardware condition in RESET (f1) state | Initial value     |
|----------------------------------------|-------------------|
| Program counter                        | 0000h             |
| Status flag                            | 01h               |
| Interrupt enable flip-flop (EI)        | 00h               |
| MASK0 ,1, 2, 3                         | 00h               |
| Interrupt latch ( IL )                 | 00h               |
| P9, 16, 25, 27, 28, 29, 30             | 00h               |
| P4, 8, 23, 24                          | 0Fh               |
| XIN                                    | Start oscillation |

The  $\overline{RESET}$  pin is a hysteresis input pin and it has a pull-up resistor available by mask option. The simplest RESET circuit is connect  $\overline{RESET}$  pin with a capacitor to  $V_{SS}$  and a diode to  $V_{DD}$ .





## **EM73862 I/O PORT DESCRIPTION:**

| Port |   | Input function                                        |   | Output function                  | Note        |
|------|---|-------------------------------------------------------|---|----------------------------------|-------------|
| 0    | Е | Input port, wakeup function                           |   |                                  |             |
| 1    |   |                                                       |   |                                  |             |
| 2    |   |                                                       |   |                                  |             |
| 3    |   |                                                       |   |                                  |             |
| 4    | Е | input port                                            | Е | Output port, P4.0/SOUND          |             |
| 5    |   |                                                       |   |                                  |             |
| 6    |   |                                                       |   |                                  |             |
| 7    |   |                                                       |   |                                  |             |
| 8    | Е | Input port, wakeup function, external interrupt input | Е | Output port                      |             |
| 9    |   |                                                       | I | P9.3 : RAM bank selection        |             |
| 10   |   |                                                       |   |                                  |             |
| 11   |   |                                                       |   |                                  |             |
| 12   |   |                                                       |   |                                  |             |
| 13   |   |                                                       |   |                                  |             |
| 14   |   |                                                       |   |                                  |             |
| 15   |   |                                                       |   |                                  |             |
| 16   |   |                                                       | I | Sleep/Hold mode control register |             |
| 17   |   |                                                       |   |                                  |             |
| 18   |   |                                                       |   |                                  |             |
| 19   |   |                                                       |   |                                  |             |
| 20   |   |                                                       |   |                                  |             |
| 21   |   |                                                       |   |                                  |             |
| 22   |   |                                                       |   |                                  |             |
| 23   |   |                                                       | I | Sound effect frequency register  | low nibble  |
| 24   |   |                                                       | I | Sound effect command register    | high nibble |
| 25   |   |                                                       | I | Timebase control register        |             |
| 26   |   |                                                       |   |                                  |             |
| 27   |   |                                                       | I | LCD control register             |             |
| 28   |   |                                                       | I | Timer/counter A control register |             |
| 29   |   |                                                       | I | Timer/counter B control register |             |
| 30   |   |                                                       | I | Sound effect command register    |             |
| 31   |   |                                                       |   |                                  |             |



## ABSOLUTE MAXIMUM RATINGS

| Items                 | Sym.                 | Ratings                      | Conditions              |
|-----------------------|----------------------|------------------------------|-------------------------|
| Supply Voltage        | $V_{_{ m DD}}$       | -0.5V to 4V                  |                         |
| Input Voltage         | $V_{_{\mathrm{IN}}}$ | $-0.5$ V to $V_{DD} + 0.5$ V |                         |
| Output Voltage        | V <sub>o</sub>       | $-0.5V$ to $V_{DD} + 0.5V$   |                         |
| Power Dissipation     | $P_{\rm D}$          | 300mW                        | $T_{OPR} = 50^{\circ}C$ |
| Operating Temperature | $T_{OPR}$            | 0°C to 50°C                  |                         |
| Storage Temperature   | $T_{STG}$            | -55°C to 125°C               |                         |

## RECOMMANDED OPERATING CONDITIONS

| Items               | Sym.            | Ratings                                                        | Condition              |
|---------------------|-----------------|----------------------------------------------------------------|------------------------|
| Supply Voltage      | $V_{_{ m DD}}$  | 2.4V to 3.3V                                                   |                        |
| Input Voltage       | $V_{_{ m IH}}$  | $0.90 \mathrm{xV}_{\mathrm{DD}}$ to $\mathrm{V}_{\mathrm{DD}}$ |                        |
|                     | V <sub>IL</sub> | $0V \text{ to } 0.10xV_{DD}$                                   |                        |
| Operating Frequency | $F_{c}$         | 1M to 4MHz                                                     | CLK (RC osc)           |
|                     |                 | 1M to 4.19MHz                                                  | XIN,XOUT (crystal osc) |

# $\underline{ \text{DC ELECTRICAL CHARACTERISTICS}} \; (\text{V}_{\text{DD}} = 3 \pm 0.3 \text{V}, \, \text{V}_{\text{SS}} = 0 \text{V}, \, \text{T}_{\text{OPR}} = 25 \, ^{\circ}\text{C})$

| Parameters               | Sym.                 | Min.                              | Typ. | Max.         | Unit      | Conditi5ons                                                        |
|--------------------------|----------------------|-----------------------------------|------|--------------|-----------|--------------------------------------------------------------------|
| Supply current           | $I_{DD}$             | -                                 | 0.7  | 2            | mA        | V <sub>DD</sub> =3.3V,no load,Fc=4MHz                              |
|                          | DD                   |                                   |      |              |           | $(RC \text{ osc} : R=6.2K\Omega, C=20pF)$                          |
|                          |                      | -                                 | 0.1  | 1            | μΑ        | V <sub>DD</sub> =3.3V, sleep mode                                  |
| Hysteresis voltage       | V <sub>HYS+</sub>    | $0.5V_{_{ m DD}}$                 | -    | $0.75V_{DD}$ | V         | RESET, P0, P8                                                      |
|                          | V <sub>HYS-</sub>    | $0.2V_{\scriptscriptstyle  m DD}$ | -    | $0.4V_{DD}$  | V         |                                                                    |
| Input current            | $I_{_{\mathrm{IH}}}$ | -                                 | -    | ±1           | μΑ        | $P0, \overline{RESET}, V_{DD} = 3.3V, V_{IH} = 3.3/0V$             |
|                          |                      | -                                 | -    | ±1           | μΑ        | Open-drain, $V_{DD}=3.3V$ , $V_{IH}=3.3/0V$                        |
|                          | $I_{_{\rm IL}}$      | -                                 | -    | -500         | μΑ        | Push-pull, V <sub>DD</sub> =3.3V, V <sub>IL</sub> =0.4V, except P4 |
| Output voltage           | $V_{OH}$             | 2.4                               | -    | -            | V         | Push-pull, V <sub>DD</sub> =2.7V,P4, SOUND,I <sub>OH</sub> =-0.9mA |
|                          |                      | 2.0                               | -    | -            | V         | Push-pull, $V_{DD}$ =2.7V,others, $I_{OH}$ =-40 $\mu$ A            |
|                          | $V_{OL}$             | -                                 | -    | 0.3          | V         | $V_{DD}$ =2.7V, $I_{OL}$ =0.9mA,P4,SOUND                           |
| Leakage current          | $I_{LO}$             | -                                 | -    | 1            | μΑ        | Open-drain, $V_{DD}=3.3V$ , $V_{O}=3.3V$                           |
| Input resistor           | $R_{IH}$             | 100                               | 200  | 300          | ΚΩ        | P0                                                                 |
|                          |                      | 300                               | 600  | 900          | $K\Omega$ | RESET                                                              |
| V <sub>RLC</sub> current | $I_{RLC}$            | 60                                | 75   | 90           | μΑ        | $V_{DD}$ - $V_{RLC}$ =3V, 1/4 bias, bias resistor=10K $\Omega$     |
|                          |                      | 48                                | 60   | 72           | μΑ        | $V_{DD}$ - $V_{RLC}$ =3V, 1/5 bias, bias resistor=10K $\Omega$     |
| Frequency stability      |                      | -                                 | 15   | -            | %         | Fc=4MHz,RC osc,[F(3V)-F(2.4V)]/F(3V)                               |
| Frequency variation      |                      | -                                 | 20   | -            | %         | Fc=4MHz, V <sub>DD</sub> =3V,RC osc,                               |
|                          |                      |                                   |      |              |           | [F(typical)-F(worse case)]/F(typical)                              |



## **RESET PIN TYPE**

TYPE RESET-A



## **OSCILLATION PIN TYPE**

TYPE OSC-A



## TYPE OSC-C



## **INPUT PIN TYPE**

TYPE INPUT-A



## TYPE INPUT-B



## I/O PIN TYPE

TYPE I/O



## TYPE I/O-A





## TYPE I/O-I

#### path B path A Input data Output TYPE I/O data Output latch data Special function : mask option output

## TYPE I/O-L



For set and clear bit of port instructions, data goes through path A from output data latch to CPU. Path A:

Path B: For input and test instructions, data from output pin go through path B to CPU and the output data latch will be set to high.



## **PAD DIAGRAM**



| Pad No. | Symbol     | X       | Y      |
|---------|------------|---------|--------|
| 1       | P4.0/SOUND | -70.0   | 1198.2 |
| 2       | COM7       | -234.0  | 1189.6 |
| 3       | COM6       | -377.7  | 1189.6 |
| 4       | COM5       | -517.7  | 1189.6 |
| 5       | COM4       | -661.3  | 1189.6 |
| 6       | COM3       | -801.3  | 1189.6 |
| 7       | COM2       | -945.0  | 1189.6 |
| 8       | COM1       | -1085.0 | 1189.6 |
| 9       | COM0       | -1228.6 | 1189.6 |
| 10      | SEG39      | -1199.3 | 1014.5 |
| 11      | SEG38      | -1199.3 | 870.8  |
| 12      | SEG37      | -1199.3 | 730.8  |
| 13      | SEG36      | -1199.3 | 587.2  |
| 14      | SEG35      | -1199.3 | 447.2  |
| 15      | SEG34      | -1199.3 | 303.6  |
| 16      | SEG33      | -1199.3 | 163.6  |

<sup>\*</sup> This specification are subject to be changed without notice.



| Pad No. | Symbol             | X       | Y       |
|---------|--------------------|---------|---------|
| 17      | SEG32              | -1199.3 | 19.9    |
| 18      | SEG31              | -1199.3 | -120.1  |
| 19      | SEG30              | -1199.3 | -263.7  |
| 20      | SEG29              | -1199.3 | -403.7  |
| 21      | SEG28              | -1199.3 | -547.4  |
| 22      | SEG27              | -1199.3 | -687.4  |
| 23      | SEG26              | -1199.3 | -831.0  |
| 24      | SEG25              | -1199.3 | -971.0  |
| 25      | SEG24              | -1199.3 | -1114.6 |
| 26      | SEG23              | -1199.3 | -1256.3 |
| 27      | SEG22              | -1050.7 | -1229.4 |
| 28      | SEG21              | -910.7  | -1229.4 |
| 29      | SEG20              | -767.1  | -1229.4 |
| 30      | SEG19              | -627.1  | -1229.4 |
| 31      | SEG18              | -483.5  | -1229.4 |
| 32      | SEG17              | -343.5  | -1229.4 |
| 33      | SEG16              | -199.8  | -1229.4 |
| 34      | SEG15              | -59.8   | -1229.4 |
| 35      | SEG14              | 83.8    | -1229.4 |
| 36      | SEG13              | 223.8   | -1229.4 |
| 37      | SEG12              | 367.5   | -1229.4 |
| 38      | SEG11              | 507.5   | -1229.4 |
| 39      | SEG10              | 651.1   | -1229.4 |
| 40      | SEG9               | 791.1   | -1229.4 |
| 41      | SEG8               | 934.7   | -1229.4 |
| 42      | SEG7               | 1074.7  | -1229.4 |
| 43      | SEG6               | 1218.4  | -1229.4 |
| 44      | SEG5               | 1193.9  | -1070.2 |
| 45      | SEG4               | 1193.9  | -926.6  |
| 46      | SEG3               | 1193.9  | -786.6  |
| 47      | SEG2               | 1193.9  | -642.9  |
| 48      | SEG1               | 1193.9  | -502.9  |
| 49      | SEG0               | 1193.9  | -359.3  |
| 50      | $V_{SS}$           | 1193.9  | -196.3  |
| 51      | P8.0(INT1)/WAKEUPA | 1202.4  | -27.1   |
| 52      | P8.1(TRGB)/WAKEUPB | 1202.4  | 112.9   |
| 53      | P8.2(INT0)/WAKEUPC | 1202.4  | 254.7   |
| 54      | P8.3(TRGA)/WAKEUPD | 1202.4  | 394.7   |
| 55      | P0.0/WAKEUP0       | 1183.9  | 541.3   |
| 56      | P0.1/WAKEUP1       | 1183.9  | 682.0   |

<sup>\*</sup> This specification are subject to be changed without notice.



| Pad No. | Symbol         | X      | Y      |
|---------|----------------|--------|--------|
| 57      | P0.2/WAKEUP2   | 1183.9 | 826.2  |
| 58      | P0.3/WAKEUP3   | 1183.9 | 966.9  |
| 59      | NC             |        |        |
| 60      | NC             |        |        |
| 61      | VRLC           | 1184.7 | 1189.6 |
| 62      | TEST           | 1039.5 | 1179.7 |
| 63      | RESET          | 895.3  | 1179.7 |
| 64      | XIN/CLK        | 705.6  | 1181.8 |
| 65      | XOUT/NC        | 476.2  | 1195.8 |
| 66      | $V_{_{ m DD}}$ | 246.6  | 1198.2 |
| 67      | NC             |        |        |
| 68      | SOUND          | 70.0   | 1198.2 |

Chip Size : 2800 x 2860  $\mu m$  Note : For PCB layout,IC substrate must be floated or connect to  $V_{ss}.$ 



## INSTRUCTION TABLE

## (1) Data Transfer

| Mnemonic | Object code ( binary ) | Operation description                          | Byte | Cycle | F | lag |    |
|----------|------------------------|------------------------------------------------|------|-------|---|-----|----|
|          |                        |                                                |      |       | C | Z   | S  |
| LDA x    | 0110 1010 xxxx xxxx    | $Acc\leftarrow RAM[x]$                         | 2    | 2     | - | Z   | 1  |
| LDAM     | 0101 1010              | $Acc \leftarrow RAM[HL]$                       | 1    | 1     | - | Z   | 1  |
| LDAX     | 0110 0101              | $Acc \leftarrow ROM[DP]_{L}$                   | 1    | 2     | - | Z   | 1  |
| LDAXI    | 0110 0111              | $Acc \leftarrow ROM[DP]_{H}, DP+1$             | 1    | 2     | - | Z   | 1  |
| LDH #k   | 1001 kkkk              | HR←k                                           | 1    | 1     | - | -   | 1  |
| LDHL x   | 0100 1110 xxxx xx00    | $LR \leftarrow RAM[x], HR \leftarrow RAM[x+1]$ | 2    | 2     | - | -   | 1  |
| LDIA #k  | 1101 kkkk              | Acc←k                                          | 1    | 1     | - | Z   | 1  |
| LDL #k   | 1000 kkkk              | LR←k                                           | 1    | 1     | - | -   | 1  |
| STA x    | 0110 1001 xxxx xxxx    | RAM[x]←Acc                                     | 2    | 2     | - | -   | 1  |
| STAM     | 0101 1001              | RAM[HL]←Acc                                    | 1    | 1     | - | -   | 1  |
| STAMD    | 0111 1101              | RAM[HL]←Acc, LR-1                              | 1    | 1     | - | Z   | С  |
| STAMI    | 0111 1111              | $RAM[HL] \leftarrow Acc, LR+1$                 | 1    | 1     | - | Z   | C' |
| STD #k,y | 0100 1000 kkkk yyyy    | RAM[y]←k                                       | 2    | 2     | - | -   | 1  |
| STDMI #k | 1010 kkkk              | RAM[HL]←k, LR+1                                | 1    | 1     | - | Z   | C' |
| THA      | 0111 0110              | Acc←HR                                         | 1    | 1     | - | Z   | 1  |
| TLA      | 0111 0100              | Acc←LR                                         | 1    | 1     | - | Z   | 1  |

## (2) Rotate

| Mnemonic | Object code ( binary ) | Operation description                                | Byte | Cycle | F | lag |    |
|----------|------------------------|------------------------------------------------------|------|-------|---|-----|----|
|          |                        |                                                      |      |       | C | Z   | S  |
| RLCA     | 0101 0000              | ←CF←Acc←                                             | 1    | 1     | C | Z   | C' |
| RRCA     | 0101 0001              | $\hookrightarrow$ CF $\rightarrow$ Acc $\rightarrow$ | 1    | 1     | С | Z   | C' |

## (3) Arithmetic operation

| Mnemonic | Object code ( binary ) | Operation description              | Byte | Cycle | ele Flag |   |    |
|----------|------------------------|------------------------------------|------|-------|----------|---|----|
|          |                        |                                    |      |       | С        | Z | S  |
| ADCAM    | 0111 0000              | $Acc\leftarrow Acc + RAM[HL] + CF$ | 1    | 1     | С        | Z | C' |
| ADD #k,y | 0100 1001 kkkk yyyy    | $RAM[y] \leftarrow RAM[y] + k$     | 2    | 2     | -        | Z | C' |
| ADDA #k  | 0110 1110 0101 kkkk    | Acc←Acc+k                          | 2    | 2     | -        | Z | C' |
| ADDAM    | 0111 0001              | $Acc\leftarrow Acc + RAM[HL]$      | 1    | 1     | -        | Z | C' |
| ADDH #k  | 0110 1110 1001 kkkk    | HR←HR+k                            | 2    | 2     | -        | Z | C' |
| ADDL #k  | 0110 1110 0001 kkkk    | LR←LR+k                            | 2    | 2     | -        | Z | C' |
| ADDM #k  | 0110 1110 1101 kkkk    | $RAM[HL] \leftarrow RAM[HL] + k$   | 2    | 2     | -        | Z | C' |
| DECA     | 0101 1100              | Acc←Acc-1                          | 1    | 1     | -        | Z | С  |
| DECL     | 0111 1100              | LR←LR-1                            | 1    | 1     | -        | Z | C  |
| DECM     | 0101 1101              | RAM[HL]←RAM[HL] -1                 | 1    | 1     | -        | Z | С  |
| INCA     | 0101 1110              | Acc←Acc + 1                        | 1    | 1     | -        | Z | C' |



| INCL    | 0111 1110           | LR←LR + 1               | 1 | 1 | - | Z | C' |
|---------|---------------------|-------------------------|---|---|---|---|----|
| INCM    | 0101 1111           | RAM[HL]←RAM[HL]+1       | 1 | 1 | - | Z | C' |
| SUBA #k | 0110 1110 0111 kkkk | Acc←k-Acc               | 2 | 2 | - | Z | С  |
| SBCAM   | 0111 0010           | Acc←RAM[HLl - Acc - CF' | 1 | 1 | С | Z | С  |
| SUBM #k | 0110 1110 1111 kkkk | RAM[HL]←k - RAM[HL]     | 2 | 2 | - | Z | C  |

## (4) Logical operation

| Mnemonic | Object code ( binary ) | Operation description             | Byte | Cycle | F | ag |    |
|----------|------------------------|-----------------------------------|------|-------|---|----|----|
|          |                        |                                   |      |       | С | Z  | S  |
| ANDA #k  | 0110 1110 0110 kkkk    | Acc←Acc&k                         | 2    | 2     | - | Z  | Z' |
| ANDAM    | 0111 1011              | Acc←Acc & RAM[HL]                 | 1    | 1     | - | Z  | Z' |
| ANDM #k  | 0110 1110 1110 kkkk    | RAM[HL]←RAM[HL]&k                 | 2    | 2     | - | Z  | Z' |
| ORA #k   | 0110 1110 0100 kkkk    | Acc←Acc ¦k                        | 2    | 2     | - | Z  | Z' |
| ORAM     | 0111 1000              | $Acc \leftarrow Acc \mid RAM[HL]$ | 1    | 1     | - | Z  | Z' |
| ORM #k   | 0110 1110 1100 kkkk    | RAM[HL]←RAM[HL]¦k                 | 2    | 2     | - | Z  | Z' |
| XORAM    | 0111 1001              | Acc←Acc^RAM[HL]                   | 1    | 1     | - | Z  | Z' |

## (5) Exchange

| Mnemonic | Object code ( binary ) | Operation description         | Byte | Cycle | F | lag |   |
|----------|------------------------|-------------------------------|------|-------|---|-----|---|
|          |                        |                               |      |       | C | Z   | S |
| EXA x    | 0110 1000 xxxx xxxx    | $Acc \leftrightarrow RAM[x]$  | 2    | 2     | - | Z   | 1 |
| EXAH     | 0110 0110              | Acc↔HR                        | 1    | 2     | - | Z   | 1 |
| EXAL     | 0110 0100              | Acc⇔LR                        | 1    | 2     | - | Z   | 1 |
| EXAM     | 0101 1000              | $Acc \leftrightarrow RAM[HL]$ | 1    | 1     | - | Z   | 1 |
| EXHL x   | 0100 1100 xxxx xx00    | $LR \leftrightarrow RAM[x],$  |      |       |   |     |   |
|          |                        | $HR \leftrightarrow RAM[x+1]$ | 2    | 2     | - | -   | 1 |

## (6) Branch

| Mnemonic | Object code ( binary )   | Operation description                                             | Byte | Cycle | F | Flag |   |
|----------|--------------------------|-------------------------------------------------------------------|------|-------|---|------|---|
|          |                          |                                                                   |      |       | C | Z    | S |
| SBR a    | 00aa aaaa                | If SF=1 then PC $\leftarrow$ PC <sub>12-6</sub> .a <sub>5-0</sub> | 1    | 1     | - | _    | 1 |
|          |                          | else null                                                         |      |       |   |      |   |
| LBR a    | 1100 aaaa aaaa aaaa      | If SF= 1 then PC←a else null                                      | 2    | 2     | - | -    | 1 |
| SLBR a   | 0101 0101 1100 aaaa      | If SF=1 then PC←a else null                                       | 3    | 3     | - | _    | 1 |
|          | aaaa aaaa (a:1000~1FFFh) |                                                                   |      |       |   |      |   |
|          | 0101 0111 1100 aaaa      |                                                                   |      |       |   |      |   |
|          | aaaa aaaa (a:0000~0FFFh) |                                                                   |      |       |   |      |   |

## (7) Compare

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | F | lag |    |
|----------|------------------------|-----------------------|------|-------|---|-----|----|
|          |                        |                       |      |       | C | Z   | S  |
| CMP #k,y | 0100 1011 kkkk yyyy    | k-RAM[y]              | 2    | 2     | С | Z   | Z' |
| CMPA x   | 0110 1011 xxxx xxxx    | RAM[x]-Acc            | 2    | 2     | С | Z   | Z' |

<sup>\*</sup> This specification are subject to be changed without notice.



| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | F | lag |    |
|----------|------------------------|-----------------------|------|-------|---|-----|----|
|          |                        |                       |      |       | C | Z   | S  |
| CMPAM    | 0111 0011              | RAM[HL] - Acc         | 1    | 1     | C | Z   | Z' |
| CMPH #k  | 0110 1110 1011 kkkk    | k - HR                | 2    | 2     | - | Z   | C  |
| CMPIA #k | 1011 kkkk              | k - Acc               | 1    | 1     | C | Z   | Z' |
| CMPL #k  | 0110 1110 0011 kkkk    | k-LR                  | 2    | 2     | - | Z   | С  |

## (8) Bit manipulation

| Mnemo | onic | Object code ( binary ) | Operation description                       | Byte | Cycle | F | lag |   |
|-------|------|------------------------|---------------------------------------------|------|-------|---|-----|---|
|       |      |                        |                                             |      |       | C | Z   | S |
| CLM   | b    | 1111 00bb              | $RAM[HL]_b \leftarrow 0$                    | 1    | 1     | - | -   | 1 |
| CLP   | p,b  | 0110 1101 11bb pppp    | $PORT[p]_{b} \leftarrow 0$                  | 2    | 2     | - | -   | 1 |
| CLPL  |      | 0110 0000              | $PORT[LR_{3-2}+4]LR_{1-0} \leftarrow 0$     | 1    | 2     | - | -   | 1 |
| CLR   | y,b  | 0110 1100 11bb yyyy    | $RAM[y]_b \leftarrow 0$                     | 2    | 2     | - | -   | 1 |
| SEM   | b    | 1111 01bb              | $RAM[HL]_b \leftarrow 1$                    | 1    | 1     | - | -   | 1 |
| SEP   | p,b  | 0110 1101 01bb pppp    | $PORT[p]_b \leftarrow 1$                    | 2    | 2     | - | -   | 1 |
| SEPL  |      | 0110 0010              | $PORT[LR_{3-2}+4]LR_{1-0}\leftarrow 1$      | 1    | 2     | - | -   | 1 |
| SET   | y,b  | 0110 1100 01bb yyyy    | $RAM[y]_b \leftarrow 1$                     | 2    | 2     | - | -   | 1 |
| TF    | y,b  | 0110 1100 00bb yyyy    | SF←RAM[y] <sub>b</sub> '                    | 2    | 2     | - | -   | * |
| TFA   | b    | 1111 10bb              | SF←Acc <sub>b</sub> '                       | 1    | 1     | - | -   | * |
| TFM   | b    | 1111 11bb              | SF←RAM[HL] <sub>b</sub> '                   | 1    | 1     | - | -   | * |
| TFP   | p,b  | 0110 1101 00bb pppp    | $SF \leftarrow PORT[p]_{b}'$                | 2    | 2     | - | -   | * |
| TFPL  |      | 0110 0001              | $SF \leftarrow PORT[LR_{3-2} + 4]LR_{1-0}'$ | 1    | 2     | - | -   | * |
| TT    | y,b  | 0110 1100 10bb yyyy    | $SF \leftarrow RAM[y]_b$                    | 2    | 2     | - | -   | * |
| TTP   | p,b  | 0110 1101 10bb pppp    | $SF \leftarrow PORT[p]_b$                   | 2    | 2     | - | -   | * |

## (9) Subroutine

| Mnemonic | Object code ( binary ) | Operation description                                     | Byte | Cycle | F | lag |   |
|----------|------------------------|-----------------------------------------------------------|------|-------|---|-----|---|
|          |                        |                                                           |      |       | C | Z   | S |
| LCALL a  | 0100 0aaa aaaa aaaa    | STACK[SP]←PC,                                             | 2    | 2     | - | -   | - |
|          |                        | SP←SP -1, PC←a                                            |      |       |   |     |   |
| SCALL a  | 1110 nnnn              | STACK[SP]←PC,                                             | 1    | 2     | - | -   | - |
|          |                        | $SP \leftarrow SP - 1$ , $PC \leftarrow a$ , $a = 8n + 6$ |      |       |   |     |   |
|          |                        | $(n = 1 \sim 15),0086h (n = 0)$                           |      |       |   |     |   |
| RET      | 0100 1111              | $SP \leftarrow SP + 1, PC \leftarrow STACK[SP]$           | 1    | 2     | - | -   | - |

## (10) Input/output

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | Flag |   |    |
|----------|------------------------|-----------------------|------|-------|------|---|----|
|          |                        |                       |      |       | С    | Z | S  |
| INA p    | 0110 1111 0100 pppp    | Acc←PORT[p]           | 2    | 2     | -    | Z | Z' |
| INM p    | 0110 1111 1100 pppp    | RAM[HL]←PORT[p]       | 2    | 2     | -    | - | Z' |
| OUT #k,p | 0100 1010 kkkk pppp    | PORT[p]←k             | 2    | 2     | -    | - | 1  |
| OUTA p   | 0110 1111 000p pppp    | PORT[p]←Acc           | 2    | 2     | -    | - | 1  |
| OUTM p   | 0110 1111 100p pppp    | PORT[p]←RAM[HL]       | 2    | 2     | -    | - | 1  |



## (11) Flag manipulation

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | Flag |              |   |
|----------|------------------------|-----------------------|------|-------|------|--------------|---|
|          |                        |                       |      |       | C    | $\mathbf{Z}$ | S |
| TFCFC    | 0101 0011              | SF←CF', CF←0          | 1    | 1     | 0    | -            | * |
| TTCFS    | 0101 0010              | SF←CF, CF←1           | 1    | 1     | 1    | -            | * |
| TZS      | 0101 1011              | SF←ZF                 | 1    | 1     | -    | -            | * |

## (12) Interrupt control

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | Fl | ag |   |
|----------|------------------------|-----------------------|------|-------|----|----|---|
|          |                        |                       |      |       | C  | Z  | S |
| CIL r    | 0110 0011 11rr rrrr    | IL←IL & r             | 2    | 2     | -  | -  | 1 |
| DICIL r  | 0110 0011 10rr rrrr    | EIF←0,IL←IL&r         | 2    | 2     | -  | -  | 1 |
| EICIL r  | 0110 0011 01rr rrrr    | EIF←1,IL←IL&r         | 2    | 2     | _  | -  | 1 |
| EXAE     | 0111 0101              | MASK↔Acc              | 1    | 1     | -  | -  | 1 |
| RTI      | 0100 1101              | SP←SP+1,FLAG.PC       | 1    | 2     | *  | *  | * |
|          |                        | ←STACK[SP],EIF ←1     |      |       |    |    |   |

## (13) CPU control

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | Fl | Flag         |   |
|----------|------------------------|-----------------------|------|-------|----|--------------|---|
|          |                        |                       |      |       | C  | $\mathbf{Z}$ | S |
| NOP      | 0101 0110              | no operation          | 1    | 1     | -  | -            | - |

## (14) Timer/Counter & Data pointer & Stack pointer control

| Mnemonic | Object code ( binary ) | Operation description     | Byte | Cycle | F | lag |   |
|----------|------------------------|---------------------------|------|-------|---|-----|---|
|          |                        | _                         |      |       | С | Z   | S |
| LDADPL   | 0110 1010 1111 1100    | $Acc \leftarrow [DP]_L$   | 2    | 2     | - | Z   | 1 |
| LDADPM   | 0110 1010 1111 1101    | $Acc \leftarrow [DP]_{M}$ | 2    | 2     | - | Z   | 1 |
| LDADPH   | 0110 1010 1111 1110    | Acc←[DP] <sub>H</sub>     | 2    | 2     | - | Z   | 1 |
| LDASP    | 0110 1010 1111 1111    | Acc←SP                    | 2    | 2     | - | Z   | 1 |
| LDATAL   | 0110 1010 1111 0100    | Acc←[TA] <sub>L</sub>     | 2    | 2     | - | Z   | 1 |
| LDATAM   | 0110 1010 1111 0101    | Acc←[TA] <sub>M</sub>     | 2    | 2     | - | Z   | 1 |
| LDATAH   | 0110 1010 1111 0110    | Acc←[TA] <sub>H</sub>     | 2    | 2     | - | Z   | 1 |
| LDATBL   | 0110 1010 1111 1000    | $Acc\leftarrow[TB]_{L}$   | 2    | 2     | - | Z   | 1 |
| LDATBM   | 0110 1010 1111 1001    | Acc←[TB] <sub>M</sub>     | 2    | 2     | - | Z   | 1 |
| LDATBH   | 0110 1010 1111 1010    | Acc←[TB] <sub>H</sub>     | 2    | 2     | - | Z   | 1 |
| STADPL   | 0110 1001 1111 1100    | [DP] <sub>L</sub> ←Acc    | 2    | 2     | - | -   | 1 |
| STADPM   | 0110 1001 1111 1101    | [DP] <sub>M</sub> ←Acc    | 2    | 2     | - | -   | 1 |
| STADPH   | 0110 1001 1111 1110    | [DP] <sub>H</sub> ←Acc    | 2    | 2     | - | -   | 1 |
| STASP    | 0110 1001 1111 1111    | SP←Acc                    | 2    | 2     | - | -   | 1 |
| STATAL   | 0110 1001 1111 0100    | [TA] <sub>L</sub> ←Acc    | 2    | 2     | - | _   | 1 |
| STATAM   | 0110 1001 1111 0101    | [TA] <sub>M</sub> ←Acc    | 2    | 2     | - | -   | 1 |
| STATAH   | 0110 1001 1111 0110    | [TA] <sub>H</sub> ←Acc    | 2    | 2     | - | -   | 1 |
| STATBL   | 0110 1001 1111 1000    | [ TB] <sub>L</sub> ←Acc   | 2    | 2     | - | -   | 1 |
| STATBM   | 0110 1001 1111 1001    | [TB] <sub>M</sub> ←Acc    | 2    | 2     | - | -   | 1 |
| STATBH   | 0110 1001 1111 1010    | [TB] <sub>H</sub> ←Acc    | 2    | 2     | - | -   | 1 |

<sup>\*</sup> This specification are subject to be changed without notice.



## \*\*\*\* SYMBOL DESCRIPTION

| Symbol               | Description                           | Symbol               | Description                           |
|----------------------|---------------------------------------|----------------------|---------------------------------------|
| HR                   | H register                            | LR                   | L register                            |
| PC                   | Program counter                       | DP                   | Data pointer                          |
| SP                   | Stack pointer                         | STACK[SP]            | Stack specified by SP                 |
| A <sub>CC</sub>      | Accumulator                           | FLAG                 | All flags                             |
| CF                   | Carry flag                            | ZF                   | Zero flag                             |
| SF                   | Status flag                           | EI                   | Enable interrupt register             |
| IL                   | Interrupt latch                       | MASK                 | Interrupt mask                        |
| PORT[p]              | Port ( address : p )                  | TA                   | Timer/counter A                       |
| TB                   | Timer/counter B                       | RAM[HL]              | Data memory (address : HL)            |
| RAM[x]               | Data memory (address : x )            | ROM[DP] <sub>r</sub> | Low 4-bit of program memory           |
| ROM[DP] <sub>H</sub> | High 4-bit of program memory          | [DP] <sub>L</sub>    | Low 4-bit of data pointer register    |
| [DP] <sub>M</sub>    | Middle 4-bit of data pointer register | [DP] <sub>H</sub>    | High 4-bit of data pointer register   |
| $[TA]_{I}([TB]_{I})$ | Low 4-bit of timer/counter A          | $[TA]_{M}([TB]_{M})$ | Middle 4-bit of timer/counter A       |
|                      | (timer/counter B) register            | .,,                  | (timer/counter B) register            |
| $[TA]_{H}([TB]_{H})$ | High 4-bit of timer/counter A         | LR <sub>1-0</sub>    | Contents of bit assigned by bit       |
|                      | (timer/counter B) register            | 1 0                  | 1 to 0 of LR                          |
| LR <sub>3-2</sub>    | Bit 3 to 2 of LR                      | a <sub>5-0</sub>     | Bit 5 to 0 of destination address for |
|                      |                                       |                      | branch instruction                    |
| PC <sub>12-6</sub>   | Bit 12 to 6 of program counter        | <b>←</b>             | Transfer                              |
| $\leftrightarrow$    | Exchange                              | +                    | Addition                              |
| -                    | Substraction                          | &                    | Logic AND                             |
|                      | Logic OR                              | ٨                    | Logic XOR                             |
| 1                    | Inverse operation                     |                      | Concatenation                         |
| #k                   | 4-bit immediate data                  | X                    | 8-bit RAM address                     |
| у                    | 4-bit zero-page address               | p                    | 4-bit or 5-bit port address           |
| b                    | Bit address                           | r                    | 6-bit interrupt latch                 |



## **WARNING**

All interrupt must be disable, when EM73862 executes the instruction SLBR, otherwise the program of EM73862 will not be expected.

Example:



The branch instruction between upper 4K bytes and lower 4K bytes program ROM is SLBR.