# HYC�N 紘康科技

## **HY10P** Family

User's Guide Mixed Signal Microcontroller



#### **Table of Contents**

| 1.   | READING GUIDANCE                                          | 5  |
|------|-----------------------------------------------------------|----|
| 1.1. | Terms and Definition                                      | 6  |
| 2.   | CENTRAL PROCESSING UNIT (CPU)                             | 8  |
| 2.1. | CPU Core                                                  | 8  |
| 2.2. | Memory                                                    | 9  |
| 3.   | OSCILLATOR, CLOCK SOURCE AND POWER CONSUMPTION MANAGEMENT | 22 |
| 3.1. | Oscillator                                                | 22 |
| 3.2. | CPU and Peripheral Circuit Clock Source                   | 23 |
| 3.3. | Register Instruction-Working Clock Source Controller      | 26 |
| 3.4. | Power Consumption Management and Operation Status         | 29 |
| 4.   | RESET                                                     | 30 |
| 4.1. | Reset Event Description                                   |    |
| 4.2. | Status Register                                           | 32 |
| 4.3. | Register List-Data Memory Reset Status                    | 35 |
| 5.   | INTERRUPT                                                 | 37 |
| 5.1. | Register Instruction-Interrupt                            |    |
| 6.   | INPUT/ OUTPUT PORT (I/O)                                  | 40 |
| 6.1. | Introduction of PORT related register                     | 41 |
| 6.2. | Input/ Output Port 1, I/O Port1                           | 41 |
| 6.3. | Input/ Output Port 2, I/O Port2                           | 43 |
| 6.4. | Input/ Output Port 3,I/O Port3                            | 45 |
| 7.   | WATCH DOG TIMER                                           | 47 |

#### HY10S40 Emulate Chip User' Guide Embedded 18-Bit ΣΔΑDC

#### 8-Bit RISC-like Mixed Signal Microcontroller



| 7.1.  | WDT Manual                                      |
|-------|-------------------------------------------------|
| 7.2.  | Register Instruction-WDT                        |
| 8. 1  | -IMER-A                                         |
| 8.1.  | Register Instruction-TMA51                      |
| 9. 1  | 6-BIT TIMER B (TMB)                             |
| 9.1.  | 4 Types Counting Modes of TMB53                 |
| 9.2.  | TMB1 Control Register List and Instructions64   |
| 10. F | POWER SYSTEM                                    |
| 10.1. | VDDA Manual                                     |
| 10.2. | ACM Manual                                      |
| 10.3. | Register Instruction-PWR66                      |
| 11.   | NALOG DIGITAL CONVERTER SD18,ΣΔΑDC67            |
| 11.1. | SD18 Manual69                                   |
| 11.2. | Analog Channel Input Features75                 |
| 11.3. | Register Instruction-SD1877                     |
| 12. E | BIE AND 16-BIT HARDWARE DATA RECORDER81         |
| 12.1. | BIE Manual82                                    |
| 12.2. | Hardware Data Recorder                          |
| 12.3. | Register Instruction-BIE                        |
| 13. ( | COMMUNICATION INTERFACE (CI)                    |
| 13.1. | I2C Inter-Integrated Circuit Serial interface86 |
| 13.2. | Data Transmission Ratio Calculation88           |
| 13.3. | Time-Out Function                               |

#### HY10S40 Emulate Chip User' Guide Embedded 18-Bit ΣΔΑDC 8-Bit RISC-like Mixed Signal Microcontroller



| 14. R | EVISION RECORD                               | 99 |
|-------|----------------------------------------------|----|
| 13.3. |                                              | 90 |
| 13.5  | I2C Register Instructions                    | 92 |
| 13.4. | I2C Serial Interface Communication Flowchart | 89 |



#### 1. Reading Guidance

#### Attention :

1. HYCON Technology Corp. reserves the right to change the content of this datasheet without further notice. For most up-to-date information, please constantly visit our website: <u>http://www.hycontek.com</u>.

2. HYCON Technology Corp. is not responsible for problems caused by figures or application circuits narrated herein whose related industrial properties belong to third parties.

3. Specifications of any HYCON Technology Corp. products detailed or contained herein stipulate the performance, characteristics, and functions of the specified products in the independent state. We does not guarantee of the performance, characteristics, and functions of the specified products as placed in the customer's products or equipment. Constant and sufficient verification and evaluation is highly advised.

4. Please note the operating conditions of input voltage, output voltage and load current and ensure the IC internal power consumption does not exceed that of package tolerance. HYCON Technology Corp. assumes no responsibility for equipment failures that resulted from using products at values that exceed, even momentarily, rated values listed in products specifications of HYCON products specified herein.

5. Notwithstanding this product has built-in ESD protection circuit, please do not exert excessive static electricity to protection circuit.

6. Products specified or contained herein cannot be employed in applications which require extremely high levels of reliability, such as device or equipment affecting the human body, health/medical equipments, security systems, or any apparatus installed in aircrafts and other vehicles.

7. Despite the fact that HYCON Technology Corp. endeavors to enhance product quality as well as reliability in every possible way, failure or malfunction of semiconductor products may happen. Hence, users are strongly recommended to comply with safety design including redundancy and fire-precaution equipments to prevent any accidents and fires that may follow.

8. Use of the information described herein for other purposes and/or reproduction or copying without the permission of HYCON Technology Corp. is strictly prohibited.

#### 1.1. Terms and Definition

#### 1.1.1. Glossary

| 1MegaWord                   |
|-----------------------------|
| 1KiloByte                   |
| Analog to Digital Converter |
| bit                         |
| Brown-Out Reset             |
| Bank Select Register        |
| Byte                        |
| Capture and Compare         |
| Central Processing Unit     |
| Digital-to-Analog Converter |
| Data Memory                 |
| Enhance Comparator          |
| File Select Register        |
| General Purpose Register    |
| High Accuracy Oscillator    |
| Low Noise OP AMP            |
| Low Power Oscillator        |
| Least Significant Bit       |
| Memory                      |
| Main Program Memory         |
| Most Significant Bit        |
| One Time Program-EPROM      |
| Program Counter             |
| PWM and PFD                 |
| Sigma-Delta ADC             |
| Special Register            |
| Static Random Access Memory |
| Stack                       |
| Watch Dog Timer             |
| Work Register               |
|                             |





#### 1.1.2. Register Related Glossary

| []       | Register length                     |
|----------|-------------------------------------|
| <>       | Register value                      |
| ABC[7:0] | ABC register had 0 to 7bit          |
| ABC<111> | ABC register had 3bit and value     |
|          | had 111 of binary                   |
| ABC<11x> | x : can be neglected, it can be set |
|          | as 1 or 0                           |
| rw       | Read/Write                          |
| r        | Read only                           |
| r0       | Read as 0                           |
| r1       | Read as 1                           |
| W        | Write only                          |
| w0       | Write as 0                          |
| w1       | Write as 1                          |
| h0       | cleared by Hardware                 |
| h1       | set by Hardware                     |
| u0       | cleared by User                     |
| u1       | set by User                         |
| -        | Not use                             |
| !        | users are forbidden to change       |
| u        | unchanged                           |
| х        | unknown                             |
| d        | depends on condition                |
|          |                                     |



#### 2. Central Processing Unit (CPU)

#### 2.1. CPU Core

To get higher efficiency, CPU Core (H08) is adopted Harvard architecture concept. It separates the program memory and data memory respectively. Furthermore, the address of program memory increases the convenience of program writing for user.

CPU Features include:

Separate design structures of program memory and data memory increase the instruction execution speed and improve the CPU efficiency.

Max addressing capabilities are 1MW for program memory and 4096KB for data memory respectively.

Max 46 operation instructions include block switching and stacking control of data memory.

One instruction can complete data moving of FSR register with max 16-bit and address table look-up instruction of 1MW program memory.

The operation of data memory includes the data moving of program counter (PC), status register (Status) and stack register (Stack).

The CPU core is H08B core of starter edition.



#### 2.2. Memory

The structure of memory has two types. One is program memory, which is composed of OTP, and the other is data memory, which is composed of SRAM. On different model product, planned memory size is also different. Therefore, it must pay special attention on specification of the product when reading the operation manual.

Program Memory:

Main Program Memory (MPM)

Program Counter (PC)

Stack (STK)

Data Memory:

Special Register (SR)

General Purpose Register (GPR)

**Related Register Abstract of Memory:** (x: means it is composed of multiple registers.)

PC[10:0] PCHSR[2:0], PCLATH[2:0], PCLATL[7:0] TOS[10:0] TOSH[2:0],TOSL[7:0] FSR0[7:0] FSR0L[7:0] INDF0 INDF0[7:0] POINC0 POINC0[7:0] PODEC0 PODEC0[7:0] PRINC0[7:0] PRINC0 PLUSW0 PLUSW0[7:0] STKCN STKFL[0],STKOV[0],STKUN[0],STKPRT[2:0] **PSTATUS** SKERR[0]



#### 2.2.1. Program Memory



Fig 2-1 Program Memory Architecture

#### 2.2.1.1. Main Program Memory (MPM)

#### Main Program Memory Architecture is as the following:

- Interrupt Vector Position
- Reset Vector Position

Addressing capability is from 0x00000h to 0x7FFh, with a total capacity of 2048 Word.

When the chip is not taken program writing, data type of all addresses is 1. After writing, the addresses will be 1 or 0 according to the written data type. Note: in program development, if the assemble option of simulation software (HYIDE) has burn protection function setting, the data type of chip is 0 at the addresses that burning can be read.

#### 2.2.1.2. Program Counter (PC)

Program Counter (PC) is composed of shift register PCSR and buffer register PCLAT. See Fig 2-2.







Chip used in tool development of PC [10:0] has 11-bit data length. It is composed of two special registers, PCSRH [2:0] and PCLATL [7:0]. PCLATL [7:0] and PCLATH [2:0] can be read / written directly, while PCSRH [2:0] cannot be read / written directly and it must use buffer register PCLATH [2:0] as indirect reading /writing.

- Before reading PC [10:0], it must read PCLATL [7:0] first and then read PCLATH [2:0] before reading correct data. Reverse order will not read correct data.
- Before writing PC [10:0], it must write PCLATH [2:0] and then PCLATL [7:0] finally.
   Reverse order will not write correct data.



#### 2.2.1.3. Stack (STK)

Stack (STK) is mainly composed of stack pointer control register STKCN, top stack register TOS0, stack layer register STKn<sup>1</sup>, stack error flag SKERR(Stack Error) and stack error reset controller SKRST[0], as in Fig 2-3.



Fig 2-3 Stack Architecture

Top stack register TOS [10:0] has 11-bit data length. It is composed of two registers, TOSH [2:0] and TOSL [7:0]. When STKPRT [2:0] =<0>, TOS [10:0] =<0> is null. When the program executes CALL instruction or appears interrupt (INT) service, stack pointer STKPRT [2:0] makes plus one motion and writes PC address when the event appears into TOS [10:0] register of the time. When the program executes RETx instruction, stack pointer STKPRT [2:0] makes minus one motion. Before taking minus one motion, it will write TOS [10:0] data in PC [10:0] in advance. After writing is completed, STKPRT [2:0] makes minus one motion and changes the current TOS [10:0] value.

- It has no special rules for TOS [10:0] register reading and can be read directly.
- TOS[10:0] register writhing can use CALL instruction or interrupt (INT) to write PC[10:0] data, or uses POP instruction to discard current TOS[10:0] data and make STKPRT[2:0]minus one and load new TOS[10:0] data.

During stack operation process, it may appear Stack full STKFL [0], Stack overflow STKOV [0] or Stack underflow STKUN[0] and other events. Stack full is an indication flag before Stack overflow. At the moment, it can discard current TOS [10:0] and make STKPRT [2:0] minus one and write stack layer data with new pointer in TOS [10:0] via POP instruction execution. Note: when STKPRT [2:0]=<0>, POP instruction execution will not appear underflow condition. At the moment, STKPRT [2:0] is still <0>. Therefore, the user must judge whether it is empty stack by oneself.

to TOS.

<sup>&</sup>lt;sup>1</sup> Stack layer register STKn: Each layer of stack has data register with the same length of top stack register TOS. When the stack pointer STKPRT is appointed, the content of data register is sent



When the stack appears overflow and underflow, it may lead to unexpected execution results for program. When necessary, it can restart chip via setting. In program development process, it can set stack reset control bit SKRST  $[0]^2$  as <1> via software setting. When stack appears underflow or overflow, it may generate reset signal and shall restart chip after the SKERR [0] is set as <1>.

- Stack full: When STKFL [0] is set as <1>, PC[10:0] is not affected.
- Stack underflow : When STKUN[0] is set as <1>, PC[10:0] is moved to 0x00000hposition and stack pointer STKPRT points to 0 Level. If SKRST [0] is set as <1>, it may generate reset signal after stack underflow, and SKERR [0] is set as <1>. STKUN
   [0] is set as <0> after reset.
- Stack overflow: When STKOV[0] is set as <1>, PC[10:0] is not affected and STKPRT is still stopped at the final layer and it will press new value, i.e. it may reserve the last one pressing data after stack full. If SKRST[0] is set as <1>, it may generate reset signal after stack overflow, and SKERR [0] is set as <1>. STKOV[0] is set as <0> after reset.
- Error: When SKERR[0] is set as <1>, chip appears stack error. If SKRST[0] is set as <1>, STKUN[0] and STKOV[0] are set as <0> after reset.
- When it appears stack full, if it appears overflow condition as ignorance and continues executing POP instruction as ignorance and causes underflow condition, STKFL[0], STKOV[0] and STKOV[0] are set as <1> simultaneously. Therefore, it is suggested to make cleaning action for flags to avoid erroneous judgment of program when any one of above conditions appears.

If programming method has omitted the known overflow condition, it is suggested to use POP instruction to clear overflow flag and continue executing program after overflow appears. Otherwise, Interrupt or Call instruction generated stack writing motion after overflow will overlay current TOS[10:0] data.

<sup>&</sup>lt;sup>2</sup> SKRST[0] is stack error generated reset signal control bit. It cannot be read /written directly and can only be set via software development at the program development stage, i.e. it must select whether it generates reset signal when stack error appears at the program development stage. If reset is selected, the bit is set as 1 after powering on the chip. Otherwise, it is set as <0>.



#### 2.2.1.4. Register Instruction---Program Memory Controller

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |                         |       |              |             |         |           |        |             |             |  |  |
|---------|------------------------------------------------------------------------------------------------------------|-------|-------------------------|-------|--------------|-------------|---------|-----------|--------|-------------|-------------|--|--|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                  |       |                         |       |              |             |         |           |        |             |             |  |  |
| Address | Name                                                                                                       | Bit 7 | Bit 6                   | Bit 5 | Bit 4        | Bit 3       | Bit 2   | Bit 1     | Bit 0  | ARST        | IRST        |  |  |
| 016h    | TOSH                                                                                                       | -     | -                       | -     | -            | -           | TOS[10] | TOS[9]    | TOS[8] | xxxx        | uuuu        |  |  |
| 017h    | TOSL                                                                                                       |       |                         | Тор   | of-Stack Low | Byte (TOS<7 | /:0>)   |           |        | XXXX XXXX   | սսսս սսսս   |  |  |
| 018h    | SKCN                                                                                                       | SKFL  | SKUN                    | SKOV  | -            | -           |         | SKPRT[2:0 | ]      | 000000      | u\$\$\$\$\$ |  |  |
| 01Ah    | PCLATH                                                                                                     | -     | -                       | -     | -            | -           | PC[10]  | PC[9]     | PC[8]  |             | 0000        |  |  |
| 01Bh    | PCLATL                                                                                                     |       | PC Low Byte for PC<7:0> |       |              |             |         |           |        |             |             |  |  |
| 02Ch    | PSTATUS                                                                                                    | POR   | PD                      | то    | IDL          | RST         | SKERR   | -         | -      | \$000 \$00. | uu\$u u\$u. |  |  |

Table 2-1 Program Memory Control Register

#### TOSU/TOSH/TOSL: Stacked Top Stack Register

TOSH: TOS[10:8]

TOSL: TOS[7:0]

#### STKPTR: Stack Controller

STKFL: Stack Full Flag

- 1: Occurred
- 0: Not Occurred

STKUN: Stack Underflow Flag

- 1: Occurred
- 0: Not Occurred

STKOV: Stack Overflow Flag

- 1: Occurred
- 0: Not Occurred

#### STKPRT[2:0]: Stack Pointer Register

```
111: 7<sup>th</sup> layer
```

110: 6<sup>th</sup> layer

00000: 0 layer TOS[10:0]=0x0000h

#### PCLATU/PCLATH/PCLATL: Program Counter PC[10:0]

PCLATH: PC[10:8]

```
PCLATL: PC[7:0]
```

#### PSTATUS: Status Register

SKERR: Stack Error Generated Reset Flag

1: Occurred

0: Not Occurred



#### 2.2.2. Data Memory (DM)

Data Memory (DM) is composed of Specially Register (SR) and General Purpose Register (GPR). Furthermore, it takes every 256byte as a block. 128byte Specially Register and 128 byte General Purpose Register is as in Fig 2-4.



Fig 2-4 Data Memory (DM) Architecture

#### 2.2.2.1. Memory and Instruction

H08 instruction set can be divided A and B two version, which have great difference in memory application, such as addressing capability, hardware multiplier, table look-up instruction, support functions and parameters definition. Here just illustrate definition of instruction memory parameters. See Instruction part of Instruction Set on detailed instruction parameter illustration.

Instructions with address computation function in instruction set have three parameters at most, i.e. "f", "d" and "a".

"f" refers to Data or Data Memory Address.

"d" refers to data storage place after computation. If d=0, it is stored in WREG register. If d=1, it is stored in Data Memory Register.

"a" is memory operation block appointing. If a=0, it is operated in block 0. If a=1, it is operated in BSR [3:0] appointed block.



#### 2.2.2.2. Block Selection Control Register

Data memory is planned every 256byte as a block, i.e.  $000h\sim0FFh$  is a block. If it is going to read / write data register after 0FFh address, it shall set block control register BSR [3:0] and instruction parameter "a" correctly. It is illustrated as the following:

- When a = 0, no matter BSR[3:0] is appointed at any block, the reading / writing of instruction to memory can only be at block 0.
- When a = 1, the reading / writing of H08A CPU Core instruction to data memory will be at BSR [3:0] appointed block. The reading / writing of H08B CPU Core instruction to data memory will be at block 0.



Example 2-1 Relation between Block Selector Example Program and Data Memory



#### 2.2.2.3. Special Register (SR)

Special Register (SR) includes CPU Core peripheral function related registers. It mainly has control function register and data return register. If it takes reading for address which is not defined in data register or address used bit, read data is 0.

In SR, it also has several registers dedicated in instruction collocation. It just introduces two kinds of commonly used registers. One is working register WREG and the other is indirect addressing register FSR. The rest special registers, which are not introduced here, will be taken detailed illustration in each chapter.

#### 2.2.2.3.1. Working Register (WREG)

Working register is shortened as W. It is the most frequently used register for instruction collocation, ranging from data movement, computation and judgment etc.



#### 2.2.2.3.2. Indirect Addressing Register, FSR and INDF

FSR indirect addressing register is composed of index register FSR0[9:0] and index registers INDF0[7:0] and INDF1[7:0]. As the functions are similar, it just illustrates FSR0.

FSR0L [7:0] can write 16-bit data by using an instruction via a special instruction.

INDF0 [7:0] is index register and it can read the data of FSRL0 [7:0] pointed data memory address. Functions are described as the following:

- POINC0[7:0]: When read /write POINC0[7:0] register via instruction, the following events may appear:
  - Return the contents of current FSR0 [7:0] pointed address firstly.
  - The value of index register FSR0 [7:0] is added one and pointed to next address.
- PODEC0[7:0]: When read /write PODEC0[7:0] register via instruction, the following events may appear:
  - Return the contents of current FSR0 [7:0] pointed address firstly.
  - The value of index register FSR0 [7:0] is minus one and pointed to previous address.
- PRINC0[7:0]: When read /write POINC0[7:0] register via instruction, the following events may appear:
  - The value of index register FSR0 [7:0] is added one and pointed to next address firstly.
  - Return the contents of current FSR0 [7:0] pointed address then.
- PLUSW0 [7:0]: When read /write PLUSW0 [7:0] register via instruction, the following events may appear:
  - Add the value of index register FSR0 [7:0] to the content of working register W firstly.
  - Return contents of current FSR0 [7:0] pointed address. W content is values with sign bit, i.e. ±128d.

#### 2.2.2.3.3. General Purpose Register (GPR)

General Purpose Register (GPR) takes data storage, computation, flag setting and other free planning area for the users.



#### 2.2.2.4. Register Instruction---Data Memory Controller

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |                                                            |              |               |               |              |            |       |           |           |  |  |
|---------|------------------------------------------------------------------------------------------------------------|-------|------------------------------------------------------------|--------------|---------------|---------------|--------------|------------|-------|-----------|-----------|--|--|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                  |       |                                                            |              |               |               |              |            |       |           |           |  |  |
| Address | Name                                                                                                       | Bit 7 | Bit 6                                                      | Bit 5        | Bit 4         | Bit 3         | Bit 2        | Bit 1      | Bit 0 | ARST      | IRST      |  |  |
| 000h    | INDF0                                                                                                      |       | Contents of                                                | of FSR0 to a | address data  | memoryvalue   | of FSR0 not  | changed    |       | XXXX XXXX | սսսս սսսս |  |  |
| 001h    | POINC0                                                                                                     |       | Contents of F                                              | SR0 to ad    | dress data me | emoryvalue of | FSR0 post-ir | cremented  |       | XXXX XXXX | սսսս սսսս |  |  |
| 002h    | PODEC0                                                                                                     |       | Contents of F                                              | SR0 to add   | dress data me | moryvalue of  | FSR0 post-de | ecremented |       | XXXX XXXX | սսսս սսսս |  |  |
| 003h    | PRINC0                                                                                                     |       | Contents of                                                | FSR0 to ad   | dress data m  | emoryvalue of | FSR0 pre-in  | cremented  |       | XXXX XXXX | սսսս սսսս |  |  |
| 004h    | PLUSW0                                                                                                     |       | Contents                                                   | of FSR0 to   | address data  | memoryvalue   | of FSR0 offs | et by W    |       | XXXX XXXX | นนนน นนนน |  |  |
| 010H    | FSR0L                                                                                                      |       | Indirect Data Memory Address Pointer 0 Low Byte, FSR0[7:0] |              |               |               |              |            |       |           | นนนน นนนน |  |  |
| 029h    | WREG                                                                                                       |       |                                                            |              | Working       | Register      |              |            |       | XXXX XXXX | นนนน นนนน |  |  |

Table 2-2 Data Memory Control Register

#### INDF0/POINC0/PODEC0/PRINC0/PLUSW0: Index register with different functions

INDF0[7:0]: .See 2.2.2.3.2 Indirect Addressing Register, FSR and INDF Description in detail.
POINC0[7:0]: See 2.2.2.3.2 Indirect Addressing Register, FSR and INDF Description in detail.
PODEC0[7:0]: See 2.2.2.3.2 Indirect Addressing Register, FSR and INDF Description in detail.
PRINC0[7:0]: See 2.2.2.3.2 Indirect Addressing Register, FSR and INDF Description in detail.
PLUSW0[7:0]: See 2.2.2.3.2 Indirect Addressing Register, FSR and INDF Description in detail.

#### FSR0: Indirectly Addresses Index Register

FSR0L[7:0]: See 2.2.2.3.2 Indirect Addressing Register, FSR and INDF Description in detail.

#### WREG: Indirectly Addresses Index Register

WREG[7:0]: See 2.2.2.3.1 Working Register, WREG Description in detail.



#### 2.2.3. Register List-Data Memory

|               |                 |                                                                  | "-"no use,"   | *"read/wr  | ite,"w"write, | "r"read,"r0"o   | only read 0," | r1"only read | i 1,"w0"only | write 0,"w1" | only write 1 |
|---------------|-----------------|------------------------------------------------------------------|---------------|------------|---------------|-----------------|---------------|--------------|--------------|--------------|--------------|
|               |                 |                                                                  |               |            |               | •               |               |              | unchanged,"c |              |              |
| Address       | Name            | Bit 7                                                            | Bit 6         | Bit 5      | Bit 4         | Bit 3           | Bit 2         | Bit 1        | Bit 0        | ARST         | IRST         |
| 000h          | INDF0           | Contents of FSR0 to address data memoryvalue of FSR0 not changed |               |            |               |                 |               |              |              |              | นนนน นนนน    |
| 001h          | POINC0          |                                                                  | Contents of F | SR0 to ad  | dress data me | emoryvalue of   | FSR0 post-ir  | ncremented   |              | XXXX XXXX    | นนนน นนนน    |
| 002h          | PODEC0          |                                                                  | Contents of F | SR0 to add | dress data me | moryvalue of    | FSR0 post-d   | ecremented   |              | XXXX XXXX    | นนนน นนนน    |
| 003h          | PRINC0          |                                                                  | Contents of F | SR0 to ac  | Idress data m | emoryvalue of   | FSR0 pre-in   | cremented    |              | XXXX XXXX    | นนนน นนนน    |
| 004h          | PLUSW0          |                                                                  | Contents of   | of FSR0 to | address data  | memoryvalue     | of FSR0 offs  | set by W     |              | XXXX XXXX    | սսսս սսսս    |
| 010H          | FSR0L           |                                                                  | Indired       | ct Data Me | mory Address  | Pointer 0 Lov   | v Byte,FSR0   | 7:0]         |              | XXXX XXXX    | սսսս սսսս    |
| 016h          | TOSH            | -                                                                | -             | -          | -             | -               | TOS[10]       | TOS[9]       | TOS[8]       | xxxx         | uuuu         |
| 017h          | TOSL            |                                                                  |               | Тор        | -of-Stack Low | Byte (TOS<7     | :0>)          |              |              | XXXX XXXX    | սսսս սսսս    |
| 018h          | STKPTR          | SKFL                                                             | SKUN          | SKOV       | -             | -               |               | SKPRT[2:0    | ]            | 000000       | u\$\$\$\$\$  |
| 01Ah          | PCLATH          | -                                                                | -             | -          | -             | -               | PC[10]        | PC[9]        | PC[8]        |              | 0000         |
| 01Bh          | PCLATL          |                                                                  |               |            | PC Low Byte   | e for PC<7:0>   |               |              |              | 0000 0000    | 0000 0000    |
| 023h          | INTE1           | GIE                                                              | ADIE          | -          | WDTIE         | TB1IE           | TMAIE         | -            | E0IE         | 0000 0000    | Ouuu uuuu    |
| 024h          | INTE2           | -                                                                | -             | -          | -             | I2CERIE         | I2CIE         | -            | -            | 0000 0000    | นนนน นนนน    |
| 026h          | INTF1           | -                                                                | ADIF          | -          | WDTIF         | TB1IF           | TMAIF         | -            | E0IF         | .000 0000    | .uuu uuuu    |
| 027h          | INTF2           | -                                                                | -             | -          | -             | I2CERIF         | I2CIF         | -            | -            | 0000 0000    | սսսս սսսս    |
| 029h          | WREG            |                                                                  |               |            | Working       | Register        |               |              |              | XXXX XXXX    | սսսս սսսս    |
| 02Bh          | STATUS          | -                                                                | -             | -          | С             | -               | -             | -            | Z            | x xxxx       | u uuuu       |
| 02Ch          | PSTATUS         | BOR                                                              | PD            | то         | IDL           | RST             | SKERR         | -            | -            | \$000 \$00.  | uu\$u u\$u.  |
| 02Eh          | BIECN           | -                                                                | -             | -          | -             | VPPHV           | -             | BIEWR        | BIERD        | 1 \$.00      | 1 \$.uu      |
| 02Fh          | BIEARH          | ENBIE                                                            | -             | -          | -             | -               | 11-bit look   | up Table as  | BIEAH[2:0]   | 0 xxxx       | u uuuu       |
| 030h          | BIEARL          |                                                                  | BIE Address   | Register a | as BIEAL[5:0] | or 11-bit look- | up Table as   | BIEAL[7:0]   |              | XXXX XXXX    | นนนน นนนน    |
| 031h          | BIEDRH          |                                                                  |               | -          | BIE High Byte | Data Registe    | r             |              |              | XXXX XXXX    | սսսս սսսս    |
| 032h          | BIEDRL          |                                                                  |               |            | BIE Low Byte  | Data Register   | r             |              |              | XXXX XXXX    | นนนน นนนน    |
| 033h          | PWRCN           | ENL                                                              | DO[1:0]       | VDE        | DAX[1:0]      | -               | -             | ADRST        | CSFON        | 0000 0000    | uuuu u00u    |
| 034h          | OSCCN0          | OSC                                                              | S[1:0]        | DF         | HS[1:0]       |                 | DMS[2:0]      |              | CPUS         | 0000 0000    | นนนน นนนน    |
| 035h          | OSCCN1          | -                                                                |               |            | ADCS[2:0      | ļ<br>]          |               | 3[1:0]       | TMBS         | 0000 0000    | uuuu uuu.    |
| 036h          | OSCCN2          | -                                                                | -             | _          | -             | HAON            |               | ENHAO        | LPO          | .000 0011    | .uuu uu11    |
| 037h          | WDTCN           | -                                                                | -             |            | -             | ENWDT           |               | DWDT[2:0     |              | 0000 0000    | uuuu \$000   |
| 038h          | TMACN           | ENTMA                                                            | TMACL         | TMAS       |               | DTMA[2:0]       | I             | -            | -            | 0000 00      | u0uu uu      |
| 039h          | TMAR            |                                                                  |               |            | TMA count     | er Register     |               |              |              | 0000 0000    |              |
| 041h          | CSFCN0          | SKRST                                                            | EN_RST_PIN    |            |               |                 | TR[5:0]       |              |              | 0.10 0000    |              |
| 043h          | ADCRH           | ORACI                                                            |               |            | C conversion  | memory High     |               |              |              | xxxx xxxx    |              |
| 044h          | ADCRM           |                                                                  |               |            |               | emory Middle    | <b>7</b>      |              |              |              |              |
| 04411<br>045h | ADCRIVI         |                                                                  |               |            |               | memory Low E    | <b>,</b>      |              |              |              |              |
|               | ADCRL<br>ADCCN1 | ENADC                                                            | ENHIGN        | ENCHP      |               | ,               |               | ADGN[2:0     | 1            | XXXX XXXX    | 0000 0000    |
| 046h          |                 | LINADO                                                           | LININGIN      | LINCHP     | -             |                 |               | DCSET[2:0    |              | 0000 0000    |              |
| 047h          | ADCCN2          | -                                                                | -             | -01        | -             | VREGN           |               | DC3E1[2:0    | Li,          | 0000         | 0000         |
| 048h          | ADCCN3          |                                                                  | OSR[3         | .0]        |               | -               | -             | -            | -            | 0000.        | 0000.        |

Table 2-3 Data Memory List

#### HY10S40 Emulate Chip User' Guide Embedded 18-Bit ΣΔΑDC

8-Bit RISC-like Mixed Signal Microcontroller

|             | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |                                     |            |               |                 |           |          |           |           |           |  |
|-------------|------------------------------------------------------------------------------------------------------------|-------|-------------------------------------|------------|---------------|-----------------|-----------|----------|-----------|-----------|-----------|--|
|             | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on con                        |       |                                     |            |               |                 |           |          |           |           |           |  |
| Address     | Name                                                                                                       | Bit 7 | Bit 6                               | Bit 5      | Bit 4         | Bit 3           | Bit 2     | Bit 1    | Bit 0     | ARST      | IRST      |  |
| 049h        | AINET1                                                                                                     |       | INH[2:0]                            |            | INL[2:0]      |                 | INIS      | -        | 0000 000. | 0000 000. |           |  |
| 04Ah        | AINET2                                                                                                     | -     | VRH[1                               | :0]        | INX           | [1:0]           | VRL       | .[1:0]   | -         | .000 000. | .000 000. |  |
| 04Eh        | TB1Flag                                                                                                    | -     | -                                   | PWM6A      | PWM5A         | PWM4A           | PWM3A     | PWM2A    | PWM1A     | 00 0000   | uu uuuu   |  |
| 04Fh        | TB1CN0                                                                                                     | ENTB1 | TB1M[                               | 1:0]       | TB1R          | T[1:0]          | TB1CL     | -        | -         | 0000 0000 | นนนน น0นน |  |
| 050h        | TB1CN1                                                                                                     | PA1IV | P                                   | WMA1[2:0   | ]             | PA0IV           |           | PWMA0[2: | 0]        | 0000 0000 | นนนน นนนน |  |
| 051h        | TB1RH                                                                                                      |       |                                     | Tir        | merB1 counte  | r Register [15  | :8]       |          |           | XXXX XXXX | นนนน นนนน |  |
| 052h        | TB1RL                                                                                                      |       |                                     | Ti         | imerB1 counte | er Register [7: | :0]       |          |           | XXXX XXXX | นนนน นนนน |  |
| 053h        | TB1C0H                                                                                                     |       |                                     | TimerB     | 1 counter Cor | ndition Registe | er [15:8] |          |           | XXXX XXXX | นนนน นนนน |  |
| 054h        | TB1C0L                                                                                                     |       |                                     | TimerE     | 31 counter Co | ndition Regist  | ter [7:0] |          |           | XXXX XXXX | นนนน นนนน |  |
| 055h        | TB1C1H                                                                                                     |       |                                     | TimerB     | 1 counter Cor | ndition Registe | er [15:8] |          |           | XXXX XXXX | นนนน นนนน |  |
| 056h        | TB1C1L                                                                                                     |       |                                     | TimerE     | 31 counter Co | ndition Regist  | ter [7:0] |          |           | XXXX XXXX | นนนน นนนน |  |
| 057h        | TB1C2H                                                                                                     |       |                                     | TimerB     | 1 counter Cor | ndition Registe | er [15:8] |          |           | XXXX XXXX | นนนน นนนน |  |
| 058h        | TB1C2L                                                                                                     |       |                                     | TimerE     | 31 counter Co | ndition Regist  | ter [7:0] |          |           | XXXX XXXX | นนนน นนนน |  |
| 061h        | CFG                                                                                                        |       |                                     | Rsv.       |               |                 | GCRst     | ENI2CT   | ENI2C     |           | uuu       |  |
| 062h        | ACT                                                                                                        | SLAVE | -                                   | -          | I2CER         | START           | STOP      | I2CINT   | ACK       | 0000 0000 | นนนน นนนน |  |
| 063h        | STA                                                                                                        | MACTF | SACTF                               | RDBF       | RWF           | DFF             | ACKF      | GCF      | ARBF      | 0001 0000 | นนนน นนนน |  |
| 064h        | CRG                                                                                                        |       |                                     |            | CRG           | [7:0]           |           |          |           | 0000 0000 | นนนน นนนน |  |
| 065h        | TOC                                                                                                        | I2CTF |                                     | DI2C[2:0]  |               |                 | I2CTI     | _T[3:0]  |           | 0000 0000 | นนนน นนนน |  |
| 066h        | RDB                                                                                                        |       |                                     |            | RDB[7:1]      |                 |           |          | RDB[0]    | XXXX XXXX | นนนน นนนน |  |
| 067h        | TDB0                                                                                                       |       |                                     |            | TDB0[7:1]     |                 |           |          | TDB[0]    | XXXX XXXX | นนนน นนนน |  |
| 068h        | SID0                                                                                                       |       | SID[7:1],1                          | he corresp | onding addre  | ss of the 7-bit | mode      |          | SIDV[0]   | 0000 0000 | นนนน นนนน |  |
| 070h        | PT1                                                                                                        | -     | -                                   | -          | -             | -               | -         | -        | PT10      | xxxx      | xxxx      |  |
| 071h        | TRISC1                                                                                                     | -     | -                                   | -          | -             | -               | -         | -        | -         | 0000 0000 | นนนน นนนน |  |
| 072h        | PT1DA                                                                                                      | -     | -                                   | -          | -             | -               | -         | -        | -         | 0000 0000 | นนนน นนนน |  |
| 073h        | PT1PU                                                                                                      | -     | -                                   | -          | -             | -               | -         | -        | -         | 0000 0000 | นนนน นนนน |  |
| 074h        | PT1EG                                                                                                      | -     | -                                   | FPWMA1     | FPWMA0        | -               | -         | EOE      | G[1:0]    | 0000      | uuuu      |  |
| 075h        | PT2                                                                                                        | -     | -                                   | -          | -             | -               | -         | PT21     | PT20      | XX        | xx        |  |
| 076h        | TRISC2                                                                                                     | -     | -                                   | -          | -             | -               | -         | TC21     | TC20      |           | uu        |  |
| 077h        | PT2DA                                                                                                      | -     | -                                   | -          | -             | -               | -         | DA21     | DA20      |           | uu        |  |
| 078h        | PT2PU                                                                                                      | -     | -                                   | -          | -             | -               | -         | PU21     | PU20      |           | uu        |  |
| 079h        | PT3                                                                                                        | -     | -                                   | PT35       | PT34          | PT33            | PT32      | PT31     | PT30      | xx xxxx   | xx xxxx   |  |
| 07Ah        | TRISC3                                                                                                     | -     | -                                   | TC35       | TC34          | TC33            | TC32      | TC31     | TC30      | 00 0000   | uu uuuu   |  |
| 07Bh        | PT3DA                                                                                                      | -     | -                                   | DA35       | DA34          | DA33            | DA32      | DA31     | DA30      | 00 0000   | uu uuuu   |  |
| 07Ch        | PT3PU                                                                                                      | -     | -                                   | PU35       | PU34          | PU33            | PU32      | PU31     | PU30      | 00 0000   | uu uuuu   |  |
| 080h ~ 0FFh | GPR0                                                                                                       |       | General Purpose Register as 128Byte |            |               |                 |           |          |           |           | นนนน นนนน |  |

Table 2-4 Data Memory List (Continued)





#### 3. Oscillator, Clock Source and Power Consumption Management

HY10P Series have two clock sources, ie HAO and LPO, as in Table 3-1. It can distribute and manage CPU and peripheral working frequency feasibly through clock controller register. Furthermore, it can adjust power consumption of chip properly to reach the energy saving purpose.

#### Abstract of Clock Control Register:

| OSCCN0 | OSCS[1:0],DHS[1:0],DMS[2:0],CPUS[0] |
|--------|-------------------------------------|
|--------|-------------------------------------|

OSCCN1 LCPS[1:0],ADCS[2:0],DTMB[1:0],TMBS[0]

OSCCN2 HAOM[1:0],ENHAO[0],LPO[0]

| Sign | Frequency | Frequ                     | uency Contr   | Instructio  | n Execution Status |             |
|------|-----------|---------------------------|---------------|-------------|--------------------|-------------|
|      |           | OSCCN2[7:0] Configuration |               |             |                    |             |
|      |           | ENHAO[0]                  | HAOM[1]       | HAOM[0]     | SLP                | IDLE        |
| HAO  | 8MHz      | 1 1 1                     |               | Stop        | Oscillation        |             |
|      | 4MHz      | 1                         | 0             | 1           | Stop               | Oscillation |
|      | 2MHz      | 1                         | 0             | 0           | Stop               | Oscillation |
| LPO  | 14KHz     | Oscillation i             | s started aft | er the chip | Stop               | Oscillation |
|      |           | i                         | s power on.   |             |                    |             |

Table 3-1 Internal RC Oscillator Parameter, Frequency Controller Configuration and Instruction Status

#### 3.1. Oscillator

#### 3.1.1. HAO Oscillator

HAO is internal high speed RC oscillator. Typical output frequency is 2.0~8.0MHz. When CPU of HY10P series products uses other oscillators as working clock source, it can shut off the HAO oscillator via ENHAO[0] setting.

#### 3.1.2. LPO Oscillator

LPO is internal low speed RC oscillator. Typical output frequency is 14KHz. As the current consumption of LPO is about 0.7uA, it is mainly applied to low speed and power saving CPU working mode and Watch Dog Timer clock source.

After HY10P series of products execute Sleep instructions, LPO oscillator is shut off. LPO will be started oscillation automatically when the chip is awakened.



#### 3.2. CPU and Peripheral Circuit Clock Source

#### 3.2.1. Clock Source Configuration

Two groups of oscillators output (OSC\_HAO、OSC\_LPO) will be started /stopped, switched and pre-scaled frequency via pre-set working clock distributor, and then enter CPU and all peripheral circuits of chip, as in Fig 3-1.



Fig 3-1 Pre-set Working Clock Distributor

#### 3.2.2. CPU Clock Source

CPU has several working frequency for option. Via CPUS [0], optional working frequency is from HS\_CK or DHS\_CK.

Instruction working frequency adopts 1/4 CPU\_CK design and frequency is divided to frequency source of INTR\_CK.

- When operating ΣΔADC, it is suggested to divide current working frequency after using HS\_CK for CPU to obtain better performance.
- When CPU\_CK frequency and instruction execute cycle, it is as in Fig 3-2. Table 3-2 lists the relation between CPU working frequency and instruction cycle briefly.







| Working Freque | CPU       | Instruction |         |  |
|----------------|-----------|-------------|---------|--|
| ncy<br>CPU_CK  | Frequency | Frequency   | Cycle   |  |
| 8MHZ           | 8MHZ      | 2MHz        | 0.5us   |  |
| 4MHz           | 4MHz      | 1MHz        | 1us     |  |
| 2MHz           | 2MHz      | 500kHz      | 2us     |  |
| 14KHz          | 14KHz     | 3.5KHz      | 285.7us |  |

Table 3-2 CPU Working Frequency and Instruction Execution Cycle



#### 3.2.3. CPU Peripheral Circuit Clock Source

Working clock of HY10P series peripheral circuits is configured by different configuration controller and frequency pre-scaler. The configuration will make detailed illustration in peripheral units, so peripheral working clock configuration diagram is just attached here, as in Fig 3-3.



Fig 3-3 Peripheral Working Clock Configuration Diagram



#### 3.3. Register Instruction-Working Clock Source Controller

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |            |       |           |       |          |        |       |           |           |  |
|---------|------------------------------------------------------------------------------------------------------------|-------|------------|-------|-----------|-------|----------|--------|-------|-----------|-----------|--|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                  |       |            |       |           |       |          |        |       |           |           |  |
| Address | Name                                                                                                       | Bit 7 | Bit 6      | Bit 5 | Bit 4     | Bit 3 | Bit 2    | Bit 1  | Bit 0 | ARST      | IRST      |  |
| 033h    | PWRCN                                                                                                      |       |            |       |           |       |          |        | CSFON | 0000 0000 | uuuu u00u |  |
| 034h    | OSCCN0                                                                                                     | OSC   | S[1:0]     | DH    | HS[1:0]   |       | DMS[2:0] |        | CPUS  | 0000 0000 | սսսս սսսս |  |
| 035h    | OSCCN1                                                                                                     | -     | -          |       | ADCS[2:0] | ]     | DTM      | B[1:0] | TMBS  | 0000 0000 | uuuu uuu. |  |
| 036h    | OSCCN2                                                                                                     | -     | -          | -     | -         | HAON  | И[1:0]   | ENHAO  | LPO   | .000 0011 | .uuu uu11 |  |
| 041h    | CSFCN0                                                                                                     | SKRST | EN_RST_PIN |       |           | HAO   | TR[5:0]  |        |       | 0.10 0000 | u.uu uuuu |  |

Table 3-3 Working Clock Source Control Register

#### OSCCN0 [7:0] Chip Working Frequency Control Register 0

Frequency Controller of OSCS [1:0] HS\_CK

<11> Not Used

- <10>OSC\_HAO
- <01>OSC\_LPO
- <00>OSC\_HAO

Frequency Allocation Selector of DHS [1:0] DHS\_CK

<11>HS\_CK ÷ 8

- <10>HS\_CK ÷ 4
- <01>HS\_CK ÷ 2
- <00>HS\_CK ÷ 1

Frequency Allocation Selector of DMS [2:0] DMS\_CK

<111>DHS\_CK ÷ 256

- <110>DHS\_CK ÷ 128
- <101>DHS\_CK ÷ 64
- <100>DHS\_CK ÷ 32
- <011>DHS\_CK ÷ 16
- <010>DHS\_CK ÷ 8
- <001>DHS\_CK ÷ 4
- <000>DHS CK ÷ 2

Frequency Selector of CPUS [0] CPU\_CK

- <1>DHS\_CK
- <0>HS\_CK

## HY10S40 Emulate Chip User' Guide

Embedded 18-Bit ΣΔΑDC 8-Bit RISC-like Mixed Signal Microcontroller



#### **OSCCN1** [7:0] Chip Working Frequency Control Register 1

ADCS [2:0]: SD18 Peripheral Working Frequency Pre-eliminator

- 111: ADC\_CK/256
- 110: ADC\_CK/128
- 101: ADC\_CK/64
- 100: ADC\_CK/32
- 011: ADC\_CK/16
- 010: ADC\_CK/8
- 001: ADC\_CK/4
- 000: ADC\_CK/2

#### Frequency Allocation Selector of DTMB [1:0] DTMB\_CK

- <11>TMB\_CK ÷ 8
- <10>TMB\_CK ÷ 4
- <01>TMB\_CK ÷ 2
- <00>TMB\_CK ÷ 1

Frequency Selector of TMBS [0] TMB\_CK

<1>LPC\_CK

<0>HS\_CK

#### OSCCN2 [7:0] Chip Working Frequency Control Register 2

HAOM [1:0] Internal Oscillator HAO Oscillation Frequency Selector

- <11>8MHz
- <10> cannot be set
- <01>4MHz
- <00>2MHz

ENHAO: Internal HAO Start Control Bit

- 1: Start
- 0: Stop

LPO [0] Internal Oscillator LPO Status Flag

```
<1> Start
```

<0>Stop

The bit is status bit. It can only be read but not written. After executing Sleep instruction, LPO oscillator will be stopped automatically. When the chip is awakened, LPO will be started automatically.



#### PWRCN [7:0] Linear Regulator and Analog Control Register

CSFON [0] CSF (Chip Special Function) Start writing controller

- <1> Start CSF writing function. When the user is necessary to set block control register, it must set
- the CFSON[0] as <1> before writing in CSFCN0[7:0].
- <0> Not start CSF function.

#### CSFCN0[7:0] Special Control Bit Register

#### HAOTR[5:0]HAO Frequency Center Adjustment Controller

| []                           |                              |                                |
|------------------------------|------------------------------|--------------------------------|
| <111111>Adjust -10%, minimum | <101001>Adjust -2.90%        | <010011>Adjust 4.06%           |
| <111110>Adjust -9.68%        | <101000>Adjust -2.58%        | <010010>Adjust 4.38%           |
| <111101>Adjust -9.35%        | <100111>Adjust -2.26%        | <010001>Adjust 4.69%           |
| <111100>Adjust -9.03%        | <100110>Adjust -1.94%        | <010000>Adjust 5.00%           |
| <111011>Adjust -8.71%        | <100101>Adjust -1.61%        | <001111>Adjust 5.31%           |
| <111010>Adjust -8.39%        | <100100>Adjust -1.29%        | <001110>Adjust 5.63%           |
| <111001>Adjust -8.06%        | <100011>Adjust -0.97%        | <001101>Adjust 5.94%           |
| <111000>Adjust -7.74%        | <100010>Adjust -0.65%        | <001100>Adjust 6.25%           |
| <110111>Adjust -7.42%        | <100001>Adjust -0.32%        | <001011>Adjust 6.56%           |
| <110110>Adjust -7.10%        | <100000> Central point 0.00% | <001010>Adjust 6.88%           |
| <110101>Adjust -6.77%        | <011111>Adjust 0.31%         | <001001>Adjust 7.19%           |
| <110100>Adjust -6.45%        | <011110>Adjust 0.63%         | <001000>Adjust 7.50%           |
| <110011>Adjust -6.13%        | <011101>Adjust 0.94%         | <000111>Adjust 7.81%           |
| <110010>Adjust -5.81%        | <011100>Adjust 1.25%         | <000110>Adjust 8.13%           |
| <110001>Adjust -5.48%        | <011011>Adjust 1.56%         | <000101>Adjust 8.44%           |
| <110000>Adjust -5.16%        | <011010>Adjust 1.88%         | <000100>Adjust 8.75%           |
| <101111>Adjust -4.84%        | <011001>Adjust 2.19%         | <000011>Adjust 9.06%           |
| <101110>Adjust -4.52%        | <011000>Adjust 2.50%         | <000010>Adjust 9.38%           |
| <101101>Adjust -4.19%        | <010111>Adjust 2.81%         | <000001>Adjust 9.69%           |
| <101100>Adjust -3.87%        | <010110>Adjust 3.13%         | <000000>Adjust 10.00%, maximum |
| <101011>Adjust -3.55%        | <010101>Adjust 3.44%         |                                |
| <101010>Adjust -3.23%        | <010100>Adjust 3.75%         |                                |
|                              |                              |                                |



#### 3.4. Power Consumption Management and Operation Status

HY10P series CPU provides three types of working modes to make user obtain best management on execution effectiveness and power saving. The three types of modes are operation mode, standby mode and sleep mode.

#### 3.4.1. Operation Mode

Operation mode mainly refers to that CPU handles all appeared events according to clock source. At the moment, chip peripheral can be operated normally and power consumption handles max status under the same clock.

#### 3.4.2. Standby Mode

Standby mode is entered via IDLE instruction. It mainly refers to that CPU stops operating waiting for wake when enter energy saving status, and sets IDLEB [0] flag bit of PSTATUS reset register as <1>. Under this mode, chip peripheral can be operated normally. When the peripheral appears interrupt event, it will awaken CPU<sup>3</sup>. Additionally, watch dog counter finally generated signal belongs to interrupt signal, but not reset signal.

Under standby mode, CPU is in pause mode and is stopped under the IDLE instruction. The internal oscillator is not affected and also is not closed. If the user wants to reach energy saving status, it depends on the application condition. At the moment, it shall switch off peripheral or oscillator and other resources. The chip must get to the standby mode status via external interrupt source or other peripheral resource interrupt signal.

Under standby mode, if it encounters interrupt resource and leaves standby mode, it needs 2 instruction cycles time to back to 04H position of interrupt vector. If the CPU frequency source is internal ideal 2MHZ, the other instruction cycle time is 2usec. Therefore, it needs 4usec program for awakening and to back to the position of interrupt vector. If CPU frequency source is internal ideal 14KHZ, the other instruction cycle time is 286usec. Therefore, it needs 536usec program for awakening and to back to the position of interrupt vector.

If under standby mode, CPU frequency source is internal 14KHZ, and internal 2MHZ oscillator has been closed, while 2MHZ oscillator is started after awakening, complete starting 2MHZ oscillator requires two 14KHZ instruction awakening time plus 128 2MHZ instruction oscillation time. It is equivalent to about 792usec. After it, internal 2MHZ oscillator can be completed oscillation normally.

<sup>&</sup>lt;sup>3</sup>After CPU is suffered interrupt signal awakening, PC (Program Counter) will jump to interrupt vector position (0x004h). See *Reset and Interrupt Section* on detailed illustration on PSTATUS reset register and interrupt service vector.



#### 4. RESET

HY10P series of reset circuits include the following 4 types of events to trigger reset signal. Reset block diagram is as Fig 4-1.

- BOR power interference reset
- **RST** external reset input pin
- WDT watch dog reset

SKERR stack error reset (determined by the user)

#### Abstract of Operation Status Register:

PSTATUS BOR[0],PD[0],TO[0],IDL[0],SKERR[0]





These reset events can be divided into software reset and hardware reset, as in Table 4-1. CPU reset program is started by 0x0000h.

| r |          | -     | -       | -                                               |
|---|----------|-------|---------|-------------------------------------------------|
|   | Reset    | Event | Sign    | Description                                     |
|   | Туре     |       |         |                                                 |
|   | Hardware | BOR   |         | CPU restart needs internal oscillator           |
|   |          | RST   | A-RESET | completes counter starting before entering      |
|   | Reset    |       |         | normal operation status.                        |
| ĺ | Software | WDT   | I-RESET | It only clears partial register. CPU is back to |
|   | Reset    | SKERR | I-RESEI | normal operation status rapidly.                |

Table 4-1 Reset Rank List

#### 4.1. Reset Event Description

#### 4.1.1. BOR Power Interference Reset

When CPU is suffered from external interference during powering on process or the power is suffered from external interference, CPU will enter into normal operation voltage from abnormal operation and low operation voltage. Therefore, if CPU cannot be in reset status



when the operation voltage is too low, it may cause crash of CPU and make the operation of peripheral circuits abnormal. Therefore, it must rely on BOR circuit function. When it detects that operation voltage is suffered from interference and voltage level is lower than the designed value, it may generate reset signal and make chip enter restart status, until the operation voltage is recovered. Then it will relieve reset signal and make chip enter normal operation mode.

When BOR reset occurs, BOR[0] flag in PSTATUS[7:0] register is set as <1> to record the occurred event.

HY10P series of BOR circuits will generate about 0.6uA power consumption. It cannot be closed via program or other setting method.

#### 4.1.2. RST External Input Reset

When the voltage level of external RST pin is lower than designed value<sup>4</sup>, it may generate reset signal and make chip enter restart status, until the operation voltage is recovered. Then it will relieve reset signal and make chip enter normal operation mode.

#### 4.1.3. WDT Watch Dog Counter Reset

WDT watch dog counter may generate reset signal and make chip enter rapid start status when the operation mode counter is ended. When WDT watch dog occurs reset, TO[0] flag in the PSTATUS[7:0] register will be set as <1> to record the occurred event.

Note: WDT watch dog finally generated signal has two types. It may generate reset signal when the chip is under operation mode. If the chip is under standby mode, it may generate interrupt event signal to awaken CPU. See *Watch DOG WDT Section* on detailed operation description.

#### 4.1.4. SKERR Stack Error Reset

When the program occurs stack overflow or underflow, it may generate reset signal and make chip enter rapid start status. When SKERR stack error reset occurs, SKERR[0] flag in PSTATUS[7:0] register is set as <1> to record the occurred event. See *Memory Section* on detailed operation description.

<sup>&</sup>lt;sup>4</sup> The pin has another two kinds of functions. One is when RST input voltage is pulled up to meet  $V_{IU}$  specification, the chip enters OTP program mode. The other is when RST input voltage meets  $V_{IL}$  specification, the chip enters current leakage test mode.



#### 4.2. Status Register

Chip operation status is displayed in PSTATUS[7:0] reset register. Mutual relation is as in Table 4-2.

|                |         |     |    | ,  |     |    | et ensinge | , |   |
|----------------|---------|-----|----|----|-----|----|------------|---|---|
| Name /Status   | Address | 7   | 6  | 5  | 4   | 3  | 2          | 1 | 0 |
| PSTATUS        | 02CH    | BOR | PD | ТО | IDL | ST | SKERR      | - | - |
| Hardware Reset | BOR     | 1   | 0  | 0  | 0   | 0  | 0          | - | - |
| (A-RESET)      | RST     | 0   | 0  | 0  | 0   | 1  | 0          | - | - |
| Software Reset | WDT     | u   | u  | 1  | u   | u  | u          | - | - |
| (I-RESET)      | SKERR   | u   | u  | u  | u   | u  | 1          | - | - |

"0": Not Occured, "1": Occurred, "u": Not Changed, "-": Not Used

Table 4-2 Reset Status Flags Relation Table



#### 4.2.1. Sequence Diagram of Reset Status

Sequence diagram from hardware reset signal occurrence to entering operation status is as in Fig 4-2. Time from different reset signal occurrence to entering operation status is as in Table 3-2(b).



Fig 4-2 Sequence Diagram of Reset & Operation Mode and Status Flags



#### 4.2.2. Register Instruction---Reset Status

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |            |       |          |        |        |        |       |             |             |
|---------|------------------------------------------------------------------------------------------------------------|-------|------------|-------|----------|--------|--------|--------|-------|-------------|-------------|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                  |       |            |       |          |        |        |        |       |             |             |
| Address | Name                                                                                                       | Bit 7 | Bit 6      | Bit 5 | Bit 4    | Bit 3  | Bit 2  | Bit 1  | Bit 0 | ARST        | IRST        |
| 02Ch    | PSTATUS                                                                                                    | BOR   | PD         | то    | IDL      | RST    | SKERR  | -      | -     | \$000 \$00. | uu\$u u\$u. |
| 033h    | PWRCN                                                                                                      | ENL   | DO[1:0]    | VD    | DAX[1:0] | ENREFO | AD1RST | AD2RST | CSFON | 0000 0000   | uuuu u00u   |
| 041h    | CSFCN0                                                                                                     | SKRST | EN_RST_PIN |       |          |        |        |        |       | 0.10 0000   | u.uu uuuu   |

Table 4-3 Reset Register

#### PSTATUS: Status Register

BOR[0]: BOR reset event flag

<1>Power interference reset has been occurred. It shall use RST or instruction for clearing.

<0>Not occurred interference reset

PD[0] : SLEEP event flag

<1>Sleep event has been occurred. It shall use BOR, RST or instruction for clearing.

<0> Not occurred sleep event

TO[0] : WDT operation mode counting overflow flag

<1> WDT reset event has been occurred. It shall use BOR, RST or instruction for clearing.

<0> Not occurred WDT counting overflow event

IDL [0] ; Standby IDLE event flag

<1> IDLE event has been occurred. It shall use BOR, RST or instruction for clearing.

<0> Not occurred IDLE event

RST[0] : External RST pin low potential event flag

<1> RST pin reset event has been occurred. It shall use BOR, or instruction for clearing.

<0> Not occurred RST pin reset event

SKERR[0] : Stack error reset flag

<1> Stack error. It shall use BOR, RST or instruction for clearing.

<0> No stack error

#### PWRCN[7:0] Linear Regulator and Analog Control Register

CSFON [0] CSF (Chip Special Function) Start writing controller

<1> Start CSF writing function. When the user is necessary to set block control register, it must set

the CFSON[0] as <1> before writing in CSFCN0[7:0].

<0> Not start CSF function. CSFCN0[7:0] register cannot be read / written.

#### CSFCN0[7:0] Special Control Bit Register

SKRST[0] Stack error reset controller

- <1> Start error reset chip
- <0> Not start error reset chip

EN\_RST\_PIN[0] Reset chip pin set

<1>Not start hardware reset chip pin, set PT1.0 as general input.

<0> Start hardware reset chip pin. PT1.0 is set as RST pin.



#### 4.3. Register List-Data Memory Reset Status

| only write  | write 0,"w1"                                                                    | d 1,"w0"only v       | r1"only read                                                          | nly read 0,"  | 'r"read,"r0"o   | ite,"w"write,' | *"read/wr  | "-"no use,"   |        |                |         |
|-------------|---------------------------------------------------------------------------------|----------------------|-----------------------------------------------------------------------|---------------|-----------------|----------------|------------|---------------|--------|----------------|---------|
| n conditio  | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends of |                      |                                                                       |               |                 |                |            |               |        |                |         |
| IRST        | ARST                                                                            | Bit 0                | Bit 1                                                                 | Bit 2         | Bit 3           | Bit 4          | Bit 5      | Bit 6         | Bit 7  | Name           | Address |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      | changed                                                               | of FSR0 not   | memoryvalue     | address data   | f FSR0 to  | Contents of   |        | INDF0          | 000h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      | Contents of FSR0 to address data memoryvalue of FSR0 post-incremented |               |                 |                |            |               |        |                |         |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      | ecremented                                                            | FSR0 post-de  | moryvalue of    | dress data me  | SR0 to add | Contents of F |        | PODEC0         | 002h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      | cremented                                                             | FSR0 pre-in   | emoryvalue of   | ldress data me | SR0 to ad  | Contents of F |        | PRINC0         | 003h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      | set by W                                                              | of FSR0 offs  | memoryvalue     | address data   | of FSR0 to | Contents of   |        | PLUSW0         | 004h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      | [7:0]                                                                 | v Byte,FSR0   | Pointer 0 Lov   | mory Address   | ct Data Me | Indired       |        | FSR0L          | 010H    |
| uuuu        | xxxx                                                                            | TOS[8]               | TOS[9]                                                                | TOS[10]       | -               | -              | -          | -             | -      | TOSH           | 016h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      |                                                                       | :0>)          | Byte (TOS<7     | -of-Stack Low  | Тор        |               |        | TOSL           | 017h    |
| u\$\$\$\$\$ | 000000                                                                          | )]                   | SKPRT[2:0                                                             |               | -               | -              | SKOV       | SKUN          | SKFL   | STKPTR         | 018h    |
| 0000        | 0000                                                                            | PC[8]                | PC[9]                                                                 | PC[10]        | -               | -              | -          | -             | -      | PCLATH         | 01Ah    |
| 0000 0000   | 0000 0000                                                                       |                      |                                                                       |               | for PC<7:0>     | PC Low Byte    |            |               |        | PCLATL         | 01Bh    |
| Օսսս սսսս   | 0000 0000                                                                       | E0IE                 | -                                                                     | TMAIE         | TB1IE           | WDTIE          | -          | ADIE          | GIE    | INTE1          | 023h    |
| นนนน นนนเ   | 0000 0000                                                                       | -                    | -                                                                     | I2CIE         | I2CERIE         | -              | -          | -             | -      | INTE2          | 024h    |
| .uuu uuuu   | .000 0000                                                                       | E0IF                 | -                                                                     | TMAIF         | TB1IF           | WDTIF          | -          | ADIF          | -      | INTF1          | 026h    |
| นนนน นนนเ   | 0000 0000                                                                       | -                    | -                                                                     | I2CIF         | I2CERIF         | -              | -          | -             | -      | INTF2          | 027h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      |                                                                       |               | Register        | Working        |            |               |        | WREG           | 029h    |
| u uuuu      | x xxxx                                                                          | Z                    | -                                                                     | -             | -               | С              | -          | -             | -      | STATUS         | 02Bh    |
| uu\$u u\$u  | \$000 \$00.                                                                     | -                    | -                                                                     | SKERR         | RST             | IDL            | то         | PD            | BOR    | PSTATUS        | 02Ch    |
| 1 \$.uu     | 1 \$.00                                                                         | BIERD                | BIEWR                                                                 | -             | VPPHV           | -              | -          | -             | -      | BIECN          | 02Eh    |
| u uuuu      | 0 xxxx                                                                          | BIEAH[2:0]           | -up Table as                                                          | 11-bit look   | -               | -              | -          | -             | ENBIE  | BIEARH         | 02Fh    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      | BIEAL[7:0]                                                            | up Table as I | or 11-bit look- | s BIEAL[5:0]   | Register a | BIE Address   |        | BIEARL         | 030h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      |                                                                       | r             | Data Registe    | BIE High Byte  |            |               |        | BIEDRH         | 031h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      |                                                                       |               | Data Register   | BIE Low Byte   |            |               |        | BIEDRL         | 032h    |
| นนนน น00เ   | 0000 0000                                                                       | CSFON                | ADRST                                                                 | -             | -               | DAX[1:0]       | VDD        | DO[1:0]       | ENLD   | PWRCN          | 033h    |
| นนนน นนนเ   | 0000 0000                                                                       | CPUS                 |                                                                       | DMS[2:0]      |                 | IS[1:0]        | DH         | S[1:0]        | OSC    | OSCCN0         | 034h    |
| นนนน นนน    | 0000 0000                                                                       | TMBS                 | B[1:0]                                                                | DTM           |                 | ADCS[2:0]      |            | -             | -      | OSCCN1         | 035h    |
| .uuu uu11   | .000 0011                                                                       | LPO                  | ENHAO                                                                 | /[1:0]        | HAON            | -              | -          | -             | -      | OSCCN2         | 036h    |
| uuuu \$000  | 0000 0000                                                                       | ]                    | DWDT[2:0]                                                             |               | ENWDT           | -              |            | -             | -      | WDTCN          | 037h    |
| u0uu uu     | 0000 00                                                                         | -                    | -                                                                     |               | DTMA[2:0]       |                | TMAS       | TMACL         | ENTMA  | TMACN          | 038h    |
| นนนน นนนเ   | 0000 0000                                                                       | TMA counter Register |                                                                       |               |                 |                |            | TMAR          | 039h   |                |         |
| น.นน นนนเ   | 0.10 0000                                                                       |                      |                                                                       |               |                 |                |            |               | CSFCN0 | 041h           |         |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      |                                                                       |               |                 |                |            |               |        | ADCRH          | 043h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      |                                                                       |               |                 |                |            |               |        |                | 044h    |
| นนนน นนนเ   | XXXX XXXX                                                                       |                      |                                                                       |               |                 | C conversion i |            |               |        | ADCRM<br>ADCRL | 045h    |
| 0000 0000   | 0000 0000                                                                       | ]                    | ADGN[2:0]                                                             |               | -               | -              | ENCHP      | ENHIGN        | ENADC  | ADCCN1         | 046h    |
| 0000        | 0000                                                                            |                      | DCSET[2:0                                                             |               | VREGN           | -              | -          | -             | -      | ADCCN2         | 047h    |
| 0000.       | 0000.                                                                           | -                    | -                                                                     | -             | -               |                | :0]        | OSR[3:        |        | ADCCN3         | 048h    |

Table 4-4 Data Memory Reset Status

### HY10S40 Emulate Chip User' Guide

Embedded 18-Bit ΣΔADC

8-Bit RISC-like Mixed Signal Microcontroller

| -          | -           | l 1,"w0"only v | -           |              | -               |                |              | "-"no use,' |       |         |            |
|------------|-------------|----------------|-------------|--------------|-----------------|----------------|--------------|-------------|-------|---------|------------|
| n conditio | d"depends o | unchanged,"d   | iknown,"u"ເ | ed bit,"x"un | unimplement     | ent status,"." | "\$"for even |             |       |         |            |
| IRST       | ARST        | Bit 0          | Bit 1       | Bit 2        | Bit 3           | Bit 4          | Bit 5        | Bit 6       | Bit 7 | Name    | Address    |
| 0000 000   | 0000 000.   | -              | INIS        |              | INL[2:0]        |                |              | INH[2:0]    |       | AINET1  | 049h       |
| .000 000   | .000 000.   | -              | [1:0]       | VRL          | [1:0]           | INX            | :0]          | VRH[1       | -     | AINET2  | 04Ah       |
| uu uuuu    | 00 0000     | PWM1A          | PWM2A       | PWM3A        | PWM4A           | PWM5A          | PWM6A        | -           | -     | TB1Flag | 04Eh       |
| սսսս սՕս   | 0000 0000   | -              | -           | TB1CL        | T[1:0]          | TB1R           | 1:0]         | TB1M[       | ENTB1 | TB1CN0  | 04Fh       |
| นนนน นนน   | 0000 0000   | 0]             | PWMA0[2:0   |              | PA0IV           | ]              | WMA1[2:0     | F           | PA1IV | TB1CN1  | 050h       |
| นนนน นนน   | XXXX XXXX   |                |             | :8]          | r Register [15  | merB1 counte   | Ti           |             |       | TB1RH   | 051h       |
| นนนน นนน   | XXXX XXXX   |                |             | 0]           | er Register [7: | imerB1 counte  | Т            |             |       | TB1RL   | 052h       |
| นนนน นนน   | XXXX XXXX   |                |             | er [15:8]    | dition Registe  | 1 counter Cor  | TimerB       |             |       | TB1C0H  | 053h       |
| นนนน นนน   | XXXX XXXX   |                |             | er [7:0]     | ndition Regist  | 31 counter Co  | TimerE       |             |       | TB1C0L  | 054h       |
| นนนน นนน   | XXXX XXXX   |                |             | er [15:8]    | dition Registe  | 1 counter Cor  | TimerB       |             |       | TB1C1H  | 055h       |
| นนนน นนน   | XXXX XXXX   |                |             | er [7:0]     | ndition Regist  | 31 counter Co  | TimerE       |             |       | TB1C1L  | 056h       |
| นนนน นนน   | XXXX XXXX   |                |             | er [15:8]    | dition Registe  | 1 counter Cor  | TimerB       |             |       | TB1C2H  | 057h       |
| นนนน นนน   | XXXX XXXX   | -              |             | er [7:0]     | ndition Regist  | 31 counter Co  | TimerE       |             |       | TB1C2L  | 058h       |
| uuu        |             | ENI2C          | ENI2CT      | I2CRST       |                 |                | Rsv.         |             |       | CFG     | 061h       |
| นนนน นนน   | 0000 0000   | ACK            | I2CINT      | STOP         | START           | I2CER          | -            | -           | SLAVE | ACT     | 062h       |
| นนนน นนน   | 0001 0000   | ARBF           | GCF         | ACKF         | DFF             | RWF            | RDBF         | SACTF       | MACTF | STA     | 063h       |
| นนนน นนน   | 0000 0000   |                |             |              | [7:0]           | CRG            |              |             |       | CRG     | 064h       |
| นนนน นนน   | 0000 0000   |                | .T[3:0]     | I2CTL        |                 |                | DI2C[2:0]    |             | I2CTF | тос     | 065h       |
| นนนน นนน   | XXXX XXXX   | RDB[0]         |             |              |                 | RDB[7:1]       |              |             |       | RDB     | 066h       |
| นนนน นนน   | XXXX XXXX   | TDB[0]         |             |              |                 | TDB0[7:1]      |              |             |       | TDB0    | 067h       |
| นนนน นนน   | 0000 0000   | SIDV[0]        |             | mode         | ss of the 7-bit | onding addre   | The corresp  | SID[7:1],1  |       | SID0    | 068h       |
| xxxx       | xxxx        | PT10           | -           | -            | -               | -              | -            | -           | -     | PT1     | 070h       |
| นนนน นนน   | 0000 0000   | -              | -           | -            | -               | -              | -            | -           | -     | TRISC1  | 071h       |
| นนนน นนน   | 0000 0000   | -              | -           | -            | -               | -              | -            | -           | -     | PT1DA   | 072h       |
| นนนน นนน   | 0000 0000   | -              | -           | -            | -               | -              | -            | •           | -     | PT1PU   | 073h       |
| uuuu       | 0000        | G[1:0]         | E0E         | -            | -               | FPWMA0         | FPWMA1       | -           | -     | PT1EG   | 074h       |
| xx         | xx          | PT20           | PT21        | -            | -               | -              | -            | -           | -     | PT2     | 075h       |
| uu         |             | TC20           | TC21        | -            | -               | -              | -            | -           | -     | TRISC2  | 076h       |
| uu         |             | DA20           | DA21        | -            | -               | -              | -            | -           | -     | PT2DA   | 077h       |
| uu         |             | PU20           | PU21        | -            | -               | -              | -            | -           | -     | PT2PU   | 078h       |
| xx xxxx    | xx xxxx     | PT30           | PT31        | PT32         | PT33            | PT34           | PT35         | -           | -     | PT3     | 079h       |
| uu uuuu    | 00 0000     | TC30           | TC31        | TC32         | TC33            | TC34           | TC35         | -           | -     | TRISC3  | 07Ah       |
| uu uuuu    | 00 0000     | DA30           | DA31        | DA32         | DA33            | DA34           | DA35         | -           | -     | PT3DA   | 07Bh       |
| uu uuuu    | 00 0000     | PU30           | PU31        | PU32         | PU33            | PU34           | PU35         | -           | -     | PT3PU   | 07Ch       |
| นนนน นนน   | นนนน นนนน   |                |             | Byte         | egister as 12   | eral Purpose R | Gene         |             |       | GPR0    | 80h ~ 0FFh |

Table 4-5 Data Memory Reset Status(Continued)





# 5. Interrupt

Interrupt is composed of interrupt start controller INTE and interrupt event flag INTF. When Interrupt service is established, if it appears interrupt event, program counter (PC) will jump to interrupt address 0x0004h in PM to execute interrupt service program.

# Abstract of Interrupt Control Register:

- INTEO GIE[0],ADCIE[0],TMCIE[0],TMBIE[0],TMAIE[0],WDTIE[0],E1IE[0],E0IE[0]
- INTE1 I2CERIE[0], I2CIE[0]
- INTFO ADCIF[0],TMCIF[0],TMBIF[0],TMAIF[0],WDTIF[0],E1IF[0],E0IF[0]
- INTF1 I2CERIF[0],I2CIF[0]



Fig5-1 Interrupt Vector Block Diagram

Interrupt service event governor has two layers totally. The higher layer is interrupt service event controller GIE [0] and the lower layer is interrupt event start control bit.

- To start interrupt event, it only needs to set the controller of corresponding interrupt event start controller INTEx [7:0] as <1>. On the contrary, it will close the interrupt event when it is set as <0>.
- To start interrupt service, it only needs to set the interrupt service controller GIE[0] of interrupt control register INTE0[7:0] as <1>. On the contrary, it will close the interrupt service when it is set as <0>.

When entering into interrupt service vector, GIE [0] will be set as <0> automatically. When it is going to return interrupt occurrence address after completing interrupt service program execution, it can execute interrupt return instruction RETI directly. At the moment, GIE [0] will be set as <1> automatically. Or it executes return instruction RET, and GIE [0] status maintains at 0 at the moment.



# 5.1. Register Instruction-Interrupt

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |     |      |            |                |             |              |              |              |             |             |  |  |
|---------|------------------------------------------------------------------------------------------------------------|-----|------|------------|----------------|-------------|--------------|--------------|--------------|-------------|-------------|--|--|
|         |                                                                                                            |     |      | "\$"for ev | ent status,"." | unimplement | ed bit,"x"un | الاnown,"u"ı | unchanged,"d | l"depends o | n condition |  |  |
| Address |                                                                                                            |     |      |            |                |             |              |              |              |             |             |  |  |
| 023h    | INTE0                                                                                                      | GIE | ADIE | -          | WDTIE          | TB1IE       | TMAIE        | -            | E0IE         | 0000 0000   | 0uuu uuuu   |  |  |
| 024h    | INTE1                                                                                                      | -   | -    | -          | -              | I2CERIE     | I2CIE        | -            | -            | 0000 0000   | սսսս սսսս   |  |  |
| 026h    | INTF0                                                                                                      | -   | ADIF | -          | WDTIF          | TB1IF       | TMAIF        | -            | E0IF         | .000 0000   | .uuu uuuu   |  |  |
| 027h    | INTF1                                                                                                      | -   | -    | -          | -              | I2CERIF     | I2CIF        | -            | -            | 0000 0000   | սսսս սսսս   |  |  |

Table 5-1 Interrupt Register

#### **INTE0: Interrupt Start Control Register 0**

GIE [0]: Interrupt Service Controller

1: Start

0: Close

ADCIE[0]: ADC Interrupt Event Start Controller

1: Start (Analog Digital Converter, SD18)

0: Close

TMBIE[0]: Timer-B Interrupt Event Start Controller

1: Start (Timing/ Timer B, TMB)

0: Close

TMAIE[0]: Timer-A Interrupt Event Start Controller

1: Start (Timing/ Timer A, TMA)

0: Close

WDTIE[0]: Watch Dog Interrupt Event Start Controller

1: Start (Watch Dog, WDT)

0: Close

E0IE[0]: Input Pin 0 Interrupt Event Start Controller

1: Start (External Input Pin, PT1.0)

0: Close

#### INTE1: Interrupt Start Control Register 1

I2CERIE[0] peripheral I2C error interrupt vector service controller

<1>Start I2C interrupt vector service

<0>Close I2C interrupt vector service

I2CIE[0] peripheral I2C interrupt vector service controller

<1>Start I2C interrupt vector service

<0>Close I2C interrupt vector service



#### **INTF0: Interrupt Event Flag Register 0**

ADCIF[0]: ADC Interrupt Event Flag

Occurred (Analog Digital Converter, SD18)
Not Occurred

TMBIF[0]: Timer-B Interrupt Event Flag

Occurred (Timing/Timer B,TMB)
Not Occurred

TMAIF[0]: Timer-A Interrupt Event Flag

Occurred (Timing/Timer A,TMA)
Not Occurred

WDTIF[0]: Watch Dog Interrupt Event Flag

Occurred (Watch Dog, WDT)
Not Occurred

EOIF[0]: Input Pin 0 Interrupt Event Flag

Occurred (External Input Pin, PT1.0)
Not Occurred

#### INTF1: Interrupt Event Flag Register 1

I2CERIF[0] peripheral I2C error interrupt event flag controller

- <1> Occurred I2C interrupt event
- <0> Not Occurred I2C interrupt event

I2CIF[0] peripheral I2C interrupt event flag controller

- <1> Occurred I2C interrupt event
- <0> Not Occurred I2C interrupt event



# 6. Input/ Output Port (I/O)

Every 8 pins of Input/ Output Port (I/O) are one port. It can be taken as digital input and output and analog signal measuring channel. Each port is controlled by a group of registers. It may have different I/O register composition for different products.

# Abstract of I/O related register:

- PT PT1[0], PT2[1:0], PT3[5:0]
- **TRISC** TC2[1:0], TC3[5:0],
- **PTDA** DA2[1:0]
- **PTPU** PU2[1:0], PU3[5:0]
- PT1EG FPWMA[1:0], E0EG[1:0]



Fig 6-1 I/O Architecture Block Diagram



# 6.1. Introduction of PORT related register

PORT mainly provides digital or analog signal input and output pins.

## 6.1.1. PT Status Control Register

When I/O is set as input, it can read current I/O status at corresponding register position.

I/O input is high potential when the reading is 1 at the moment, and low potential when is 0. When I/O is set as output, it can control output status at corresponding register position.

I/O output is high potential when it is set as <1> at the moment, and low potential when is<0>.

## 6.1.2. TRISC Input / Output Control Register

When I/O is selected as input or output, set <1>I/O as output status and <0> as input status. When I/O is set as input status, it must give definite input potential when the chip enters into sleep status. Don't make I/O in floating status to avoid causing power leakage phenomena of chip.

## 6.1.3. PTDA Digital or Analog Input Control Register

When I/O is set as analog or digital input status, set <1> is analog and <0> is digital input. It shall consider the setting status of other I/O related register when taking setting to avoid mutual interference of digital /analog signal.

## 6.1.4. PTPU Pull-up Resistor Control Register

When I/O is set as whether pull-up resistor function is started. Set <1> as I/O starting and set <0> as disconnection. Before the chip enters into sleep mode, if I/O is set as digital input status and external circuit connection way may cause floating phenomena of I/O, it can start pull-up resistor to avoid I.O floating and causing the chip entering into sleep mode and producing current leakage.

# 6.1.5. PTEG Interrupt Signal Creation Condition

When I/O external input potential belongs to certain changes, it may cause interrupt signal. Potential changes can be divided into rising edge  $(0\rightarrow 1)$  change, falling edge  $(1\rightarrow 0)$  change and potential transition  $(0\rightarrow 1 \text{ or } 1\rightarrow 0)$ .

# 6.2. Input/ Output Port 1, I/O Port1

i": Input, "o": Output, "a": Analog , "c": cmos i/o, "x": No definition, "p": power ",

|          | Des  | sign   | Re       | gister Se     | etting     |                           |
|----------|------|--------|----------|---------------|------------|---------------------------|
| Pin Name | Туре | Buffer | CSFON[0] | EN_RST_PIN[0] | PT1EG[1:0] | Description               |
| PT1.0    | i    | С      | 1        | 0             | XX         | Digital input pin         |
| INT0     | i    | S      | 1        | 0             | 00~11      | External interrupt source |
| VPP      | р    | р      | Х        | х             | ХХ         | OTP burning voltage pin   |
| RST      | i    | s      | 1        | 1             | XX         | Reset pin                 |

#### Table 6-1 PORT1 Function



# 6.2.1. Register Instruction---PORT1

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |            |            |                |            |               |              |              |             |             |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------|-------|------------|------------|----------------|------------|---------------|--------------|--------------|-------------|-------------|--|--|--|
|         |                                                                                                            |       |            | "\$"for ev | ent status,"." | unimplemen | ted bit,"x"ur | الاnown,"u"ı | unchanged,"d | l"depends o | n condition |  |  |  |
| Address | Name                                                                                                       | Bit 7 | Bit 6      | Bit 5      | Bit 4          | Bit 3      | Bit 2         | Bit 1        | Bit 0        | ARST        | IRST        |  |  |  |
| 023h    | INTE0                                                                                                      | GIE   | ADIE       | -          | WDTIE          | TB1IE      | TMAIE         | -            | E0IE         | 0000 0000   | 0uuu uuuu   |  |  |  |
| 026h    | INTF0                                                                                                      |       |            |            |                |            |               |              | E0IF         | .000 0000   | .uuu uuuu   |  |  |  |
| 033h    | PWRCN                                                                                                      | ENLE  | DO[1:0]    | VDE        | DAX[1:0]       | 0000 0000  | uuuu u00u     |              |              |             |             |  |  |  |
| 041h    | CSFCN0                                                                                                     |       | EN_RST_PIN |            |                |            |               |              |              | 0.10 0000   | u.uu uuuu   |  |  |  |
| 070h    | PT1                                                                                                        | -     | -          | -          | -              | xxxx       | xxxx          |              |              |             |             |  |  |  |
| 074h    | PT1EG                                                                                                      |       | -          |            |                | G[1:0]     | 0000          | uuuu         |              |             |             |  |  |  |

Table 6-2 PORT1 Control Register

#### INTE0/INTF0: See Chapter Interrupt .

#### PT1: PORT1 Status Control Register

PT1.0: External pin control bit

- 1: high potential
- 0: low potential

#### PT1EG[1:0]: Pin interrupt way control register

#### E0EG[1:0] pin PT1.0 interrupt way controller

<11>potential transition (0 $\rightarrow$ 1 or 1 $\rightarrow$ 0), i.e. Producing interrupt event; interrupt event shall be

occurred after reading PT1.0[0].

<10> potential transition ( $0 \rightarrow 1$  or  $1 \rightarrow 0$ ), i.e. Producing interrupt event; interrupt event will be occurred so long as potential transition.

<01>rising edge  $(0\rightarrow 1)$ 

<00>falling edge  $(1\rightarrow 0)$ 

PT1.0 default is reset mode(when BOR occurs), built-in 180K ohm resistors pull high.

If PT1.0 changes setting, it must set ADDR 41h CSFUN bit<6>=1 after setting ADDR 33h PWRCN

bit<0>=1. Change PT1.0 setting as input mode. Then, set ADDR 33h PWRCN bit<0>=0 to avoid modifying false writing to the setting.

#### PWRCN[7:0]: Linear Regulator and Analog Control Register

CSFON [0] CSF (Chip Special Function) Start writing controller

<1> Start CSF writing function. When the user is necessary to set block control register, it must set the CFSON[0] as <1> before writing in CSFCN0[7:0].

<0> Not start CSF function. CSFCN0 register cannot be read and written.

#### CSFCN0[7:0]: Special Control Bit Register

EN\_RST\_PIN[0] Hardware reset pin setting

<1>Not start hardware reset chip pin, set PT1.0 as general input.

<0> Start hardware reset chip pin. PT1.0 is set as RST pin.



# 6.3. Input/ Output Port 2, I/O Port2

|          | Des  | sign   | Reg   | jister Set | tting    |                           |
|----------|------|--------|-------|------------|----------|---------------------------|
| Pin Name | Туре | Buffer | TC[0] | DA[0]      | FPWMA[0] | Description               |
| PT2.0    | i/o  | с      | х     | 0          | 0        | Digital input /output pin |
| AI6      | a    | а      | х     | 1          | 0        | Analog input pin          |
| PWMA0    | 0    | с      | 1     | 0          | 1        | PWM output pin            |
| PT2.1    | i/o  | с      | Х     | 0          | 0        | Digital input /output pin |
| AI7      | а    | а      | х     | 1          | 0        | Analog input pin          |
| PWMA1    | 0    | с      | 1     | 0          | 1        | PWM output pin            |

i": Input, "o": Output, "a": Analog, "c": cmos i/o, "x": No definition, "p": power

Table 6-3 PORT2 Function



# 6.3.1. Register Instruction---PORT2

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |       |             |                |             |              |           |              |             |             |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------|-------|-------|-------------|----------------|-------------|--------------|-----------|--------------|-------------|-------------|--|--|--|
|         |                                                                                                            |       |       | "\$"for eve | ent status,"." | unimplement | ed bit,"x"un | known,"u" | unchanged,"d | l"depends o | n conditior |  |  |  |
| Address | Name                                                                                                       | Bit 7 | Bit 6 | Bit 5       | Bit 4          | Bit 3       | Bit 2        | Bit 1     | Bit 0        | ARST        | IRST        |  |  |  |
| 074h    | PT1EG                                                                                                      | -     |       | FPWMA1      | FPWMA0         | -           | -            |           |              | 0000        | uuuu        |  |  |  |
| 075h    | PT2                                                                                                        | -     | -     | -           | -              |             |              | PT21      | PT20         | xx          | xx          |  |  |  |
| 076h    | TRISC2                                                                                                     | -     | -     | -           | -              | -           | -            | TC21      | TC20         | 00          | uu          |  |  |  |
| 077h    | PT2DA                                                                                                      | -     | -     | -           | -              | -           | -            | DA21      | DA20         |             | uu          |  |  |  |
| 078h    | PT2PU                                                                                                      | -     | -     | -           | -              | -           | -            | PU21      | PU20         | 00          | uu          |  |  |  |

#### Table 6-4 PORT2 Control Register

#### PT2: PORT2 Status Control Register

PT2.x: External pin control bit  $(0 \le x \le 1)$ 

1: high potential

0: low potential

#### TRISC2: I/O Control Register

TC2.x: External pin input /output control bit  $(0 \le x \le 1)$ 

1: output

0: input

#### PT2DA: Digital or analog input control register

DA2.x: External pin input analog or digital signal control bit ( $0 \le x \le 1$ )

1: analog

0: digital

#### PT2PU: Pull-up resistor control register

PU2.x: External pin pull-up resistor control bit  $(0 \le x \le 1)$ 

1: Start

0: Close

#### PT1EG[1:0] Pin interrupt way control register

PWMA1[0]: PWMA1 pin output controller

<1>output

<0>not output

PWMA0[0]: PWMA0 pin output controller

<1>output

<0>not output



# 6.4. Input/ Output Port 3,I/O Port3

| 66:22. | 1      | 11 - V. | 0       | 11 - Y. | A       | 11 - V. |          |       | Curra ittle | 4 m <sup>2</sup> m m m m | ii??. | NI- | -l - f : - : t : | ii |       |
|--------|--------|---------|---------|---------|---------|---------|----------|-------|-------------|--------------------------|-------|-----|------------------|----|-------|
| 1:     | input, | 0:      | Output, | a :     | Analog, | С:      | cmos I/C | ), S: | Smith       | trigger,                 | х:    | INO | definition,      | р: | power |

|          | Des  | sian   | Regi  | ster  |                                       |
|----------|------|--------|-------|-------|---------------------------------------|
| Pin Name |      |        | Sett  | ing   | Description                           |
|          | Туре | Buffer | TC[0] | DA[0] |                                       |
| PT3.0    | i/o  | С      | х     | 0     | Digital I/O pin                       |
| AIO      | а    | а      | 0     | 1     | Analog input pin                      |
| PT3.1    | i/o  | С      | х     | 0     | Digital I/O pin                       |
| Al1      | а    | a      | 0     | 1     | Analog input pin                      |
| PSCK     |      | s      | 0     | 0     | OTP reading/writing interface SCK pin |
| PT3.2    | i/o  | С      | х     | 0     | Digital I/O pin                       |
| AI2      | а    | a      | 0     | 1     | Analog input pin                      |
| PSDI     | i    | s      | 0     | 0     | OTP reading/writing interface SDI pin |
| PT3.3    | i/o  | с      | х     | 0     | Digital I/O pin                       |
| AI3      | а    | а      | 0     | 1     | Analog input pin                      |
| PSDO     | 0    | с      | 1     | 0     | OTP reading/writing interface SDO pin |
| PT3.4    | i/o  | С      | х     | 0     | Digital I/O pin                       |
| AI4      | а    | a      | 0     | 1     | Analog input pin                      |
| SCL      | i/o  | s      | х     | 0     | I2C communication interface pin       |
| PT3.5    | i/o  | С      | х     | 0     | Digital I/O pin                       |
| AI5      | а    | а      | 0     | 1     | Analog input pin                      |
| SDA      | i/o  | s      | х     | 0     | I2C communication interface pin       |

Table 6-5 PORT3 Function



# 6.4.1. Register Instruction---PORT3

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |       |            |                |             |              |             |              |             |             |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------|-------|-------|------------|----------------|-------------|--------------|-------------|--------------|-------------|-------------|--|--|--|
|         |                                                                                                            |       |       | "\$"for ev | ent status,"." | unimplement | ed bit,"x"un | ıknown,"u"ı | unchanged,"d | l"depends o | n condition |  |  |  |
| Address | Name                                                                                                       | Bit 7 | Bit 6 | Bit 5      | Bit 4          | Bit 3       | Bit 2        | Bit 1       | Bit 0        | ARST        | IRST        |  |  |  |
| 079h    | PT3                                                                                                        | -     | -     | PT35       | PT34           | PT33        | PT32         | PT31        | PT30         | xx xxxx     | xx xxxx     |  |  |  |
| 07Ah    | TRISC3                                                                                                     | -     | -     | TC35       | TC34           | TC33        | TC32         | TC31        | TC30         | 00 0000     | uu uuuu     |  |  |  |
| 07Bh    | PT3DA                                                                                                      | -     | -     | DA35       | DA34           | DA33        | DA32         | DA31        | DA30         | 00 0000     | uu uuuu     |  |  |  |
| 07Ch    | PT3PU                                                                                                      | -     | -     | PU35       | PU34           | PU33        | PU32         | PU31        | PU30         | 00 0000     | uu uuuu     |  |  |  |

#### Table 6-6 PORT3 Control Register

#### PT3: PORT3Status Control Register

PT3.x: External Pin Control Bit (0≦x≦5)

1: high potential.

0: low potential

#### **TRISC3: I/O Control Register**

TC3.x: External Pin I/O Control Bit  $(0 \le x \le 5)$ 

1: Output

0: Input

#### PT3DA: Digital or analog input control register

DA3.x: External Pin input analog or digital signal control bit  $(0 \le x \le 5)$ 

1: analog

0: digital

#### PT3PU: Pull-up resistor control register

PU3.x: External pin pull-up resistor control bit  $(0 \le x \le 5)$ 

- 1: Start
- 0: Close



# 7. Watch Dog Timer

Namely, watch dog WDT is the guarder of chip. It is mainly used to genrate awakening event.

**Operation Mode** 

- Overflow of watch dog counter produces reset signal to restart the chip.
- Software can be used to zero timer.

Sleep Mode

• Watch dog WDT is closed, and cannot be used.

Standby Mode

• Overflow of watch dog counter produces interrupt event to awaken the chip.

# Abstract of WDT Related Register:

TMACN ENWDT[0],WDTS[2:0]

- PSTATUS TO[0]
- INTF WDTIF[0]
- INTE WDTIE[0]



Fig 7-1 Watch Dog Block Diagram

# 7.1. WDT Manual

# 7.1.1. WDT Initialization Setting

WDT timing controller DWDT[2:0] can determine the working frequency WDT\_CK of WDT counter and overflow. After overflow of timer, it can produce WDT reset signal TO or interrupt event WDTIF<sup>5</sup>.

# 7.1.2. WDT Interrupt Event Service

WDT interrupt event can only be operated at standby mode of the chip. When WDTIE[0] and GIE[0] are set as <1>, after overflow of WDT counter, it may produce interrupt event. It may

<sup>&</sup>lt;sup>5</sup> WDT uses internal clock source LPO. Therefore, it can be operated at Normal Mode and Idle Mode of the chip. Under normal mode, it can use software to clear the timer and make it not reset the chip as the ending of counting. However, under idle mode, it cannot clear WDT timer via any method.



set WDTIF[0] as<1>. Furthermore, PC jumps to interrupt vector position <0>x0004h. On the contrary, when WDTIE[0] and GIE[0] are set as <0>, it will not produce any interrupt.

## 7.1.3. WDT Starting

WDT must be started when the chip is under operation mode, i.e. set WDT start controller ENWDT[0] as <1> to start WDT. After starting, it cannot use software to set ENWDT[0] as <0>. But when WDT is under standby mode, if awakened interrupt event is produced when WDT counting is ended, the hardware will set ENWDT[0] as<0> automatically.

After DWDT[2:0] setting, when WDT reset or interrupt occurs, DWDT will be cleared to 000b and it needs software for resetting.



# 7.2. Register Instruction-WDT

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |                                                                            |       |              |                |             |              |            |              |             |             |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------|--------------|----------------|-------------|--------------|------------|--------------|-------------|-------------|--|--|--|
|         |                                                                                                            |                                                                            |       | "\$"for even | ent status,"." | unimplement | ed bit,"x"ur | nknown,"u" | unchanged,"c | l"depends o | n condition |  |  |  |
| Address | Name                                                                                                       | Bit 7                                                                      | Bit 6 | Bit 5        | Bit 4          | Bit 3       | Bit 2        | Bit 1      | Bit 0        | ARST        | IRST        |  |  |  |
| 023h    | INTE0                                                                                                      | GIE                                                                        | ADIE  | -            | WDTIE          | TB1IE       | TMAIE        | -          | E0IE         | 0000 0000   | 0uuu uuuu   |  |  |  |
| 026h    | INTF0                                                                                                      | -                                                                          |       |              | WDTIF          |             |              |            |              | .000 0000   | .uuu uuuu   |  |  |  |
| 02Ch    | PSTATUS                                                                                                    | POR                                                                        | PD    | то           | IDL            | RST         | SKERR        | -          | -            | \$000 \$00. | uu\$u u\$u. |  |  |  |
| 037h    | WDTCN                                                                                                      | NDTCN         ENWDT         DWDT[2:0]         0000 0000         uuuu \$000 |       |              |                |             |              |            |              |             |             |  |  |  |

Table 7-1 WDT Control Register

#### INTE0/INTF0 : See Chapter Interrupt

#### PSTATUS : See Chapter RESET

#### **TMACN: Timing / Timer A Control Register**

ENWDT: WDT Start Controller

1: Start

0: Close ;( unable set software<0>)

DWDT[2] : Watch Dog WDT\_CK Working Frequency Selector

<1>LPO ÷8

<0>LPO ÷128, (LPO ÷ 8 ÷ 16 )

DWDT[2:0]: Counting Overflow Frequency

<111>WDT\_CK ÷ 8, (LPO ÷ 8 ÷ 8)

<110>WDT\_CK ÷ 16, (LPO ÷ 8 ÷ 16)

<101>WDT\_CK ÷ 32, (LPO ÷ 8 ÷ 32)

<100>WDT\_CK ÷ 64, (LPO ÷ 8 ÷ 64)

<011>WDT\_CK ÷ 128, (LPO ÷ 8 ÷ 16 ÷ 128)

<010>WDT\_CK ÷ 256, (LPO ÷ 8 ÷ 16 ÷ 256)

<001>WDT\_CK ÷ 512, (LPO ÷ 8 ÷ 16 ÷ 512)

<000>WDT\_CK ÷ 1024, (LPO ÷ 8 ÷ 16 ÷ 1024)



# 8. Timer-A

Timer A is 8-bit design architecture. TMA can be operated under operation mode and standby mode.

Increasing Type Timer

4-segment overflow value selection

Overflow produced interrupt event

Readable Timer Value

## Abstract of TMA Register:

- TMACN ENTMA[0],TMACK[0],TMAS[1:0]
- TMAR TMAR[7:0]

INTE0 TMAIE[0]

INTFO TMAIF[0]



Fig 8-1 Timer A Block Diagram

Operation Instructions:

- Set TMAS[0] selected TMA\_CK frequency. Reduce the frequency via frequency pre-eliminator 256. Then input DTMA frequency eliminator.
- Set ENTMA[0] as <1> to start TMA; on the contrary, set as<0> to close and clear TMAR[7:0].
- When DTMA[2:0] timing condition is established, it may produce interrupt event and make TMAR[7:0] progressively increase 1.
- TMA interrupt event TMAIF[0] must have interrupt service when TMAIE[0] is set as <1> and GIE[0] is set as <1>.
- Reading TMAR[7:0] will not make TMA timer zeroed.
- After the user sets TMACL[0] as <1> and clear all timers of TMA, TMACL[0]will be set as <0> automatically.
- TMAR[7:0] can read TMA progressively increased value of the timer, and can write motion to clear the timing value of TMAR[7:0].



# 8.1. Register Instruction-TMA

|         |         |       | "-"no use," | *"read/wr  | ite,"w"write,' | "r"read,"r0" | only read 0," | r1"only read | l 1,"w0"only \ | write 0,"w1" | only write 1 |
|---------|---------|-------|-------------|------------|----------------|--------------|---------------|--------------|----------------|--------------|--------------|
|         |         |       |             | "\$"for ev | ent status,"." | unimplemen   | ted bit,"x"ur | าknown,"u"เ  | unchanged,"c   | l"depends o  | n condition  |
| Address | Name    | Bit 7 | Bit 6       | Bit 5      | Bit 4          | Bit 3        | Bit 2         | Bit 1        | Bit 0          | ARST         | IRST         |
| 023h    | INTE0   | GIE   |             | -          |                |              | TMAIE         | -            |                | 0000 0000    | 0uuu uuuu    |
| 026h    | INTF0   | -     |             | -          |                |              | TMAIF         | -            |                | .000 0000    | .uuu uuuu    |
| 02Ch    | PSTATUS |       |             | то         |                |              |               | -            | -              | \$000 \$00.  | uu\$u u\$u.  |
| 034h    | OSCCN0  | OSC   | S[1:0]      | Dł         | HS[1:0]        |              | DMS[2:0]      |              | CUPS           | 0000 0000    | սսսս սսսս    |
| 035h    | OSCCN1  | LCP   | S[1:0]      |            |                |              |               |              |                | 0000 0000    | uuuu uuu.    |
| 036h    | OSCCN2  | ENRTC | -           | X          | FS[1:0]        | .000 0011    | .uuu uu11     |              |                |              |              |
| 038h    | TMACN   | ENTMA | TMACL       | TMAS       |                | DTMA[2:0]    |               | -            | -              | 0000 00      | u0uu uu      |
| 039h    | TMAR    |       |             |            | TMA count      | er Register  |               |              |                | 0000 0000    | นนนน นนนน    |

Table 8-1 TMA Control Register

#### INTE0/INTF0: See Chapter INTERRUPT

#### TMACN: Timer A Control Register

ENTMA: Timer-A Start Controller

1: Start

0: Close; Zeroing of Timer

TMACL[0]: TMA Zeroing of Timer

<1>TMA Counting.

<0>TMA Zeroing of Timer.

TMAS[0] : TMA Working Frequency Selector

<1>LPC\_CK

#### <0>DMS\_CK

DTMA[2:0] Start and Close Controller

- <111>TMA\_CK ÷ 256
- <110>TMA\_CK ÷ 128
- <101>TMA\_CK ÷ 64
- <100>TMA CK ÷ 32
- <011>TMA\_CK ÷ 16
- <010>TMA\_CK ÷ 8
- <001>TMA\_CK ÷ 4
- <000>TMA\_CK ÷ 2

TMAR: Increment Counter of TMA can be read but not be written.



# 9. 16-bit Timer B (TMB)

Timer B (hereinafter referred to as TMB) has 2 PWM output, which is PWMA0/1 respectively. Each TMB has 4 types of operation mode. All timers of each mode have special function design to satisfy different application method.



Fig 9-1 Timer B Block Diagram

- Timer Registers of TMB are
  - Increment / decrement timer TB1R [15:0] (this is a hardware counter and cannot be read or written)
  - Overflow event condition controller TB1C0[15:0]
  - PWMA condition controller TB1C1[15:0]
  - Enable controller ENTMB[0]
  - Mode controller TB1M[1:0]
  - Zeroing controller TB1CL[0]
  - Operation frequency pre-eliminator DTMB[1:0]
- 4 types of counting modes of TMB
  - 16-bit counting
  - 16 bit pulse generator mode
  - Dual 8-bit PWM mode
  - 8+8bit PWM mode
- System power consumption operation of TMB
  - Operation Mode
  - Idle Mode
- TB1R[15:0] Zeroing and Re-counting Condition
  - Read TMB related register, and it will not make TB1R[15:0] zero and re-count.
  - Writing TB1C0[15:0] and TB1C1[15:0] will not make TB1R[15:0] zero and re-count.
  - Writing TB1CN0 control register will not make TB1R[15:0] zero and re-count.
  - When TB1R[15:0] progressive counting is up to more than TB1C0[15:0], it will make TB1R[15:0] zero and re-count.



- After user set TB1CL[0] as <1> and clear TB1R[15:0] timer, TB1CL[0] is set as<0> automatically.

# 9.1. 4 Types Counting Modes of TMB

# 9.1.1. 16-bit counting

Set the counting mode selector TB1M[1:0] as <00> to make TMB operate under 16-bit counting mode. Under this mode, it has the following features:

 When TB1R[15:0] progressive counting is equal to TB1C0[15:0], it generator overflow event TB1IF[0] and zero and re-count TB1R[15:0].



Figure 9-2 16-bit Timer Waveform and Using Schematic Diagram

- Operation Instructions of 16-bit Counting Mode
  - Initial Configuration
    - TMB source operating frequency is fixed at HAO Set DTMB[1:0] to determine TMB operation frequency.
    - TB1M[1:0 is set as<00>. Plan TMB1 as 16-bit timer.
    - Write data to TB1C0[15:0]. (TB1C0H\*256+TB1C0L)
  - Trigger counting signal as Always Enable status, i.e. cycle count.
  - Set ENTMB[0] as <1> to start timer.



- During counting process, the user can set counting zeroing controller TB1CL[0] as <1> to recount, and TB1CL[0] will be set as <0> automatically.
- Set ENTMB[0] as <0> to close the timer.
- Operation Instructions of 16-bit PWM Mode
  - Initialization Configuration (PWM Frequency and Duty Cycle Setting)
    - TMB source operating frequency is fixed at HAO Set DTMB[1:0] to determine TMB operation frequency.
    - TB1M[1:0] is set as <00>. Plan TMB1 as 16-bit timer.
    - Trigger counting signal as Always Enable, i.e. cycle count.
    - Write data to TB1C0[15:0] (TB1C0H\*256+TB1C0L)to determine the frequency of PWM.
    - Write data to TB1C1[15:0] (TB1C1H\*256+TB1C1L) to determine the Duty Cycle of PWM.
    - Set ENTMB[0] as <1> to start timer.
    - Generator PWM0 Waveform
      - When TB1R[15:0] counting value is equal to TB1C1[15:0], it makes the status of PWM0 be 0 →1.
  - PWM Output Control
    - Set the pin output PWM waveform status as output status, and set ENPWM0[0] as <1>to start output as PWM function. Confirm whether the pin related setting is correct.
  - When ENTMB[0] is set as <0>, it will close timer and PWM output.
  - Calculation equation of PWM1 frequency Duty Cycle is:

 $PWM0 Frequency = \frac{DTMB_CK}{TB1C0[15:0]+1}$  $PWM0 Duty Cycle = \frac{(TB1C0[15:0]+1) - TB1C1[15:0]}{TB1C0[15:0]+1}$ 

## 9.1.2. 16 bit pulse generator mode

The counting mode selector TB1M[1: 0] settings <01> so TMB operates in 16-bit mode pulse generator, which generates a pulse wave number is (TB1C1H \* 256 + TB1C1L).

After the pulse generator, TMB will automatically shut down. To the end of the pulse generator issues an interrupt, set (TB1C0H \* 256 + TB1C0L) settings (TB1C1H \* 256 + TB1C1L) the same.

TBC0H/256+TBC0L

Figure 9-316 bit pulse generator Waveform and Using Schematic Diagram



# 9.1.3. Dual 8-bit PWM mode



Figure 9-4 PWM1 Waveform and Using Schematic Diagram

- PWM0 Output Operation Instructions
  - Initialization Configuration (PWM Frequency and Duty Cycle Setting)
    - TMB source operating frequency is fixed at HAO Set DTMB[1:0] to determine TMB operation frequency.
    - TB1M[1:0] is set as <10>. Plan TMB1 as Dual 8-bit count.



- Trigger counting signal as Always Enable, i.e. cycle count.
- Write data to TB1C0L[7:0] to determine the frequency of PWM.
- Write data to TB1C1L[7:0] to determine the Duty Cycle of PWM.
- Set ENTMB [0] as <1> to start timer.
- Generator PWM0 Waveform
  - When TB1R[7:0] counting value is equal to TB1C1L[7:0], it makes the status of PWM0 be 0->1.
  - When TB1R[7:0] recounting value is equal to TB1C0L[7:0], it makes the status of PWM0 be 1->0. Furthermore, it generator overflow event and makes TMBIF[0] set as <1> and zero and retake increment counting. At the moment, it will produce interrupt event service when GIE[0] \ TMBIE[0] is set as <1>.
- PWM Output Control
  - Set the pin output PWM waveform status as output status, and set ENPWM0[0] as <1>to start output as PWM function. Confirm whether the pin related setting is correct.
- When ENTMB[0] is set as <0>, it will close timer and PWM output.
- Calculation equation of PWM0 frequency Duty Cycle is:

 $PWM0 Frequency = \frac{DTMB\_CK}{TB1C0L[7:0]+1}$  $PWM0 Duty Cycle = \frac{(TB1C0L[7:0]+1) - TB1C1L[7:0]}{TB1C0L[7:0]+1}$ 





Figure 9-5 PWM1 Waveform and Using Schematic Diagram

- PWM1 Output Operation Instructions
  - Initialization Configuration (PWM Frequency and Duty Cycle Setting)
    - TMB source operating frequency is fixed at HAO Set DTMB[1:0] to determine TMB operation frequency.
    - TB1M[1:0] is set as <10>. Plan TMB1 as Dual 8-bit count.
    - Trigger counting signal as Always Enable, i.e. cycle count.
    - Write data to TB1C0H[7:0] to determine the frequency of PWM.
    - Write data to TB1C1H[7:0] to determine the Duty Cycle of PWM.
    - Set ENTMB[0] as <1> to start timer.
  - Generator PWM1 Waveform
    - When TB1R[15:8] counting value is equal to TB1C1H[15:8], it makes the status of PWM0 be 0→1.
    - When TB1R[15:8] recounting value is equal to TB1C0H[15:8], it makes the status of PWM0 be 1→0. Furthermore, it generator overflow event and makes TMBIF[0] set as <1> and zero and retake increment counting. At the moment, it will produce interrupt event service when GIE[0] \ TMBIE[0] is set as <1>.
  - PWM Output Control
    - Set the pin output PWM waveform status as output status, and set ENPWM1[0] as <1>to



start output as PWM function. Confirm whether the pin related setting is correct.

- When ENTMB[0] is set as <0>, it will close timer and PWM output.
- Calculation equation of PWM0 frequency Duty Cycle is:

 $PWM1 Frequency = \frac{DTMB_CK}{TB1C0H[15:8]+1}$  $PWM1 Duty Cycle = \frac{(TB1C0H[15:8]+1) - TB1C1H[15:8]}{TB1C0H[15:8]+1}$ 

## 9.1.4. 8+8-bit PWM

When TMB is set as 8+8-bit mode and PWM output waveform is selected as PWM5, it can produce 8+8bit PWM output.

8+8-bit PWM is composed of TB1R[7:0], TB1C0L[15:8], TB1C1L[7:0] and TB1C1H[15:8] control registers and internal digital circuit. TB1C0[7:0] is PWM frequency controller, TB1C1L[7:0] is PWM duty cycle controller, and TB1C1H[15:8] is 8+8-bit PWM duty cycle trimmer.

| Setting                       |                                                    | -                                                  | -                                                  | TB1C1                                               | H[15:8]                                             | -                                                   | -                                                    | -                                                      |
|-------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|------------------------------------------------------|--------------------------------------------------------|
| Weighted Quantity             | 80h                                                | 40h                                                | 20h                                                | 10h                                                 | 08h                                                 | 04h                                                 | 02h                                                  | 01h                                                    |
| Fine tuning of PWM duty cycle | 1/2                                                | 1/4                                                | 1/8                                                | 1/16                                                | 1/32                                                | 1/64                                                | 1/128                                                | 1/256                                                  |
| Description                   | 2 times of TMB overflow,one half N+1and one half N | 4 times of TMB overflow,one half N+1and one half N | 8 times of TMB overflow,one half N+1and one half N | 16 times of TMB overflow,one half N+1and one half N | 32 times of TMB overflow,one half N+1and one half N | 64 times of TMB overflow,one half N+1and one half N | 128 times of TMB overflow,one half N+1and one half N | 256 times of TMB overflow , one half N+1and one half N |

Setting and instruction of 8+8-bit PWM duty cycle spinne TB1C1H[15:8] are as in the following table.

Table 9-1 Duty Cycle Trimmer Setting Table

- Description of duty cycle trimmer TB1C1H[15:8], in which N is the width of duty cycle, (*Note:* N = TB1C1[7:0])
  - Basic Type



- TB1C1H[15:8] is set as 80h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 2 output periods as a group--- one is N+1 and the other is N.
- TB1C1H[15:8] is set as 40h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 4 output periods as a group--- 2 continuous output is N+1 and the other 2 is N.
- TB1C1H[15:8] is set as 20h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 8 output periods as a group--- 4 continuous output is N+1 and the other 4 is N.
- TB1C1H[15:8] is set as 10h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 16 output periods as a group--- 8 continuous output is N+1 and the other 8 is N.
- TB1C1H[15:8] is set as 08h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 32 output periods as a group---16 continuous output is N+1 and the other 16 is N.
- TB1C1H[15:8] is set as 04h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it produces waveform taking 64 output periods as a group--- 32 continuous output is N+1 and the other 32 is N.
- TB1C1H[15:8] is set as 02h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 128 output periods as a group--- 64 continuous output is N+1 and the other 64 is N.
- TB1C1H[15:8] is set as 01h, and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 256 output periods as a group--- 128 continuous output is N+1 and the other 128 is N.

## ■ Logic Computation OR Superimposition Type

(only takes1/2+1/4,1/2+1/8,~,1/2+1/4+1/8+1/16+1/32+1/64+1/128,1/2+1/4+1/8+1/16+1/32+ 1/64+1/256 as description and demonstration)

- TB1C1H[15:8] is set as C0h(1/2+1/4), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 4 output periods as a group--- 1 output is N+1 and the other 3 is N.
- TB1C1H[15:8] is set as A0h(1/2+1/8), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 8 output periods as a group--- 2 output is N+1 and the other 6 is N.
- TB1C1H[15:8] is set as 90h(1/2+1/16), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 16 output periods as a group--- 4 output is N+1 and the other 12 is N.



- TB1C1H[15:8] is set as 88h(1/2+1/32), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 32 output periods as a group--- 8 output is N+1 and the other 24 is N.
- TB1C1H[15:8] is set as 84h(1/2+1/64), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 64 output periods as a group--- 16 output is N+1 and the other 40 is N.
- TB1C1H[15:8] is set as 90h(1/2+1/128), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 128 output periods as a group--- 32 output is N+1 and the other 96 is N.
- TB1C1H[15:8] is set as 90h(1/2+1/256), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 256 output periods as a group---64 output is N+1 and the other 192 is N.
- TB1C1H[15:8] is set as C0h(1/2+1/4+1/8), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 8 output periods as a group--- 1 output is N+1 and the other 7 is N.
- TB1C1H[15:8] is set as C0h(1/2+1/4+1/8), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 8 output periods as a group--- 1 output is N+1 and the other 7 is N.
- TB1C1H[15:8] is set as C0h(1/2+1/4+1/8+1/16), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 16 output periods as a group--- 1 output is N+1 and the other 15 is N.
- TB1C1H[15:8] is set as C0h(1/2+1/4+1/8+1/16+1/32), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 32 output periods as a group--- 1 output is N+1 and the other 31 is N.
- TB1C1H[15:8] is set as C0h(1/2+1/4+1/8+1/16+1/32+1/64), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 64 output periods as a group--- 1 output is N+1 and the other 63 is N.
- TB1C1H[15:8] is set as C0h(1/2+1/4+1/8+1/16+1/32+1/64+1/128), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 128 output periods as a group--- 1 output is N+1 and the other 127 is N.
- TB1C1H[15:8] is set as C0h(1/2+1/4+1/8+1/16+1/32+1/64+1/128+1/256), and it makes waveform of PWM duty cycle occur N+1 and N output, i.e. it generator waveform taking 256 output periods as a group--- 1 output is N+1 and the other 255 is N.
- Following Table 9 -2 and Figure 9-6 sections list 8+8-bit PWM waveform changing of TB1C1H[15:8] under different setting for user's reference.

# HY10S40 Emulate Chip User' Guide

# Embedded 18-Bit ΣΔADC

8-Bit RISC-like Mixed Signal Microcontroller

|                                        | 8+8bit PV     | /M                   |   |     |     |     |     |     |     | Т   | BN O | verflov | v Time | S |     |     |   |     |     |     |     |
|----------------------------------------|---------------|----------------------|---|-----|-----|-----|-----|-----|-----|-----|------|---------|--------|---|-----|-----|---|-----|-----|-----|-----|
| Type                                   | TBC2<br>[7:0] | Logic<br>computation | 0 | F   | 2   | e   | 4   | 5   | 9   | 2   | 8    | 6       | 10     | ۲ | 127 | 128 | ۲ | 252 | 253 | 254 | 255 |
|                                        | 80h           | 1/2                  | Ν | N+1 | N   | N+1 | N   | N+1 | N   | N+1 | Ν    | N+1     | N      | 1 | N+1 | N   | 1 | Ν   | N+1 | Ν   | N+1 |
|                                        | 40h           | 1/4                  | N | N   | N+1 | N   | N   | N   | N+1 | N   | N    | N       | N+1    | ~ | N   | N   | 1 | Ν   | Ν   | N+1 | Ν   |
| E                                      | 20h           | 1/8                  | N | N   | N   | N   | N+1 | N   | Ν   | N   | Ν    | N       | N      | ~ | N   | N   | ~ | N+1 | Ν   | Ν   | Ν   |
| avefo                                  | 10h           | 1/16                 | N | N   | N   | N   | N   | N   | Ν   | N   | N+1  | N       | N      | ~ | N   | N   | ~ | N   | Ν   | Ν   | Ν   |
| Basic Waveform                         | 08h           | 1/32                 | Ν | N   | N   | N   | N   | N   | Ν   | N   | N    | N       | Ν      | ~ | N   | N   | ~ | N   | Ν   | Ν   | Ν   |
| Ba                                     | 04h           | 1/64                 | N | N   | N   | N   | N   | N   | Ν   | N   | Ν    | N       | N      | ~ | N   | N   | ~ | N   | Ν   | N   | Ν   |
|                                        | 02h           | 1/128                | Ν | N   | N   | N   | N   | N   | Ν   | N   | N    | N       | Ν      | ~ | N   | N   | ~ | N   | Ν   | Ν   | Ν   |
|                                        | 01h           | 1/256                | N | N   | N   | N   | N   | N   | Z   | N   | N    | N       | N      | 1 | N   | N+1 | 1 | Ν   | Z   | Ν   | Ν   |
| ,pe                                    | C0h           | 3/4                  | N | N+1 | N+1 | N+1 | N   | N+1 | N+1 | N+1 | Ν    | N+1     | N+1    | ~ | N+1 | N   | ~ | N   | N+1 | N+1 | N+1 |
| sition Ty                              | A0h           | 5/8                  | N | N+1 | N   | N+1 | N+1 | N+1 | Ν   | N+1 | N    | N+1     | N      | ~ | N+1 | N   | ~ | N+1 | N+1 | Ν   | N+1 |
| erimpos                                | E0h           | 7/8                  | N | N+1 | Ν    | N+1     | N      | ~ | N+1 | N   | ~ | N+1 | N+1 | N+1 | N+1 |
| n Supe                                 | F0h           | 15/16                | N | N+1  | N+1     | N      | ~ | N+1 | N   | ~ | N+1 | N+1 | N+1 | N+1 |
| Logic Computation Superimposition Type | A1h           | 161/256              | N | N+1 | N   | N+1 | N+1 | N+1 | Ν   | N+1 | Ν    | N+1     | N      | ~ | N+1 | N+1 | ~ | N+1 | N+1 | Ν   | N+1 |
| gic Corr                               | F1h           | 241/256              | Ν | N+1  | N+1     | Ν      | ~ | N+1 | N+1 | ~ | N+1 | N+1 | N+1 | N+1 |
| Loç                                    | FFh           | 255/256              | N | N+1  | N+1     | N+1    | ~ | N+1 | N+1 | ~ | N+1 | N+1 | N+1 | N+1 |

Table 9 -2 8+8-bit PWM Output Waveform and Using Schematic Table







Figure 9-6 8+8-bit PWM Output Waveform Schematic Diagram

- 8+8-bit PWM Output Operation Instructions
  - Initialization Configuration (PWM Frequency and Duty Cycle Setting)
    - TMB source operating frequency is fixed at HAO Set DTMB[1:0] to determine TMB operation frequency.
    - TB1M[1:0] is set as <11>. Plan TMB1 as 8+8-bit count.
    - Trigger counting signal as Always Enable, i.e. cycle count.
    - Write data to TB1C0L[7:0] to determine the frequency of PWM.
    - Write data to TB1C1H[15:8] to determine the Duty Cycle of PWM.
    - Set ENTMB[0] as <1> to start timer.
  - Generator 8+8-BIT PWM Waveform
    - When TB1R[7:0] counting value is equal to TB1C0L[7:0], it makes the status of 8+8-Bit PWM be 0→1.
    - When TB1R[7:0] recounting value is equal to TB1C1L[7:0], it makes the status of 8+8-Bit PWM be 1→0.

✓ Furthermore, it produces overflow event and makes TB1IF[0] set as <1> and zero and retake increment counting. At the moment, it will produce interrupt event service when GIE[0] 
TB1IE[0] is

set as <1>.



✓ At the moment, all TB1C1H[7:0] set data is adjust 8+8-Bit PWM output as N+1 and N. As in Table 8-1, N=TB1C1L[7:0].

- PWM Output Control
  - Set the pin output PWM waveform status as output status, and set ENPWM0[0] as <1>to start output as PWM function. Confirm whether the pin related setting is correct.
- When ENTMB[0] is set as <0>, it will close timer and PWM output.
- Calculation equation of 8+8-Bit PWM frequency Duty Cycle is:

 $PWM Frequency = \frac{DTMB\_CK}{TB1C0L[7:0]+1}$  $PWM Duty Cycle = \frac{(TB1C1L[7:0]+1) + \frac{TB1C1H[15:8]}{256}}{TB1C0L[7:0]+1}$ 



# 9.2. TMB1 Control Register List and Instructions

|         | "-"no use, "*"read/write, "w"write, "r"read, "r0"only read 0, "r1"only read 1, "w0"only write 0, "w1"only write |                                            |                                           |        |               |                |            |      |       |           |                   |  |  |
|---------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------|--------|---------------|----------------|------------|------|-------|-----------|-------------------|--|--|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                       |                                            |                                           |        |               |                |            |      |       |           |                   |  |  |
| Address | File Name                                                                                                       | Bit7                                       | Bit6                                      | Bit5   | Bit4          | Bit3           | Bit2       | Bit1 | Bit0  | A-RESET   | R/W               |  |  |
| 58H     | TB1CN0                                                                                                          | ENTMB                                      | TB1M[1:0]                                 |        | DTMB[1:0]     |                | -          | -    | TMBCL | 0000 0000 | *,*,*,*,*,*,*     |  |  |
| 59H     | TB1C0L                                                                                                          |                                            | TimerB1 counter Condition Register0 [7:0] |        |               |                |            |      |       |           |                   |  |  |
| 5AH     | TB1C0H                                                                                                          | TimerB1 counter Condition Register0 [15:8] |                                           |        |               |                |            |      |       | XXXX XXXX | *,*,*,*,*,*,*,*   |  |  |
| 5BH     | TB1C1L                                                                                                          |                                            | TimerB1 counter Condition Register1 [7:0] |        |               |                |            |      |       |           | * * * * * * * * * |  |  |
| 5CH     | TB1C1H                                                                                                          |                                            |                                           | TimerB | 1 counter Con | dition Registe | er1 [15:8] |      |       | XXXX XXXX | * * * * * * * * * |  |  |

Table 9-3 TMB1/2/3 Related Register

#### INTE0/INTF0 : Please refer to Interrupt Chapter

#### TB1CN0 : Timer-B Control Register

| Bit    | Name      | Description                                                            |
|--------|-----------|------------------------------------------------------------------------|
| Bit7   | ENTMB     | Timer-B enable controller                                              |
|        |           | <1> Enable count                                                       |
|        |           | <0> Disable Count ; Zero counters                                      |
| Bit6~5 | TB1M[1:0] | TMB Operation Mode Selector                                            |
|        |           | <00>16bit counter mode.                                                |
|        |           | TMB_CLK/(TBC0H*256+TBC0L) Periodic interruption occurs                 |
|        |           | <01> 16bit pulse generator mode. Pulse generation quantity             |
|        |           | (TB1C1H*256+TB1C1L)                                                    |
|        |           | <10> Dual 8-bit PWM mode.                                              |
|        |           | PWMO0 Duty isTB1C1L/TB1C0L                                             |
|        |           | PWMO1 Duty is TB1C1H/TB1C0H                                            |
|        |           | <11> 8+8bit PWM mode. Output Duty is TB1C1L/TB1C0L+TB1C1H/256          |
| Bit4~3 | DTMB      | Timer-B operating frequency prescaler                                  |
|        |           | <00>TMB clock=HS(default)                                              |
|        |           | <01>TMB clock=HS/4                                                     |
|        |           | <10>TMB clock=HS/8                                                     |
|        |           | <11>TMB clock=HS/16                                                    |
| Bit0   | TMBCL     | TMB clear of counter                                                   |
|        |           | <1> TMB clear of counter, When writing "1" clear TMBR and Pre-counter, |
|        |           | automatically returns to "0"                                           |
|        |           | <0> TMB Counting                                                       |

TB1C0H : TMB1 Count condition register TB1C0[15:8]

- TB1C0L : TMB1 Count condition register TB1C0 [7:0]
- TB1C1H : TMB1 Count condition register TB1C1[15:8]
- TB1C1L : TMB1 Count condition register TB1C1 [7:0]



# 10. Power System

Power System (PWR) has a linear regulator power VDDA and analog circuit ground power ACM. The provided chip analog peripheral circuit is used appropriately to drive external circuit.

VDDA Linear Regulator Power

- 3-segment voltage adjustment design
- 4 types of operation modes
- External bias voltage design
- Low temperature drift coefficient

ACM Internal Analog Circuit Ground Power

- Output Voltage 1.2V
- Low temperature drift coefficient

## Abstract of PWR Register:

**PWRCN** ENLDO[1:0],VDDAX[1:0]







# 10.1. VDDA Manual

# 10.1.1. VDDA Initialization Setting:

Voltage stabilization selector VDDAX[1:0] can set VDDA pin output voltage as 3.0V, 2.7V and 2.4V. As VDDA is linear voltage stabilization power, it must mote whether the VDD working voltage value is lower than the set value of VDDA output voltage when using, so as to avoid causing unexpected circuit malfunction.

# 10.1.2. VDDA Used External Bias:

VDDA can adopt external input voltage design. When the user provided power source by oneself, it must be input by VDDA pin impressed voltage method. When this method is adopted, it must close VDDA, i.e. ENLDO[1:0] is set as 00. It must note this method may affect the efficiency of analog circuit. Therefore, it shall be careful.

## 10.1.3. VDDA Starting

When ENLDO[1:0] is set as <11>, it will start VDDA regulator. When starting VDDA regulator, it shall avoid SD18 in starting status. Furthermore, it can only start SD18 when VDDA voltage is stable. When it is external connection with 1uF(10uF) voltage stabilization capacitor, it needs 500uS(5mS) stabilization time.

## 10.2. ACM Manual

## **10.2.1.** ACM Initialization Setting:

When internal analog circuit ground power ACM is used, it must start VDDA first. ACM internal produced output voltage is fixed as 1.2V.

# 10.3. Register Instruction-PWR

|         | "-"no use, "*"read/write, "w"write, "r"read, "r0"only read 0, "r1"only read 1, "w0"only write 0, "w1"only write 1 |       |         |            |       |       |        |        |       |           |           |  |
|---------|-------------------------------------------------------------------------------------------------------------------|-------|---------|------------|-------|-------|--------|--------|-------|-----------|-----------|--|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                         |       |         |            |       |       |        |        |       |           |           |  |
| Address | Name                                                                                                              | Bit 7 | Bit 6   | Bit 5      | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0 | ARST      | IRST      |  |
| 033h    | PWRCN                                                                                                             | ENL   | DO[1:0] | VDDAX[1:0] |       |       | AD1RST | AD2RST | CSFON | 0000 0000 | uuuu u00u |  |

Table 10-4 PWR Register

#### **PWRCN: Power System Control Register**

ENLDO [1:0]: Internal linear regulator start/ close controller

<11> Output VDDA voltage

<10>Close LDO, and output is pulled to VSS.

<01> Output VDD voltage

<00> Close LDO, and VDDA pin has high input impedance mode.

VDDAX[1:0]: VDDA Voltage Stabilization Selector

- 11: 2.4V
- 10: 2.7V
- 01: 3.0V
- 00: Not Used



# 11. Analog Digital Converter SD18,ΣΔADC

SD18 is Over Sampling Sigma Delta Analog-to-Digital Converter with high resolution. It has 24-bit output, and includes 4 parts, i.e. multi-functional input multiplexer, Input Buffer and pre- Programmable Gain Amplifier (PGA,), $\Sigma\Delta$ AD, Sigma Delta Modulator and Comb Filter.

Multi-functional Input Multiplexer:

- Switch and select several groups of different channels. Single chip can take several kinds of measuring.
- Input channel can make inversion and short circuit, and eliminate ADC wandering of zero point.
- Built-in temperature sensing circuit output voltage

 $\Sigma\Delta$  Sigma Delta Modulator:

- Adjust the input voltage magnification factor. Optional magnification factors are 1/4, 1/2, 1, 2, 4, 8 and 16 times
- Optional reference voltage magnification is 1 or 1/2.
- 3-bit DC input bias setting
- Adjustable sampling frequency of modulator: 31.5kHz~250kHz

Comb Filter:

- Adjustable OSR(Over Sampling Ratio)= 32~32768, ADC output speed is about 7.81kHz~8Hz(sampling frequency=250kHz)
- Produce interrupt event

## Abstract of SD18 register:

| ADCR[23:0] | ADCRH[7:0], ADCRM[7:0], ADCRL[7:0],   |
|------------|---------------------------------------|
| ADCCN1     | ENADC[0],ENHIGN[0],ENCHP[0],ADGN[2:0] |
| ADCCN2     | VREGN[0],DCSET[2:0]                   |
| ADCCN3     | OSR[3:0]                              |
| AINET1     | INH[2:0],INL[2:0],INIS[0]             |
| AINET2     | VRH[1:0],INX[1:0],VRL[1:0]            |

# HY10S40 Emulate Chip User' Guide Embedded 18-Bit ΣΔΑDC

8-Bit RISC-like Mixed Signal Microcontroller





Fig 11-1 SD18 Block Diagram



# 11.1. SD18 Manual

# 11.1.1. SD18 Initialization Setting

## 11.1.1.1. Work Frequency Collocation Mode

SD18 sampling frequency is set by sampling frequency selector ADCCK [0], and SD18 work frequency is provided by DHS\_CK. The max sampling frequency is no more than 300kHz and min sampling frequency is no less than 25kHz. Quicker sampling frequency can obtain better resolution under the same output speed, but the input impedance will also be reduced. When DHS\_CK frequency surpasses max allowable value, it must take frequency adjustment via over-sampling frequency pre-eliminator ADCS [2:0], as in Table 11-1.



| - 3DTo hol-operational work nequelog(onit. Ki |         |     |           |      |      |      |      |     |     |  |  |  |
|-----------------------------------------------|---------|-----|-----------|------|------|------|------|-----|-----|--|--|--|
|                                               | Setting |     | ADCS[2:0] |      |      |      |      |     |     |  |  |  |
| HS_CK                                         | DHS_CK  | 000 | 001       | 010  | 011  | 100  | 101  | 110 | 111 |  |  |  |
| 8000                                          | HS_CK/1 | -   | -         | 250  | 125  | 62.5 | 31.2 | -   | -   |  |  |  |
| 8000                                          | HS_CK/2 | -   | 250       | 125  | 62.5 | 31.2 | -    | -   | -   |  |  |  |
| 4000                                          | HS_CK/1 | -   | 250       | 125  | 62.5 | 31.2 | -    | -   | -   |  |  |  |
| 4000                                          | HS_CK/2 | 250 | 125       | 62.5 | 31.2 | -    | -    | -   | -   |  |  |  |
| 2000                                          | HS_CK/1 | 250 | 125       | 62.5 | 31.2 | -    | -    | -   | -   |  |  |  |

Fig 11-2 SD18 Work Frequency Block Diagram

"-": SD18 non-operational work frequency(Unit: KHz)

Table 11-1 SD18 Work Frequency Setting Table



# 11.1.1.2. Multi-functional Input Multiplexer Collocation Mode

Multi-functional Input Multiplexer may produce two groups of Differential Output signals, i.e. signal for testing **SI+**,**SI-** and reference voltage **VR+**  $\times$  **VR**-.

- SI± input signal selector INH[2:0], INL[2:0] and SI± input signal converter INX[1:0] can send the input signals to SI+ or SI- end via the following paths, such as Fig 11-3 and Table 11-2 (a) ;
  - AI0~AI7pins via INH and INL channel
  - LNOP output signal OPO
  - Reference power source ACM
- VR± voltage signal selectors VRH[1:0] and VRL[1:0] can determine SD18 reference voltage is sent to VR+ or VR- end via the following paths, as in Table 11-2 (b).
  - AI0~AI4 pins via VRH and VRL channel
  - Reference power source ACM
  - Work power source VSS
- When SI± input signal short circuit INIS[0] is set as <1>, it can make INH and INL channels short circuits. On the contrary, when it is set as <0>, INH and INL channels are not short circuits.



| Setting               | INH[2:0],INL[2:0] |     |     |     |       |       |      |     |  |  |
|-----------------------|-------------------|-----|-----|-----|-------|-------|------|-----|--|--|
| Signal for<br>Testing | 000               | 001 | 010 | 011 | 100   | 101   | 110  | 111 |  |  |
| SI+                   | AI0               | Al2 | Al4 | Al6 | VDD/2 | VDD/4 | VDDA | VSS |  |  |
| SI-                   | Al1               | AI3 | AI5 | AI7 |       |       | ACM  | VSS |  |  |

| Setting | VRH[1:0],VRL[1:0] |     |     |     |  |  |  |  |  |
|---------|-------------------|-----|-----|-----|--|--|--|--|--|
| Input   | 00                | 01  | 10  | 11  |  |  |  |  |  |
| VR+     | VDDA              | ACM | AI0 | Al1 |  |  |  |  |  |
| VR-     | VSS               | Al2 | AI3 | Al4 |  |  |  |  |  |

Table 11-2 (a)SI± Input Selector

Table 11-2 (b) VR± Input Selector



# 11.1.1.3. $\Sigma\Delta$ Modulator Configuration Mode

SD18 is adopted second order  $\Sigma\Delta$  modulator. The signal for testing and reference voltage can be taken magnification and bias adjustment via the following settings.

- When ΔVR± magnification adjuster VREGN[0] is set as <1>, it will take 1/2 magnification adjustment for reference voltage signal, and also change the ratio of input signals ΔSI± = (SI+ SI-) and ΔVR± = (VR+ VR-). When it is set as <0>, it takes 1 time of adjustment.
- Via the setting of magnification adjuster ADGN[2:0], input signal can be up to max 16 times of signal magnification, as in Table 11-3 (a).
- When ENCHP[0] is set as <0>, it can make the input signal reduce frequency caused frequency noise via chopper. On the contrary, when ENCHP[0] is set as <1>, input signal will come round the chopper.
- Input signal SI± can adjust the input signal zero position to increase measurement range via DC input bias adjuster DCSET[2:0]. Bias method is adopted magnification value of weighted reference signal VR±, as in Table 11-3 (b).
- When taking signal measuring, it shall note the matching problem of external input signal impedance and ADC. See *11.2 Analog Channel Input Features*

| Setting | ADGN[2:0] |      |     |     |     |     |     |     |  |  |
|---------|-----------|------|-----|-----|-----|-----|-----|-----|--|--|
| Input   | 000       | 001  | 010 | 011 | 100 | 101 | 110 | 111 |  |  |
| AD Gain | -         | x1/2 | x1  | x2  | x4  | x8  | x16 | -   |  |  |

| Setting |     | DCSET[2:0] |      |      |     |      |      |      |  |  |  |
|---------|-----|------------|------|------|-----|------|------|------|--|--|--|
| Input   | 000 | 001        | 010  | 011  | 100 | 101  | 110  | 111  |  |  |  |
| SI±     | +0  | +1/4       | +1/2 | +3/4 | +0  | -1/4 | -1/2 | -3/4 |  |  |  |

Table 11-3 (a)ADGN[2:0] Magnification Collocation List

Unit: VR±

## Table 11-3 (b) SI± Input Signal Weighted Reference Voltage Magnification List



After  $\Sigma\Delta$  modulator takes pre-PGA and modulator magnification bias adjustment, the calculation formulas of equivalent signal for testing  $\Delta$ SI\_I and equivalent reference voltage  $\Delta$ VR\_I are as the following respectively: *Formula 11-1* 

 $\Delta SI\_I = PGAGN \times ADGN \times \Delta SI \pm + (DCSET \times \Delta VR \pm)$ 

## Formula 11-2

 $\Delta VR \_ I = VRGN \times \Delta VR \pm$ 

Notes: To ensure  $\Sigma\Delta$  modulator output get higher resolution and degree of linearity, equivalent reference voltage  $\Delta VR_I$  is suggested as  $\pm \Delta VR_I$ =0.8V~1.2V, and equivalent signal for testing  $\Delta SI_I$  is operated at  $\Delta SI_I$ =±0.9 x  $\Delta VR_I$ .



# 11.1.1.4. Comb Filter Setting Mode

 $\Sigma\Delta$  Modulator output1-bit data is sent to second order Comb Filter, then it is covered into 24-bit value via Comb Filter and stored in ADCR[23:0] register. The update speed of ADCR[23:0] data is the output speed of SD18, and the calculation mode is the ratio of SD18 sampling frequency to SD 18 output speed. SD 18 output speed frequency is also called OSR (Over Sampling Ratio).

Therefore, the SD18 output speed is ADC\_CK÷OSR, and OSR value can produce different SD18 conversion frequency via OSR[2:0] settings, as in Table 11-3 (c).

| Setting |      | OSR[2:0] |      |      |      |      |      |      |      |      |      |
|---------|------|----------|------|------|------|------|------|------|------|------|------|
| ADC_CK  | 0000 | 0001     | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 |
| 250K    | 7812 | 3906     | 1953 | 976  | 488  | 244  | 122  | 61   | 30   | 15   | 7    |
| 125K    | 3906 | 1953     | 976  | 488  | 244  | 122  | 61   | 30   | 15   | 7    | 3    |

Table 11-3 (c) Simple List of SD18 Over-sampling Rate Frequency Collocation

ADCR [23:0] is composed of ADCRH[7:0], ADCRM[7:0] and ADCRL[7:0] respectively, and is used to store Comb Filter output 24-bit data. Comb Filter data format is as in Fig 11-4.

+FSR/-FSR: Max measuring range of positive phase and negative phase

|                                                                   | Equivalent                                | ADCR[23:0]           |                                |  |  |  |  |
|-------------------------------------------------------------------|-------------------------------------------|----------------------|--------------------------------|--|--|--|--|
|                                                                   | Signal for Test                           | Hex                  | Binary                         |  |  |  |  |
| Bipolar Output                                                    | $\Delta VR \_ I$                          | 7FFFFF <sup>*1</sup> | 0111-1111- 1111-1111-1111-1111 |  |  |  |  |
|                                                                   | $\Delta VR\_I \times \frac{1}{2^{22}}$    | 000001               | 0000-0000-0000-0000-00001      |  |  |  |  |
| Two                                                               | 0                                         | 000000               | 0000-0000 0000-0000 0000-0000  |  |  |  |  |
| Complement<br>Format                                              | $-\Delta VR \_ I \times \frac{1}{2^{22}}$ | FFFFFF               | 1111-1111-1111-1111-1111-1111  |  |  |  |  |
|                                                                   | $-\Delta VR \_ I$                         | C00000               | 1100-0000 0000-0000 0000-0000  |  |  |  |  |
| Table 11-4 Relationship Table between ADCR[23:0] and Input Signal |                                           |                      |                                |  |  |  |  |



Fig 11-4 ADCR [23:0] Resolution Schematic Diagram

Note: \* 1. ADCR ΔVR\_I full scale is 3FFFFFh. When overflow is 7FFFFFh, not 400000h i.e. 3FFFFF +1 -> 7FFFFF



# 11.1.2. Interrupt Service Setting

When comb filter value is completed converting and stored in ADCR[23:0] register, it will produce interrupt signal and ADCIF[0] is set as <1>. At the moment, it shall set ADCIE[0] and GIE[0] as <1> if interrupt event service is needed.

# 11.1.3. SD18 Starting

It can start SD18 to take analog digital conversion when ENADC[0] is set as <1>. On the contrary, when ENADC[0] is set as <0>, SD18 will be closed. The power of SD18 is VDDA, and ACM is used as the reference point of internal common-mode voltage. Therefore, it must start VDDA and ACM before starting SD18.

The work voltage of SD18 is provided by VDDA, and the Aix input pin voltage shall be no more than VDDA voltage. When VDDA power is closed (which is not taken internal start or external input), it may cause power leakage of the network and cause large chip wear and tear and current consumption indirectly if SD18 input signal network **SI±** and reference voltage network **VR±** exist voltage. Therefore, when VDDA power is closed, SD18 input signal network or reference voltage network must be selected properly. The network switch is adjusted internal ACM or VSS to avoid external voltage causing power leakage of network.



## 11.2. Analog Channel Input Features

SD18 is taken analog signal handling by using switchable capacitor circuit. When input buffer is not used, to ensure getting correct value of sampling capacitor voltage, max output impedance of input signal must be restricted. Furthermore, it shall have mutual dependence relationship with SD18 sampling frequency and signal magnification selection.



Rs = External signal source resistance Vs+ =Positive external signal source Vs- =Negative external signal source R<sub>A</sub> = Sample channel resistance C<sub>A</sub> = Sampling capacitance

Fig 11-5 Aix Input Capacitor and Impedance Module

From Fig 11-5, when input signal is input directly without via buffer, it must consider the effects of input signal internal resistance Rs and sampling frequency ADC\_CK & parasitic resistance  $R_A$  and capacitor  $C_A$  of SD18. Related formulas are as the following:

### Formula 11-3

 $t_s > (R_s + R_A + 180\Omega) \times C_A \times [ln(2^{ENOB} \times Gain) + 2]$ 

ts: SD18 shortest sampling time

ENOB: Expected to obtain SD18 Effective Number of Bits

Gain: (PGA Gain)×(ΣΔAD Gain)

### Formula 11-4

$$F_s = \frac{1}{2 \times t_s}$$

Fs: SD18 shortest sampling time

As the composition of SD18 includes PGA and  $\Sigma\Delta AD$  and the two parts have respective  $R_A$  and  $C_A$  value on design, the calculation of shortest sampling time  $t_s$  is considered and measured according to the directly matched part of input signal .

If PGA is used and amplification factor of  $\Sigma\Delta AD$  is set as 4 directly,  $R_A$ =10K $\Omega$  and  $C_A$ =2pF when  $t_s$  is calculated.

If PGA is used as pre- amplification and amplification factor is 2, while the amplification factor of  $\Sigma\Delta$ AD is still set as 4 to make the integral amplification factor be up to 8 times, but the calculation of t<sub>s</sub> only depends on input signal and directly matched amplifier, corresponding relationship of R<sub>A</sub>



and  $C_A$  in formulas of  $R_A$ =1.25K $\Omega$  and  $C_A$ =16pF to all Gain parts of SD18 is as in Table 11-5(a)/(b)/(c) .

| $\Sigma \bigtriangleup AD$ Gain | CA      | RA                    |
|---------------------------------|---------|-----------------------|
| x1/4                            | 0.125pF | <b>10Κ</b> Ω          |
| x1/2                            | 0.25pF  | $10 \mathrm{K}\Omega$ |
| x1                              | 0.5pF   | $10 \mathrm{K}\Omega$ |
| x2                              | 1pF     | $10 \text{K}\Omega$   |
| x4                              | 2pF     | $10 \mathrm{K}\Omega$ |
| x8                              | 4pF     | $5K\Omega$            |
| x16                             | 8pF     | <b>2.5K</b> Ω         |

Table 11-5(a) Relationship Table of SD18 Gain and  $R_A\& C_A$ 

| PGA<br>Gain    | CA                   | RA                         |
|----------------|----------------------|----------------------------|
| x2<br>x4<br>x8 | 16pF<br>32pF<br>64pF | 1.25KΩ<br>0.625KΩ<br>0.3KΩ |
| X8             | 64pF                 | $0.3 \mathrm{K}\Omega$     |

Table 11-5(b) Relationship Table of PGA Gain and  $R_A$  &  $C_A$ 

| VR<br>Gain | CA     | RA   |
|------------|--------|------|
| x1/2       | 0.25pF | 10ΚΩ |
| x1         | 0.5pF  | 10ΚΩ |

Table 11-5(c) Relationship Table of VR Gain and  $R_A\& C_A$ 

SD18 is mainly applied to measure low-frequency signals. However, actually, signals for testing may include many high-frequency noise signal. According to the signal sampling principle, high-frequency noise signal higher than sampling frequency may produce zero drift and low frequency noise signal after sampling, and cause measurement error further. Therefore, we recommend adding 10nF~100nF filter capacitor at the chip differential signal for test and reference voltage ends to strengthen the accuracy of measurement.



# 11.3. Register Instruction-SD18

|         | "-"no use,"*"read/write,"w"write,"r"read,"r0"only read 0,"r1"only read 1,"w0"only write 0,"w1"only write 1 |       |                                   |       |                     |              |          |           |       |           |           |
|---------|------------------------------------------------------------------------------------------------------------|-------|-----------------------------------|-------|---------------------|--------------|----------|-----------|-------|-----------|-----------|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                  |       |                                   |       |                     |              |          |           |       |           |           |
| Address | Name                                                                                                       | Bit 7 | Bit 6                             | Bit 5 | Bit 4               | Bit 3        | Bit 2    | Bit 1     | Bit 0 | ARST      | IRST      |
| 023h    | INTE0                                                                                                      | GIE   | ADIE                              | -     | WDTIE               | TB1IE        | TMAIE    | -         | E0IE  | 0000 0000 | 0uuu uuuu |
| 026h    | INTF0                                                                                                      | -     | ADIF                              |       |                     |              |          |           |       | .000 0000 | .uuu uuuu |
| 033h    | PWRCN                                                                                                      | ENLE  | DO[1:0]                           | VDE   | DAX[1:0]            |              | -        | ADRST     | CSFON | 0000 0000 | uuuu u00u |
| 034h    | OSCCN0                                                                                                     | OSC   | S[1:0]                            | DH    | IS[1:0]             |              | DMS[2:0] |           | CUPS  | 0000 0000 | սսսս սսսս |
| 035h    | OSCCN1                                                                                                     | LCP   | S[1:0]                            |       | ADCS[2:0]           | ]            | DTM      | B[1:0]    | TMBS  | 0000 0000 | uuuu uuu. |
| 036h    | OSCCN2                                                                                                     | ENRTC | -                                 | TX    | <sup>-</sup> S[1:0] | HAON         | M[1:0]   | ENHAO     | LPO   | .000 0011 | .uuu uu11 |
| 043h    | ADCRH                                                                                                      |       |                                   | AD    | C conversion        | memory High  | Byte     |           |       | XXXX XXXX | սսսս սսսս |
| 044h    | ADCRM                                                                                                      |       | ADC conversion memory Middle Byte |       |                     |              |          |           |       | XXXX XXXX | սսսս սսսս |
| 045h    | ADCRL                                                                                                      |       |                                   | AD    | C conversion i      | memory Low B | Byte     |           |       | XXXX XXXX | սսսս սսսս |
| 046h    | ADCCN1                                                                                                     | ENADC | ENHIGN                            | ENCHP | -                   | -            |          | ADGN[2:0] | ]     | 0000 0000 | 0000 0000 |
| 047h    | ADCCN2                                                                                                     | -     | -                                 | -     | -                   | VREGN        |          | DCSET[2:0 | )]    | 0000      | 0000      |
| 048h    | ADCCN3                                                                                                     |       | OSR[3                             | :0]   |                     |              |          |           |       | 0000.     | 0000.     |
| 049h    | AINET1                                                                                                     |       | INH[2:0]                          |       | INL[2:0] INIS -     |              |          |           | -     | 0000 000. | 0000 000. |
| 04Ah    | AINET2                                                                                                     | -     | VRH[1                             | :0]   | INX                 | [1:0]        | VRL      | [1:0]     | -     | .000 000. | .000 000. |
| 075h    | PT2                                                                                                        | -     | -                                 | -     | -                   | -            | -        | PT21      | PT20  | xx        | XX        |
| 076h    | TRISC2                                                                                                     | -     | -                                 | -     | -                   | -            | -        | TC21      | TC20  |           | uu        |
| 077h    | PT2DA                                                                                                      | -     | -                                 | -     | -                   | -            | -        | DA21      | DA20  | 00        | uu        |
| 078h    | PT2PU                                                                                                      | -     | -                                 | -     | -                   | -            | -        | PU21      | PU20  | 00        | uu        |
| 079h    | PT3                                                                                                        | -     | -                                 | PT35  | PT34                | PT33         | PT32     | PT31      | PT30  | xx xxxx   | xx xxxx   |
| 07Ah    | TRISC3                                                                                                     | -     | -                                 | TC35  | TC34                | TC33         | TC32     | TC31      | TC30  | 00 0000   | uu uuuu   |
| 07Bh    | PT3DA                                                                                                      | -     | -                                 | DA35  | DA34                | DA33         | DA32     | DA31      | DA30  | 00 0000   | uu uuuu   |

Table 11-6 SD18 Register

### INTEO/INTF0 : See Chapter Interrupt

#### **PWRCN** : See Chapter **Power System**

ADRST[0]: ΣΔADC and Comb Filter Reset Controller

<1> Reset; writing motion occurs.

<0>Not reset

OSCCN0/ OSCCN1/ OSCCN2: See Chapter Oscillator, Clock Source and Power Consumption

#### Management

ADC0RH/M/L: Out Register of SD18



### ADCCN1: SD18 Control Register 1

ENADC: SD18 Start Controller

- 1: Start
- 0: Close

#### ENHIGN: Retain original test using

1: Setting Disable. When it is set as 1, it may cause resolution reduction of SD18.

0: Definition Setting

#### ENCHP: SD18 Internal chopper

- 1: Setting Disable. When it is set as 1, it may cause resolution reduction of SD18.
- 0: Definition Setting

#### ADGN[2:0]: AD Magnification Adjuster

- 111: Not using
- 110: x16
- 101: x8
- 100: x4
- 011: x2
- 010: x1
- 001: x1/2
- 000: Not using

#### ADCCN2: SD18 Control Register 2

VREGN: VR± Magnification Adjuster

- 1: x1/2
- 0: x1

DCSET[2:0]: SI± Bias Adjuster

- 111: -3/4 VR±
- 110: -1/2 VR±
- 101: -1/4 VR±
- 100: No Bias
- 011: +3/4 VR±
- 010: +1/2 VR±
- 001: +1/4 VR±
- 000: No Bias



### ADCCN3: SD18 Control Register 3

OSR[3:0]: SD18 Over-sampling rate frequency eliminator

1010: 32768 1001: 16384 1000: 8192 0111: 4096 0110: 2048 0101: 1024 0100: 512 0011: 256

0010: 128

0001:64

0000: 32

#### AINET1: AI Network Control Register 1

INH[2:0]: SI±"+" input signal selector

- 111: VSS
- 110: VDDA
- 101: VDD/4
- 100: VDD/2
- 011: Al6
- 010: Al4
- 001: Al2
- 000: AI0

INL[2:0]: SI±"-" input signal selector

- 111: VSS
- 110: ACM
- 101: Not using
- 100: Not using
- 011: AI7
- 010: AI5
- 001: AI3
- 000: Al1

INIS: SI± input signal short circuit controller

- 1: Short circuit
- 0: No short circuit



### AINET2: AI Network Control Register 2

VRH[1:0]: VR±"+" Voltage signal selector

- 11: Al1
- 10: AI0
- 01: ACM
- 00: VDDA
- INX[1:0]: SI± input signal converter
  - 11: INH→ADL,INL→ADH
  - 10: INH floating, INH→ADH & ADH
  - 01: INL→ADH & ADL,INH floating
  - 00: INH→ADH,INL→ADL

VRL[1:0]: VR±"-" Voltage signal selector

- 11: Al4
- 10: AI3
- 01: Al2
- 00: VSS



# 12. BIE and 16-bit Hardware Data Recorder

Built-in EPROM (shortened as BIE) is composed of BIEAR[11:0] index register, BIEDR[15:0] value register and BIECN[7:0] control register. Related controllers and flags are BIEARL[7:0]/BIEARH[3:0] address controller, ENBIE[0] start controller, BIEWR[0] writing controller, BIERD[0] reading controller and VPPHV[0] voltage condition flags.

- BIE Features:
  - Use BIE function to store product serial number, security code and data and materials after program computation.
  - Provide additional 64words (equivalent to 128 bytes) for PM. Storage address range is 00H~3FH. Take data processing.
  - Have reading, writing and 16-bit table look-up function.
  - External hardware only needs connect VPP 6V burn voltage with VPP pins externally.
  - VPPHV[0] is flag register that reflects VPP pin voltage status immediately.
  - The reading of BIE is unnecessary to consider pin externally connected voltage. It is only necessary to consider effective voltage is equivalent to VDD.
  - Burn time of each byte of data is about 150ms.



Fig 12-1 Built-In EPROM Architecture

8-Bit RISC-like Mixed Signal Microcontroller



# Abstract of BIE Register:

BIECNVPPHV[0], BIEWR[0], BIERD[0]BIEARHENBIE[0],BIE\_BIEAH[2:0]BIEARLBIEAL[7:0]BIEDRHBIEDH[15:8]BIEDRLBIEDL[7:0]



Fig 12-2 BIE Block Diagram

### 12.1. BIE Manual

### 12.1.1. BIE Reading

- When the user reads BIE:
  - Set **BIE**ARL as readable **BIE** Address (Max 3FH, **BIE**ARL[7]=0, **BIE**ARL[6]=0)
  - BSF BIECN, BIERD,F
    - The instruction is invalid when **BIE** Address surpasses 3FH.
    - ◆ BIE READ motion has no relation with VPP potential, but it cannot be 0V.
  - Judge whether BIECN [BIERD] is cleared to be 0 automatically after **BIE** reading is completed.
  - Read BIEDRH, BIEDRL for the BIE Data

Notes: Before reading **BIE**, close ADC function (ADCCN1 [ENADC] =0b) first and capacity of resisting disturbance of ADC can be enhanced. After the **BIE** reading is completed, restart ADC function to take signal measurement.



# 12.1.2. BIE Writing

- Before the user writes **BIE**, read VPPHV first to confirm whether VPP voltage is correct.
- When the user writes BIE:
  - Set **BIE**ARL as writable **BIE** address (max 3FH , **BIE**ARL[7]=0, **BIE**ARL[6]=0)
  - Set **BIE**DRH, **BIE**DRL as writable **BIE** data
  - BSF **BIE**CN, **BIE**WR,F
    - The instruction is invalid when **BIE** address surpasses 3FH.
    - The instruction is invalid when VPP is not 6V.
  - Judge whether BIECN [BIEWR] is cleared to be 0 automatically after BIE writing is completed.
  - When current consumption is increased obviously, it is suggested taking **BIE** writing motion at ADC testing mode.

Notes: Before writing **BIE**, close ADC function (ADCCN1 [ENADC] =0b) first and capacity of resisting disturbance of ADC can be enhanced. After the **BIE** writing is completed, restart ADC function to take signal measurement.

# 12.1.3. Notes

- Before reading and writing BIE, please set CPU frequency source as HAO first. Otherwise, the motion may be abnormal.
- After BIE READ/WRITE motion is completed, BIERD/BIEWR is cleared to be 0 automatically, and BIEARL is increased automatically (max 3FH).
- It is suggested using BSF instruction to set BIERD of BIEWR. The instruction is invalid if the both are set as 1 simultaneously.
- When VPP is in high potential, after CPU is reset, PT1.5 maintains 65ms unknown potential (high potential or low potential) status output.
- Power on sequences: 1. Powering on VDD first, 2. Powering on VPP next.
- Before reading **BIE** or writing **BIE**, close ADC function (ADCCN1 [ENADC] =0b) first and capacity of resisting disturbance of ADC can be enhanced. After the **BIE** reading or **BIE** writing is completed, restart ADC function to take signal measurement.



### 12.2. Hardware Data Recorder

When BIE peripheral does not start burn function, it can be used as 16-bit hardware data recorder, but it can only read program memory and cannot take data writing.

It is unnecessary to consider pin externally connected power voltage for hardware data recorder reading. The following are operation instructions:

- Set the address of the table to be read as BIEARH, BIEARL(Up to 7FFH)
- After BIECN[BIERD] is set as <1>, check BIECN [BIERD] is automatically cleared to 0, determine whether the completion of the look-up table.
- Then reads BIEDRH, BIEDRL registers, look-up table is the Data.

| 16BITS_RE | AD:             |                                                          |
|-----------|-----------------|----------------------------------------------------------|
| MVL       | HIGH Table      | ;Set table look-up address                               |
| MVF       | BIEARH,F,ACCE   |                                                          |
| MVL       | LOW Table       |                                                          |
| MVF       | BIEARL,F,ACCE   |                                                          |
| BSF       | BIECN, BIERD,F  |                                                          |
| WAITRDBI  | ≣:              |                                                          |
| BTS       | Z BIECN, BIERD, | 1 ; check BIECN [BIERD] is automatically cleared to 0,   |
|           |                 | ; determine whether the completion of the look-up table. |
| JMP       | WAITRDBIE       |                                                          |
| MVF       | BIEDRL, W, 1    |                                                          |
| MVF       | BUF0, F, 1      | ; move BIEDRL data to BUF0                               |
|           |                 |                                                          |
| MVF       | BIEDRH, W, 1    |                                                          |
| MVF       | BUF1, F, 1      | ; move BIEDRH data to BUF1                               |

Example 12-1 16Bits Table Look-up Software Setting Example Program



# 12.3. Register Instruction-BIE

|         | "-"no use, "*"read/write, "w"write, "r"read, "r0"only read 0, "r1"only read 1, "w0"only write 0, "w1"only write 1 |       |                             |       |              |               |             |              |            |           |           |
|---------|-------------------------------------------------------------------------------------------------------------------|-------|-----------------------------|-------|--------------|---------------|-------------|--------------|------------|-----------|-----------|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition                         |       |                             |       |              |               |             |              |            |           |           |
| Address | Name                                                                                                              | Bit 7 | Bit 6                       | Bit 5 | Bit 4        | Bit 3         | Bit 2       | Bit 1        | Bit 0      | ARST      | IRST      |
| 02Eh    | BIECN                                                                                                             | -     | -                           | -     | -            | VPPHV         | -           | BIEWR        | BIERD      | 1 \$.00   | 1 \$.uu   |
| 02Fh    | BIEARH                                                                                                            | ENBIE | -                           | -     | -            | -             | 11-bit look | -up Table as | BIEAH[2:0] | 0 xxxx    | u uuuu    |
| 030h    | BIEARL BIE Address Register as BIEAL[5:0] or 11-bit look-up Table as BIEA[7:0]                                    |       |                             |       |              |               |             |              |            | XXXX XXXX | սսսս սսսս |
| 031h    | BIEDRH                                                                                                            |       | BIE High Byte Data Register |       |              |               |             |              |            | XXXX XXXX | սսսս սսսս |
| 032h    | BIEDRL                                                                                                            |       |                             |       | BIE Low Byte | Data Register |             |              |            | XXXX XXXX | นนนน นนนน |



### **BIECN: BIE Control Register**

VPPHV: Check VPP

0: VPP No external connection with burn power 6V

1: VPP external connection with burn power 6V

BIEWR: Write BIE control bit

0: Non- writable

1: Writable

BIERD: Read BIE control bit

0: Non-readable

1: Readable

#### **BIEARH: BIE Address Definition**

ENBIE: Mode Selection

0: OTP READ MODE

1: BIE MODE

BIEAH[2:0]: OTP address

### **BIEARL: BIE Low Byte Address Definition**

BIEAL[5:0]: OTP address

#### **BIEDH: BIE High Byte Data Definition**

BIEDL: BIE Low Byte Data Definition



# 13. Communication interface (CI)

Main type of communication interface (shortened as CI ) is I2C serial communication.

# 13.1. I2C Inter-Integrated Circuit Serial interface

I2C communication interface includes two types of operation modes, i.e. mater mode and slave mode. Master mode can combine Transmission Controller (Tx Controller) to transmit 12C packet format signal to 12C Bus according to the system requirements, and use Clock Generator to determine the required transmission ratio. Slave Controller can receive signal on 12C Bus. It receives master communication requirements on Bus, and combines Transmission Controller to post back the master required data. Additionally, Slave controller built-in receiving circuit is also a channel for Master Controller to receive posted back data.



Fig 13-1 I2C System Architecture

- Functional Features of I2C Serial Interface:
  - Standard I2C serial interface includes 2 pins---serial data and (SDA) and serial clock.
  - The pin is Open Drain output structure. It needs external pull-up resistor, to ensure high potential output.
  - Standard I2C serial interface can be configured as Master, Slave or Master /Slave mode.
  - Programmable clock is allowable to adjust I2C transmission speed.
  - Data transmission between the master and slave is two-way.
  - I2C allows rather large work voltage range.
  - The reference design of I2C uses a 7-bit address space, but reserves 16-bit address. Therefore, it can communicate with 112 nodes in a group of bus-bar.

### Embedded 18-Bit ΣΔΑDC 8-Bit RISC-like Mixed Signal Microcontroller



Fig 13-2 I2C Communication Wiring Schematic Diagram

- I2CSerial Interface Signal:
  - START: When master SCL is in high potential, it issues SDA and transfers from high potential to low potential. Then it starts transmit data.
  - DATA or ADDRESS signal: I2C serial interface protocol requires data on SDA can only be changed when SCL is in low potential.
  - Acknowledge Signal: When device (slave) for data receiving receives the 8<sup>th</sup> bit, it sends low potential to device (slave) for data sending, and indicates data has been received.
  - STOP Signal: When Master SCL is in high potential, it issues SDA and transfers from low potential to high potential to. Then data transition is ended.



Fig 13-3 I2C Bus-bar Timing Diagram





# 13.2. Data Transmission Ratio Calculation

12C internal register CRG[7:0] can control data transmission speed under master mode. The value produces SCL pin signal of master via internal counter. Therefore, data transmission ratio can be calculated by using the following formula according to the frequency of 12C clock source I2C\_CK.

Data Baud Rate(Hz)= $\frac{I2C_CK}{[4 \times (CRG[7:0]+1)]}$ 

# 13.3. Time-Out Function

Time-out control is to avoid 12C controller locks the 12C communication bus-bar deadly and provides sufficient time for 12C controller handling requirements during the operation process of 12C. Therefore, 12C will pull SCL to low after every acknowledge bit and make Master cannot transmit next clock signal, i.e. Clock Stretching. However, when MCU is too busy to acknowledge 12C controller or any other causes make MCU cannot acknowledge 12C controller, SCL of 12C communication bus-bar will be locked at Low deadly.

To avoid the above conditions, Time-out controller can determine the Time-out conditions when SCL is in Low status via work frequency eliminator DI2C[2:0] and time condition controller I2CTLT[3:0] according to the user's requirements. Condition handling has the following status:

When it is detected the time of SCL pulled by the local host satisfies the conditions, 12C controller will release SCL compulsively and issue interrupt event to CPU.

When SCL is not up to Time-out time and is released as High, the internal timer of Time-out controller will be reset, and take recounting when SCL is pulled to Low again next time.



# 13.4. I2C Serial Interface Communication Flowchart

- I2CSerial Interface Terms
  - (SPIA): It means issued orders of Action Control Register (ACT).
  - S is Start instruction.
  - P is Stop instruction.
  - I is interrupt flag.

A is Acknowledge instruction.

- SPIA: It means Action Control Register reading value. It can be applied to judge whether the interrupt flag or other instruction is operated completely.
- STA: It means Status register (STA) reading value. It is used to indicate current 12C circuit operation status.
- The following flowchart takes Fig 13-4 indicated "Grey Bottom Round Block", "White Bottom Round Block" and "Square Block" to indicate 12C interface status respectively:

Grey Bottom Round Block : It means interrupt flag has been set as 12C status. White Bottom Round Block : It means interrupt flag has not been set. It needs the MCU read the12C status actively.

Square Block : It means it needs the MCU issue instruction to 12C.

| Status with IRQ    |
|--------------------|
| Status without IRQ |
| Action             |

Fig 13-4 Flowchart Symbols

Embedded 18-Bit ΣΔADC



Fig 13-5 Master Transmitter Mode



Embedded 18-Bit ΣΔADC







Embedded 18-Bit ΣΔADC





Fig 13 -7 Slave Transmitter Mode

Embedded 18-Bit ΣΔADC





Fig 13-8 Slave Receiver Mode

Embedded 18-Bit ΣΔADC





Fig 13-9 General Call Mode



# 13.5. I2C Register Instructions

|         |                                                                                           |                 | "-"no use,"      | *"read/wr  | ite,"w"write,' | "r"read,"r0"o   | only read 0," | r1"only read | 1,"w0"only | write 0,"w1" | only write 1 |
|---------|-------------------------------------------------------------------------------------------|-----------------|------------------|------------|----------------|-----------------|---------------|--------------|------------|--------------|--------------|
|         | "\$"for event status,"."unimplemented bit,"x"unknown,"u"unchanged,"d"depends on condition |                 |                  |            |                |                 |               |              |            |              |              |
| Address | Name                                                                                      | Bit 7           | Bit 6            | Bit 5      | Bit 4          | Bit 3           | Bit 2         | Bit 1        | Bit 0      | ARST         | IRST         |
| 024h    | INTE2                                                                                     | -               | -                | -          | -              | I2CERIE         | I2CIE         | -            | -          | 0000 0000    | սսսս սսսս    |
| 027h    | INTF2                                                                                     | -               | -                | -          | -              | I2CERIF         | I2CIF         | -            | -          | 0000 0000    | นนนน นนนน    |
| 061h    | CFG                                                                                       |                 |                  | Rsv.       |                |                 | I2CRST        | ENI2CT       | ENI2C      |              | uuu          |
| 062h    | ACT                                                                                       | SLAVE           | -                | -          | I2CER          | START           | STOP          | I2CINT       | ACK        | 0000 0000    | սսսս սսսս    |
| 063h    | STA                                                                                       | MACTF           | SACTF            | RDBF       | RWF            | DFF             | ACKF          | GCF          | ARBF       | 0001 0000    | սսսս սսսս    |
| 064h    | CRG                                                                                       |                 |                  |            | CRG            | i[7:0]          |               |              |            | 0000 0000    | սսսս սսսս    |
| 065h    | TOC                                                                                       | I2CTF           |                  | DI2C[2:0]  |                |                 | I2CTI         | _T[3:0]      |            | 0000 0000    | սսսս սսսս    |
| 066h    | RDB                                                                                       | RDB[7:1] RDB[0] |                  |            |                |                 |               |              | RDB[0]     | XXXX XXXX    | սսսս սսսս    |
| 067h    | TDB0                                                                                      |                 | TDB0[7:1] TDB[0] |            |                |                 |               |              |            | XXXX XXXX    | นนนน นนนน    |
| 068h    | SID0                                                                                      |                 | SID[7:1],T       | he corresp | onding addre   | ss of the 7-bit | mode          |              | SIDV[0]    | 0000 0000    | սսսս սսսս    |

Fig 13-1 I2C Register

### INTE1/INTF1: See Chapter Interrupt.

### CFG: I2C Setting Register

GCRst: I2C General call reset enable control

- 1: Start
- 0: Close

Note: When the I2C Slave mode is turned on with the GCRst function at the same time, if the I2C Controller receives the General call ID 00h and the first data is "06h", the General Call Reset condition holds, The interrupt signal (Interrupt) that was originally sent to the local processor will be replaced by a reset signal, Providing an external host can reset functions of the machine via a chip I2C Bus.

ENI2CT: I2C Start Time-out Monitoring Function Bit

1: I2C Start Time-out Monitoring Function

0: Close

ENI2C: I2C Start Function Control Bit

- 1: Start I2C CI
- 0: Close

X Notes: When ENI2C is closed, it will close internal Clock of 12C, except Configuration Register can take writing motion. The rest registers cannot write data.



### **ACT: Action Register**

SLAVE: Slave Start Control

- 1: Start
- 0: Close
- I2CER: Error Interrupt Flag
  - 1: Occurred error interrupt
  - 0: Normal, 0 writing will eliminate error interrupt flag to enable 12C take next status execution.

### START: Start Order Bit

- 1: Produce Start Signal at I2C Bus
- 0: Normal
- STOP: Stop Order Bit
  - 1: Produce Start Signal at I2C Bus
  - 0: Normal
- I2CINT: Interrupt Flag
  - 1: Occurred 12C interrupt
  - 0: Normal, 0 writing will eliminate interrupt flag to enable 12C take next status execution.
- ACK: ACK(Acknowledge) Bit
  - 1: ACK Acknowledged
  - 0: Not Acknowledged ACK or Acknowledged NACK



### STA: I2C Status Register

- MACTF: Master Mode Active Flag
- 1: Started
- 0: Not Started
- SACTF: Slave Mode Active Flag
- 1: Started
- 0: Not Started
- RDBF: Received Stop/Repeat-Start Flag
  - 1: Received Stop/Repeat-Start Flag has been sent or received,
  - 0: Normal
- RWF: Read/Write State Flag)
  - 1: Read order has been sent or received,
  - 0: Write order has been sent or received,
- DFF: Data Field Flag
  - 1: I2C Data has been sent or received,
  - 0: Normal
- ACKF: Acknowledge Flag (ACK Flag)
  - 1: ACK has been sent or received,
  - 0: ACK has not been sent or received,
- GCF: General Call Flag
  - 1: Currently General Call Operation
  - 0: Normal
- ARBF: Arbitration Lost Flag
  - 1: Arbitration Lost
  - 0: Normal

### CRG: I2C Clock Control Register

CRG [7:0]: I2C Bus Data Baud Rate Control

Data transmission on I2C Bus is determined by clock signal on SCL pins, and the clock rate of SCL pin can be calculated by clock source frequency CPU\_CK and CRG according to the following formula:

Data Baud Rate(Hz) =  $\frac{I2C\_CK}{[4 \times (CRG[7:0]+1)]}$ 



### **TOC: I2C Time-out Control Register**

I2CTF: Time-out Flag

- 1: I2C Bus Clock Stretching Time-out
- 0: Normal

DI2C[2:0]: Time-out Clock Pre-scale

0: CLKPS = CPU\_CK / 1

1: CLKPS = CPU\_CK / 2

2: CLKPS = CPU\_CK / 4

3: CLKPS = CPU\_CK / 8

- 4: CLKPS = CPU\_CK / 16
- 5: CLKPS = CPU\_CK / 32
- 6: CLKPS = CPU\_CK / 64
- 7: CLKPS = CPU\_CK / 128

I2CTLT[3:0]: Time-out Limit : The occurrence of Time-out is triggered after CLKPS is counted I2CTLT + 1 times.

0: 1x CLKPS Cycle 1: 2x CLKPS Cycle 2: 3x CLKPS Cycle 3: 4x CLKPS Cycle ... 15: 16x CLKPS Cycle

### **RDB: Data Receiving Register**

RDB [7:1]: The content is receiving address (A7~A1) or data (D7~D1). RDB [0]: The content is receiving read/write order or data (D0).

#### **TDB0: Data Transition Register**

TDB0 [7:1]: The content is receiving address (A7~A1) or data (D7~D1).

TDB [0]: The content is receiving read/write order or data (D0).

X Notes : During communication process, when the machine belongs to non Address or Data transmission status, it must set the register as FFh, as Bit 7 of TDB0 is 0 and it may lock the SDA Bus at Low deadly.

#### SID0: Slave Mode ID Code Setting Register

SID[7:1]: Slave Mode ID Code (A7~A1)

SIDV[0]: Effective Control of Slave Mode ID Code

- 0: Invalid Slave Mode ID Code
- 1: Valid Slave Mode ID Code



# **14. REVISION RECORD**

Major differences are stated thereinafter:

| Date       | Version | Page  | Revision Summary                                      |
|------------|---------|-------|-------------------------------------------------------|
| 2013/08    | V03     | All   | First edition                                         |
| 2017/08/30 | V06     | 73    | 1. Added ADCR ΔVR_I Full Scale Note                   |
|            |         | ALL   | 2. Synchronize Chinese version                        |
|            |         | 52~64 | 3. Modify the description of the Chapter 9 TMB        |
| 2017/11/16 | V07     | 81~85 | Modify the description of the BIE and 16-bit hardware |
|            |         |       | look-up table                                         |
|            |         |       |                                                       |
|            |         |       |                                                       |
|            |         |       |                                                       |