保密等级:公开

# HBG 浩博高科技

### **HB8102P Remote controller**

Version: V1.0.0

**Date** : 2011/03/01

Site : www.hbgic.com

Phone: 86-755-86656400



# Index

| 1, | General Descriptions             | 1    |
|----|----------------------------------|------|
| 2、 | Features                         | 1    |
| 3、 | Package SOP14/SOP16 /SOP8        | 2    |
| 4、 | Pads Information                 | 2    |
| 5、 | Electrical Characteristics       | 3    |
|    | 5.1. Absolute Maximum Ratings    | 3    |
|    | 5.2.DC/AC Characteristics        | 3    |
| 6、 | Functional Description           | 4    |
|    | 6.1. Program ROM (PROM)          | 4    |
|    | 6.2. SRAM and I/O Memory Map     | 6    |
|    | 6.3. Halt Mode & Wake up         | 9    |
|    | 6.4. Watch Dog Timer Reset (WDT) | .10  |
|    | 6.5. Programable 8 bits TIMER1   | .10  |
|    | 6.6. Reset                       | . 11 |
|    | 6.7. Low Voltage Reset           | . 11 |
|    | 6.8. System Clock Oscillator     | . 11 |
|    | 6.9. I/O Port                    | .12  |
| 7、 | Application Circuit              | .16  |
| 8、 | Internal Option Registers        | .17  |
| 9、 | Revision History                 | .17  |



#### 1, General Descriptions

The HB8102P IC is a high-performance 4-bit RISC micro-controller embedded with 2KX12 OTP, 32X4 bits SRAM, 12 Input/Output pins, one input pin and built-in one IR LED drive pin. it's flexible and cost-effective solution for remote control of TV, FANS, Air conditioners ... etc.

#### 2. Features

- MCU Operating voltage: 1.8V to 3.6V
- MCU Operation frequency:
  - (a) Internal 32MHz RC OSC : 250KHz/1MHz/2MHz/4MHz
  - (b) External 4MHz X'tal OSC: 250KHz/500KHz/1MHz/2MHz
- Memory Size
- □ Program ROM size: 2KX12 bits (OTP type)

SRAM size: 32x4 bits

- Wake up function for power-down mode
- ☐ HALT mode wake up source: can be wake up from HALT mode to NORMAL mode and executing wake up sub-routine program.
- Provided 12 input /output pins: each I/O has bit programmable as input or output port,
   these 12 I/Os also provided wake up function and pull up resistors configured by registers.
- (a) They are provided with high sink current 20mA @VDD=3V, VOL=0.5V.
- (b) They are provided with drive current 7mA @VDD=3V, VOH=2.5V.
- (c) Pull up 150k ohm resistor @VDD=3V.
- Provided 1 input pin (PA3), shared with RESETB/VPP pin by option, with pull up 150k ohm resistor @ VDD=3V.
- Built-in one IR LED drive pin.
- (Sink current: IoL=210mA at VDD=3V and VoL=0.3V)
- Provided key scan function in halt mode, power consumption <3uA @VDD=3V, key scan
  can be enabled/disabled by control register, any of these I/O pins will not act as key scan
  pin if this I/O's direction is setting as output port, others are setting as input pin, they will
  execute key scan function.</li>
- (a) In HALT mode, if key scan function enabled, power consumption <3uA @VDD=3V.
- (b) In HALT mode, if key scan function disabled, power consumption <1uA @VDD=3V.
- One 8 bits timer, clock source of timer is 8MHz/8192 (1KHz), the content of timer can be cleared and read by program.
- Oscillator type by option
- (a) External X'tal oscillator 4MHz (external ceramic resonator or crystal oscillator, the pin of X'tal is shared with PB0 and PB1 pin )
- (b) Built-in internal RC OSC 32 MHz frequency deviation within  $\pm 2\%$  VDD=1.8V~3.6V, temp= -20 °C ~70 °C
- Four reset condition
- □ Low voltage reset (LVR=1.5V)
- □ Power on RC-reset
- □ External reset (RSTB) pin shared with PA3 by option.
- □ Watch dog timer overflow reset (WDT period is 1 sec)



#### 3 Package SOP14/SOP16/SOP8

Remote controller



#### 4. Pads Information

|                   |       | State After |                                                                 |
|-------------------|-------|-------------|-----------------------------------------------------------------|
| PAD Name          | Туре  | Reset       | Description                                                     |
| Reset/Power Input | :     |             |                                                                 |
| VDD               | Р     | High        | Power input pin.                                                |
| VSS               | Р     | Low         | Ground input pin.                                               |
| General I/O ports |       |             |                                                                 |
| PA0~PA2           | I/O   | XXXX        | PA0~PA2 are programmable bi-direction pin.                      |
|                   |       |             | Pull up resistor 150k ohm.                                      |
|                   |       |             | Edge ( rising or falling ) trigger function as input mode.      |
| PA3/VPP           | I     | Х           | PA3 is a shared pin with external reset RSTB pin by option.     |
| (RSTB)            |       |             | Pull up resistor 150k ohm.                                      |
|                   |       |             | PA3 is also as VPP pin, no option is needed.                    |
|                   |       |             | Edge ( rising or falling ) trigger function.                    |
| PB0~PB1           | I/O   | XX          | PB0 and PB1 are programmable bi-direction pin.                  |
| (XOUT,XIN)        | (O,I) |             | Pull up resistor 150k ohm.                                      |
|                   |       |             | PB1/XIN, PB0/XOUT by option, XIN and XOUT connected to          |
|                   |       |             | external X'tal 4MHz.                                            |
|                   |       |             | Edge ( rising or falling ) trigger function as input mode.      |
| PB2~PB3           | I/O   | XXXX        | PB2, PB3 is a programmable bi-direction pin.                    |
|                   |       |             | Pull up resistor 150k ohm.                                      |
|                   |       |             | Edge ( rising or falling ) trigger function as input mode.      |
| PC0               | I/O   | Х           | PC0 is a programmable bi-direction pin. Pull up resistor 150k   |
|                   |       |             | ohm. Edge ( rising or falling ) trigger function as input mode. |
| IROUT             | 0     | Х           | IROUT is an IR signal output pin.                               |
| (PC1)             |       |             | Open drain and high sink current type.                          |
|                   |       |             | IROUT/PC1 is a shared pin, by control register controlled.      |
|                   |       |             | PC1 is an open drain output port.                               |
| PD0~PD3           | I/O   | XXXX        | PD0 ~ PD3 are a programmable Input /Output port.                |
|                   |       |             | Pull up resistor 150k ohm.                                      |
|                   |       |             | Edge ( rising or falling ) trigger function.                    |

#### **Block Diagram**



#### **5.** Electrical Characteristics

# **5.1. Absolute Maximum Ratings ABSOLUTE MAXIMUM RATINGS**

| PARAMETER             | SYSMBOL          | RATING          | UNIT |
|-----------------------|------------------|-----------------|------|
| DC Supply Voltage     | V+               | < 7.0           | V    |
| Input Voltage Range   | V <sub>IN</sub>  | -0.5 to VDD+0.5 | V    |
| Operating Temperature | T <sub>A</sub>   | -40 to 85       | °C   |
| Storage Temperature   | T <sub>STO</sub> | -50 to 150      | °C   |

# 5.2.DC/AC Characteristics DC CHARACTERISTICS ( $TA = 25^{\circ}C$ , VDD = 3V, unless otherwise noted )

| PARAMETER         | SYMBOL             | TEST CONDITIONS                    |                     |     | LIMIT               | UNIT  |
|-------------------|--------------------|------------------------------------|---------------------|-----|---------------------|-------|
| FARAMETER         | STWIBOL            | TEST CONDITIONS                    | Min                 | Тур | Max                 | ONIT  |
| Operating voltage | $V_{DD}$           | -                                  | 1.8                 | -   | 3.6                 | V     |
| Operating Current | I <sub>OP1</sub>   | 3V , MCU run at 4 MIPS             | -                   | 2.2 | -                   | mA    |
| Standby Current   | I <sub>STBY1</sub> | MCU stop, WDT off,<br>key scan off | -                   | 0.1 |                     | uA    |
| Standby Current   | I <sub>STBY2</sub> | MCU stop, WDT off,<br>key scan on  | -                   | 0.7 | 3                   | uA    |
| Input High Level  | V <sub>IH</sub>    | All I/O port                       | 0.8*V <sub>DD</sub> | -   | -                   | V     |
| Input Low Level   | V <sub>IL</sub>    | All I/O port                       | -                   | -   | 0.2*V <sub>DD</sub> | V     |
| Output Drive      | I <sub>OH</sub>    | VDD=3V , V <sub>OH</sub> =2.5V     | -                   | -7  | -                   | mA    |
| Output Sink       | I <sub>OL1</sub>   | VDD=3V , V <sub>OL</sub> =0.5V     | -                   | 20  | -                   | mA    |
| Output Sink       | I <sub>OL2</sub>   | VDD=3V , V <sub>OL</sub> =0.3V     | -                   | 210 | -                   | mA    |
| Input Resistor    | R <sub>up</sub>    | Pull up 150K ohm                   | -                   | 150 | -                   | K ohm |
| LVR               | $V_{LVR}$          |                                    |                     | 1.5 |                     | V     |



#### AC CHARACTERISTICS (TA = $25^{\circ}$ C, VDD = 3V, unless otherwise noted)

| PARAMETER                                   | SYMBO             | TEST                          |       | LIMIT                                 |       |      |  |  |
|---------------------------------------------|-------------------|-------------------------------|-------|---------------------------------------|-------|------|--|--|
| TANAMETER                                   | L                 | CONDITIONS                    | Min   | Тур                                   | Max   | UNIT |  |  |
| Internal<br>HRCOSC<br>Frequency             | F <sub>OSC1</sub> | VDD=1.8SV~3.6V<br>Temp.= 25°C | 31.36 | 32±2%                                 | 32.64 | MHz  |  |  |
| External EXTOSC                             | F <sub>XTAL</sub> | VDD=1.8V~3.6V                 |       | 1~4                                   |       | MHz  |  |  |
| MCU Operation frequency                     | F <sub>MCU1</sub> | VDD=1.8V~3.6V                 |       | 4MHz/2MHz/1MHz/2<br>50KHz             |       | MHz  |  |  |
| MCU Operation voltage                       | V <sub>MCU</sub>  |                               | 1.8   | 3.0                                   | 3.6   | V    |  |  |
| Internal LRCOSC<br>Frequency                | F <sub>LOSC</sub> | VDD=3V                        |       | 20KHz±50%                             |       | KHz  |  |  |
| WDT period                                  | $T_{WDT}$         | VDD=1.8V~3.6V                 |       | 1                                     |       | Sec  |  |  |
| Stable clock<br>delay after<br>HRCOSC clock | CKstable1         | ( Note 1 )                    | -     | 320us +1024 x (1/ FMCK)<br>( Note 2 ) |       | us   |  |  |
| Stable clock delay after wake               | CKstable2         | ( Note 3 )                    |       | 1024 x (1/ FMCK)<br>( Note 2 )        |       | us   |  |  |

Note1: The stable clock delay is place after first clock output of HRCOSC or external X'tal before user's first instruction, it means the user's program will get more stable clock after power on reset.

Note2: Fmck = MCU operating clock

Note3: The stable clock delay (CKstable2) is place after first clock output of HRCOSC or external X'tal before user's first instruction, it means the user's program will get more stable clock after wake up.

#### **6.** Functional Description

This MCU inside HB8102P is a high performance process, and operation frequency could be from 250KHz up to 8MHz depending on the application.

#### 6.1. Program ROM (PROM)

HB8102P supports 2K words OTP ROM, the address for ROM is located on \$000H ~ \$7FFH, address \$000H ~ \$\$5FFh stores execution program and system area, and the last 512 location (except address \$640h ~ \$66Fh) is reserved area for testing program. The user shall not use this area in any case. Assembler shall check user program on this limitation. Hardware does not need to check this restriction. PROM is divided into two parts, one is user program area (address \$000 ~ \$5FFh), and address \$640h ~ \$66Fh is for data storing only, it can be read in any mode even in locked mode.



| Address     | Description                                                                |  |  |  |  |  |  |
|-------------|----------------------------------------------------------------------------|--|--|--|--|--|--|
| 000h ~ 0FFh |                                                                            |  |  |  |  |  |  |
| 100h ~ 1FFh |                                                                            |  |  |  |  |  |  |
| 200h ~ 2FFh | User area (1.5KX12)                                                        |  |  |  |  |  |  |
|             |                                                                            |  |  |  |  |  |  |
| 500h ~ 5FFh |                                                                            |  |  |  |  |  |  |
| 600h ~ 63Fh | Reserved area                                                              |  |  |  |  |  |  |
| 640h ~ 66Fh | user area(48X12), only for data storing only, don't use to storing program |  |  |  |  |  |  |
| 670h ~ 7FFh | Reserved area                                                              |  |  |  |  |  |  |

Note: The content of OTP ROM address \$640h~\$66Fh can be read by program which using DMDL, DMDM and DMDH registers. The address \$600h~\$63Fh, \$670h~\$7FFh can't be read by program.

Read PROM data is addressed by the DMA2~DMA0 three registers which address range is located in \$000H ~ \$5FFH and \$640H~\$66FH. After these registers (DMA0~2) are specified by firmware, the 12bits. data of PROM can be moved to A register by three times, they are LD A, (DMDL) LD A, (DMDM) and LD A, (DMDH).

| Symbol   | Addr   | R/W   | Reset  | D3         | D2         | D1          | D0         | Description                                 |                         |
|----------|--------|-------|--------|------------|------------|-------------|------------|---------------------------------------------|-------------------------|
| DMA0     | 18H    | R/W   | xxxx   | DMA0.3     | DMA0.2     | DMA0.1      | DMA0.0     | DMA0~DMA3 three registers built a 11 bit    |                         |
| DMA1     | 19H    | R/W   | xxxx   | DMA1.3     | DMA1.2     | DMA1.1      | DMA1.0     | addressing space for read PROM data,        |                         |
| DMA2     | 4 4 11 | R/W   | www    | Х          | DMAGG      |             |            | DMA0 is lowest nibble address, DMA2 is      |                         |
| DMA2     | 1AH    | IK/VV | XXXX   | X          | DMA2.2     | DWA2.2      | DMA2.1     | DMA2.0                                      | highest nibble address. |
|          |        |       |        |            |            |             |            | DMDL is used to read low nibble data of     |                         |
|          |        |       |        | DMDL.3     | DMDL.2     | DMDL.1      |            | program ROM by address DMA0 ~               |                         |
| DMDL     | 1CH    | R     | R xxxx |            |            |             | DMDL.0     | DMA2. Writing Ah to this register will turn |                         |
|          |        |       |        |            |            |             |            | off option mode, write AH again will turn   |                         |
|          |        |       |        |            |            |             |            | on option mode.( only for test prog.)       |                         |
|          |        |       |        |            |            |             |            | DMDM is used to read middle nibble data     |                         |
| DMDM     | 1DH    | R     | www    | DMDM.3     | DMDM 2     | DMDM.1      | DMDM 0     | from program ROM by address DMA0 ~          |                         |
| DIVIDIVI | וטח    | ĸ     | XXXX   | DIVIDIVI.3 | DIVIDIVI.2 | DIVIDIVI. I | DIVIDIVI.U | DMA2. Writing this register with data 05h   |                         |
|          |        |       |        |            |            |             |            | will clear watch dog timer (WDT)            |                         |
| DMDH     | 1EH    | R     | www    | DMDIIA     | DMDII a    | DMDUA       | .1 DMDH.0  | DMDH is used to read the high nibble data   |                         |
| DMDH     | IEM    | ĸ     | XXXX   | DMDH.3     | DIVIDH.2   | חטואט.1     |            | program ROM by address DMA0~DMA2            |                         |

For example, assume that ROM (356H) = 587H.

LD A, #3

LD (DMA2), A

LD A, #5

LD (DMA1), A

LD A, #6

LD (DMA0), A ; PROM address = 356H

LD A, (DMDL) ; A register = 7H ; low nibble data of PROM address 356H
LD A, (DMDM) ; A register = 8H; middle nibble data of PROM address 356H
LD A, (DMDH) ; A register = 5H; high nibble data of PROM address 356H



#### 6.2. SRAM and I/O Memory Map

HB8102P provided 32 nibbles SRAM on the locations \$20H~\$3FH, these address of SRAM is different from PROM's address.

| Direct Addressing (us    | se MAH ) | Real SRAM<br>Address | SRAM MAP                                                    |
|--------------------------|----------|----------------------|-------------------------------------------------------------|
| MAH=XH ( MAH no effect ) | 00H~1FH  |                      | Common I/O port and SFR(special function register) register |
| MAH=0H                   | 20H~3FH  | 00H~1FH              | USER SRAM (32x4)                                            |

#### 6.2.1. I/O Memory Map

The I/O memory map consists of common I/O and extended I/O. These I/O provide some data operation instructions as the following

#### 6.2.2. Common I/O

The previously described common block is defined as the common I/O block. A common I/O provided LD/ADC/SBC/OR/AND/XOR/INC/DEC/RLC/RRC/CMP operation. Bit set/clear can only be operated on the address range from 00H to 0FH, except indirect operation is used.

U: unchanged X: unknown value;R/W: readable & writeable;R: readable only;W: writeable only

| Symbol Addr R/W Reset D3 D2 D4 D0 Description |      |     |       |                        |       |            |               |                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------|------|-----|-------|------------------------|-------|------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol                                        | Addr | R/W | Reset | D3                     | D2    | D1         | D0            | Description                                                                                                                                                                                                                                                                                                                   |
| STATUS                                        | 00H  | R/W | 00xx  | 0                      | 0     | CF         | ZF            | ZF : Zero status register CF : Carry status register                                                                                                                                                                                                                                                                          |
| Reserved                                      | 01H  | R/W | xxxx  | Х                      | х     | Х          | Х             | Reserved                                                                                                                                                                                                                                                                                                                      |
| IOC_PA                                        | 02H  | R/W | 0     | USER<br>0              | IOCA2 | IOCA1      | IOCA0         | IOCA0~IOCA2: control Port A I/O direction.  1: set PA0~PA2 as output port.  0: set PA0~PA2 as input port of corresponding PA0~PA2 bit  USER0: 1 bit user RAM                                                                                                                                                                  |
| DATA_PA                                       | 03H  | R/W | xxxx  | DPA3(<br>Read<br>only) | DPA2  | DPA1       | DPA0          | Read Port A data from PA0~PA3 port and write data to PA0~PA2 (I/O direction is defined by IOC_PA register)                                                                                                                                                                                                                    |
| PC_CTRL                                       | 04Н  | R/W | xxxx  | PC0P<br>U              | PC0WK | IOCP<br>C0 | DPC0(<br>R/W) | DPC0( PC0 PIN) is an bi-direction I/O port.  IOCPC0: control PC0 IO direction.  1: set PC0 as output port.  0: set PC0 as input port  PC0WK: wake up enable control  0: PC0 wake up disabled  1: PC0 wake up enabled  PC0PU: control PC0 pull up resistor.  0: PC0 pull up resistor disabled  1: PC0 pull up resistor enabled |



| Symbol   | Addr | R/W | Reset | D3      | D2      | D1      | D0      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Descri    | ption                                               |
|----------|------|-----|-------|---------|---------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------------------------------------|
| IOC_PB   | 05H  | R/W | 0     | IOCB3   | IOCB2   | IOCB1   | юсво    | direction. 1: set PB0~                                                                                                                                                                                                                                                                                                                                                                                                                                          | -PB3 as ∈ | input port of                                       |
| DATA_PB  | 06H  | R/W | xxxx  | DPB3    | DPB2    | DPB1    | DPB0    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PB0~P     | om PB0~PB3 port<br>B3 (I/O direction<br>3 register) |
| USER1    | 07H  | R/W | xxxx  | USER1.3 | USER1.2 | USER1.1 | USER1.0 | General pu                                                                                                                                                                                                                                                                                                                                                                                                                                                      | rpose us  | er RAM                                              |
| Reserved | 08H  | R/W | xxxx  | Х       | Х       | Х       | х       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |                                                     |
| Reserved | 09H  | R/W | xxxx  | Х       | Х       | Х       | Х       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |                                                     |
| Reserved | 0AH  | R/W | XXXX  | Х       | Х       | Х       | Х       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |                                                     |
| Reserved | 0BH  | R/W | xxxx  | Х       | Х       | Х       | Х       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |                                                     |
| IOC_PD   | 0СН  | R/W | 0     | IOCD3   | IOCD2   | IOCD1   | IOCD0   | direction.<br>1: set PD0~                                                                                                                                                                                                                                                                                                                                                                                                                                       | ·PD3 as i | output port. input port of ~PD3 bit                 |
| DATA_PD  | 0DH  | R/W | xxxx  | DPD3    | DPD2    | DPD1    | DPD0    | and write to                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PD0~P     | om PD0~PD3 port D3 (I/O direction O register)       |
| SCALER1  | ОЕН  | R/W | 0     | TM1EN   | TM1IFG  | T1DIV1  | T1DIV0  | is define by IOC_PD register)  T1DIV1~0T1DIV: The pre-scaler of TIMER1 Timer 1 clock source defined below: FMCK = MCU operating clock  T1DIV1 T1DIV0 TM1CK  0 0 FMCK/8192  0 1 FMCK/4096  1 0 FMCK/2048  1 1 FMCK/1024  TM1IFG: Timer 1 overflow flag 0: no overflow was occurred. 1: overflow was occurred, it can be cleared by software.  TM1EN: Timer 1 enabled/disabled 0:Timer 1 disabled, the content of Timer1 is cleared to all 00h. 1:Timer 1 enabled |           |                                                     |



| Symbol        | Addr | R/W  | Reset | D3        | D2      | D1      | D0       | Description                               |
|---------------|------|------|-------|-----------|---------|---------|----------|-------------------------------------------|
| HOEDO         | OFIL | DAM  |       | USER2.    | USER2.  | USER2.  | USER2.   | General purpose user RAM                  |
| USER2         | 0FH  | R/W  | XXXX  | 3         | 2       | 1       | 0        |                                           |
|               |      |      |       |           |         |         |          | TIM1.3~TIM1.0: Low nibble data of         |
| TIMA          | 4411 | R    | 0     | TIM4 0    | TIM4 0  | T1884 4 | TIM4 0   | TIMER 1, it must be read by following     |
| TIM1_L        | 11H  | К    | 0     | TIM1.3    | TIM1.2  | TIM1.1  | TIM1.0   | sequence, low nibble first, and then      |
|               |      |      |       |           |         |         |          | read high nibble later.                   |
|               |      |      |       |           |         |         |          | TIM1.7~TIM1.4: High nibble data of        |
| TIM1_H        | 12H  | R    | 0     | TIM1.7    | TIM1.6  | TIM1.5  | TIM1.4   | TIMER 1, it must be read by following     |
| I IIWI I _ FI | 1211 | K    | U     | 11IVI 1.7 | THWIT.O | THWIT.5 | 111V11.4 | sequence, low nibble first, and then      |
|               |      |      |       |           |         |         |          | read high nibble later.                   |
|               |      |      |       | DPC1      |         |         |          | DPC1(PC1/IROUT) is an output port for     |
| IR_DIV        | 13H  | R/W  | 0     | (IROUT)   | IRDIV2  | IRDIV1  | IRDIV0   | IR LED driving.IRDIV2~IRDIV0: define      |
|               |      |      |       | (         |         |         |          | outputfrequency and duty of IROUT pin     |
| Reserved      | 14H~ |      |       |           |         |         |          | Reserved                                  |
|               | 17H  |      |       |           |         |         |          |                                           |
| MAO           | 18H  | R/W  | xxxx  | DMA0.3    | DMA0.2  | DMA0.1  | DMA0.0   | DMA0~DMA3 three registers built a 11      |
|               | .0   | 1011 | жж    |           |         |         |          | bits addressing space for read PROM       |
| DMA1          | 19H  | R/W  | XXXX  | DMA1.3    | DMA1.2  | DMA1.1  | DMA1.0   | data, DMA0 is lowest nibble address,      |
| DMA2          | 1AH  | R/W  | xxxx  | x         | DMA2.2  | DMA2.1  | DMA2.0   | DMA2 is highest nibble address.           |
| Reserved      | 1BH  | х    | xxxx  | x         | x       | x       | х        | Reserved                                  |
|               |      |      |       |           |         |         |          | DMDL is used to read low nibble data of   |
|               |      |      |       |           |         |         |          | program ROM by address DMA0 ~             |
| DMDL          | 1CH  | R    | xxxx  | DMDL.3    | DMDL.2  | DMDL.1  | DMDL.0   | DMA2.                                     |
|               | 1011 |      | AAAA  | 222.0     | J       | 552     | 222.0    | Writing Ah to this register will turn off |
|               |      |      |       |           |         |         |          | option mode, write AH again will turn     |
|               |      |      |       |           |         |         |          | on option mode.( only for test prog.)     |
|               |      |      |       |           |         |         |          | DMDM is used to read middle nibble        |
|               |      |      |       | DMDM.     |         |         |          | data from program ROM by address          |
| DMDM          | 1DH  | R    | XXXX  | 3         | DMDM.2  | DMDM.1  | DMDM.0   | DMA0 ~ DMA2.                              |
|               |      |      |       |           |         |         |          | Writing this register with data 05h will  |
|               |      |      |       |           |         |         |          | clear watch dog timer (WDT)               |
|               |      |      |       |           |         |         |          | DMDH is used to read the high nibble      |
| DMDH          | 1EH  | R    | XXXX  | DMDH.3    | DMDH.2  | DMDH.1  | DMDH.0   | data program ROM by address               |
|               |      |      |       |           |         |         |          | DMA0~DMA2                                 |
| Reserved      | 1FH  | W/R  | XXXX  | Х         | Х       | Х       | Х        | Reserved                                  |
| USER          | 20H~ |      |       |           |         |         |          |                                           |
| SRAM          |      | R/W  | xxxx  | SRAM.3    | SRAM.2  | SRAM.1  | SRAM.0   |                                           |
| 32            | 3FH  |      |       |           |         |         |          |                                           |
| nibbles       |      |      |       |           |         |         |          |                                           |



#### 6.2.3. Extended I/O

To extend I/O memory space, HB8102P provided two special instructions, "LD A, **EXIO**(n)" and "LD **EXIO**(n), A", where  $n = 00H \sim 0FH$ " to obtain the 16 extra I/O registers. These registers are used for the I/O port pull up resistors control and wake up control, they can be accessed by two "LD" data transfer instruction only. For example, the pull up resistor of port A is enabled, the program as shown below.

LD A, #FH

LD EXIO(00H), A

U: unchanged X: unknown value R/W: readable & writeable R: readable only W: writeable only

| Symbol   | Addr    | R/W | Reset | D3     | D2     | D1     | D0     | Description                         |
|----------|---------|-----|-------|--------|--------|--------|--------|-------------------------------------|
|          |         |     |       |        |        |        |        | Port A pull up 150K ohm resistor    |
| PAPU     | 00H     | W   | 0000  | PAPU.3 | PAPU.2 | PAPU.1 | PAPU.0 | 0: Port A pull up resistor disabled |
|          |         |     |       |        |        |        |        | 1: Port A pull up resistor enabled  |
| Reserved | 01H     | X   | xxxx  | X      | X      | X      | X      | Reserved                            |
|          |         |     |       |        |        |        |        | Port B pull up 150K ohm resistor    |
| PBPU     | 02H     | W   | 0000  | PBPU.3 | PBPU.2 | PBPU.1 | PBPU.0 | 0: Port B pull up resistor disabled |
|          |         |     |       |        |        |        |        | 1: Port B pull up resistor enabled  |
| Reserved | 03H     | X   | xxxx  | X      | X      | X      | X      | Reserved                            |
|          |         |     |       |        |        |        |        | Port D pull up 150K ohm resistor    |
| PDPU     | 04H     | W   | 0000  | PDPU.3 | PDPU.2 | PDPU.1 | PDPU.0 | 0: Port D pull up resistor disabled |
|          |         |     |       |        |        |        |        | 1: Port D pull up resistor enabled  |
| Reserved | 05H     | X   | xxxx  | Х      | X      | Х      | Х      | Reserved                            |
|          |         |     |       |        |        |        |        | Port A wake up enable control       |
| PAWK     | 06H     | W   | 0000  | PAWK.3 | PAWK.2 | PAWK.1 | PAWK.0 | 0: Port A wake up disabled          |
|          |         |     |       |        |        |        |        | 1: Port A wake up enabled           |
|          |         |     |       | PBWK.  | PBWK.  | PBWK.  | PBWK.  | Port B wake up enable control       |
| PBWK     | 07H     | W   | 0000  | 3      | 2      | 1      | 0      | 0: Port B wake up disabled          |
|          |         |     |       |        | _      | •      |        | 1: Port B wake up enabled           |
|          |         |     |       | PDWK.  | PDWK.  | PDWK.  | PDWK.  | Port D wake up enable control       |
| PDWK     | H80     | W   | 0000  | 3      | 2      | 1      | 0      | 0: Port D wake up disabled          |
|          |         |     |       | •      | _      | •      |        | 1: Port D wake up enabled           |
| Reserved | 09H~0FH |     |       |        |        |        |        | Reserved                            |

#### 6.3. Halt Mode & Wake up

The MCU is changed into HALT mode ( MCU clock and HRCOSC stop) when HALT instruction executed. It provides a power saving mode for those applications requiring a very low stand-by current. The PA0~PA3, PB0~PB3, PD0~PD3 and PC0 are provided the wake up function when rising edge or falling edge trigger was occurred in halt mode. The program counter will be changed to \$004H when HALT instruction executed immediately, and program counter will go to next address after stable time delay (CKstable1, see page 4) while wake up condition was occurred. "system resetb" signal will release HALT state and execute reset procedure because reset is first priority when in HALT mode, so program counter will be changed from \$004h to \$000h, program counter goes to next address after stable time delay ( CKstable1, see page 4). Furthermore, the SRAM will keep their previous data without changed in this mode.



#### 6.4. Watch Dog Timer Reset (WDT)

The watch dog timer (WDT) is used to reset whole chip when detect unexpected execution sequence caused by accident condition, avoiding dead lock of MCU program. This timer can be enabled or disabled by option. WDT will not have any action when WDT disabled. Firmware shall run an "clear watch dog timer" (write data 5h to register \$1D) instruction before WDT time out if WDT is enabled. It will generate a reset signal to reset whole system when WDT overflow. The watch dog timer is a simple counter. It's provided only one time-out period 1sec when WDTEN option enabled, and the clock source uses internal HRCOSC oscillator. WDT can works in NORMAL mode but disabled in HALT mode.

WDT will be reset when wake up from halt, after power on reset or firmware cleared by firmware. The reset watch dog timer sequence is as below:

#### LD A, #05H

#### LD (1DH), A; clear watch dog timer

Notice: For avoiding dead lock and system stable, It's strongly recommended don't use more than one "reset watch dog" in program.

#### 6.5. Programable 8 bits TIMER1

The Timer 1 is an 8 bit up timer. The overflow interval can be easy generated by reading the content value of timer 1 and reset values of Timer 1 to 00h by setting TIM1EN=0. The content value of Timer 1 would be readable only by programmer.



| Symbol  | Addr | DΛM   | Reset | D3     | D2     | D1     | D0     | Dosorinti                                    | on        |                    |              |             |
|---------|------|-------|-------|--------|--------|--------|--------|----------------------------------------------|-----------|--------------------|--------------|-------------|
| Symbol  | Addr | IK/VV | Reset | D3     | DZ     | וט     | DU     | Description                                  |           |                    |              |             |
|         |      |       |       |        |        |        |        | TIM1.3~T                                     | IM1.0: Lo | ow nibble data     | a of TIMER   | 1, it must  |
| TIM1_L  | 11H  | R     | 0000  | TIM1.3 | TIM1.2 | TIM1.1 | TIM1.0 | be rea                                       | d by foll | owing seque        | nce, low ni  | bble first, |
|         |      |       |       |        |        |        |        | and th                                       | en read   | high nibble la     | ater.        |             |
|         |      |       |       |        |        |        |        | TIM1.7~T                                     | IM1.4: H  | ligh nibble d      | data of TIN  | MER 1, it   |
| TIM1 H  | 12H  | R     | 0000  | TIM1.7 | TIM1.6 | TIM1.5 | TIM1.4 |                                              |           | ov following s     |              |             |
| _       |      |       |       |        |        |        |        | first, and then read high nibble later.      |           |                    |              |             |
|         |      |       |       |        |        |        |        | T1DIV1~0T1DIV: The pre-scaler of TIMER1Timer |           |                    |              | 1Timer 1    |
|         |      |       |       |        |        |        |        | clock so                                     | ource d   | efined belov       | w: FMCK      | = MCU       |
|         |      |       |       |        |        |        |        | operating                                    |           |                    |              |             |
|         |      |       |       |        |        |        |        | آ ا                                          | 1         | T                  | 7            |             |
|         |      |       |       |        |        |        |        | T1DIV1                                       | T1DIV0    | TM1CK              |              |             |
|         |      |       |       |        |        |        |        | 0                                            | 0         | FMCK/8192          |              |             |
|         |      |       |       |        |        |        |        | 0                                            | 1         | <b>F</b> мск /4096 |              |             |
| SCALER1 | 0EH  | R/W   | 0000  | TM1EN  | TM1IFG | T1DIV1 | T1DIV0 | 1                                            | 0         | <b>F</b> мск /2048 |              |             |
|         |      |       |       |        |        |        |        | 1                                            | 1         | <b>F</b> мск /1024 |              |             |
|         |      |       |       |        |        |        |        | TM1IFG:                                      | Timer 1   | overflow flag      | 0: no over   | flow was    |
|         |      |       |       |        |        |        |        | occurred                                     | . 1: ove  | erflow was o       | occurred, it | t can be    |
|         |      |       |       |        |        |        |        | cleared                                      | by s      | oftware. T         | M1EN: T      | imer 1      |
|         |      |       |       |        |        |        |        | enabled/d                                    | disabled  | 0:Timer 1 di       | isabled, the | e content   |
|         |      |       |       |        |        |        |        | of Timer1                                    | is clear  | ed to all 00h.     | 1:Timer 1 e  | nabled      |



The clock source of Timer 1 can come from the frequency divider, there are 4 kinds of clock rate selected by register T1DIV1 and T1DIV0 in this divider, and the divider's clock source is come from MCU operation clock.

TM1CK= Timer 1 clock source (FMCK = MCU operating clock)

| T1DIV1 | T1DIV0 | TM1CK              |
|--------|--------|--------------------|
| 0      | 0      | <b>F</b> мск /8192 |
| 0      | 1      | <b>F</b> мск /4096 |
| 1      | 0      | <b>F</b> мск /2048 |
| 1      | 1      | <b>F</b> мск /1024 |

The 8 bits content of Timer 1 can be reset to 00h by TMI1EN setting to 0, it will be up count while Timer 1 clock source rising after TIM1EN setting to 1. The read operation sequence of TIM1.7~TIM1.0 must be follow low nibble (TIM1\_L) first and high nibble (TIM1\_H) later. The Timer 1 will issue an overflow

flag ( register TIM1FG=1 ) when the content data of Timer 1 from FFH to 00H, and Timer 1 will continue counting from 00h to FFh periodical repeat automatically.

#### **6.6. Reset**

The "system resetb" signal is combine with four signals which are power on reset, low voltage reset (LVR), external RSTB pin and WDT overflow reset. A dedicated RSTB pin is provided to reset this chip by external. For normal operation of this chip, a good RSTB is needed. This pin provided built-in 150K ohm pull up resistor. The MCU will go back to NORMAL mode when RSTB was occurred in HALT mode.



#### 6.7. Low Voltage Reset

When VDD power is applied to the chip, the low voltage RSTB default is enabled initially, it will be disabled when in halt mode. The internal system RSTB will be generated if VDD power below about VLVR(1.6V)

#### 6.8. System Clock Oscillator

The HB8102P is provided internal high speed RC oscillator (HRCOSC) and external X'tal oscillator or ceramic resonator (XTOSC) for many application requirements. It's a dual clock MCU system.

Condition VDD=2.4V~3.6V

| TYPE   | OSC frequency                                         | MCU clock ( FMCK )                                                     |
|--------|-------------------------------------------------------|------------------------------------------------------------------------|
| HRCOSC | (1) 32MHz ±2%<br>(2) 32MHz -15%~+15%by PB0/OSC<br>pin | Fhrcosc/8/16/32/128MCU run at 4<br>MHz/2MHz/1MHz/250KHz by option      |
| XTOSC  | 1MHz~16MHz                                            | FxTosc/2/4/8/16 if use 4MHz crystal MCU run at 2MHZ/1MHz/500KHz/250KHz |



System clock can be stopped by HALT command. Once stopped, only wake-up triggering inputs ( PA0~PA3, PB0~PB3, PD0~PD3 or PC0 ) or RSTB ( if PA3 set as RSTB by option) can re-start oscillation. Such oscillation will do 'stable check' before release control to software. There are 128 MCU cycles stable clock delay, It's arrange after first clock output of HRCOSC/XTOSC and before user's first instruction, it means the user's program will get more stable clock after power on reset or wake up from halt mode.

XTOSC: External X'tal oscillator, XIN and XOUT are shared with PB1 and PB0 by option, suitable connected with external ceramic resonator/crystal 1MHz~16MHz. It can be driven by external clock in this mode also, no crystal or resonator needed. The picture as shown below.



#### 6.9. I/O Port

This chip provided total 12 I/O ports, they are bi-direction I/O port PA0~PA2, PB0~PB3, PD0~PD3 and PC0, the I/O ports provided with input and output direction controlled by IOC\_PA, IOC\_PB, IOC\_PD and IOCPC0, and all I/O also provided wake up and pull up resistor function by control register.

6.9.1. Port A /Port B (input/output) Common I/O

| Symbol  | Addr | R/W | RSTB | D3                     | D2    | D1    | D0    | Description                                                                                                                                                 |
|---------|------|-----|------|------------------------|-------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IOC_PA  | 02H  | R/W | 0000 | USER0                  | IOCA2 | IOCA1 | IOCA0 | IOCA0~IOCA2: control Port A I/O direction.  1: set PA0~PA2 as output port.  0: set PA0~PA2 as input port of corresponding PA0~PA2 bit USER0: 1 bit user RAM |
| DATA_PA | 03H  | R/W | xxxx | DPA3<br>(Read<br>only) | DPA2  | DPA1  | DPA0  | Read Port A data from PA0~PA3 port and write data to PA0~PA2 ( I/O direction is defined by IOC_PA register)                                                 |
| IOC_PB  | 05H  | R/W | 0000 | IOCB3                  | IOCB2 | IOCB1 | IOCB0 | IOCB0~IOCB3: control Port B I/O direction.  1: set PB0~PB3 as output port  0: set PB0~PB3 as input port of corresponding PB0~PB3 bit                        |
| DATA_PB | 06H  | R/W | xxxx | DPB3                   | DPB2  | DPB1  | DPB0  | Read Port B data from PB0~PB3 port and write to PB0~PB3 (I/O direction is define by IOC_PB register)                                                        |



#### Extended I/O

| Symbol | Addr | R/W | Reset | D3     | D2     | D1     | D0     | Description                         |
|--------|------|-----|-------|--------|--------|--------|--------|-------------------------------------|
|        |      |     |       |        |        |        |        | Port A pull up 150K ohm resistor    |
| PAPU   | 00H  | W   | 0000  | PAPU.3 | PAPU.2 | PAPU.1 | PAPU.0 | 0: Port A pull up resistor disabled |
|        |      |     |       |        |        |        |        | 1: Port A pull up resistor enabled  |
|        |      |     |       |        |        |        |        | Port B pull up 150K ohm resistor    |
| PBPU   | 02H  | W   | 0000  | PBPU.3 | PBPU.2 | PBPU.1 | PBPU.0 | 0: Port B pull up resistor disabled |
|        |      |     |       |        |        |        |        | 1: Port B pull up resistor enabled  |
|        |      |     |       |        |        |        |        | Port A wake up enable control       |
| PAWK   | 06H  | W   | 0000  | PAWK.3 | PAWK.2 | PAWK.1 | PAWK.0 | 0: Port A wake up disabled          |
|        |      |     |       |        |        |        |        | 1: Port A wake up enabled           |
|        |      |     |       |        |        |        |        | Port B wake up enable control       |
| PBWK   | 07H  | W   | 0000  | PBWK.3 | PBWK.2 | PBWK.1 | PBWK.0 | 0: Port B wake up disabled          |
|        |      |     |       |        |        |        |        | 1: Port B wake up enabled           |

The Port A and Port B are 4-bit I/O port except PA3 is an input port. They can be bit programmable setting as input port or output port. In output mode, the data can be written out to external pin by DATA\_PA OR DATA\_PB register, and reading this output port will get data from DATA\_PA or DATA\_PB register. Pull-up resistor (150K ohm) will be disabled when output mode is selected.

In input mode, Port A and Port B data can be read from external pin by reading DATA\_PA or DATA\_PB register, and they are provided pull-up resistor 150K or not by PAPU, PBPU registers.

In addition, each pin of Port A and Port B also can be with wake up function by using register PAWK or PBWK setting to 1. In HALT mode, If Port A or Port B with wake up enabled by these registers, any edge trigger (rising or falling) is occurred on Port A or Port B will wake up system and turn on HRCOSC or XTOSC oscillator, and the program counter of MCU will jump to the address 04H, running the wake up sub-routing program.

PA3 is an input pin only, provided with pull up 150K ohm and edge wake up function. It's shared with external reset pin (RSTB) pin by option, and VPP pin

PB0 is shared with XOUT by option and PB1 is shared with XIN pin by option. These XIN and XOUT PIN can be connected to external X'tal to replace internal oscillator HRCOSC.

#### 6.9.2. Port C (output)

PC0 is an bi-direction I/O port and it can be set as input port or output port by IOCPC0 register. In addition, it also provided edge trigger (rising or falling) wake up function and pull up resistor.

PC1(IROUT) is an open drain output port with large sink current structure, the IR wave form generated from IR function generator and output to PC1(IROUT) pin. The IR function generator can generate different duty and frequency by IR\_DIV register defined.

#### HB8102P Remote controller

| Symbol  | Addr | R/W | Reset | D3              | D2     | D1     | D0            | Description                                                                                                                                                                                                                                                                                                          |
|---------|------|-----|-------|-----------------|--------|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PC_CTRL | 04Н  | R/W | xxxx  | PC0PU           | PC0WK  | IOCPC0 | DPC0<br>(R/W) | DPC0( PC0 PIN) is an bi-direction I/O port. IOCPC0: control PC0 IO direction. 1: set PC0 as output port. 0: set PC0 as input port PC0WK: wake up enable control 0: PC0 wake up disabled 1: PC0 wake up enabled PC0PU: control PC0 pull up resistor. 0: PC0 pull up resistor disabled 1: PC0 pull up resistor enabled |
| IR_DIV  | 13H  | R/W | 0000  | DPC1<br>(IROUT) | IRDIV2 | IRDIV1 | IRDIV0        | DPC1(PC1/IROUT) is an output port for IR LED driving. IRDIV2~IRDIV0: define output frequency and duty of IROUT pin                                                                                                                                                                                                   |

The IR\_DRV register vs. PC1(IROUT) PIN definition table:

There are two type clock source selected by XTEN option when use IR LED function generator.

- 1.If XTEN=0, Internal RC OSC enabled, IR clock source (Fir ) = 32MHz/8=4MHz
- 2.If XTEN=1, External X'tal OSC enabled, IR clock source (Fir ) = external X'tal frequency = 4MHz

( Notice : PB0 and PB1 pin must be connected to 4MHz crystal in this mode )

| IRDIV2~IRDIV0 | Internal | IROUT PIN output duty & frequency |                                   |  |  |
|---------------|----------|-----------------------------------|-----------------------------------|--|--|
| registers     | Divider  | Duty                              | Frequency                         |  |  |
| 000           | х        | х                                 | DPC1 register output to IROUT pin |  |  |
| 001           | Fir /105 | 52/105 (1/2)                      | 38.09KHz                          |  |  |
| 010           | Fir /105 | 1/3                               | 38.09KHz                          |  |  |
| 011           | FIR /70  | 1/2                               | 57.14KHz                          |  |  |
| 100           | FIR /71  | 23/71 ( 1/3)                      | 56.33KHz                          |  |  |
| 101           | FIR /95  | 31/95 (1/3)                       | 42.10KHz                          |  |  |
| 110           | FIR /100 | 33/100 ( 1/3)                     | 40.00KHz                          |  |  |
| 111           | Fir /111 | 1/3                               | 36.03KHz                          |  |  |



#### 6.9.3 Port D (input/output)

| Reserved | 0BH | R/W | xxxx | Х      | Х      | Х      | Х      | Reserved                                                                                                                              |  |  |
|----------|-----|-----|------|--------|--------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|
| IOC_PD   | ОСН | R/W | 0000 | IOCD3  | IOCD2  | IOCD1  | IOCD0  | IOCD0~IOCD3: control Port D I/O direction.  1: set PD0~PD3 as output port.  0: set PD0~PD3 as input port of corresponding PD0~PD3 bit |  |  |
| DATA_PD  | 0DH | R/W | xxxx | DPD3   | DPD2   | DPD1   | DPD0   | Read Port D data from PD0~PD3 por and write to PD0~PD3 (I/O direction is define by IOC_PD register)                                   |  |  |
| PDPU     | 04H | w   | 0000 | PDPU.3 | PDPU.2 | PDPU.1 | PDPU.0 | Port D pull up 150K ohm resistor 0: Port D pull up resistor disabled 1: Port D pull up resistor enabled                               |  |  |
| PDWK     | 08H | w   | 0000 | PDWK.3 | PDWK.2 | PDWK.1 | PDWK.0 | Port D wake up enable control 0: Port D wake up disabled 1: Port D wake up enabled                                                    |  |  |

Whether all 4 bits of the Port D is input or output port depends on IOC\_PD control register. Port D also provided edge trigger (rising or falling) wake up and pull up resistor 150K, function just like Port A or Port B.

#### 5.9.4. Wake up function for keyboard scan in halt mode

All Port A, Port B, PC0, Port D are provided a special wake up function for hardware keyboard scan in halt mode automatically, and this function can be enabled by code option and enabled or disabled for individual PIN by corresponding wake up registers.

It's built-in one low power RC oscillator 20KHz  $\,\pm\,$  50% for the clock of keyboard scan function operation.

The detail action of keyboard scan is described below:

- 1. Keyboard scan function enabled by code option KBSCEN.
- 2. Set all scan key I/O to input mode.
- 3. Pull up resistor enabled by PAPU, PBPU, PC0PU, PDPU register.
- 4. Wake up function enabled by PAWK, PBWK, PC0WK, PDWK register. Keyboard scan function can be

disabled for individual pin by corresponding wake up control registers set to 0.

- 5. Execute HALT instruction into power down mode.
- 6. When in halt mode, only one I/O port direction switch to output state and others are in input state with pull up resistor. The output port will output one low-pulse from PA2~PA0, PB3~PB0, PD3~PD0 and PC0 sequentially if all wake up registers of all I/O port is enabled. The period of keyboard scan time is fixed ( about 2.4ms  $\pm$  50%), even only 1 port enabled keyboard scan function. The I/O direction won't be changed if the keyboard scan function of specified I/O port disabled by wake up registers (PAWK, PBWK, PC0WK or PDWK register).
- 7. In halt mode, MCU will be waked up by rising or falling edge of I/O ports which key scan function is enabled.



The waveform of keyboard scan function

### 7. Application Circuit



Note: Substrate must be connected to VSS.



# **8. Internal Option Registers**

| Option Name     | Function Description                      |                                                                   |                            |                         |  |  |  |  |  |  |
|-----------------|-------------------------------------------|-------------------------------------------------------------------|----------------------------|-------------------------|--|--|--|--|--|--|
|                 | WDT enable/disable control                |                                                                   |                            |                         |  |  |  |  |  |  |
| WDTEN           | 0: WDT enabled ( WDT period is 1 second ) |                                                                   |                            |                         |  |  |  |  |  |  |
| 1: WDT disabled |                                           |                                                                   |                            |                         |  |  |  |  |  |  |
|                 | PA3 pin sh                                | nared with                                                        | RSTB pin control           |                         |  |  |  |  |  |  |
| PA3_RSTB        | 0: PA3 is F                               | RSTB pin                                                          |                            |                         |  |  |  |  |  |  |
|                 | 1: PA3 is r                               | normal I/O                                                        | port                       |                         |  |  |  |  |  |  |
|                 | External c                                | rystal mod                                                        | e enabled/disabled         |                         |  |  |  |  |  |  |
| XTENB           | 0: Externa                                | 0: External crystal mode enabled, PB0, PB1 should be connected to |                            |                         |  |  |  |  |  |  |
| XILIND          | External X'tal.                           |                                                                   |                            |                         |  |  |  |  |  |  |
|                 | 1: Externa                                | l crystal m                                                       | ode disabled, PB0, PB1     | I is I/O port function. |  |  |  |  |  |  |
|                 | MCU oper                                  | ating clock                                                       | k define ( external crysta | al frequency= Fxtal)    |  |  |  |  |  |  |
| MCKS1           | MCKS1                                     | MCKS0                                                             | Option XTENB=1             | Option XTENB=0          |  |  |  |  |  |  |
|                 |                                           |                                                                   | Use internal               | Use external            |  |  |  |  |  |  |
|                 |                                           |                                                                   | HRCOSC                     | EXTOSC (FXTAL)          |  |  |  |  |  |  |
|                 | 0                                         | 0                                                                 | MCU run at 250KHz          | MCU run at Fхтоsc /16   |  |  |  |  |  |  |
| MCKS0           | 0                                         | 1                                                                 | MCU run at 1MHz            | MCU run at Fхтоsc /8    |  |  |  |  |  |  |
|                 | 1                                         | 0                                                                 | MCU run at 2MHz            | MCU run at Fхтоsc /4    |  |  |  |  |  |  |
|                 | 1                                         | 1 1 MCU run at 4MHz                                               |                            | MCU run at Fxtosc /2    |  |  |  |  |  |  |
|                 | keyboard scan option enabled/disabled     |                                                                   |                            |                         |  |  |  |  |  |  |
| KBSCEN          | 0: Keyboa                                 | rd scan fu                                                        | nction disabled            |                         |  |  |  |  |  |  |
|                 | 1: Keyboa                                 | rd scan fu                                                        | nction enabled             |                         |  |  |  |  |  |  |

## 9. Revision History

| Version | Description                                                     | Page | Date         |
|---------|-----------------------------------------------------------------|------|--------------|
| V1.0.0  | Established                                                     |      | Mar. 1, 2011 |
|         | 1. LVR=1.5V                                                     | P1   |              |
| V1.0.1  | 2. Added Package SOP8                                           | P2   | Apr, 6 2011  |
|         | 3. Delete "except indirect operation is used"                   | P5   |              |
|         | 1. Sink current: IoL=210mA at VDD=3V and VoL=0.3V               | P1   |              |
| V1.0.2  | equency deviation within ±2%, VDD=1.8V~3.6V,temp= -20 °C ~70 °C |      | Apr,21 2011  |
|         | 2. It's provided only one time-out period 1sec                  | P8   |              |