

# HTG12B0 4-Bit Microcontroller

## Features

- Operating voltage: 2.4V~3.6V
- Eight input lines
- Eight input/output lines
- Five working registers
- $\bullet \quad 4K \times 8 \times 4 \ program \ ROM$
- + 128  $\times$  4  $\times$  8 (4096) bits data memory RAM
- Sound effect circuit
- $40 \text{ segment} \times 16 \text{ common}, 1/4 \text{ bias LCD driver}$
- LCD output is fixed at 4.4V

## **General Description**

The HTG12B0 is a processor from HOLTEK's 4-bit stand-alone single chip microcontroller specially designed for LCD display and time piece product applications.

- RC oscillator & 32768Hz crystal oscillator
- 8-bit timer with internal or external clock source
- Internal timer overflow

1

- Up to  $4\mu s$  instruction cycle with 1MHz system clock
- One level subroutine nesting
- Halt feature reduces power consumption
- 8-bit table read instruction

It is ideally suited for multiple LCD for time piece low power applications among which are calculators, scales, calendar and hand held LCD products.



# **Block Diagram**



 $\mathbf{2}$ 

Note: ACC: Accumulator R0~R4: Working registers ROMB: ROM bank switch RAMB: RAM bank switch LCDC: LCD control register PA, PB: I/O ports PS, PM: Input ports



# Pad Assignment

| -                          | PM3              | T512 | TEST1 | TEST2 | SEG0  | SEG1  | SEG2  | SEG3  | SEG4  | SEG5  | SEG6  | SEG7  | SEG8  | SEG9  | SEG10 | SEG11 | SEG12 | SEG13 | SEG14 | SEG15 | SEG16 | SEG17 | SEG18    | _              |
|----------------------------|------------------|------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------------|
|                            | 94               | 93   | 92    | 91    | 90    | 89    | 88    | 87    | 86    | 85    | 84    | 83    | 82    | 81    | 80    | 79    | 78    | 77    | 76    | 75    | 74    | 73    | 72       |                |
| PM2<br>PM1                 | 1                |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 71       | SEG19          |
| PM0<br>PS3<br>PS2          | 3<br>4<br>5      |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 70<br>69 | SEG20<br>SEG21 |
| PS1<br>PS0<br>TMCLK<br>RES | 6<br>7<br>8<br>9 |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 68<br>67 | SEG22<br>SEG23 |
| PB3                        | 10               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 66<br>65 | SEG24<br>SEG25 |
| PB2                        | 11               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 64<br>63 | SEG26<br>SEG27 |
| PB1                        | 12               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |          |                |
| PB0                        | 13               |      |       |       |       |       |       |       |       |       |       | Ī     |       |       |       |       |       |       |       |       |       |       | 62<br>61 | SEG28<br>SEG29 |
| PA0                        | 14               |      |       |       |       |       |       |       |       |       | -     | (     | 0, 0  | )     | •     |       |       |       |       |       |       |       | _        |                |
| PA1                        | 15               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 60<br>59 | SEG30<br>SEG31 |
| PA2                        | 16               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 58       | SEG32          |
| PA3                        | 17               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 57       | SEG33          |
| T1D                        | 18               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 56<br>55 | SEG34<br>SEG35 |
| BZ                         | 19               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |          | 32033          |
| BZ<br>VDD                  | 20<br>21         |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 54<br>53 | SEG36<br>SEG37 |
| OSCO                       | 22               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |          | 02007          |
| OSCI<br>XOUT               | 23<br>24         |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 52<br>51 | SEG38<br>SEG39 |
| XIN                        | 25               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |          | 02000          |
| VSS                        | 26               |      |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       | 50       | СОМ0           |
|                            | 27               | _    | 29    | _     | 31    | _     | 33    |       | 35    |       |       | 38    | 39    | 40    | 41    | _     | 43    |       | 45    |       | 47    | 48    | 49       |                |
|                            | VLC1             | VLC2 | VLC3  | VLC4  | VOUT1 | VOUT2 | VOUT3 | VOUT4 | COM15 | COM14 | COM13 | COM12 | COM11 | COM10 | COM9  | COM8  | COM7  | COM6  | COM5  | COM4  | COM3  | COM2  | COM1     |                |

Chip size:  $3060 \times 5140 \ (\mu m)^2$ 

\* The IC substrate should be connected to VSS in the PCB layout artwork.

3



# HTG12B0

| Pad ( | Coordinate | S |
|-------|------------|---|
|-------|------------|---|

| Pad Coc | ordinates |          |         |         |          |         |          | Unit: µm |
|---------|-----------|----------|---------|---------|----------|---------|----------|----------|
| Pad No. | X         | Y        | Pad No. | X       | Y        | Pad No. | X        | Y        |
| 1       | -1394.56  | 2163.72  | 33      | 1204.48 | -2436.28 | 65      | 1398.48  | 972.60   |
| 2       | -1394.56  | 2043.72  | 34      | 1324.48 | -2436.28 | 66      | 1398.48  | 1092.60  |
| 3       | -1394.56  | 1923.72  | 35      | 1398.48 | -2436.28 | 67      | 1398.48  | 1381.40  |
| 4       | -1394.56  | 1803.72  | 36      | 1398.48 | -2436.28 | 68      | 1398.48  | 1501.40  |
| 5       | -1394.56  | 1683.72  | 37      | 1398.48 | -2436.28 | 69      | 1398.48  | 1790.20  |
| 6       | -1394.56  | 1563.72  | 38      | 1398.48 | -2436.28 | 70      | 1398.48  | 1910.20  |
| 7       | -1394.56  | 1443.72  | 39      | 1398.48 | -2436.28 | 71      | 1398.48  | 2199.00  |
| 8       | -1394.56  | 1323.72  | 40      | 1398.48 | -2436.28 | 72      | 1327.44  | 2436.28  |
| 9       | -1394.56  | 1203.72  | 41      | 1398.48 | -2436.28 | 73      | 1207.44  | 2436.28  |
| 10      | -1368.40  | 998.68   | 42      | 1398.48 | -2436.28 | 74      | 1087.44  | 2436.28  |
| 11      | -1368.40  | 749.88   | 43      | 1398.48 | -2436.28 | 75      | 967.44   | 2436.28  |
| 12      | -1368.40  | 515.16   | 44      | 1398.48 | -2436.28 | 76      | 847.44   | 2436.28  |
| 13      | -1368.40  | 266.36   | 45      | 1398.48 | -2436.28 | 77      | 727.44   | 2436.28  |
| 14      | -1368.40  | 31.64    | 46      | 1398.48 | -2436.28 | 78      | 607.44   | 2436.28  |
| 15      | -1368.40  | -217.16  | 47      | 1398.48 | -2436.28 | 79      | 487.44   | 2436.28  |
| 16      | -1368.40  | -451.88  | 48      | 1398.48 | -2436.28 | 80      | 367.44   | 2436.28  |
| 17      | -1368.40  | -700.68  | 49      | 1398.48 | -2436.28 | 81      | 247.44   | 2436.28  |
| 18      | -1368.40  | -935.40  | 50      | 1398.48 | -2177.80 | 82      | 127.44   | 2436.28  |
| 19      | -1304.07  | -1189.85 | 51      | 1398.48 | -1889.00 | 83      | 7.44     | 2436.28  |
| 20      | -1304.07  | -1344.25 | 52      | 1398.48 | -1769.00 | 84      | -112.56  | 2436.28  |
| 21      | -1318.48  | -1483.72 | 53      | 1398.48 | -1480.20 | 85      | -232.56  | 2436.28  |
| 22      | -1355.04  | -1630.76 | 54      | 1398.48 | -1360.20 | 86      | -352.56  | 2436.28  |
| 23      | -1355.04  | -1750.76 | 55      | 1398.48 | -1071.40 | 87      | -472.56  | 2436.28  |
| 24      | -1355.04  | -1885.00 | 56      | 1398.48 | -951.40  | 88      | -592.56  | 2436.28  |
| 25      | -1355.04  | -2005.00 | 57      | 1398.48 | -662.60  | 89      | -712.56  | 2436.28  |
| 26      | -1343.84  | -2164.44 | 58      | 1398.48 | -542.60  | 90      | -832.56  | 2436.28  |
| 27      | -1315.52  | -2436.28 | 59      | 1398.48 | -253.80  | 91      | -952.56  | 2436.28  |
| 28      | -1195.52  | -2436.28 | 60      | 1398.48 | -133.80  | 92      | -1072.56 | 2436.28  |
| 29      | -1075.52  | -2436.28 | 61      | 1398.48 | 155.00   | 93      | -1192.56 | 2436.28  |
| 30      | -955.52   | -2436.28 | 62      | 1398.48 | 275.00   | 94      | -1312.56 | 2436.28  |
| 31      | -835.52   | -2436.28 | 63      | 1398.48 | 563.80   |         |          |          |
| 32      | -715.52   | -2436.28 | 64      | 1398.48 | 683.80   |         |          |          |

September 8, 1999



### **Pad Description**

| Pad No.              | Pad Name                      | I/O              | Mask<br>Option                                          | Description                                                                                                                           |
|----------------------|-------------------------------|------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 4~7<br>94, 1~3       | PS3~PS0<br>PM3~PM0            | Ι                | Pull-high or<br>None.<br>Note 2                         | Input pins for input only                                                                                                             |
| 8                    | TMCLK                         | Ι                | Pull-high<br>or None.<br>Note 4                         | Input for TIMER clock<br>TIMER can be clocked by an external clock or an<br>internal frequency source.                                |
| 9                    | $\overline{\text{RES}}$       | Ι                |                                                         | Input to reset an internal LSI<br>Reset is active on logical low level.                                                               |
| 17~14<br>10~13       | PA3~PA0<br>PB3~PB0            | I/O              | CMOS or<br>NMOS with<br>Pull-high or<br>None.<br>Note 3 | Input/output pins                                                                                                                     |
| 19, 20               | $BZ, \overline{BZ}$           | 0                | Note 1                                                  | Sound effect outputs                                                                                                                  |
| 21                   | VDD                           | Ι                |                                                         | Positive power supply                                                                                                                 |
| 23<br>22             | OSCI<br>OSCO                  | I<br>O           |                                                         | An external resistor between OSCI and OSCO is needed for internal system clock.                                                       |
| 25<br>24             | XIN<br>XOUT                   | I<br>O           |                                                         | 32768Hz crystal oscillator for time base, LCD clock                                                                                   |
| 26                   | VSS                           | Ι                |                                                         | Negative power supply, GND                                                                                                            |
| 27~30                | VLC1~VLC4                     | Ι                |                                                         | LCD system power 1/4 bias generated                                                                                                   |
| 31~34                | VOUT1~VOUT4                   | Ι                |                                                         | ${ m LCD}$ system voltage booster condenser connecting terminal                                                                       |
| 35~50                | COM15~COM0                    | 0                |                                                         | Output for LCD panel common plate                                                                                                     |
| 51~90                | SEG39~SEG0                    | 0                |                                                         | LCD driver outputs for LCD panel segment                                                                                              |
| 93<br>18<br>92<br>91 | T512<br>T1D<br>TEST1<br>TEST2 | 0<br>0<br>I<br>I |                                                         | For test mode only<br>TEST1 and TEST2 are left open when the chip is<br>in normal operation (with an internal pull-high<br>resistor). |

Note: 1. The system clock provides six different sources selectable by mask option to drive the sound effect clock. If the Holtek sound library is used, only 128K and 64K are acceptable.

- 2. Each bit of ports PM, PS can be a trigger source of the HALT interrupt, selectable by mask option.
- 3. Each bit of ports PA, PB can be selected as CMOS for output pin only, or as NMOS for I/O pin with pull-high resistor or none by mask option.
- 4. 14 internal clock sources can be selected by mask option to drive TMCLK. Note that TMCLK should not be connected to a pull high resistor if an internal source is used.





# Absolute Maximum Ratings

| Supply | Voltage | -0.3V | to 5.5 | V |
|--------|---------|-------|--------|---|
|        |         |       |        |   |

Storage Temperature.....-50°C to 125°C

| Input VoltageV_{SS}=0.3 t | o V <sub>DD</sub> +0.3 |
|---------------------------|------------------------|
| Operating Temperature0    | °C to 70°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**

Ta=25°C

|                  | <b>D</b> (                                                       | Г               | est Conditions                       | 74.             | T    | ЪЛ              | TT !4 |
|------------------|------------------------------------------------------------------|-----------------|--------------------------------------|-----------------|------|-----------------|-------|
| Symbol           | Parameter                                                        | V <sub>DD</sub> | Conditions                           | Min.            | Тур. | Max.            | Unit  |
| V <sub>DD</sub>  | Operating Voltage                                                | _               |                                      | 2.4             | 3    | 3.6             | V     |
| I <sub>DD</sub>  | Operating Current                                                | 3V              | No load,<br>f <sub>SYS</sub> =512kHz |                 | 200  | 300             | μΑ    |
| I <sub>STB</sub> | Standby Current,<br>(f <sub>SYS</sub> OFF and RTC ON,<br>LCD ON) | 3V              | Halt mode                            |                 | 10   | 15              | μА    |
| V <sub>IL</sub>  | Input Low Voltage                                                | 3V              |                                      | 0               | _    | $0.2 V_{DD}$    | V     |
| $V_{\rm IH}$     | Input High Voltage                                               | 3V              |                                      | $0.8V_{\rm DD}$ |      | V <sub>DD</sub> | V     |
| I <sub>OL1</sub> | PA, PB, BZ and $\overline{\text{BZ}}$<br>Output Sink Current     | 3V              | $V_{OL}$ =0.3V                       | 1.5             | 3    | _               | mA    |
| I <sub>OH1</sub> | PA, PB, BZ and BZ<br>Output Source Current                       | 3V              | V <sub>OH</sub> =2.7V                | -0.5            | -1   | _               | mA    |
| I <sub>OL2</sub> | Segment Output Sink<br>Current                                   | 3V              | $V_{OL}$ =0.44V<br>$V_{LCD}$ =4.4V   | 100             | 200  | _               | μΑ    |
| I <sub>OH2</sub> | Segment Output Source<br>Current                                 | 3V              | $V_{OH}$ =4.0V<br>$V_{LCD}$ =4.4V    | 30              | 60   |                 | μΑ    |
| R <sub>PH</sub>  | Pull-high Resistor                                               | 3V              | PS, PM, <del>RES</del> ,<br>TMCLK    | 50              | 100  | 150             | kΩ    |
| V <sub>LCD</sub> | $V_{LCD}$ Output Voltage                                         | 3V              |                                      | 3.96            | 4.4  | 4.84            | V     |

September 8, 1999



### A.C. Characteristics

| G11                | Demonster                      | Г               | est Conditions         | ъл.  | <b>m</b>   | МГ   | Unit |  |
|--------------------|--------------------------------|-----------------|------------------------|------|------------|------|------|--|
| Symbol             | Parameter                      | V <sub>DD</sub> | Conditions             | Min. | Тур.       | Max. |      |  |
| f <sub>SYS</sub>   | System Clock                   | 3V              | R=620kΩ~51kΩ           | 128  |            | 1000 | kHz  |  |
| t <sub>CY</sub>    | Cycle Time                     | 3V              | f <sub>SYS</sub> =1MHz |      | 4          |      | μs   |  |
| f <sub>TIMER</sub> | Timer I/P Frequency<br>(TMCLK) | 3V              |                        | 0    |            | 1000 | kHz  |  |
| t <sub>RES</sub>   | Reset Pulse Width              |                 |                        | 5    |            |      | ms   |  |
| f <sub>SOUND</sub> | Sound Effect Clock             |                 |                        |      | *64 or 128 |      | kHz  |  |

7

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

### **Functional Description**

#### **Program counter – PC**

This counter addresses the program ROM and is arranged as a 12-bit binary counter from PC0 to PC11 whose contents specify a maximum of 4096 addresses. The program counter counts with an increment of 1 or 2 with each execution of an instruction.

When executing the jump instruction (JMP, JNZ, JC, JTMR,...), a subroutine call, initial reset, internal interrupt, RTC interrupt or returning from a subroutine, the program counter is loaded with the corresponding instruction data as shown in the table.

Note: P0~P11: Instruction code

@: PC11 keeps current value
S0~S11: Stack register bits
ROMB0 and ROMB1 are set to 0 at power on reset.

#### **Program memory – ROM**

The program memory is the executable memory and is arranged in a 4096×8-bit format. There are four banks for program memory in HTG12B0, each bank shown in the figure can be switched by assigning ROMB0 and ROMB1 (bit0 and bit1 of ROMB). ROMB is the ROM bank pointer and can be written only by executing "MOV ROMB, A" instruction. Bit 2 and bit 3 of ROMB are unused bits. The address is specified by the program counter (PC). Four special locations are reserved as described next. • Location 000H: (Bank 0) Activating the processor RES pin causes the first instruction to be fetched from location 0.







Program memory ROMB=XX01B



• Location 004H: (Bank 0~3)

Contains the timer interrupt resulting from a TIMER overflow. If the interrupt is enabled, the CPU begins execution at location 004H.

- Location 008H: (Bank 0~3) Activating the RTC of the processor with the interrupts enabled causes the program to jump to this location.
- Locations n00H to nFFH: (Bank 0~3)
- Each page in the program memory consists of 256 bytes. This area from n00H to nFFH and F00H to FFFH can be used as a look-up table. Instructions such as READ R4A, READ MR0A, READF R4A, READF MR0A can read the table and transfer the contents of the table to ACC and R4 or to ACC and a data memory address specified by the register pair R1,R0. However as R1,R0 can only store 8 bits, these instructions cannot fully specify the full 12 bit program memory address. For this reason a jump instruction should first be used to place the program counter in the right page. The above instructions can then be used to read the look up table data.

Note that the page number n must be greater than zero since some locations in page 0 are reserved for specific usage. This area may function as normal program memory.

The program memory mapping is shown in the diagram.

In the execution of an instruction, the program counter is added before the execution phase, so careful manipulation of READ MR0A and READ R4A is required in the page margin.







Program memory ROMB=XX11B

|                           | Program Counter |       |      |      |     |     |     |     |     |     |     |     |     |     |
|---------------------------|-----------------|-------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Mode                      | PC13            | PC12  | PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 |
| Initial<br>reset          | ROMB1           | ROMB0 | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Internal<br>interrupt     | ROMB1           | ROMB0 | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 0   | 0   |
| RTC<br>interrupt          | ROMB1           | ROMB0 | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 0   | 0   | 0   |
| Jump, call<br>instruction | ROMB1           | ROMB0 | P11  | P10  | P9  | P8  | P7  | P6  | P5  | P4  | P3  | P2  | P1  | P0  |
| Conditional<br>branch     | ROMB1           | ROMB0 | @    | P10  | P9  | P8  | P7  | P6  | P5  | P4  | P3  | P2  | P1  | P0  |
| Return from<br>subroutine | ROMB1           | ROMB0 | S11  | S10  | S9  | S8  | S7  | S6  | S5  | S4  | S3  | S2  | S1  | S0  |

#### Program memory

8





Temporary data memory

#### Stack register

The stack register is a group of registers used to save the contents of the program counter (PC) and is arranged into 13 bits  $\times$  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 an interrupt routine which is signaled by a return instruction, RET or RETI restore 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

There are five working registers (R0, R1, R2, R3, R4) usually used to store the frequently accessed intermediate results. Using the instructions INC Rn and DEC Rn the working registers can increment (+1) or decrement (-1). The JNZ Rn (n=0, 1, 4) instruction makes efficient use of the working registers as a program loop counter. Also the register pairs R0,R1 and R2,R3 are used as a data memory pointer when the memory transfer instruction is executed.

#### Data memory – RAM

The static data memory (RAM) is arranged in 128×4-bit format and is used to store data. All of the data memory locations are indirectly addressable through the register pair R1,R0 or R3,R2; for example MOV A,[R3R2] or MOV [R3R2],A.

There are two areas in the data memory, the temporary data area and display data area. Access to the temporary data area is from 00H to 7FH of RAM bank 0~RAM bank 7. Access to the display data area is from B0H to FFH of LCD bank 0 and bank 1.

There are eight banks for the temporary data memory in HTG12B0, each bank shown in the figure can be switched by assigning RAMB0~RAMB2 (bit 0~bit 2 of RAMB). RAMB is the RAM bank pointer and can be written only by executing "MOV RAMB, A" instruction. Bit 3 of RAMB is unused bit. Each bank maps to different area of the data memory.

There are two banks for displaying the data memory, each bank can be switched by the assignment of LCDC0 (bit 0 of LCDC). LCDC is a control register for LCD application and can be written only by executing "MOV LCDC, A" instruction.

When data is written into the display data area, it is automatically read by the LCD driver which then generates the corresponding LCD driving signals.



Display data memory



The locations between the temporary and display data areas are undefined and cannot be used.

#### Accumulator – ACC

The accumulator is the most important data register in the processor. It is one of the sources of input to the ALU and the destination of the results of the operations performed in the ALU. Data to and from the I/O ports and memory also passes through the accumulator.

#### Arithmetic and logic unit – ALU

This circuit performs the following arithmetic and logic operations ...

- Add with or without carry
- Subtract with or without carry
- AND, OR, Exclusive–OR
- Rotate right, left through carry
- · BCD decimal adjust for addition
- Increment, decrement
- Data transfers
- Branch decisions

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

#### Timer/counter

The HTG12B0 contains a programmable 8-bit count-up counter which can be used to count external events or used as a clock to generate an accurate time base.

If the 8-bit timer clock is supplied by an external source from pin TMCLK, synchronization problems may occur when reading the data from the timer. It is therefore recommended that the timer is stopped before retrieving the data. The 8-bit counter will increment on the rising edge of the clock whether it is internally or externally generated.

The Timer/Counter may be set and read with software instructions and stopped by a hardware reset or a TIMER OFF instruction. To restart the timer, load the counter with the value XXH and then issue a TIMER ON instruction. Note that XX is the desired start count immediate value of the 8 bits. Once the Timer/Counter is started it increments to a maximum count of FFH and then overflows to zero (00H). It then continues to count until stopped by a TIMER OFF instruction or a reset.

The increment from the maximum count of FFH to a zero (00H) triggers a timer flag TF and an internal interrupt request. The interrupt may be enabled or disabled by executing the EI and DI instructions. If the interrupt is enabled, the timer overflow will cause a subroutine call to location 4. The state of the timer flag can also be tested with the conditional jump instruction JTMR. The timer flag is cleared after the interrupt or the JTMR instruction is executed.

If an internal source is used, the frequency is determined by the system clock and the parameter n as defined in the equation. 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... 3 selectable by mask option.

#### RTC

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



The output of RTC can be selected by mask option.

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

The RTC output is used to generate an interrupt signal.

10



#### Interrupt

The HTG12B0 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 one 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 results 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 interrupt 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 HTG12B0 provides a  $\overline{\text{RES}}$  pin for system initialization. This pin is equipped with an internal pull high resistor and in combination with an external  $0.1\mu \sim 1\mu\text{F}$  capacitor, it provides an internal reset pulse of sufficient length to guarantee a reset to all internal circuits. If the reset pulse is generated externally, the  $\overline{\text{RES}}$ pin must be held low at least 5ms. When  $\overline{\text{RES}}$  is active, the internal block will be initialized as shown below:

| PC                              | 000H                        |
|---------------------------------|-----------------------------|
| TIMER                           | Stop                        |
| Timer flag                      | Reset (low)                 |
| SOUND                           | Sound off and One sing mode |
| Output port A                   | High (or floating state)    |
| LCD output                      | Enable                      |
| $BZ$ and $\overline{BZ}$ output | Low level                   |
| ROMB                            | XX00B                       |
| RAMB                            | X000B                       |
| LCDC                            | 1100B                       |

#### HALT

This is a special feature of the HTG12B0 to interrupt the chip's normal operation and reduce power consumption. When a HALT is executed the following happens ...

- The system clock will be stopped
- The contents of the on-chip RAM and registers remain unchanged
- RTC oscillator keeps on running
- BZ and  $\overline{BZ}$  maintain low level output

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

#### Initial reset: 00H

Wake-up: next address of the HALT instruction

11

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

Case 1: 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 PM, 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 effects

The HTG12B0 includes sound effect circuitry which offers up to 16 sounds with 3 tones, boom and noise effects. Holtek supports a sound library including melodies, alarms, machine guns etc..

If the instruction "SOUND A" is executed, the specified sound begins. Each time "SOUND OFF" is executed, it terminates the singing sound immediately.

There are two singing modes, SONE mode and SLOOP mode activated by SOUND ONE and SOUND LOOP. In SONE mode the specified sound plays only once. In the SLOOP mode the specified sound keeps re-playing.

Since sounds  $0 \sim 11$  contain 32 notes and sounds  $12 \sim 15$  include 64 notes the latter possesses 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 supports only sound clock frequency of 128K or 64K. To use Holtek's sound library the proper system clock and mask option should be selected.

#### LCD display memory

As mentioned in the data memory section, the LCD display memory is embedded in the data memory. It can be read and written to in the same way as normal data memory.

The figure illustrates the mapping between the display memory and LCD pattern for the HTG12B0.

There is an ON/OFF switch for display controlled by bit 3 of LCDC (LCDC 3). The corresponding bit of the LCDC 3 represents "ON" or "OFF" of display of LCD display memory.

The LCD display module may have any form as long as the number of commons does not exceed 16 and the number of segments is not over 40.



September 8, 1999





LCD display memory (LCDC0=1)

#### LCD driver output

All of the LCD segments are random after an initial clear. The bias voltage circuits of the LCD display is built-in and no external resistor is required.

The output number of the HTG12B0 LCD driver is  $40 \times 16$  which can directly drive an LCD with 1/16 duty cycle and 1/4 bias.

The frequency of the LCD driving clock source can be selected from RTC OSC or system clock by accessing bit 1 of LCDC.

There are many frequency division of the LCD clock which can be selected by mask option either from RTC OSC or system clock.

• RTC OSC

Frequency of LCD clock = 
$$\frac{16384}{2^n}$$
 Hz

....where n=0~7

Frequency of LCD clock =  $\frac{f_{SYS} / 64}{2^n}$  Hz

....where n=0~5

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

| LCD driver output is enabled by setting LCDC3  |
|------------------------------------------------|
| as "1", and disabled by setting LCDC 3 as "0". |

| Register | Bit No. | Function                                                         |
|----------|---------|------------------------------------------------------------------|
|          | 0       | Select LCD bank<br>0=Bank 0 (Com0~7)<br>1=Bank 1 (Com8~15)       |
| LCDC     | 1       | Select LCD clock source<br>0=RTC OSC (32768Hz)<br>1=System clock |
| LCDC     | 2       | PM3 edge latch control bit<br>1=Enabled<br>0=Disabled            |
|          | 3       | Control LCD display<br>0=OFF<br>1=ON                             |

LCDC Register

An example of an LCD driving waveform (1/16 duty and 1/4 bias) is shown below.



VLCD is fixed at 4.4V when  $V_{DD}$  is from 2.4V to 3.6V.

13



#### Oscillator

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

The system clock is also used as the reference signal of the sound effect clock or internal frequency source of the TIMER.

Another crystal oscillator is needed for use as the reference signal of the LCD driving clock and RTC interrupt clock source.

A 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\mu s$  if the system frequency is up to 1MHz.



RC and RTC oscillator

#### Interfacing

The HTG12B0 microcontrollers communicate with the outside world through two input pins PS and PM and two output pins PA and PB.

#### Input ports - PS, PM

All of the ports can have internal pull high resistors determined by mask option. Every bit of the input ports PS and PM can be specified as a trigger source for waking up the HALT interrupt by mask option. A high to low transition on one of these pins will wake up the device from a HALT status.



Input ports PS, PM

PM3 has a falling edge latch function selected by mask option. Once the falling edge signal is latched, it will remain in its state until the clear instruction is executed by setting bit 2 of LCDC from high to low.

#### Input/output port - PA, PB

PA and PB can be used for input/output or output operation by selecting NMOS or CMOS mask option respectively, and each bit can be configured with or without pull-high resistor when the NMOS is selected. If the NMOS is selected, it should be noted that, before reading, data from pads should output "1" to the related bits to disable the NMOS device.



Input/output port PA, PB

14



### Mask options

HTG12B0 provides the following mask option for different applications.

- Each bit of input ports PS, PM with pull-high resistor
- Each bit of input ports PS, PM function as HALT wake-up trigger.
- Each bit of input/output port PA, PB with CMOS or NMOS with pull-high or none.
- 8-bit programmable TIMER with internal or external frequency sources. There are 14 internal frequency sources which can be selected as a clocking signal.

If using internal frequency sources as clocking signal TMCLK cannot connect with pull-high resistor.

- 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.
- LCD clock source division: If RTC OSC is selected, the frequency of LCD clock=16384/2<sup>n</sup> Hz, n=0~7. If system clock is selected, the frequency of LCD clock=  $\frac{f_{SYS} / 64}{2^n}$  Hz, n=0~5.
- PM3 falling edge latch function.

September 8, 1999



# **Application Circuits**



 $R^*:$  Depends on the required system clock frequency. (R=620k $\Omega$ ~51k $\Omega$ , at VDD=3V) X'tal: Realtime clock frequency. (X'tal=32768Hz)





# Instruction Set Summary

| Mnemonic                   | Description                                    | Byte | Cycle                                 | CF           |
|----------------------------|------------------------------------------------|------|---------------------------------------|--------------|
| Arithmetic                 |                                                |      |                                       |              |
| ADD A,[R1R0]               | Add data memory to ACC                         | 1    | 1                                     | V            |
| ADC A,[R1R0]               | Add data memory with carry to ACC              | 1    | 1                                     |              |
| SUB A,[R1R0]               | Subtract data memory from ACC                  | 1    | 1                                     | V            |
| SBC A,[R1R0]               | Subtract data memory from ACC with borrow      | 1    | 1                                     | V            |
| ADD A,XH                   | Add immediate data to ACC                      | 2    | 2                                     |              |
| SUB A,XH                   | Subtract immediate data from ACC               | 2    | 2                                     | V            |
| 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              |                                                |      |                                       |              |
| Decrement                  |                                                |      |                                       |              |
| INC A                      | Increment ACC                                  | 1    | 1                                     |              |
| INC Rn                     | Increment register, n=0~4                      | 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, n=0~4                      | 1    | 1                                     |              |
| DEC [R1R0]                 | Decrement data memory                          | 1    | 1                                     |              |
| DEC [R3R2]                 | Decrement data memory                          | 1    | 1                                     |              |
| Data Move                  |                                                |      |                                       |              |
| MOV ROMB, A                | MOV ACC to ROMB                                | 1    | 1                                     |              |
| MOV ROMB, A<br>MOV RAMB, A | MOV ACC to RAMB                                |      | 1                                     |              |
|                            | MOV ACC to RAMB<br>MOV ACC to LCDC             | 1    | 1                                     |              |
| MOV LCDC, A                | Mov Acc to LeDe<br>Move register to ACC, n=0~4 |      |                                       |              |
| MOV A,Rn                   |                                                |      | 1                                     | _            |
| MOV Rn,A                   | Move ACC to register, n=0~4                    |      |                                       |              |
| MOV A,[R1R0]               | Move data memory to ACC                        | 1    | $\begin{vmatrix} 1\\ 1 \end{vmatrix}$ |              |
| MOV A,[R3R2]               | Move data memory to ACC                        |      |                                       |              |
| 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                                     |              |

September 8, 1999



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

September 8, 1999



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

September 8, 1999



# HTG12B0

# **Instruction Definition**

| ADC A,[R1R0] | Add data memory contents and carry to accumulator                                                                                     |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------|--|
| Machine Code | $0\ 0\ 0\ 0\ 1\ 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)+C$                                                                                                       |  |
| ADD A,XH     | Add immediate data to accumulator                                                                                                     |  |
| Machine Code | 0 1 0 0 0 0 0 0 0 0 0 0 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 logically AND with the immediate data speci-<br>fied by 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 logically AND with the data memory ad-<br>dressed by the register pair "R1,R0".                            |  |
| Operation    | ACC $\leftarrow$ ACC "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 logically AND with the accumulator                                  |  |
| Operation    | $M(R1,R0) \leftarrow M(R1,R0)$ "AND" ACC                                                                                              |  |

20



| CALL address | Subroutine call                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine Code | 1111aaaa aaaaaaaa                                                                                                                                        |
| Description  | The program counter bits $0-11$ are saved in the stack. The program counter is then loaded from the directly-specified address.                          |
| Operation    | Stack $\leftarrow$ PC+2<br>PC $\leftarrow$ address                                                                                                       |
| CLC          | Clear carry flag                                                                                                                                         |
| Machine Code | 0 0 1 0 1 0 1 0                                                                                                                                          |
| Description  | The carry flag is reset to zero.                                                                                                                         |
| Operation    | $C \leftarrow 0$                                                                                                                                         |
| DAA          | Decimal-Adjust accumulator                                                                                                                               |
| Machine Code | 0 0 1 1 0 1 1 0                                                                                                                                          |
| Description  | The accumulator value is adjusted to the BCD (Binary Code Decimal) code, if the contents of the accumulator is greater, then 9 or C (Carry flag) is one. |
| Operation    | If ACC>9 or CF=1 then<br>ACC $\leftarrow$ ACC+6, C $\leftarrow$ 1<br>else<br>ACC $\leftarrow$ ACC, C $\leftarrow$ C                                      |
| DEC A        | Decrement accumulator                                                                                                                                    |
| Machine Code | 00111111                                                                                                                                                 |
| Description  | Data in the accumulator is decremented by one. 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 one. Carry flag is not affected.                                                                     |
| Operation    | $Rn \leftarrow Rn-1$ ; $Rn=R0$ , $R1$ , $R2$ , $R3$ , $R4$ , for $n=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 one. Carry flag is not affected.                                   |
| Operation    | $M(R1, R0) \leftarrow M(R1, R0) - 1$                                                                                                                     |



| DEC [R3R2]   | Decrement data memory                                                                                                   |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------|--|
| Machine Code | 00001111                                                                                                                |  |
| Description  | Data in the data memory specified by the register pair "R3, R2" is decre-<br>mented by one. Carry flag is not affected. |  |
| Operation    | $M(R3,R2) \leftarrow M(R3,R2) 1$                                                                                        |  |
| DI           | Disable interrupt                                                                                                       |  |
| Machine Code | 00100101 00000011                                                                                                       |  |
| Description  | Internal time-out interrupt and external interrupt are disabled.                                                        |  |
| EI           | Enable interrupt                                                                                                        |  |
| Machine Code | 00100101 00000010                                                                                                       |  |
| 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)+1$                                                                                                  |  |
| IN A,Pi      | Input port to accumulator                                                                                               |  |
| Machine Code | 00101100 PA 01001000 PB                                                                                                 |  |
|              | 00110010 PM 00110011 PS                                                                                                 |  |
| Description  | The data on port "Pi" is transferred to the accumulator.                                                                |  |
| Operation    | ACC $\leftarrow$ Pi; Pi=PA, PB, PM or PS                                                                                |  |
| INC A        | Increment accumulator                                                                                                   |  |
| Machine Code | $0\ 0\ 1\ 1\ 0\ 0\ 1$                                                                                                   |  |
| Description  | Data in the accumulator is incremented by one. 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 one. Carry flag is not affected.                                    |  |
| Operation    | $\textbf{Rn} \leftarrow \textbf{Rn+1} \textbf{; Rn=R0,R1,R2,R3,R4 for n=0,1,2,3,4}$                                     |  |



| INC [R1R0]   | Increment data memory                                                  |                                                                                                                   |  |
|--------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--|
| Machine Code | 0 0 0 0 1 1 0 0                                                        |                                                                                                                   |  |
| Description  | Data in the data memor<br>mented by one. Carry fl                      | ry specified by the register pair "R1,R0" is incre-<br>ag is not affected.                                        |  |
| Operation    | $M(R1,R0) \leftarrow M(R1,R0)$ +                                       | 1                                                                                                                 |  |
| INC [R3R2]   | Increment data memory                                                  | <i>y</i>                                                                                                          |  |
| Machine Code | $0 \ 0 \ 0 \ 0 \ 1 \ 1 \ 1 \ 0$                                        |                                                                                                                   |  |
| Description  | Data memory specified<br>one. Carry flag is not af                     | by the register pair "R3, R2" is incremented by fected.                                                           |  |
| Operation    | $M(R3,R2) \leftarrow M(R3,R2)$ +                                       | 1                                                                                                                 |  |
| JAn address  | Jump if accumulator Bi                                                 | t n is set                                                                                                        |  |
| Machine Code | 1 0 0 n n a a a                                                        | a a a a a a a a                                                                                                   |  |
| Description  |                                                                        | n counter are replaced with the directly'specified<br>ogram counter and PA3 of memory bank remain,<br>et to one.  |  |
| Operation    | PC (bit 0–10) $\leftarrow$ address<br>PC $\leftarrow$ PC+2, if ACC bit | s, if ACC bit n=1 (n = 0, 1, 2, 3)<br>n=0                                                                         |  |
| JC address   | Jump if carry is set                                                   |                                                                                                                   |  |
| Machine Code | 11000aaa                                                               | aaaaaaa                                                                                                           |  |
| Description  |                                                                        | n counter are replaced with the directly'specified<br>ogram counter and PA3 of memory bank remain,<br>et to one.  |  |
| Operation    | PC (bit 0–10) $\leftarrow$ address<br>PC $\leftarrow$ PC+2, if C=0     | s, if C=1                                                                                                         |  |
| JMP address  | Direct Jump                                                            |                                                                                                                   |  |
| Machine Code | 1110aaaa                                                               | aaaaaaa                                                                                                           |  |
| Description  | Bits 0–11 of the program address.                                      | n counter are replaced with the directly'specified                                                                |  |
| Operation    | $\text{PC} \leftarrow \text{address}$                                  |                                                                                                                   |  |
| JNC address  | Jump if carry is not set                                               |                                                                                                                   |  |
| Machine Code | 11001aaa                                                               | a a a a a a a a                                                                                                   |  |
| Description  |                                                                        | n counter are replaced with the directly'specified<br>ogram counter and PA3 of memory bank remain,<br>et to zero. |  |
| Operation    | PC (bit 0–10) $\leftarrow$ address<br>PC $\leftarrow$ PC+2, if C=1     | s, if C=0                                                                                                         |  |



| JNZ A,address  | Jump if accumulator is not zero                                             |                     |                                                                      |
|----------------|-----------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------|
| Machine Code   | 10111aaa                                                                    | аааааааа            |                                                                      |
| Description    |                                                                             | ogram counter ai    | placed with the directly'specified<br>nd PA3 of memory bank remain,  |
| Operation      | PC (bit 0–10) $\leftarrow$ address<br>PC $\leftarrow$ PC+2, if ACC=0        | s, if ACC≠0         |                                                                      |
| JNZ Rn,address | Jump if register is not zero                                                |                     |                                                                      |
| Machine Code   | 10100aaa                                                                    | аааааааа            | R0                                                                   |
|                | 10101aaa                                                                    | a a a a a a a a a   | R1                                                                   |
|                | 11011aaa                                                                    | a a a a a a a a a   | R4                                                                   |
| Description    |                                                                             | ogram counter ai    | blaced with the directly'specified<br>nd PA3 of memory bank remain,  |
| Operation      | PC (bit 0–10) $\leftarrow$ address<br>PC $\leftarrow$ PC+2, if Rn=0         | s, if Rn≠0; Rn=R    | 0, R1, R4                                                            |
| JTMR address   | Jump if time-out                                                            |                     |                                                                      |
| Machine Code   | 11010aaa                                                                    | aaaaaaaa            |                                                                      |
| Description    |                                                                             | rogram counter a    | placed with the directly'specified<br>and PA3 of the memory bank re- |
| Operation      | PC (bit 0–10) $\leftarrow$ address<br>PC $\leftarrow$ PC+2, if TF=0         | s, if TF=1          |                                                                      |
| JZ A,address   | Jump if accumulator is                                                      | zero                |                                                                      |
| Machine Code   | 10110aaa                                                                    | aaaaaaaa            |                                                                      |
| Description    |                                                                             | rogram counter a    | placed with the directly'specified<br>and PA3 of the memory bank re- |
| Operation      | PC (bit 0–10) $\leftarrow$ address<br>PC $\leftarrow$ PC+2, if ACC $\neq$ 0 | s, if ACC=0         |                                                                      |
| MOV A,Rn       | Move register to accum                                                      | ulator              |                                                                      |
| 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, R1,                                             | , R2, R3, R4, for 1 | n=0,1,2,3,4                                                          |



| HTG12 | 2B0 |
|-------|-----|
|-------|-----|

| MOV A,TMRH   | Move timer 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 to accumulator                                                                                                                                                    |  |
| Machine Code | 00111010                                                                                                                                                                     |  |
| Description  | The low nibble data of Timer counter is loaded to the accumulator.                                                                                                           |  |
| Operation    | $ACC \leftarrow TIMER (low nibble)$                                                                                                                                          |  |
| MOV A,XH     | Move immediate data to accumulator                                                                                                                                           |  |
| Machine Code | 0 1 1 1 d d d d                                                                                                                                                              |  |
| Description  | The 4-bit data specified by 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 LCDC, A  | Move accumulator to LCDC register                                                                                                                                            |  |
| Machine Code | $0\ 0\ 1\ 1\ 0\ 0\ 0$                                                                                                                                                        |  |
| Description  | Data in the accumulator is moved to the LCDC register.                                                                                                                       |  |
| Operation    | $LCDC \leftarrow ACC$                                                                                                                                                        |  |
| MOV R1R0,XXH | Move immediate data to R1 and R0                                                                                                                                             |  |
| Machine Code | 0101dddd 0000dddd                                                                                                                                                            |  |
| Description  | The 8-bit data specified by code are loaded to the working registers R1 and R0, the high nibble of the data is loaded to R1, and the low nibble of the data is loaded to R0. |  |
| Operation    | $R1 \leftarrow XH (high nibble)$<br>$R0 \leftarrow XH (low nibble)$                                                                                                          |  |



| MOV R3R2,XXH | Move immediate data to R3 and R2                                                                                                                                                    |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Machine Code | 0 1 1 0 d d d d 0 0 0 0 d d d d                                                                                                                                                     |  |
| Description  | The 8-bit data specified by code are loaded to the working register R3 and R2, the high nibble of the data is loaded to the R3, and the low nibble of the data is loaded to the 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 | 0 1 0 0 0 1 1 0 0 0 0 0 d d d d                                                                                                                                                     |  |
| Description  | The 4-bit data specified by code are 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, R1, R2, R3, R4, for n=0, 1, 2, 3, 4$                                                                                                                     |  |
| MOV RAMB, A  | Move accumulator to RAMB register                                                                                                                                                   |  |
| Machine Code | 00110100                                                                                                                                                                            |  |
| Description  | Data in the accumulator is moved to the RAMB register                                                                                                                               |  |
| Operation    | $RAMB \leftarrow ACC$                                                                                                                                                               |  |
| MOV ROMB, A  | Move accumulator to ROMB register                                                                                                                                                   |  |
| Machine Code | 00110101                                                                                                                                                                            |  |
| Description  | Data in the accumulator is moved to the ROMB register                                                                                                                               |  |
| Operation    | $ROMB \leftarrow ACC$                                                                                                                                                               |  |
| MOV TMRH,A   | Move accumulator to timer                                                                                                                                                           |  |
| Machine Code | 00111101                                                                                                                                                                            |  |
| Description  | The contents of accumulator is loaded to the high nibble of timer counter.                                                                                                          |  |
| Operation    | TIMER (high nibble) $\leftarrow$ ACC                                                                                                                                                |  |
| MOV TMRL,A   | Move accumulator to timer                                                                                                                                                           |  |
| Machine Code | 00111100                                                                                                                                                                            |  |
| Description  | The contents of accumulator is loaded to the low nibble of the timer counter.                                                                                                       |  |
| Operation    | $\mathbf{TIMER} \ (\mathbf{low} \ \mathbf{nibble}) \leftarrow \mathbf{ACC}$                                                                                                         |  |



| MOV [R1R0],A | Move accumulator to data memory                                                                      |  |
|--------------|------------------------------------------------------------------------------------------------------|--|
| Machine Code | 0 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$                                                                            |  |
| OV [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 | 0 0 1 1 1 1 1 0                                                                                      |  |
| Description  | Do nothing, but one instruction cycle is delayed.                                                    |  |
| OR A,XH      | Logical OR immediate data to accumulator                                                             |  |
| Machine Code | 0 1 0 0 0 1 0 0 0 0 0 0 d d d d                                                                      |  |
| Description  | Data in the accumulator is logically OR with the immediate data specified by code.                   |  |
| Operation    | $ACC \leftarrow ACC "OR" XH$                                                                         |  |
| OR A,[R1R0]  | Logical OR accumulator with data memory                                                              |  |
| Machine Code | 0 0 0 1 1 1 0 0                                                                                      |  |
| Description  | Data in the accumulator is logically OR with the data memory addressed by the register pair "R1,R0". |  |
| Operation    | ACC $\leftarrow$ ACC "OR" M(R1,R0)                                                                   |  |
| OR [R1R0],A  | Logical OR data memory with accumulator                                                              |  |
| Machine Code | $0\ 0\ 0\ 1\ 1\ 1\ 1\ 1$                                                                             |  |
| Description  | Data in the data memory addressed by the register pair "R1,R0" is logically OR with the accumulator. |  |
| Operation    | $M(R1,R0) \leftarrow M(R1,R0)$ "OR" ACC                                                              |  |
| OUT Pi,A     | Output accumulator data to port-i                                                                    |  |
| Machine Code | 00101101 PA 01001001 PB                                                                              |  |
| Description  | The data in the accumulator is transferred to the port-i and latched.                                |  |
| Operation    | $Pi \leftarrow ACC; Pi=PA \text{ or } PB$                                                            |  |



| READ MR0A    | Read ROM code of current page to M(R1,R0) and ACC                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine Code | 01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Description  | The 8-bit ROM code (current page) addressed by ACC and R4 are moved<br>to the data memory M(R1,R0) and accumulator. The high nibble of the<br>ROM code is loaded to M(R1,R0) and the low nibble of the ROM code is<br>loaded to accumulator. The address of ROM code are specified as below:<br>Current page $\rightarrow$ ROM code address bit 12~8<br>ACC $\rightarrow$ ROM code address bit 7~4<br>R4 $\rightarrow$ ROM code address bit 3~0                |
| Operation    | $\begin{array}{l} M(R1,R0) \leftarrow ROM \; code \; (high \; nibble) \\ ACC \leftarrow ROM \; code \; (low \; nibble) \end{array}$                                                                                                                                                                                                                                                                                                                            |
| 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) are<br>moved to the working register R4 and accumulator. The high nibble of<br>the ROM code is loaded to R4 and the low nibble of the ROM code is<br>loaded to the accumulator. The address of the ROM code are specified be-<br>low:<br>Current page $\rightarrow$ ROM code address bit 12~8<br>ACC $\rightarrow$ ROM code address bit 7~4<br>M(P1,P0) $\rightarrow$ ROM code address bit 3~0 |
| Operation    | $\begin{array}{l} R4 \leftarrow ROM \ code \ (high \ nibble) \\ ACC \leftarrow ROM \ code \ (low \ nibble) \end{array}$                                                                                                                                                                                                                                                                                                                                        |
| 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 are 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 accumulator.<br>page F $\rightarrow$ ROM code address bit 12~8 are "PA3 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)$                                                                                                                                                                                                                                                                                                                                                     |

September 8, 1999



| READF R4A    | Read ROM code of page F to R4 and accumulator                                                                                                                                                                                                                                                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine Code | 01001110                                                                                                                                                                                                                                                                                                                                                                                                  |
| Description  | The 8-bit ROM code (page F) addressed by ACC and M(R1,R0) are moved<br>to the working register R4 and accumulator. The high nibble of the ROM<br>code is loaded to R4 and the low nibble of the ROM code is loaded to accu-<br>mulator.<br>page F $\rightarrow$ ROM code address bit 12~8 are "PA3 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 | $0\ 0\ 1\ 0\ 1\ 1\ 1\ 0$                                                                                                                                                                                                                                                                                                                                                                                  |
| Description  | The program counter bits 0~11 are restored from the stack.                                                                                                                                                                                                                                                                                                                                                |
| Operation    | $PC \leftarrow Stack$                                                                                                                                                                                                                                                                                                                                                                                     |
| RETI         | Return from interrupt subroutine                                                                                                                                                                                                                                                                                                                                                                          |
| Machine Code | $0\ 0\ 1\ 0\ 1\ 1\ 1\ 1$                                                                                                                                                                                                                                                                                                                                                                                  |
| Description  | The program counter bits 0~11 are restored from the stack. The carry flag before entering interrupt service routine is restored.                                                                                                                                                                                                                                                                          |
| Operation    | $PC \leftarrow Stack$<br>$C \leftarrow C$ (before interrupt service routine)                                                                                                                                                                                                                                                                                                                              |
| RL A         | Rotate accumulator left                                                                                                                                                                                                                                                                                                                                                                                   |
| Machine Code | $0\ 0\ 0\ 0\ 0\ 0\ 1$                                                                                                                                                                                                                                                                                                                                                                                     |
| Description  | The contents of the accumulator are rotated one bit left. Bit 3 is rotated to bit 0 and carry flag.                                                                                                                                                                                                                                                                                                       |
| Operation    | An+1 $\leftarrow$ An; An: accumulator bit n (n=0,1,2)<br>A0 $\leftarrow$ A3<br>C $\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 one bit left. Bit 3 replaces the carry bit; the carry bit is rotated into the bit 0 position.                                                                                                                                                                                                                                                                 |
| Operation    | An+1 $\leftarrow$ An; An: Accumulator bit n (n=0,1,2)<br>A0 $\leftarrow$ C<br>C $\leftarrow$ A3                                                                                                                                                                                                                                                                                                           |



| RR A         | Rotate accumulator right                                                                                                                     |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Machine Code | 0 0 0 0 0 0 0 0                                                                                                                              |
| Description  | The contents of the accumulator are rotated one bit right. Bit 0 is rotated to bit 3 and carry flag.                                         |
| Operation    | An $\leftarrow$ An+1; An: Accumulator bit n (n=0,1,2)<br>A3 $\leftarrow$ A0<br>C $\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 one bit right. Bit 0 replaces the carry bit; the carry bit is rotated into the bit 3 position.   |
| Operation    | An $\leftarrow$ An+1; An: Accumulator bit n (n=0,1,2)<br>A3 $\leftarrow$ C<br>C $\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 the carry are subtracted from the accumulator. Carry is affected. |
| Operation    | $ACC \leftarrow ACC + \overline{M(R1,R0)} + CF$                                                                                              |
| SOUND A      | Active SOUND channel with accumulator                                                                                                        |
| Machine Code | $0\ 1\ 0\ 0\ 1\ 0\ 1\ 1$                                                                                                                     |
| 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 mode                                                                                                                    |
| Machine Code | 01001001 00000001                                                                                                                            |
| Description  | The activated sound plays repeatedly.                                                                                                        |
| SOUND OFF    | Turn off sound                                                                                                                               |
| Machine Code | 01001010                                                                                                                                     |
| Description  | The singing sound will terminate immediately.                                                                                                |
| SOUND ONE    | Turn on sound one mode                                                                                                                       |
| Machine Code | 01000101 00000000                                                                                                                            |
| Description  | The activated sound plays only one time.                                                                                                     |
|              |                                                                                                                                              |



| <b>STC</b><br>Machine Code<br>Description<br>Operation | Set carry flag<br>0 0 1 0 1 0 1 1<br>The carry flag is set to one.<br>$C \leftarrow 1$                                        |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| SUB A,XH                                               | Subtract immediate data from accumulator                                                                                      |
| Machine Code                                           | 0 1 0 0 0 0 0 1 0 0 0 0 d d d d                                                                                               |
| Description                                            | The specified data is subtracted from the accumulator. Carry is affected.                                                     |
| 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 subtracted from the accumulator. Carry is affected. |
| Operation                                              | $ACC \leftarrow ACC + \overline{M(R1,R0)} + 1$                                                                                |
| TIMER OFF                                              | Set timer stop counting                                                                                                       |
| Machine Code                                           | $0\ 0\ 1\ 1\ 1\ 0\ 0\ 1$                                                                                                      |
| Description                                            | The Timer stop counting, when the "TIMER OFF" instruction is exe-<br>cuted.                                                   |
| TIMER ON                                               | Set timer start counting                                                                                                      |
| Machine Code                                           | $0\ 0\ 1\ 1\ 1\ 0\ 0\ 0$                                                                                                      |
| Description                                            | The Timer starts counting, when the "TIMER ON" instruction is exe-<br>cuted.                                                  |
| TIMER XXH                                              | Set immediate data to timer counter                                                                                           |
| Machine Code                                           | 01000111 ddddddd                                                                                                              |
| Description                                            | The 8 bit data specified by code is loaded to the T imer counter.                                                             |
| Operation                                              | $TIMER \leftarrow XXH$                                                                                                        |
| XOR A,XH                                               | Logical XOR immediate data to accumulator                                                                                     |
| Machine Code                                           | 0 1 0 0 0 0 1 1 0 0 0 0 d d d d                                                                                               |
| Description                                            | Data in the accumulator is Exclusive–OR with the immediate data specified by code.                                            |
| Operation                                              | $ACC \leftarrow ACC$ "XOR" XH                                                                                                 |



| XOR A,[R1R0]   | Logical XOR accumulator with data memory                                                                  |
|----------------|-----------------------------------------------------------------------------------------------------------|
| Machine Code   | $0\ 0\ 0\ 1\ 1\ 0\ 1\ 1$                                                                                  |
| Description    | Data in the accumulator is Exclusive–OR with the data memory ad-<br>dressed by the register pair "R1,R0". |
| Operation      | ACC $\leftarrow$ ACC "XOR" M(R1,R0)                                                                       |
| XOR [R1R0],A   | Logical XOR data memory with accumulator                                                                  |
| Xon [initia],A | Logical Nort data memory with accumulator                                                                 |
| Machine Code   | 00011110                                                                                                  |
| • •            |                                                                                                           |

September 8, 1999



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.

33