

## 、专业PCB打样工厂,24小时加急出货 HTG12G0 Microcontroller

#### Features

- Operating voltage: 2.4V~3.3V
- Eight input lines
- Two output lines
- Five working registers
- RC oscillator for system clock
- Crystal oscillator for RTC and LCD clock
- 8K×8 program ROM
- 156×4 data RAM
- 50×8 segment LCD driver, 1/5 bias, 1/8 duty
- 8-bit programmable timer with built-in frequency source

#### **General Description**

The HTG12G0 is a 4-bit single chip microcontroller specially designed for LCD product applications.

- Internal timer overflow and RTC interrupt
- 16 kinds of programmable sound effects
- Halt function and wake-up feature reduce power consumption
- One-level subroutine nesting
- 8-bit table read instruction
- Up to 4.0μs instruction cycle with 1.0MHz system clock at V<sub>DD</sub>=3V
- 95 powerful instructions

1

It is ideally suited for applications requiring low power consumption, with many LCD segments such as calculator, scale, subsystem controller, hand-held LCD products and electronic appliances.





### **Block Diagram**



Notes: ACC: Accumulator R0~R4: Working registers PP, PS: Input ports PA2: LCD on/off switch PC: Program counter PA0~PA1: Output ports PA3: ROM bank control bit



**Pad Assignment** 



 $Chip\ size:\ 3070\times4440\ {(\mu m)}^2$  \* The IC substrate should be connected to VSS in the PCB layout artwork.



## **Pad Coordinates**

| Pad No. | X        | Y        | Pad No. | X        | Y        |
|---------|----------|----------|---------|----------|----------|
| 1       | -1403.50 | 2012.75  | 42      | 1412.00  | -1270.25 |
| 2       | -1403.50 | 1872.75  | 43      | 1412.00  | -1134.25 |
| 3       | -1403.50 | 1741.75  | 44      | 1412.00  | -998.25  |
| 4       | -1403.50 | 1610.75  | 45      | 1412.00  | -862.25  |
| 5       | -1304.00 | 1431.75  | 46      | 1412.00  | -726.25  |
| 6       | -1304.00 | 1276.25  | 47      | 1412.00  | -590.25  |
| 7       | -1358.50 | 1104.25  | 48      | 1412.00  | -454.25  |
| 8       | -1409.50 | 929.25   | 49      | 1412.00  | -318.25  |
| 9       | -1403.50 | 377.75   | 50      | 1412.00  | -182.25  |
| 10      | -1403.50 | 249.75   | 51      | 1412.00  | -46.25   |
| 11      | -1403.50 | 121.75   | 52      | 1412.00  | 89.75    |
| 12      | -1403.50 | -6.25    | 53      | 1412.00  | 225.75   |
| 13      | -1403.50 | -134.25  | 54      | 1412.00  | 361.75   |
| 14      | -1403.50 | -262.25  | 55      | 1412.00  | 497.75   |
| 15      | -1403.50 | -390.25  | 56      | 1412.00  | 633.75   |
| 16      | -1403.50 | -518.25  | 57      | 1412.00  | 769.75   |
| 17      | -1403.50 | -646.25  | 58      | 1412.00  | 905.75   |
| 18      | -1403.50 | -774.25  | 59      | 1412.00  | 1041.75  |
| 19      | -1403.50 | -902.25  | 60      | 1412.00  | 1177.75  |
| 20      | -1403.50 | -1030.25 | 61      | 1412.00  | 1313.75  |
| 21      | -1403.50 | -1158.25 | 62      | 1412.00  | 1449.75  |
| 22      | -1403.50 | -1286.25 | 63      | 1412.00  | 1585.25  |
| 23      | -1403.50 | -1414.25 | 64      | 1412.00  | 1720.75  |
| 24      | -1403.50 | -1542.25 | 65      | 1412.00  | 1865.25  |
| 25      | -1409.50 | -1680.75 | 66      | 1412.00  | 2034.75  |
| 26      | -1342.00 | -1926.25 | 67      | 1071.50  | 2037.25  |
| 27      | -1071.50 | -1920.25 | 68      | 490.00   | 2034.75  |
| 28      | -871.50  | -1920.25 | 69      | 358.00   | 2034.75  |
| 29      | -640.00  | -1994.75 | 70      | 228.00   | 2034.75  |
| 30      | -500.00  | -1994.75 | 71      | 105.00   | 2034.75  |
| 31      | -360.00  | -1994.75 | 72      | -18.00   | 2034.75  |
| 32      | -220.00  | -1994.75 | 73      | -141.00  | 2034.75  |
| 33      | -80.00   | -1994.75 | 74      | -264.00  | 2034.75  |
| 34      | 60.00    | -1994.75 | 75      | -387.00  | 2034.75  |
| 35      | 200.00   | -1994.75 | 76      | -510.00  | 2034.75  |
| 36      | 340.00   | -1994.75 | 77      | -633.00  | 2034.75  |
| 37      | 1412.00  | -2034.75 | 78      | -756.00  | 2034.75  |
| 38      | 1412.00  | -1877.25 | 79      | -879.00  | 2034.75  |
| 39      | 1412.00  | -1712.25 | 80      | -1002.00 | 2034.75  |
| 40      | 1412.00  | -1542.25 | 81      | -1129.50 | 2034.75  |
| 41      | 1412.00  | -1406.25 |         |          |          |

## HOLTEK

#### **Pad Description**

| Pad No.              | Pad name                      | I/O              | Mask Option                   | Description                                                                                                                            |
|----------------------|-------------------------------|------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 1~4,<br>36~81        | SEG3~SEG0<br>SEG49~SEG4       | 0                |                               | LCD driver outputs for LCD panel segment                                                                                               |
| 5<br>6               | BZ<br>BZ                      | 0                | *                             | Sound effect output                                                                                                                    |
| 7                    | VDD                           | Ι                | _                             | Positive power supply                                                                                                                  |
| 8<br>9               | OSCI<br>OSCO                  | I<br>O           | _                             | An external resistor between OSCI and OSCO is needed for internal system clock.                                                        |
| 10<br>19<br>20<br>26 | T512<br>TEST1<br>TEST2<br>T1D | 0<br>I<br>I<br>0 |                               | For test mode only<br>TEST1 and TEST2 must be open when the<br>HTG12G0 is in normal operation (with an<br>internal pull high resistor) |
| 11~18                | COM7~COM0                     | 0                | _                             | Output for LCD panel common plate                                                                                                      |
| 21~24                | PS3~PS0                       | Ι                | Pull-high or<br>None<br>**    | 4-bit port for input only                                                                                                              |
| 25                   | VSS                           | Ι                |                               | Negative power supply, GND                                                                                                             |
| 27<br>28             | PA1<br>PA0                    | 0                | CMOS or<br>NMOS<br>Open Drain | 2-bit latch port for output only                                                                                                       |
| 29<br>30             | XIN<br>XOUT                   | I<br>O           | _                             | 32768Hz crystal oscillator for time base                                                                                               |
| 31~34                | PP0~PP3                       | Ι                | Pull-high or<br>None<br>**    | 4-bit port for input only                                                                                                              |
| 35                   | RES                           | Ι                | _                             | Input for reset LSI inside<br>Reset is active at logical low level                                                                     |

\*: 6 internal sources deriving from the system clock can be selected as sound effect clock by mask option. If Holtek's sound library is invoked, only 128K and 64K is accepted.

\*\*: Each bit of input ports PS, PP can be a trigger source of HALT interrupt. That can be specified by mask option.

#### **Absolute Maximum Ratings**

| Supply VoltageVSS-0.3V to 13  | BV | Operating Temperature0°C to 70°C |
|-------------------------------|----|----------------------------------|
| Input VoltageVss-0.3 to VDD+0 | .3 | Storage Temperature50°C to 125°C |

Note: These are stress ratings only. Stresses exceeding the range specified under "Absolute Maximum Ratings" may cause substantial damage to the device. Functional operation of this device at other conditions beyond those listed in the specification is not implied and prolonged exposure to extreme conditions may affect device reliability.



## D.C. Characteristics

| C1 - 1           | Devenueter                                                   |                            | <b>Test Conditions</b>                      | N/?    | -    | M    |      |  |
|------------------|--------------------------------------------------------------|----------------------------|---------------------------------------------|--------|------|------|------|--|
| Symbol           | Parameter                                                    | V <sub>DD</sub> Conditions |                                             | — Min. | Тур. | Max. | Uint |  |
| V <sub>DD</sub>  | Operating Voltage                                            | _                          | _                                           | 2.4    | _    | 3.3  | V    |  |
| I <sub>DD</sub>  | Operating Current                                            | 3V                         | No load, fsys=500kHz                        | _      | 100  | 500  | μΑ   |  |
| I <sub>STB</sub> | Standby Current<br>(RTC OSC ON)<br>and LCD ON                | 3V                         | System halt                                 | _      | 10   | 20   | μΑ   |  |
| V <sub>IL1</sub> | Input Low Voltage                                            | 3V                         | PS, PP                                      | 0      | _    | 0.6  | V    |  |
| V <sub>IH1</sub> | Input High Voltage                                           | 3V                         | PS, PP                                      | 2.1    | _    | 3.0  | V    |  |
| V <sub>IL2</sub> | Input Low Voltage                                            | 3V                         | RES                                         | 0      | _    | 0.6  | V    |  |
| VIH2             | Input High Voltage                                           | 3V                         | RES                                         | 2.5    | _    | 3.0  | V    |  |
| I <sub>OL1</sub> | Port A, BZ and $\overline{\text{BZ}}$<br>Output Sink Current | 3V                         | V <sub>DD</sub> =3V, V <sub>OL</sub> =0.3V  | 1.5    | 3.0  | _    | mA   |  |
| I <sub>OH1</sub> | Port A, BZ and BZ<br>Output Source Current                   | 3V                         | V <sub>DD</sub> =3V, V <sub>OH</sub> =2.7V  | -0.5   | -1.5 | _    | mA   |  |
| I <sub>OL2</sub> | Segment 0~7 Output<br>Sink Current                           | 3V                         | V <sub>LCD</sub> =3V, V <sub>OL</sub> =0.3V | 80     | 100  | _    | μΑ   |  |
| I <sub>OH2</sub> | Segment 0~7 Output<br>Source Current                         | 3V                         | V <sub>LCD</sub> =3V, V <sub>OH</sub> =2.7V | -50    | -70  | _    | μΑ   |  |
| I <sub>OL3</sub> | Segment 8~49 Output<br>Sink Current                          | 3V                         | V <sub>LCD</sub> =3V, V <sub>OL</sub> =0.3V | 40     | 60   | _    | μΑ   |  |
| Іонз             | Segment 8~49 Output<br>Source Current                        | 3V                         | V <sub>LCD</sub> =3V, V <sub>OH</sub> =2.7V | -20    | -40  | _    | μΑ   |  |
| I <sub>OL4</sub> | Common Output Sink<br>Current                                | 3V                         | V <sub>LCD</sub> =3V, V <sub>OL</sub> =0.3V | 100    | 120  | _    | μΑ   |  |
| I <sub>OH4</sub> | Common Output<br>Source Current                              | 3V                         | V <sub>LCD</sub> =3V, V <sub>OH</sub> =2.7V | -100   | -130 | _    | μΑ   |  |
| R <sub>PH1</sub> | Pull-high Resistance                                         | 3V                         | PS, PP                                      | 15     | _    | 200  | kΩ   |  |
| R <sub>PH2</sub> | Pull-high Resistance                                         | 3V                         | RES                                         | 100    | _    | 300  | kΩ   |  |

Ta=25°C



## HTG12G0

Ta=25°C

## A.C. Characteristics

| Ch al            | Devenuetor         | Te              | st Conditions            |      | Tem                     | Mari | T    |
|------------------|--------------------|-----------------|--------------------------|------|-------------------------|------|------|
| Symbol           | Parameter          | V <sub>DD</sub> | Conditions               | Min. | Тур.                    | Max. | Unit |
| f <sub>SYS</sub> | System Clock       | 3V              | R:620kΩ~51kΩ             | 100  | _                       | 1000 | kHz  |
| flcd             | LCD Clock          | 3V              |                          | _    | 512                     | _    | Hz   |
| t <sub>COM</sub> | LCD Common Period  | _               | 1/8 duty                 | _    | (1/f <sub>LCD</sub> )x8 | _    | sec  |
| t <sub>CY</sub>  | Cycle Time         | _               | f <sub>SYS</sub> =1.0MHz | _    | 4.0                     | _    | μs   |
| t <sub>RES</sub> | Reset Pulse Width  | _               | _                        | 5    | _                       | _    | ms   |
| fsound           | Sound Effect Clock | —               | _                        | —    | 64 or 128*              | —    | kHz  |

\*: Only these two clock signal frequencies are supported by Holtek sound library.



#### **Functional Description**

#### Program counter – PC

The 12-bit program counter is controlled by PA3 which can change the ROM bank of the program memory. There are two program memory banks which are selected by PA3, each bank is 4KB ROM. The instruction"OUT PA, A" is used to change the value of PA3. Then, low or high 4K ROM is selected accordingly. All instructions are not effective on the crossing bank, unless the value of PA3 is changed in advance.

The 12-bit program counter (PC) controls the sequence in which the instructions stored in the program ROM are executed and its contents specify a max. of 4096 address.

After accessing a memory word to fetch an instruction code, the contents of the program counter are incremented by one or two, then the program counter will point to the memory word containing the next instruction code. When executing the jump instruction (JMP, JNZ, JC, JTMR...), subroutine call, internal interrupt, RTC interrupt or return from subroutine, the PC manipulates the program transfer by loading the address corresponding to each instruction.

#### Program memory - ROM

The program memory is used to store program instruction which is to be executed. It is organized into  $8192 \times 8$  bits and addressed by the program counter and PA3.

Certain locations in bank 0 of the program memory are reserved for specific usage:

• Location 0004H

This area is reserved for TIMER interrupt service program. A timer interrupt results from TIMER overflow, if interrupt is enabled, the CPU begins execution at location 0004H.

| Mode                      | Program Counter |      |      |     |     |     |            |     |     |     |     |     |     |
|---------------------------|-----------------|------|------|-----|-----|-----|------------|-----|-----|-----|-----|-----|-----|
| mode                      | PA3             | PC11 | PC10 | PC9 | PC8 | PC7 | PC6        | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 |
| Initial<br>reset          | 1               | 0    | 0    | 0   | 0   | 0   | 0          | 0   | 0   | 0   | 0   | 0   | 0   |
| Internal<br>interrupt     | PA3             | 0    | 0    | 0   | 0   | 0   | 0          | 0   | 0   | 0   | 1   | 0   | 0   |
| External<br>interrupt     | PA3             | 0    | 0    | 0   | 0   | 0   | 0          | 0   | 0   | 1   | 0   | 0   | 0   |
| Jump, call<br>instruction | PA3             | PC11 | PC10 | PC9 | PC8 | PC7 | PC6        | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 |
| Conditional<br>branch     | PA3             | @    | PC10 | PC9 | PC8 | PC7 | PC6        | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 |
| Return from<br>subroutine | PA3             | S11  | S10  | S9  | S8  | S7  | <b>S</b> 6 | S5  | S4  | S3  | S2  | S1  | S0  |

Notes: PC11~PC0: Instruction code bits S11~S0: Stack register bits @: PC11 keeps current valuePA3: Bank value bits



Location 0008H

This area is reserved for RTC interrupt service program.

• Location 0n00H~0nFFH (n=current number) and 0F00H~0FFFH.

The last 256 bytes of each page in the program memory, addressed from 0n00H to 0nFFH and 0F00H to 0FFFH can be used as a look-up table. The instructions READ R4A, READ MR0A, READF R4A, READF MR0A can read the table and transfer the contents of the table to ACC and R4 or transfer to ACC and data memory addressed by register pair "R1, R0". These areas may function as a normal program memory depending on the requirements.

Certain locations in bank 1 of the program memory are reserved for specific usage:

Location 1000H

This area is reserved for the initialization program. After reset, the CPU always begins execution at location 1000H.

Location 1004H

This area is reserved for TIMER interrupt service program. A timer interrupt results from TIMER overflow, if interrupt is enabled, the CPU begins execution at location 1004H.

- Location 1008H This area is reserved for RTC interrupt serv-
- ice program.
  Location 1n00H~1nFFH (n=current number) and 1F00H~1FFFH.

The last 256 bytes of each page in the program memory, addressed from 1n00H to 1nFFH and 1F00H to 1FFFH can be used as a look-up table. The instructions READ R4A, READ MR0A, READF R4A, READF MR0A can read the table and transfer the contents of the table to ACC and R4 or transfer to ACC and data memory addressed by register pair "R1, R0". These areas may function as a normal program memory depending on the requirements.

The program memory (ROM) mapping is shown below:



**Program memory** 

In the execution of an instruction, the program counter is added before the executing phase. So a careful manipulation of READ MROA and READ R4A is needed in the page margin.

#### Stack register

This is a special group of register which is used to save the contents of the program counter (PC) and is organized with 13 bits×1 level. One bit is used to store the carry flag. An interrupt will force the contents of the PC and the carry flag onto the stack register. A subroutine call will also cause the PC contents to be pushed onto the stack; however the carry flag will not be stored. At the end of a subroutine or interrupt routine which is signaled by a return instruction, RET or RETI restores the program counter to its previous value from stack register.

Executing "RETI" instruction will restore the carry flag from the stack register, but "RET" does not.



#### Working registers - R0, R1, R2, R3, R4

These five registers are usually used to store the frequently accessed data. The working register can be incremented (+1) or decremented (-1). The JNZ Rn,address (n=0,1,4) instruction makes very efficient use of the working register as program loop counter. The register pairs of R1, R0 and R3, R2 can also be used as the data memory pointer, when the data memory transfer instruction is executed.

#### Data memory – RAM

The data memory is a static RAM organized with  $256 \times 4$  bits and is used to store temporary data and display data. All of the data memory locations are indirectly addressable through the register pair "R1, R0" or "R3, R2".

There are two areas in the data memory, temporary data area and display data area. Access to temporary data memory is made through 00H~9BH address, and access to display data memory is made in 9CH~FFH address.

When data is written in the display area, the LCD driver automatically reads it and generates an LCD driving signal.



#### Accumulator – ACC

The register ACC plays the most important role in data manipulation and data transfer. It is not only one of the sources of input to the ALU but also the destination of the result due to ALU. Data transfer can be performed between ACC and other registers, data memory or I/O ports.

#### Arithmetic and logic unit - ALU

This circuit performs arithmetic and logic operation. The ALU provides the following functions:

- Arithmetic operation (ADD, ADC, SUB, SBC, DAA)
- Logic operation (AND, OR, XOR)
- Rotation (RL, RR, RLC, RRC)
- Increment and Decrement (INC, DEC)
- Branch decision (JZ, JNZ, JC, JNC...)

The ALU not only outputs the results of data operation but also sets the status of carry flag (C) in some instructions.

#### Timer

This is a programmable 8-bit count-up counter, internal frequency sources used to aid the user in counting and generating accurate time base.

The Timer can be pre-set and read with software instructions. "TIMER XXH", "MOV TMRL, A" and "MOV TMRH, A" preload TIMER value. "MOV A, TMRL" and "MOV A, TMRH" read the contents of TIMER to ACC.

The Timer is stopped by a hardware reset or "TIMER OFF" instruction and started by a TIMER ON instruction.

Once the Timer is started, it will increment to its maximum count (FFH) and overflows to zero (00H). It will not stop until there is a "TIMER OFF" instruction or reset. When an overflow occurs, it will set the Timer Flag (TF) simultaneously. If interrupt is enabled, the Timer circuit supports TF for internal interrupt. The state of the TF can be tested with the conditional instruction JTMR.

The Timer flag is cleared after the interrupt or JTMR instruction is executed.

The frequency of the internal frequency source can be selected by mask option.

Frequency of TIMER clock =  $\frac{\text{system clock}}{2^n}$ Where n=0,1,2.....13 except 6, by mask option

(the sixth stage is reserved for internal use).



#### RTC

There is a real time clock (RTC) function implemented on the HTG12G0. The RTC function is used to generate an accurate time period. The clock source of the RTC circuit comes from the 32768Hz crystal oscillator. The block diagram is shown as follows:



The output of the RTC can be selected by mask option.

Frequency of the RTC output =  $\frac{256}{2^n}$  n=0~7

The RTC output is used to generate an interrupt signal.

#### Interrupt

The HTG12G0 provides both TIMER and RTC interrupt modes. The DI and EI instructions are used to disable and enable the interrupts. When the RTC is activated during enable interrupt mode and the program is not within a CALL subroutine, this causes a subroutine call to location 8 and reset the interrupt latch.

Likewise when the timer flag is set in the enable interrupt mode and the program is not within a CALL subroutine, the TIMER interrupt is activated. This cause a subroutine call to location 4 and resets the timer flag. If both TIMER and RTC interrupts arrive at the same time, the RTC will be serviced first.

When running under a CALL subroutine or DI the interrupt acknowledge is on hold until the RET or EI instruction is invoked. The CALL instruction should not be used within an interrupt routine as unpredictable behaviors may occur. If within a CALL subroutine both TIMER and RTC interrupt occur, no matter what order they arrive in, the RTC interrupt will be serviced first after leaving the CALL subroutine. This also applies if the two interrupts arrive at the same time. The interrupts are disabled by a hardware reset or a DI instruction. They remain disabled until the EI instruction is executed.

#### Initial reset

The HTG12G0 provides a  $\overline{\text{RES}}$  pin for system initialization. Since the  $\overline{\text{RES}}$  pin has internal pull high resistor, only an external  $0.1\mu \sim 1\mu$  capacitor is needed. If the reset pulse is generated externally, it must be held low for at least 5 ms.

When  $\overline{\text{RES}}$  is active, the internal block will be initialized as shown below:

| PA3 and PC                       | 1000H                       |
|----------------------------------|-----------------------------|
| TIMER                            | Stop                        |
| Timer flag                       | Reset (low)                 |
| SOUND                            | Sound off and one sing mode |
| Output port A                    | High (or floating state)    |
| LCD output                       | Disabled                    |
| BZ and <mark>BZ</mark><br>output | High level                  |

#### HALT

This is a special feature of HTG12G0. It will stop the chip's normal operation and reduces power consumption. When the instruction "HALT" is executed, then

- · System oscillator will be stopped
- The contents of the on-chip RAM and registers remain unchanged
- RTC oscillator still keeps running

The system can escape HALT mode by ways of initial reset or RTC interrupt or wake-up from the following entry of program counter value.

Initial reset: 1000H

Wake-up: next address of the HALT instruction

When the halt status is terminated by the RTC interrupt, the following procedure takes place:

\* Case1: If the system is in an interrupt-disable state before entering the halt state:



- The system will be awakened and returns to the main program instruction following the HALT command.
- The RTC interrupt will be held until the system receives an enable interrupt command by which the RTC interrupt will be serviced.
- \* Case 2: If the system is in an interrupt enable state:
  - The RTC interrupt will awake the system and execute the RTC interrupt subroutine.
  - In the HALT mode, each bit of ports PP, PS, can be used as wake-up signal by mask option to wake-up the system. This signal is active in low-going transition.

#### Sound effect

HTG12G0 provides sound effect circuit which offers up to 16 sounds with 3 effects of tone, boom and noise. Holtek supports a sound library which have melody, alarm, machine gun shooting etc.

Whenever the instruction "SOUND n" or "SOUND A" is executed, the specified sound begins playing. Whenever "SOUND OFF" is executed, it terminates the singing sound immediately.

There are two singing modes, SONE mode and SLOOP mode, which is activated by "SOUND ONE" and "SOUND LOOP". In SONE mode, the sound that has been specified plays just once. In SLOOP mode, the sound being specified keeps playing repeatedly.

Since sound  $0 \sim 11$  contain 32 notes, sound  $12 \sim 15$  contain 64 notes, the later possess better sound than the former.

The frequency of the sound effect circuit can be selected by mask option.

Frequency of sound effect circuit = 
$$\frac{\text{system clock}}{2^{\text{m}}}$$

Where m=0, 1, 2, 3, 4, 5

Holtek's sound library only supports sound clock frequency 128K or 64K. To utilize Holtek's sound library, select the proper system clock and mask option.

#### LCD display memory

The LCD display memory is embedded in the data memory. It can be read and written to as normal data memory.

The figure shows the mapping between display memory and LCD pattern.

To turn on/off the display, the programmer just writes 1/0 to the corresponding bit of the display memory.

The LCD display module may have any form as long as the number of the common is no more than 8 and the segment is no more than 50.



LCD display memory

#### LCD driver output

The output number of the LCD driver is  $50 \times 8$ , directly driving a 1/8 duty cycle and 1/5 bias LCD. All LCD segments are at random during initial clear mode.

The LCD has built-in bias voltage circuit. No external resistor is needed.

The frequency of the LCD driving clock is fixed at about 512Hz. This is set by RTC OSC (32.768kHz).



LCD driver output can be enabled or disabled by setting PA2 without the influence of the related memory condition.

LCD driver output is enabled by setting PA2 as "1", and disabled by setting PA2 as "0".

An example of an LCD driving waveform (1/8 duty and 1/5 bias) is shown below:



#### **Oscillator circuit**

Only one external resistor is required for the HTG12G0 system clock.

The system clock is also used as the sound effect clock, or internal frequency source of TIMER. Another crystal oscillator is needed to be used as the reference signal of LCD driving clock and RTC interrupt clock source.

The HTG12G0 machine cycle consists of a sequence of 4 states numbered T1 to T4. Each state lasts for one oscillator period. The machine cycle is  $4.0\mu s$ , if the system frequency is up to 1.0MHz.



RC and RTC oscillator

#### Input ports - PS, PP

Ports PS, PP are 4-bit input ports. These input ports are configured as shown below:

All of these ports have internal pull-high resistor determined by mask option.

Each bit of input ports PS, PP can be a trigger source of HALT interrupt. That is also specified by mask option. A transition from high to low will make HTG12G0 wake-up.



Input ports PS, PP



#### Output port – PA

Port A is a 2-bit output port (PA0~PA1), and configured as shown below:



**Output port PA** 

The mask option available for selecting the output configuration is either normal CMOS output type or open drain NMOS output type. At the initial clear mode, the output ports are at high state (in CMOS output type) or at floating state (in NMOS output type).

Note:

PA3 controls the bit 12 of the program counter. When the instruction "OUT PA, A" is operated, port A is changed as well. PA2 controls the ON/OFF state of the LCD. Without the influence of the memory condition, "1" turns the LCD on, and "0" off.

#### Mask option

HTG12G0 provides six kinds of mask option for different applications.

- Each bit of input ports PS, PP with pull-high resistor
- Each bit of input ports PS, PP function as HALT wake-up trigger
- Each bit of output port PA0~PA1 with CMOS or open drain NMOS
- 8 bit programmable TIMER with internal frequency sources. There are 13 (the sixth stage is reserved for internal use) internal frequency sources which can be selected as a clocking signal.
- Six kinds of sound clock frequencies:  $f_{SYS}/2^m$ , m= 0, 1, 2, 3, 4, 5
- There are eight kinds of RTC interrupt frequencies. RTC interrupt frequency= 256/2<sup>n</sup>Hz, n=0~7



## **Application Circuits**



 $R^{*:}$  depends on the required system clock frequency (R=51k\Omega~620k\Omega, at V\_{DD}=3V)



## Instruction Set Summary

| Mnemonic                   | Description                               | Byte | Cycle | CF           |
|----------------------------|-------------------------------------------|------|-------|--------------|
| Arithmetic                 |                                           |      |       |              |
| ADD A,[R1R0]               | Add data memory to ACC                    | 1    | 1     | $\checkmark$ |
| ADC A, [R1R0]              | Add data memory with carry to ACC         | 1    | 1     |              |
| SUB A, [R1R0]              | Subtract data memory from ACC             | 1    | 1     | $\checkmark$ |
| SBC A, [R1R0]              | Subtract data memory from ACC with borrow | 1    | 1     |              |
| ADD A,XH                   | Add immediate data to ACC                 | 2    | 2     | $\checkmark$ |
| SUB A,XH                   | Subtract immediate data from ACC          | 2    | 2     | $\checkmark$ |
| DAA                        | Decimal adjust ACC for addition           | 1    | 1     | $\checkmark$ |
| Logic Operation            |                                           |      |       |              |
| AND A, [R1R0]              | AND data memory to ACC                    | 1    | 1     | _            |
| OR A, [R1R0]               | OR data memory to ACC                     | 1    | 1     | —            |
| XOR A, [R1R0]              | Exclusive-OR data memory to ACC           | 1    | 1     | —            |
| AND [R1R0],A               | AND ACC to data memory                    | 1    | 1     | —            |
| OR [R1R0],A                | OR ACC to data memory                     | 1    | 1     | —            |
| XOR [R1R0],A               | Exclusive-OR ACC to data memory           | 1    | 1     | —            |
| AND A,XH                   | AND immediate data to ACC                 | 2    | 2     | —            |
| OR A,XH                    | OR immediate data to ACC                  | 2    | 2     | —            |
| XOR A,XH                   | Exclusive-OR immediate data to ACC        | 2    | 2     | —            |
| Increment and<br>Decrement |                                           |      |       |              |
| INC A                      | Increment ACC                             | 1    | 1     | _            |
| INC Rn                     | Increment register                        | 1    | 1     | _            |
| INC [R1R0]                 | Increment data memory                     | 1    | 1     | —            |
| INC [R3R2]                 | Increment data memory                     | 1    | 1     | —            |
| DEC A                      | Decrement ACC                             | 1    | 1     | —            |
| DEC Rn                     | Decrement register                        | 1    | 1     | —            |
| DEC [R1R0]                 | Decrement data memory                     | 1    | 1     | —            |
| DEC [R3R2]                 | Decrement data memory                     | 1    | 1     |              |
| Data Move                  |                                           |      |       |              |
| MOV A,Rn                   | Move register to ACC                      | 1    | 1     | —            |
| MOV Rn,A                   | Move ACC to register                      | 1    | 1     | —            |
| MOV A,[R1R0]               | Move data memory to ACC                   | 1    | 1     | <br>         |
| MOV A,[R3R2]               | Move data memory to ACC                   | 1    | 1     | —            |
| MOV [R1R0],A               | Move ACC to data memory                   | 1    | 1     | —            |
| MOV [R3R2],A               | Move ACC to data memory                   | 1    | 1     | —            |
| MOV A,XH                   | Move immediate data to ACC                | 1    | 1     | —            |
| MOV R1R0,XXH               | Move immediate data to R1 and R0          | 2    | 2     | —            |
| MOV R3R2,XXH               | Move immediate data to R3 and R2          | 2    | 2     | —            |
| MOV R4,XH                  | Move immediate data to R4                 | 2    | 2     | —            |



| Mnemonic         | Description                                    | Byte        | Cycle       | CF           |
|------------------|------------------------------------------------|-------------|-------------|--------------|
| Rotate           |                                                |             |             |              |
| RL A             | Rotate ACC left                                | 1           | 1           | $\checkmark$ |
| RLC A            | Rotate ACC left through the carry              | 1           | 1           | $\checkmark$ |
| RR A             | Rotate ACC right                               | 1           | 1           | $\checkmark$ |
| RRC A            | Rotate ACC right through the carry             | 1           | 1           | $\checkmark$ |
| Input & Output   |                                                |             |             |              |
| IN A,Pi          | Input port-i to ACC, port-i=PS, PP             | 1           | 1           | _            |
| OUT PA,A         | Output ACC to port-A                           | 1           | 1           | _            |
| Branch           |                                                |             |             |              |
| JMP addr         | Jump unconditional                             | 2           | 2           | _            |
| JC addr          | Jump on carry=1                                | 2           | 2           | _            |
| JNC addr         | Jump on carry=0                                | 2           | 2           | _            |
| JTMR addr        | Jump on timer out                              | 2           | 2           | _            |
| JAn addr         | Jump on ACC bit $n=1$ , $n=0,1,2,3$            | $\tilde{2}$ | $\tilde{2}$ | _            |
| JZ A,addr        | Jump on ACC is zero                            | 2           | 2           | _            |
| JNZ A,addr       | Jump on ACC is not zero                        | 2           | 2           | _            |
| JNZ Rn,addr      | Jump on register Rn not zero, n=0,1,4          | 2           | 2           |              |
| Subroutine       |                                                |             |             |              |
| CALL addr        | Subroutine call                                | 2           | 2           | _            |
| RET              | Return from subroutine or interrupt            | 1           | 1           | _            |
| RETI             | Return from interrupt service routine          | 1           | 1           |              |
| Flag             | -                                              |             |             |              |
| CLC              | Clear carry flag                               | 1           | 1           | 0            |
| STC              | Set carry flag                                 | 1           | 1           | 1            |
| EI               | Enable interrupt                               | 1           | 1           | _            |
| DI               | Disable interrupt                              | 1           | 1           | _            |
| NOP              | No operation                                   | 1           | 1           | —            |
| Timer            |                                                |             |             |              |
| TIMER XXH        | Set 8 bits immediate data to TIMER             | 2           | 2           |              |
| TIMER ON         | Set TIMER to start counting                    | 1           | 1           | _            |
| TIMER OFF        | Set TIMER to stop counting                     | 1           | 1           | _            |
| MOV A,TMRL       | Move low nibble of TIMER to ACC                | 1           | 1           | _            |
| MOV A,TMRH       | Move high nibble of TIMER to ACC               | 1           | 1           | _            |
| MOV TMRL,A       | Move ACC to low nibble of TIMER                | 1           | 1           | _            |
| MOV TMRH,A       | Move ACC to high nibble of TIMER               | 1           | 1           | _            |
| Table Read       |                                                |             |             |              |
| READ R4A         | Read ROM code of current page to R4 & ACC      | 1           | 2           | _            |
| READ MR0A        | Read ROM code of current page to M(R1,R0), ACC | 1           | 2           | _            |
| <b>READF R4A</b> | Read ROM code of page F to R4 & ACC            | 1           | 2           | _            |
| READF MR0A       | Read ROM code of page F to M(R1,R0), ACC       | 1           | 2           | _            |



| Mnemonic      | Description                           | Byte | Cycle | CF |
|---------------|---------------------------------------|------|-------|----|
| Sound Control |                                       |      |       |    |
| SOUND n       | Active SOUND channel n                | 2    | 2     | _  |
| SOUND A       | Active SOUND channel with Accumulator | 1    | 1     |    |
| SOUND ONE     | Turn on SOUND one mode                | 1    | 1     |    |
| SOUND LOOP    | Turn on SOUND repeat mode             | 1    | 1     | _  |
| SOUND OFF     | Turn off SOUND                        | 1    | 1     | _  |
| Miscellaneous |                                       |      |       |    |
| HALT          | Enter power down mode                 | 2    | 2     | _  |



## **Instruction Definitions**

| ADC A,[R1R0] | Add data memory contents and carry to accumulator                                                                                     |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Machine code | 0 0 0 0 1 0 0 0                                                                                                                       |
| Description  | The contents of the data memory addressed by the register pair "R1,R0" and the carry are added to the accumulator. Carry is affected. |
| Operation    | $ACC \leftarrow ACC+M(R1,R0)+CF$                                                                                                      |
| ADD A,XH     | Add immediate data to accumulator                                                                                                     |
| Machine code | 0100000 0000 d d d d                                                                                                                  |
| Description  | The specified data is added to the accumulator. Carry is affected.                                                                    |
| Operation    | $ACC \leftarrow ACC + XH$                                                                                                             |
| ADD A,[R1R0] | Add data memory contents to accumulator                                                                                               |
| Machine code | 0 0 0 0 1 0 0 1                                                                                                                       |
| Description  | The contents of the data memory addressed by the register pair "R1,R0" is added to the accumulator. Carry is affected.                |
| Operation    | $ACC \leftarrow ACC+M(R1,R0)$                                                                                                         |
| AND A,XH     | Logical AND immediate data to accumulator                                                                                             |
| Machine code | 0100010 0000dddd                                                                                                                      |
| Description  | Data in the accumulator is logical AND with the immediate data specified by the code.                                                 |
| Operation    | $ACC \leftarrow ACC$ "AND" XH                                                                                                         |
| AND A,[R1R0] | Logical AND accumulator with data memory                                                                                              |
| Machine code | 0 0 0 1 1 0 1 0                                                                                                                       |
| Description  | Data in the accumulator is logical AND with the data memory addressed by the register pair "R1,R0".                                   |
| Operation    | $ACC \leftarrow ACC \text{ "AND" } M(R1,R0)$                                                                                          |
| AND [R1R0],A | Logical AND data memory with accumulator                                                                                              |
| Machine code | 0 0 0 1 1 1 0 1                                                                                                                       |
| Description  | Data in the data memory addressed by the register pair "R1,R0" is logical AND with the accumulator                                    |
| Operation    | $M(R1,R0) \leftarrow M(R1,R0)$ "AND" ACC                                                                                              |



| CALL address | Subroutine call                                                                                                                               |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code | 1111aaaa aaaaaaaa                                                                                                                             |
| Description  | The program counter bits $0{\sim}11$ are saved in the stack and the specified address loaded into the program counter.                        |
| Operation    | $\begin{array}{l} Stack \leftarrow PC+2 \\ PC \leftarrow address \end{array}$                                                                 |
| CLC          | Clear carry flag                                                                                                                              |
| Machine code | 0 0 1 0 1 0 1 0                                                                                                                               |
| Description  | The carry flag is reset to 0                                                                                                                  |
| Operation    | $CF \leftarrow 0$                                                                                                                             |
| DAA          | Decimal-Adjust accumulator                                                                                                                    |
| Machine code | 0 0 1 1 0 1 1 0                                                                                                                               |
| Description  | The accumulator value is adjusted to BCD (Binary Code Decimal), if the contents of the accumulator is greater than 9 or CF (Carry flag) is 1. |
| Operation    | If ACC>9 or CF=1 then<br>ACC $\leftarrow$ ACC+6, CF $\leftarrow$ 1<br>else<br>ACC $\leftarrow$ ACC, CF $\leftarrow$ CF                        |
| DEC A        | Decrement accumulator                                                                                                                         |
| Machine code | 00111111                                                                                                                                      |
| Description  | Data in the accumulator is decremented by 1. Carry flag is not affected.                                                                      |
| Operation    | $ACC \leftarrow ACC-1$                                                                                                                        |
| DEC Rn       | Decrement register                                                                                                                            |
| Machine code | 0 0 0 1 n n n 1                                                                                                                               |
| Description  | Data in the working register "Rn" is decremented by 1. Carry flag is not affected.                                                            |
| Operation    | $Rn \leftarrow Rn-1; Rn=R0,R1,R2,R3,R4, \text{ for }nnn=0,1,2,3,4$                                                                            |
| DEC [R1R0]   | Decrement data memory                                                                                                                         |
| Machine code | 0 0 0 0 1 1 0 1                                                                                                                               |
| Description  | Data in the data memory specified by the register pair "R1,R0" is decre-<br>mented by 1. Carry flag is not affected.                          |
| Operation    | $M(R1,R0) \leftarrow M(R1,R0) - 1$                                                                                                            |

# 

| DEC [R3R2]<br>Machine code<br>Description<br>Operation | Decrement data memory<br>$0\ 0\ 0\ 0\ 1\ 1\ 1\ 1$<br>Data in the data memory specified by the register pair "R3,R2" is decre-<br>mented by 1. Carry flag is not affected.<br>$M(R3,R2) \leftarrow M(R3,R2)-1$ |
|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -                                                      |                                                                                                                                                                                                               |
| DI                                                     | Disable interrupt                                                                                                                                                                                             |
| Machine code                                           |                                                                                                                                                                                                               |
| Description                                            | Internal time-out interrupt and external interrupt are disabled.                                                                                                                                              |
| EI                                                     | Enable interrupt                                                                                                                                                                                              |
| Machine code                                           | 00101100                                                                                                                                                                                                      |
| Description                                            | Internal time-out interrupt and external interrupt are enabled.                                                                                                                                               |
| HALT                                                   | Halt system clock                                                                                                                                                                                             |
| Machine code                                           | 00110111 00111110                                                                                                                                                                                             |
| Description                                            | Turn off system clock, and enter power down mode.                                                                                                                                                             |
| Operation                                              | $PC \leftarrow PC+2$                                                                                                                                                                                          |
| IN A,Pi                                                | Input port to accumulator                                                                                                                                                                                     |
| Machine code                                           | 00110011 PS<br>00110100 PP                                                                                                                                                                                    |
| Description                                            | The data on port "Pi" is transferred to the accumulator.                                                                                                                                                      |
| Operation                                              | $ACC \leftarrow Pi; Pi=PS \text{ or } PP$                                                                                                                                                                     |
| INC A                                                  | Increment accumulator                                                                                                                                                                                         |
| Machine code                                           | 00110001                                                                                                                                                                                                      |
| Description                                            | Data in the accumulator is incremented by 1. Carry flag is not affected.                                                                                                                                      |
| Operation                                              | $ACC \leftarrow ACC+1$                                                                                                                                                                                        |
| INC Rn                                                 | Increment register                                                                                                                                                                                            |
| Machine code                                           | 0 0 0 1 n n n 0                                                                                                                                                                                               |
| Description                                            | Data in the working register "Rn" is incremented by 1. Carry flag is not affected.                                                                                                                            |
| Operation                                              | $Rn \leftarrow Rn+1; Rn=R0\sim R4$ for nnn=0~4                                                                                                                                                                |
| INC [R1R0]                                             | Increment data memory                                                                                                                                                                                         |
| Machine code                                           | 00001100                                                                                                                                                                                                      |
| Description                                            | Data in the data memory specified by the register pair "R1,R0" is incre-<br>mented by 1. Carry flag is not affected.                                                                                          |
| Operation                                              | $M(R1,R0) \leftarrow M(R1,R0) + 1$                                                                                                                                                                            |

21



| INC [R3R2]                                                                                                           | Increment data memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code                                                                                                         | 0 0 0 0 1 1 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Description                                                                                                          | Data memory specified by the register pair "R3,R2" is incremented by 1.<br>Carry flag is not affected.                                                                                                                                                                                                                                                                                                                                                                                   |
| Operation                                                                                                            | $M(R3,R2) \leftarrow M(R3,R2) + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| JAn address                                                                                                          | Jump if accumulator bit n is set                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Machine code                                                                                                         | 100nnaaa aaaaaaaa                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Description                                                                                                          | Bits $0~10$ of the program counter are replaced with the directly-specified address but bit 11 of the program counter is unaffected, if accumulator bit n is set to 1.                                                                                                                                                                                                                                                                                                                   |
| Operation                                                                                                            | PC (bit 0~10) $\leftarrow$ address, if ACC bit n=1(n=0~3)<br>PC $\leftarrow$ PC+2, if ACC bit n=0                                                                                                                                                                                                                                                                                                                                                                                        |
| JC address                                                                                                           | Jump if carry is set                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Machine code                                                                                                         | 11000aaa aaaaaaa                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Description                                                                                                          | Bits 0~10 of the program counter are replaced with the directly-specified address but bit 11 of the program counter is unaffected, if the CF (Carry flag) is set to 1.                                                                                                                                                                                                                                                                                                                   |
| Operation                                                                                                            | PC (bit 0~10) $\leftarrow$ address, if CF=1<br>PC $\leftarrow$ PC+2, if CF=0                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| JMP address                                                                                                          | Direct jump                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| JMP address<br>Machine code                                                                                          | Direct jump<br>1110aaaa aaaaaaa                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Machine code                                                                                                         | 1110aaaa aaaaaaa<br>Bits 0~11 of the program counter are replaced with the directly-specified                                                                                                                                                                                                                                                                                                                                                                                            |
| Machine code<br>Description                                                                                          | 1110aaaa aaaaaaa<br>Bits 0~11 of the program counter are replaced with the directly-specified<br>address.                                                                                                                                                                                                                                                                                                                                                                                |
| Machine code<br>Description<br>Operation                                                                             | <ul> <li>1 1 1 0 a a a a a a a a a a a a a a a a</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Machine code<br>Description<br>Operation<br>JNC address                                                              | <ul> <li>1 1 1 0 a a a a a a a a a a a a a a a a</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Machine code<br>Description<br>Operation<br>JNC address<br>Machine code                                              | <ul> <li>1 1 1 0 a a a a a a a a a a a a a a a a</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Machine code<br>Description<br>Operation<br>JNC address<br>Machine code<br>Description                               | <pre>1 1 1 0 a a a a a a a a a a a a a a a a</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Machine code<br>Description<br>Operation<br>JNC address<br>Machine code<br>Description<br>Operation                  | 1 1 1 0 a a a aa a a a a a a a a aBits 0~11 of the program counter are replaced with the directly-specifiedaddress.PC $\leftarrow$ addressJump if carry is not set1 1 0 0 1 a a aa a a a a a a aBits 0~10 of the program counter are replaced with the directly-specifiedaddress and bit 11 of the program counter is unaffected, if the CF (Carry flag)is set to 0.PC (bit 0~10) $\leftarrow$ address, if CF=0PC $\leftarrow$ PC+2, if CF=1                                             |
| Machine code<br>Description<br>Operation<br>JNC address<br>Machine code<br>Description<br>Operation<br>JNZ A,address | 1 1 1 0 a a a aa a a a a a a a a aBits 0~11 of the program counter are replaced with the directly-specified<br>address.PC $\leftarrow$ addressJump if carry is not set1 1 0 0 1 a a aa a a a a a a aBits 0~10 of the program counter are replaced with the directly-specified<br>address and bit 11 of the program counter is unaffected, if the CF (Carry flag)<br>is set to 0.PC (bit 0~10) $\leftarrow$ address, if CF=0<br>PC $\leftarrow$ PC+2, if CF=1Jump if accumulator is not 0 |



| JNZ Rn,address | Jump if register is not 0                                                                                                                                                |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code   | 10100aaa aaaaaaa R0                                                                                                                                                      |
|                | 10101aaa aaaaaaa R1                                                                                                                                                      |
|                | 11011aaa aaaaaaa R4                                                                                                                                                      |
| Description    | Bits $0~10$ of the program counter are replaced with the directly-specified address but bit 11 of the program counter is unaffected, if the register is not 0.           |
| Operation      | PC (bit 0~10) $\leftarrow$ address, if Rn≠0; Rn=R0,R1,R4 PC $\leftarrow$ PC+2, if Rn=0                                                                                   |
| JTMR address   | Jump if time-out                                                                                                                                                         |
| Machine code   | 11010aaa aaaaaaaa                                                                                                                                                        |
| Description    | Bits $0~10$ of the program counter are replaced with the directly-specified address but bit 11 of the program counter is unaffected, if the TF (Timer flag) is set to 1. |
| Operation      | PC (bit $0 \sim 10$ ) $\leftarrow$ address, if TF=1<br>PC $\leftarrow$ PC+2, if TF=0                                                                                     |
| JZ A,address   | Jump if accumulator is 0                                                                                                                                                 |
| Machine code   | 10110aaa aaaaaaaa                                                                                                                                                        |
| Description    | Bits $0\sim10$ of the program counter are replaced with the directly-specified address but bit 11 of the program counter is unaffected, if the accumulator is 0.         |
| Operation      | PC (bit $0 \sim 10$ ) $\leftarrow$ address, if ACC=0<br>PC $\leftarrow$ PC+2, if ACC $\neq 0$                                                                            |
| MOV A,Rn       | Move register to accumulator                                                                                                                                             |
| Machine code   | 0 0 1 0 n n n 1                                                                                                                                                          |
| Description    | Data in the working register "Rn" is moved to the accumulator.                                                                                                           |
| Operation      | ACC $\leftarrow$ Rn; Rn=R0~R4, for nnn=0~4                                                                                                                               |
| MOV A,TMRH     | Move timer high nibble to accumulator                                                                                                                                    |
| Machine code   | 0 0 1 1 1 0 1 1                                                                                                                                                          |
| Description    | The high nibble data of the timer counter is loaded to the accumulator.                                                                                                  |
| Operation      | $ACC \leftarrow TIMER$ (high nibble)                                                                                                                                     |
| MOV A,TMRL     | Move timer low nibble to accumulator                                                                                                                                     |
| Machine code   | 00111010                                                                                                                                                                 |
| Description    | The low nibble data of the timer counter is loaded to the accumulator.                                                                                                   |
| Operation      | $ACC \leftarrow TIMER$ (low nibble)                                                                                                                                      |
|                |                                                                                                                                                                          |



| ΜΟΥ Α,ΧΗ     | Move immediate data to accumulator                                                                                                                        |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code | 0 1 1 1 d d d d                                                                                                                                           |
| Description  | The 4-bit data specified by the code is loaded to the accumulator.                                                                                        |
| Operation    | $ACC \leftarrow XH$                                                                                                                                       |
| MOV A,[R1R0] | Move data memory to accumulator                                                                                                                           |
| Machine code | 0 0 0 0 1 0 0                                                                                                                                             |
| Description  | Data in the data memory specified by the register pair "R1,R0" is moved to the accumulator.                                                               |
| Operation    | $ACC \leftarrow M(R1,R0)$                                                                                                                                 |
| MOV A,[R3R2] | Move data memory to accumulator                                                                                                                           |
| Machine code | 0 0 0 0 0 1 1 0                                                                                                                                           |
| Description  | Data in the data memory specified by the register pair "R3,R2" is moved to the accumulator.                                                               |
| Operation    | $ACC \leftarrow M(R3,R2)$                                                                                                                                 |
| MOV R1R0,XXH | Move immediate data to R1 and R0                                                                                                                          |
| Machine code | 0101dddd 0000dddd                                                                                                                                         |
| Description  | The 8-bit data specified by the code is loaded to the working registers R1 and R0, the high nibble of the data is loaded to R1, and the low nibble to R0. |
| Operation    | $\begin{array}{l} \text{R1} \leftarrow \text{XH (high nibble)} \\ \text{R0} \leftarrow \text{XH (low nibble)} \end{array}$                                |
| MOV R3R2,XXH | Move immediate data to R3 and R2                                                                                                                          |
| Machine code | 0110dddd 0000dddd                                                                                                                                         |
| Description  | The 8-bit data specified by the code is loaded to the working registers R3 and R2, the high nibble of the data is loaded to R3, and the low nibble to R2. |
| Operation    | $\begin{array}{l} \text{R3} \leftarrow \text{XH (high nibble)} \\ \text{R2} \leftarrow \text{XH (low nibble)} \end{array}$                                |
| MOV R4,XH    | Move immediate data to R4                                                                                                                                 |
| Machine code | 01000110 0000dddd                                                                                                                                         |
| Description  | The 4-bit data specified by the code is loaded to the working register R4.                                                                                |
| Operation    | $R4 \leftarrow XH$                                                                                                                                        |
| MOV Rn,A     | Move accumulator to register                                                                                                                              |
| Machine code | 0 0 1 0 n n n 0                                                                                                                                           |
| Description  | Data in the accumulator is moved to the working register "Rn".                                                                                            |
| Operation    | $Rn \leftarrow ACC; Rn=R0\sim R4$ , for nnn=0~4                                                                                                           |



| MOV TMRH,A   | Move accumulator to timer high nibble                                                              |
|--------------|----------------------------------------------------------------------------------------------------|
| Machine code | 00111101                                                                                           |
| Description  | The contents of the accumulator is loaded to the high nibble of the timer counter.                 |
| Operation    | TIMER(high nibble) $\leftarrow$ ACC                                                                |
| MOV TMRL,A   | Move accumulator to timer low nibble                                                               |
| Machine code | 00111100                                                                                           |
| Description  | The contents of the accumulator is loaded to the low nibble of the timer counter.                  |
| Operation    | $TIMER(low nibble) \leftarrow ACC$                                                                 |
| MOV [R1R0],A | Move accumulator to data memory                                                                    |
| Machine code | 0 0 0 0 1 0 1                                                                                      |
| Description  | Data in the accumulator is moved to the data memory specified by the register pair "R1,R0".        |
| Operation    | $M(R1,R0) \leftarrow ACC$                                                                          |
| MOV [R3R2],A | Move accumulator to data memory                                                                    |
| Machine code | 0 0 0 0 1 1 1                                                                                      |
| Description  | Data in the accumulator is moved to the data memory specified by the register pair "R3,R2".        |
| Operation    | $M(R3,R2) \leftarrow ACC$                                                                          |
| NOP          | No operation                                                                                       |
| Machine code | 00111110                                                                                           |
| Description  | Do nothing, but one instruction cycle is delayed.                                                  |
| OR A,XH      | Logical OR immediate data to accumulator                                                           |
| Machine code | 01000100 0000dddd                                                                                  |
| Description  | Data in the accumulator is logical OR with the immediate data specified by the code.               |
| Operation    | $ACC \leftarrow ACC "OR" XH$                                                                       |
| OR A,[R1R0]  | Logical OR accumulator with data memory                                                            |
| Machine code | 00011100                                                                                           |
| Description  | Data in the accumulator is logical OR with the data memory addressed by the register pair "R1,R0". |
| Operation    | $ACC \leftarrow ACC "OR" M(R1,R0)$                                                                 |



| OR [R1R0],A  | Logically OR data memory with accumulator                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code | 00011111                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Description  | Data in the data memory addressed by the register pair "R1,R0" is logical OR with the accumulator.                                                                                                                                                                                                                                                                                                                                                          |
| Operation    | $M(R1,R0) \leftarrow M(R1,R0)$ "OR" ACC                                                                                                                                                                                                                                                                                                                                                                                                                     |
| OUT PA,A     | Output accumulator data to port A                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Machine code | 00110000                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Description  | The data in the accumulator is transferred to port PA and latched.                                                                                                                                                                                                                                                                                                                                                                                          |
| Operation    | $PA \leftarrow ACC$                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| READ MR0A    | Read ROM code of current page to M(R1,R0) and ACC                                                                                                                                                                                                                                                                                                                                                                                                           |
| Machine code | 01001110                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Description  | The 8-bit ROM code (current page) addressed by ACC and R4 is moved to the data memory M(R1,R0) and the accumulator. The high nibble of the ROM code is loaded to M(R1,R0) and the low nibble of the ROM code is loaded to the accumulator. The address of the ROM code is specified below:<br>Current page $\rightarrow$ ROM code address bit 11~8<br>ACC $\rightarrow$ ROM code address bit 7~4<br>R4 $\rightarrow$ ROM code address bit 3~0               |
| Operation    | $M(R1,R0) \leftarrow ROM \text{ code (high nibble)}$<br>$ACC \leftarrow ROM \text{ code (low nibble)}$                                                                                                                                                                                                                                                                                                                                                      |
| READ R4A     | Read ROM code of current page to R4 and accumulator                                                                                                                                                                                                                                                                                                                                                                                                         |
| Machine code | 01001100                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Description  | The 8-bit ROM code (current page) addressed by ACC and M(R1,R0) is moved<br>to the working register R4 and the accumulator. The high nibble of the ROM<br>code is loaded to R4 and the low nibble of the ROM code is loaded to the<br>accumulator. The address of the ROM code is specified below:<br>Current page $\rightarrow$ ROM code address bit 11~8<br>ACC $\rightarrow$ ROM code address bit 7~4<br>M(R1,R0) $\rightarrow$ ROM code address bit 3~0 |
| Operation    | $R4 \leftarrow ROM$ code (high nibble)<br>ACC $\leftarrow ROM$ code (low nibble)                                                                                                                                                                                                                                                                                                                                                                            |



| READF MR0A   | Read ROM Code of page F to M(R1,R0) and ACC                                                                                                                                                                                                                                                                                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code | 01001111                                                                                                                                                                                                                                                                                                                                                                                              |
| Description  | The 8-bit ROM code (page F) addressed by ACC and R4 is moved to the data<br>memory M(R1,R0) and the accumulator. The high nibble of the ROM code is<br>loaded to M(R1,R0) and the low nibble of the ROM code is loaded to the<br>accumulator.<br>Page F $\rightarrow$ ROM code address bit 11~8 are "1111"<br>ACC $\rightarrow$ ROM code address bit 7~4<br>R4 $\rightarrow$ ROM code address bit 3~0 |
| Operation    | $M(R1,R0) \leftarrow high nibble of ROM code (page F)$<br>ACC $\leftarrow$ low nibble of ROM code (page F)                                                                                                                                                                                                                                                                                            |
| READF R4A    | Read ROM code of page F to R4 and accumulator                                                                                                                                                                                                                                                                                                                                                         |
| Machine code | 01001101                                                                                                                                                                                                                                                                                                                                                                                              |
| Description  | The 8-bit ROM code (page F) addressed by ACC and M(R1,R0) is moved to the working register R4 and the accumulator. The high nibble of the ROM code is loaded to R4 and the low nibble of the ROM code is loaded to the accumulator.<br>Page F $\rightarrow$ ROM code address bit 11~8 are "1111"<br>ACC $\rightarrow$ ROM code address bit 7~4<br>M(R1,R0) $\rightarrow$ ROM code address bit 3~0     |
| Operation    | $\begin{array}{l} R4 \leftarrow high \ nibble \ of \ ROM \ code \ (page \ F) \\ ACC \leftarrow low \ nibble \ of \ ROM \ code \ (page \ F) \end{array}$                                                                                                                                                                                                                                               |
| RET          | Return from subroutine or interrupt                                                                                                                                                                                                                                                                                                                                                                   |
| Machine code | 00101110                                                                                                                                                                                                                                                                                                                                                                                              |
| Description  | The program counter bits 0~11 are restored from the stack.                                                                                                                                                                                                                                                                                                                                            |
| Operation    | $PC \leftarrow Stack$                                                                                                                                                                                                                                                                                                                                                                                 |
| RETI         | Return from interrupt subroutine                                                                                                                                                                                                                                                                                                                                                                      |
| Machine code | 00101111                                                                                                                                                                                                                                                                                                                                                                                              |
| Description  | The program counter bits 0~11 are restored from the stack. The carry flag is restored before entering the interrupt service routine.                                                                                                                                                                                                                                                                  |
| Operation    | $PC \leftarrow Stack$<br>$CF \leftarrow CF$ (before interrupt service routine)                                                                                                                                                                                                                                                                                                                        |
| RLA          | Rotate accumulator left                                                                                                                                                                                                                                                                                                                                                                               |
| Machine code | 0 0 0 0 0 0 1                                                                                                                                                                                                                                                                                                                                                                                         |
| Description  | The contents of the accumulator are rotated left by 1 bit. Bit 3 is rotated to both bit 0 and the carry flag.                                                                                                                                                                                                                                                                                         |
| Operation    | An+1 $\leftarrow$ An, An: accumulator bit n (n=0,1,2)<br>A0 $\leftarrow$ A3<br>CF $\leftarrow$ A3                                                                                                                                                                                                                                                                                                     |



| RLC A        | Rotate accumulator left through carry                                                                                                                                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code | 0 0 0 0 0 1 1                                                                                                                                                                                                                              |
| Description  | The contents of the accumulator are rotated left by 1 bit. Bit 3 replaces the carry bit, which is rotated into the bit 0 position.                                                                                                         |
| Operation    | $\begin{array}{l} An+1 \leftarrow An,  An:  Accumulator  bit  n  (n=0,1,2) \\ A0 \leftarrow CF \\ CF \ \leftarrow A3 \end{array}$                                                                                                          |
| RR A         | Rotate accumulator right                                                                                                                                                                                                                   |
| Machine code | 0 0 0 0 0 0 0 0                                                                                                                                                                                                                            |
| Description  | The contents of the accumulator are rotated right by 1 bit. Bit 0 is rotated to both bit 3 and the carry flag.                                                                                                                             |
| Operation    | An $\leftarrow$ An+1, An: Accumulator bit n (n=0,1,2)<br>A3 $\leftarrow$ A0<br>CF $\leftarrow$ A0                                                                                                                                          |
| RRC A        | Rotate accumulator right through carry                                                                                                                                                                                                     |
| Machine code | 0 0 0 0 0 1 0                                                                                                                                                                                                                              |
| Description  | The contents of the accumulator are rotated right by 1 bit. Bit 0 replaces the carry bit, which is rotated into the bit 3 position.                                                                                                        |
| Operation    | An $\leftarrow$ An+1, An: Accumulator bit n (n=0,1,2)<br>A3 $\leftarrow$ CF<br>CF $\leftarrow$ A0                                                                                                                                          |
| SBC A,[R1R0] | Subtract data memory contents and carry from ACC                                                                                                                                                                                           |
| Machine code | 0 0 0 0 1 0 1 0                                                                                                                                                                                                                            |
| Description  | The contents of the data memory addressed by the register pair "R1,R0" and<br>the complement of the carry are subtracted from the accumulator. Carry is<br>set if a borrow does not take place in subtraction; otherwise carry is cleared. |
| Operation    | $ACC \leftarrow ACC + \overline{M(R1,R0)} + CF$                                                                                                                                                                                            |
| SOUND A      | Activate SOUND channel with accumulator                                                                                                                                                                                                    |
| Machine code | 01001011                                                                                                                                                                                                                                   |
| Description  | The activated sound begins playing in accordance with the contents of accumulator when the specified sound channel is matched.                                                                                                             |
| SOUND LOOP   | Turn on sound repeat cycle                                                                                                                                                                                                                 |
| Machine code | 01001001                                                                                                                                                                                                                                   |
| Description  | The activated sound plays repeatedly.                                                                                                                                                                                                      |



| SOUND OFF    | Turn off sound                                                                                                                                                                                            |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine code | 01001010                                                                                                                                                                                                  |
| Description  | The activated sound will terminate immediately.                                                                                                                                                           |
| -            |                                                                                                                                                                                                           |
| SOUND ONE    | Turn on sound one cycle                                                                                                                                                                                   |
| Machine code | 0 1 0 0 1 0 0 0                                                                                                                                                                                           |
| Description  | The activated sound plays once.                                                                                                                                                                           |
| SOUND n      | Activate SOUND channel n                                                                                                                                                                                  |
| Machine code | 01000101 0000nnnn                                                                                                                                                                                         |
| Description  | The specified sound begins playing and overwrites the previous activated sound. (nnnn=0~15)                                                                                                               |
| STC          | Set carry flag                                                                                                                                                                                            |
| Machine code | 0 0 1 0 1 0 1 1                                                                                                                                                                                           |
| Description  | The carry flag is set to one.                                                                                                                                                                             |
| Operation    | $CF \leftarrow 1$                                                                                                                                                                                         |
| SUB A,XH     | Subtract immediate data from accumulator                                                                                                                                                                  |
| Machine code | 0100001 0000dddd                                                                                                                                                                                          |
| Description  | The specified data is subtracted from the accumulator. Carry is set if a borrow does not take place in subtraction; otherwise carry is cleared.                                                           |
| Operation    | $ACC \leftarrow ACC + \overline{XH} + 1$                                                                                                                                                                  |
| SUB A,[R1R0] | Subtract data memory contents from accumulator                                                                                                                                                            |
| Machine code | 0 0 0 0 1 0 1 1                                                                                                                                                                                           |
| Description  | The contents of the data memory addressed by the register pair "R1,R0" is<br>subtracted from the accumulator. Carry is set if a borrow does not take place<br>in subtraction; otherwise carry is cleared. |
| Operation    | $ACC \leftarrow ACC + \overline{M(R1,R0)} + 1$                                                                                                                                                            |
| TIMER OFF    | Set timer to stop counting                                                                                                                                                                                |
| Machine code | 00111001                                                                                                                                                                                                  |
| Description  | The timer stops counting, when the "TIMER OFF" instruction is executed.                                                                                                                                   |
| TIMER ON     | Set timer to start counting                                                                                                                                                                               |
| Machine code | 00111000                                                                                                                                                                                                  |
| Description  | The timer starts counting, when the "TIMER ON" instruction is executed.                                                                                                                                   |



| TIMER XXH    | Set immediate data to timer counter                                                                          |
|--------------|--------------------------------------------------------------------------------------------------------------|
| Machine code | 01000111 ddddddd                                                                                             |
| Description  | The 8-bit data specified by the code is loaded to the timer counter.                                         |
| Operation    | $TIMER \leftarrow XXH$                                                                                       |
| XOR A,XH     | Logical XOR immediate data to accumulator                                                                    |
| Machine code | 0100011 0000dddd                                                                                             |
| Description  | Data in the accumulator is Exclusive-OR with the immediate data specified by the code.                       |
| Operation    | $ACC \leftarrow ACC$ "XOR" XH                                                                                |
| XOR A,[R1R0] | Logical XOR accumulator with data memory                                                                     |
| Machine code | 00011011                                                                                                     |
| Description  | Data in the accumulator is Exclusive-OR with the data memory addressed by the register pair "R1,R0".         |
| Operation    | $ACC \leftarrow ACC$ "XOR" M(R1,R0)                                                                          |
| XOR [R1R0],A | Logical XOR data memory with accumulator                                                                     |
| Machine code | 0 0 0 1 1 1 1 0                                                                                              |
| Description  | Data in the data memory addressed by the register pair "R1,R0" is logical Exclusive-OR with the accumulator. |
| Operation    | $M(R1,R0) \leftarrow M(R1,R0)$ "XOR" ACC                                                                     |



Holtek Semiconductor Inc. (Headquarters) No.3 Creation Rd. II, Science-based Industrial Park, Hsinchu, Taiwan, R.O.C. Tel: 886-3-563-1999 Fax: 886-3-563-1189

Holtek Semiconductor Inc. (Taipei Office) 5F, No.576, Sec.7 Chung Hsiao E. Rd., Taipei, Taiwan, R.O.C. Tel: 886-2-2782-9635

Fax: 886-2-2782-9636 Fax: 886-2-2782-7128 (International sales hotline)

Holtek Microelectronics Enterprises Ltd.

RM.711, Tower 2, Cheung Sha Wan Plaza, 833 Cheung Sha Wan Rd., Kowloon, Hong Kong Tel: 852-2-745-8288 Fax: 852-2-742-8657

Copyright © 1999 by HOLTEK SEMICONDUCTOR INC.

The information appearing in this Data Sheet is believed to be accurate at the time of publication. However, Holtek assumes no responsibility arising from the use of the specifications described. The applications mentioned herein are used solely for the purpose of illustration and Holtek makes no warranty or representation that such applications will be suitable without further modification, nor recommends the use of its products for application that may present a risk to human life due to malfunction or otherwise. Holtek reserves the right to alter its products without prior notification. For the most up-to-date information, please visit our web site at http://www.holtek.com.tw.

31