# EM88F711N

# 8-Bit Microprocessor

# Product Specification

ELAN MICROELECTRONICS CORP. July 2017



**Trademark Acknowledgments:** IBM is a registered trademark and PS/2 is a trademark of IBM. Windows is a trademark of Microsoft Corporation. ELAN and ELAN logo *full* are trademarks of ELAN Microelectronics Corporation

# Copyright © 2017 by ELAN Microelectronics Corporation **All Rights Reserved**

Printed in Taiwan

The contents of this specification are subject to change without further notice. ELAN Microelectronics assumes no responsibility concerning the accuracy, adequacy, or completeness of this specification. ELAN Microelectronics makes no commitment to update, or to keep current the information and material contained in this specification. Such information and material may change to conform to each confirmed order.

In no event shall ELAN Microelectronics be made responsible for any claims attributed to errors, omissions, or other inaccuracies in the information or material contained in this specification. ELAN Microelectronics shall not be liable for direct, indirect, special incidental, or consequential damages arising from the use of such information or material.

The software (if any) described in this specification is furnished under a license or nondisclosure agreement, and may be used or copied only in accordance with the terms of such agreement.

ELAN Microelectronics products are not intended for use in life support appliances, devices, or systems. Use of ELAN Microelectronics product in such applications is not supported and is prohibited. NO PART OF THIS SPECIFICATION MAY BE REPRODUCED OR TRANSMITTED IN ANY FORM OR BY ANY MEANS WITHOUT THE EXPRESSED WRITTEN PERMISSION OF ELAN MICROELECTRONICS.



# ELAN MICROELECTRONICS CORPORATION

#### **Headquarters:**

No. 12, Innovation 1st Road Hsinchu Science Park Hsinchu, TAIWAN 30076 Tel: +886 3 563-9977 Fax:+886 3 563-9966 webmaster@emc.com.tw http://www.emc.com.tw

Hong Kong: Elan (HK) Microelectronics Corporation, Ltd. Flat A, 19F., World Tech Centre 95 How Ming Street, Kwun Tong Kowloon, HONG KONG Tel: +852 2723-3376 Fax:+852 2723-7780

#### Shenzhen:

#### Elan Microelectronics Shenzhen, Ltd.

8A Floor, Microprofit Building Gaoxin South Road 6 Shenzhen Hi-tech Industrial Park Zhangjiang Hi-Tech Park South Area, Shenzhen CHINA 518057 Tel: +86 755 2601-0565 Fax:+86 755 2601-0500 elan-sz@elanic.com.cn

USA:

Elan Information **Technology Group** (U.S.A.) PO Box 601 Cupertino, CA 95015 U.S.A. Tel: +1 408 366-8225 Fax:+1 408 366-8225

#### Shanghai:

#### **ELAN Microelectronics** Shanghai, Ltd.

6F, Ke Yuan Building No. 5 Bibo Road Shanghai, CHINA 201203 Tel: +86 21 5080-3866 Fax:+86 21 5080-0273 elan-sh@elanic.com.cn



| 1 | General De    | escription                                                         | 1  |
|---|---------------|--------------------------------------------------------------------|----|
| 2 | Features      |                                                                    | 1  |
| 3 | Pin Config    | uration (Package)                                                  | 2  |
|   |               |                                                                    |    |
| 4 | Pin Descrij   | otion                                                              | 3  |
| 5 | System Ov     | erview                                                             | 6  |
|   | 5.1 Memory    | Мар                                                                | 6  |
|   | 5.2 Block Dia | agram                                                              | 7  |
| 6 | Functional    | Description                                                        | 8  |
| Ŭ |               | ional Registers                                                    |    |
|   | 6.1.1         | R0 IAR (Indirect Addressing Register)                              |    |
|   | 6.1.2         | R1 BSR (Bank Selection Control Register)                           |    |
|   | 6.1.3         | R2 PCL (Program Counter Low)                                       |    |
|   | 6.1.4         | R3 SR (Status Register)                                            |    |
|   | 6.1.5         | R4 RSR (RAM Select Register)                                       |    |
|   | 6.1.6         | Bank 0 R5 ~ R8 Port 5 ~ Port 8                                     |    |
|   | 6.1.7         | Bank 0 RB~RC IOCR5 ~ IOCR6                                         |    |
|   | 6.1.8         | Bank 0 RE OMCR (Operating Mode Control Register)                   |    |
|   | 6.1.9         | Bank 0 RF EIESCR (External Interrupt Edge Select Control Register) |    |
|   | 6.1.10        | Bank 0 R10 WUCR1 (Wake-up Control Register 1)                      |    |
|   | 6.1.11        | Bank 0 R11 Reserved                                                | 18 |
|   | 6.1.12        | Bank 0 R12 WUCR3 (Wake-up Control Register 3)                      | 18 |
|   | 6.1.13        | Bank 0 R14 SFR1 (Status Flag Register 1)                           | 18 |
|   | 6.1.14        | Bank 0 R15 SFR2 (Status Flag Register 2)                           | 19 |
|   | 6.1.15        | Bank 0 R16 SFR3 (Status Flag Register 3)                           | 20 |
|   | 6.1.16        | Bank 0 R17 SFR4 (Status Flag Register 4)                           | 20 |
|   | 6.1.17        | Bank 0 R18 SFR5 (Status Flag Register 5)                           | 20 |
|   | 6.1.18        | Bank 0 R19 SFR6 (Status Flag Register 6)                           |    |
|   | 6.1.19        | Bank0 R1A: Reserved                                                | 21 |
|   | 6.1.20        | Bank 0 R1B IMR1 (Interrupt Mask Register 1)                        |    |
|   | 6.1.21        | Bank 0 R1C IMR2 (Interrupt Mask Register 2)                        |    |
|   | 6.1.22        | Bank 0 R1D IMR3 (Interrupt Mask Register 3)                        |    |
|   | 6.1.23        | Bank 0 R1E IMR4 (Interrupt Mask Register 4)                        |    |
|   | 6.1.24        | Bank 0 R1F IMR5 (Interrupt Mask Register 5)                        |    |
|   | 6.1.25        | Bank 0 R20 IMR6 (Interrupt Mask Register 6                         |    |
|   | 6.1.26        | Bank 0 R21 WDTCR (Watchdog Timer Control Register)                 |    |
|   | 6.1.27        | Bank 0 R24 TC1CR1 (Timer/Counter 1 Control Register 1)             |    |
|   | 6.1.28        | Bank 0 R25 TC1CR2 (Timer/Counter 1 Control Register 2)             |    |
|   | 6.1.29        | Bank 0 R26 TC1DA (Timer/Counter 1 Data Buffer A)                   | 27 |



| 6.1.30 | Bank 0 R27 TC1DB (Timer/Counter 1 Data Buffer B)                          | .27  |
|--------|---------------------------------------------------------------------------|------|
| 6.1.31 | Bank0 R28~3D: Reserved                                                    | .28  |
| 6.1.32 | Bank 0 R3E ADCR1 (Analog-to-Digital Converter Control Register 1)         | .28  |
| 6.1.33 | Bank 0 R3F ADCR2 (Analog-to-Digital Converter Control Register 2)         | .29  |
| 6.1.34 | Bank 0 R40 ADISR (Analog-to-Digital Converter Input Channel Select Regist |      |
| 6.1.35 | Bank 0 R41 ADER1 (Analog-to-Digital Converter Input Control Register 1)   | .31  |
| 6.1.36 | Bank 0 R42 Reserved                                                       | . 32 |
| 6.1.37 | Bank 0 R43 ADDL (Low Byte of Analog-to-Digital Converter Data)            | . 32 |
| 6.1.38 | Bank 0 R44 ADDH (High Byte of Analog-to-Digital Converter Data)           | . 32 |
| 6.1.39 | Bank 0 R45 ADCVL (Low Byte of Analog-to-Digital Converter Compare Value   |      |
| 6.1.40 | Bank 0 R46 ADCVH (High Byte of Analog-to-Digital Converter Compare Valu   |      |
| 6.1.41 | Bank 1 R5 IOCR8                                                           |      |
| 6.1.42 | Bank 1 R8 P5PHCR (Port 5 Pull-high Control Register)                      | .33  |
| 6.1.43 | Bank 1 R9 P6PHCR (Port 6 Pull-high Control Register)                      | .33  |
| 6.1.44 | Bank 1 RA Reserved                                                        | .34  |
| 6.1.45 | Bank 1 RB P5PLCR (Port 5 Pull-low Control Register)                       | .34  |
| 6.1.46 | Bank 1 RC P6PLCR (Port 6 Pull-low Control Register)                       | .34  |
| 6.1.47 | Bank 1 RD Reserved                                                        | .34  |
| 6.1.48 | Bank 1 RE P5HDSCR (Port 5 High Drive/Sink Control Register)               | .34  |
| 6.1.49 | Bank 1 RF P6HDSCR (Port 6 High Drive/Sink Control Register)               |      |
| 6.1.50 | Bank 1 R10 Reserved                                                       |      |
| 6.1.51 | Bank 1 R11 P5ODCR (Port 5 Open-drain Control Register)                    |      |
| 6.1.52 | Bank 1 R12 P6ODCR (Port 6 Open-drain Control Register)                    | . 35 |
| 6.1.53 | Bank 1 R13 Reserved                                                       |      |
| 6.1.54 | Bank 1 R14 DeadTCR (Dead Time Control Register)                           |      |
| 6.1.55 | Bank 1 R15 DeadTR (Dead Time Register)                                    |      |
| 6.1.56 | Bank 1 R16 PWMSCR (PWM Source Clock Control Register)                     |      |
| 6.1.57 | Bank 1 R17 PWMACR (PWMA Control Register)                                 |      |
| 6.1.58 | Bank 1 R18 PRDAL (Low byte of PWMA period)                                |      |
| 6.1.59 | Bank 1 R19 PRDAH (High byte of PWMA period)                               |      |
| 6.1.60 | Bank 1 R1A DTAL (Low byte of PMWA duty)                                   |      |
| 6.1.61 | Bank 1 R1B DTAH (High byte of PMWA duty)                                  |      |
| 6.1.62 | Bank 1 R1C TMRAL (Low byte of TimerA)                                     |      |
| 6.1.63 | Bank 1 R1D TMRAH (High byte of TimerA)                                    |      |
| 6.1.64 | Bank 1 R1E PWMBCR (PWMB Control Register)                                 |      |
| 6.1.65 | Bank 1 R1F PRDBL (Low byte of PWMB period)                                |      |
| 6.1.66 | Bank 1 R20 PRDBH (High byte of PWMB period)                               |      |
| 6.1.67 | Bank 1 R21 DTBL (Low byte of PMWB duty)                                   | .40  |
| 6.1.68 | Bank 1 R22 DTBH (High byte of PMWB duty)                                  |      |
| 6.1.69 | Bank 1 R23 TMRBL (Low byte of TimerB)                                     |      |
| 6.1.70 | Bank 1 R24 TMRBH (High byte of TimerB)                                    |      |
| 6.1.71 | Bank1 R25 ~ R32: (Reserved)                                               |      |
| 6.1.72 | Bank 1 R33 URCR (UART Control Register)                                   |      |
| 6.1.73 | Bank 1 R34 URS (UART Status Register)                                     |      |
|        | Product Specification (V1.0) 07.20.20                                     | )17  |

#### Contents

| $\sim$      |  |
|-------------|--|
| <b>ELAN</b> |  |
|             |  |
| Ŧ           |  |

|      | 6.1.74         | Bank 1 R35 URTD (UART Transmit Data Buffer Register)                   | 43 |
|------|----------------|------------------------------------------------------------------------|----|
|      | 6.1.75         | Bank 1 R36 URRDL (UART Receive Data Low Buffer Register)               | 43 |
|      | 6.1.76         | Bank 1 R37 URRDH (UART Receive Data High Buffer Register)              | 43 |
|      | 6.1.77         | Bank 1 R45 TBPTL (Table Pointer Low Register)                          | 43 |
|      | 6.1.78         | Bank 1 R46 TBPTH (Table Pointer High Register)                         | 43 |
|      | 6.1.79         | Bank 1 R47 STKMON (Stack Monitor)                                      | 44 |
|      | 6.1.80         | Bank 1 R48 PCH (Program Counter High)                                  | 44 |
|      | 6.1.81         | Bank 1 R49 HLVDCR (High/Low Voltage Detector Control Register)         | 44 |
|      | 6.1.82         | Bank 1 R4A~R4C: (Reserve)                                              | 45 |
|      | 6.1.83         | Bank 0 R50~R7F, Bank 0~3 R80~RFF                                       | 45 |
| 6.2  | WDT a          | nd Prescaler                                                           | 46 |
| 6.3  | I/O Por        | ts                                                                     | 47 |
| 6.4  | Reset a        | and Wake-up                                                            | 50 |
| •••• | 6.4.1          | Reset                                                                  |    |
|      | 6.4.2          | Status of RST, T, and P of the Status Register                         |    |
| 6.5  |                | ot                                                                     |    |
| 6.6  | •              | onverter                                                               |    |
| 0.0  | 6.6.1          | ADC Data Register                                                      |    |
|      | 6.6.2          | A/D Sampling Time                                                      |    |
|      | 6.6.3          | A/D Conversion Time                                                    |    |
|      | 6.6.4          | ADC Operation during Sleep Mode                                        |    |
|      | 6.6.5          | Programming Process/Considerations                                     |    |
|      | 6.6.6          |                                                                        |    |
|      | 6.6.7          | Programming Process for Detecting Internal VDD<br>Sample Demo Programs |    |
| 6.7  |                | Sample Demo Programs                                                   |    |
| 0.7  | 6.7.1          | Timer/Counter Mode                                                     |    |
|      | 6.7.1          |                                                                        |    |
|      | 6.7.2<br>6.7.3 | Window Mode                                                            |    |
|      |                | Programmable Divider Output Mode and Pulse Width Modulation Mode       |    |
|      | 6.7.4<br>6.7.5 | 5                                                                      |    |
| 0.0  |                | Buzzer Mode                                                            |    |
| 6.8  | ```            | Pulse Width Modulation)                                                |    |
|      | 6.8.1          |                                                                        |    |
|      | 6.8.2          | Increment Timer Counter (TMRX: TMRAH/TMRAL or TMRBH/TMRBL)             |    |
|      | 6.8.3          | PWM Time Period (PRDX: PRDAL/H or PRDBL/H)                             |    |
|      | 6.8.4          | PWM Duty Cycle (DTX: DTAH/DTAL or DTBH/DTBL)                           |    |
|      | 6.8.5          | Dual PWM function                                                      |    |
| ~ ~  | 6.8.6          | PWM Programming Process/Steps                                          |    |
| 6.9  |                | (Universal Asynchronous Receiver/Transmitter)                          |    |
|      |                | ART Mode                                                               |    |
|      |                | ransmitting                                                            |    |
|      |                | eceiving                                                               |    |
|      |                | aud Rate Generator                                                     |    |
|      |                |                                                                        |    |
| 6.10 | H LVD          | (High / Low Voltage Detector)                                          | 95 |

#### Contents



| 10 | Timi | ing Diagrams                                                                  | 115 |
|----|------|-------------------------------------------------------------------------------|-----|
| 9  | AC I | Electrical Characteristics                                                    | 114 |
|    | 8.4  | VREF Characteristics                                                          | 113 |
|    | 8.3  | 1/2VDD Characteristics                                                        | 112 |
|    | 8.2  | HLVD Characteristics                                                          | 112 |
|    | 8.1  | AD Converter Characteristics                                                  | 111 |
| 8  | DC I | Electrical Characteristics                                                    | 109 |
| 7  | Abs  | olute Maximum Ratings                                                         | 108 |
|    | 6.16 | Instruction Set                                                               | 106 |
|    |      | 6.15.5 Code Option Register (Word D)                                          |     |
|    |      | 6.15.4 Code Option Register (Word 3)                                          | 104 |
|    |      | 6.15.3 Code Option Register (Word 2)                                          | 103 |
|    |      | 6.15.2 Code Option Register (Word 1)                                          |     |
|    | 0.10 | 6.15.1 Code Option Register (Word 0)                                          |     |
|    |      | Code Option                                                                   |     |
|    |      | Residue-Voltage Protection                                                    |     |
|    |      | External Power-on Reset Circuit                                               |     |
|    | 6.12 | Power-on Considerations                                                       |     |
|    |      | 6.11.3 Internal RC Oscillator Mode                                            |     |
|    |      | 6.11.1Oscillator Modes<br>6.11.2 Crystal Oscillator/Ceramic Resonators (XTAL) |     |
|    | 6.11 |                                                                               |     |
|    | 0.44 |                                                                               | 07  |

# APPENDIX

| Α | Ordering and Manufacturing Information116 |     |  |  |  |  |
|---|-------------------------------------------|-----|--|--|--|--|
| В | Package Type                              | 117 |  |  |  |  |
| С | Package Information                       | 118 |  |  |  |  |
|   | C.1 EM88F711ND14                          | 118 |  |  |  |  |
|   | C.2 EM88F711NSO14                         |     |  |  |  |  |
|   | C.3 EM88F711NMS10                         | 120 |  |  |  |  |
|   | C.4 EM88F711ND8                           | 121 |  |  |  |  |
|   | C.5 EM88F711NSO8                          | 122 |  |  |  |  |
| D | Quality Assurance and Reliability         |     |  |  |  |  |
|   | D.1 Address Trap Detect                   |     |  |  |  |  |
| Е | ED712N & HVBRG & UBRG connection          |     |  |  |  |  |



# **Specification Revision History**

| Doc. Version | Revision Description     | Date       |
|--------------|--------------------------|------------|
| 1.0          | Initial released version | 2017/07/20 |



# **User Application Note**

(Before using this chip, take a look at the following description note, for it includes important messages.)

1. We strongly recommend that you place the following circuits on the reset pin, regardless of pin function. Its purpose is to prevent floating and burning when the high voltage backflush.



- 2. The value in the dead-time register must be less than the value in the duty cycle register in order to prevent unexpected behavior on both of the PWM outputs.
- 3. The PWM output will not be set, if the duty cycle is "0".
- During ADC conversion, do not perform output instruction to maintain pins' precision. In order to
  obtain accurate values, it is necessary to avoid any data transition on I/O pins during AD
  conversion.
- 5. Order of ADC Programming
  - Before setting the AD conversion pins (ADER1~2), the corresponding input channel (ADISR) and ADC power supply (ADP = 1) must be set.
  - > After the AD conversion is completed, turn off the AD conversion pin function (ADER1~2).
- 6. AD pins that are not data-converted must be set as high-impedance input pins.



# **1** General Description

The EM88F711N is an 8-bit microprocessor designed and developed with low-power, high-speed CMOS technology. It is used to simulate the kernel: 1K\*16-bit programmable ROM. This specification is used for 16-bit kernel simulation.

# 2 Features

#### CPU configuration

- Support 1K×16-bit program ROM
- (48+64) bytes general purpose register
- 8 level stacks for subroutine nesting
- Typically 1 μA during sleep mode
- 3 programmable Level Volt Reset LVR: 2.3V/ 2.5V, 3.3V/ 3.5V, 3.8V/ 4.0V
- 16 programmable Level Voltage Detectors HLVD: 2.2V, 2.3V, 2.4V, 2.5V, 2.6V, 2.8V, 2.9V, 3.1V, 3.3V, 3.5V, 3.7V, 3.9V, 4.1V, 4.3V, 4.5V, 4.7V
- Four CPU operation modes (Normal, Sleep, Green, Idle)
   I/O port configuration
  - 3 bidirectional I/O ports: P5, P6, P8
  - 3 programmable pin change wake-up ports: P5, P6, P8
  - 3 programmable pull-down I/O ports: P5, P6, P8
  - 3 programmable pull-high I/O ports: P5, P6, P8
  - 3 programmable open-drain I/O ports: P5, P6, P8
  - 3 programmable high-sink/drive I/O ports: P5, P6, P8
- 4 external interrupt pins
- Operating voltage range:
- 2.2V~5.5V at -40°C~85°C (industrial)
- Operating frequency range (based on 2 clocks): Main oscillator:
  - Crystal mode:
    - DC ~ 20MHz at 4V; DC ~ 16MHz at 3V; DC ~ 8MHz at 2.2V IRC mode:
    - DC ~ 20MHz at 4V; DC ~ 16MHz at 3V; DC ~ 8MHz at 2.2V

|                          |                              | Drift Rate(N | UWTR)   |       |
|--------------------------|------------------------------|--------------|---------|-------|
| Internal RC<br>Frequency | Temperature<br>(-40°C~+85°C) | •            | Process | Total |
| 1MHz                     | ±2%                          | ±1%          | ±1%     | ±4%   |
| 4MHz                     | ±2%                          | ±1%          | ±1%     | ±4%   |
| 8MHz                     | ±2%                          | ±1%          | ±1%     | ±4%   |
| 10MHz                    | ±2%                          | ±1%          | ±1%     | ±4%   |
| 12MHz                    | ±2%                          | ±1%          | ±1%     | ±4%   |
| 16MHz                    | ±2%                          | ±1%          | ±1%     | ±4%   |
| 20MHz                    | ±2%                          | ±1%          | ±1%     | ±4%   |

|                          | D                            | rift Rate (UW          | TR)     |       |
|--------------------------|------------------------------|------------------------|---------|-------|
| Internal RC<br>Frequency | Temperature<br>(-40°C~+85°C) | Voltage<br>(2.2V~5.5V) | Process | Total |
| 1MHz                     | ±2%                          | ±1%                    | ±2%     | ±5%   |
| 4MHz                     | ±2%                          | ±1%                    | ±2%     | ±5%   |
| 8MHz                     | ±2%                          | ±1%                    | ±2%     | ±5%   |
| 10MHz                    | ±2%                          | ±1%                    | ±2%     | ±5%   |
| 12MHz                    | ±2%                          | ±1%                    | ±2%     | ±5%   |
| 16MHz                    | ±2%                          | ±1%                    | ±2%     | ±5%   |
| 20MHz                    | ±2%                          | ±1%                    | ±2%     | ±5%   |

#### Sub-oscillator:

- IRC mode: 16k/128k
- Peripheral configuration
- 8+1 channels Analog-to-Digital Converter with 12-bit resolution + 1 internal reference for Vref+
- 8-bit timers (TC1) with six modes including Timer, Counter, window, buzzer, PWM and PDO (programmable divider output) mode, respectively.
- Two sets of complementary PWM, /PWM
- Universal asynchronous receiver/transmitter (UART) available
- Power-down (Sleep) mode
- High EFT immunity
- 14 available interrupts (4 external, 10 internal)
- 4 external interrupts
- Input-port status changed interrupt (wake up from sleep mode)
- HLVD interrupt
- Timer interrupt
- Two complementary PWMs
- ADC completion interrupt
- UART TX, RX, RX error interrupt
- Package Type:
  - 14 pin DIP 300mil : EM88F711ND14
  - 14 pin SOP 150mil : EM88F711NSO14
  - 10 pin MSOP 118mil : EM88F711NMS10
  - 8 pin DIP 300mil : EM88F711ND8
  - 8 pin SOP 150mil : EM88F711NSO8
- Note: These are Green Products which do not contain hazardous substances.
- 99.9% single instruction cycle commands



# **3** Pin Configuration (Package)

















# 4 Pin Description

Table 1 EM88F711N Pin Description

| Legend:    | ST: Schmitt Trigger input        | AN: Analog pin    |
|------------|----------------------------------|-------------------|
| CMOS: CMOS | output XTAL: Oscillation pin for | crystal/resonator |

| Name                | Function | Input<br>Type | Output<br>Type | Description                                                                                      |
|---------------------|----------|---------------|----------------|--------------------------------------------------------------------------------------------------|
| P50/OSCO            | P50      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| 1 00,0000           | OSCO     | -             | XTAL           | Clock output from crystal oscillator                                                             |
|                     | P51      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P51/OSCI/RCOUT      | OSCI     | XTAL          | -              | External clock crystal resonator oscillator input pin                                            |
|                     | RCOUT    | _             | CMOS           | Clock output of internal RC oscillator<br>Clock output of external RC oscillator (open-drain)    |
|                     | P52      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P52/AD0/INT2/2W-SDA | AD0      | AN            | -              | ADC Input 0                                                                                      |
|                     | INT2     | ST            | -              | External interrupt pin                                                                           |
|                     | (2W-SDA) | ST            | CMOS           | DATA pin for Writer programming                                                                  |
|                     | P53      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P53/AD1/INT1/2W-SCL | AD1      | AN            | -              | ADC Input 1                                                                                      |
|                     | INT1     | ST            | -              | External interrupt pin                                                                           |
|                     | (2W-SCL) | ST            | -              | CLOCK pin for Writer programming                                                                 |
|                     | P54      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
|                     | AD2      | AN            | -              | ADC Input 2                                                                                      |
| P54/AD2/TC1/INT0    | TC1      | ST            | CMOS           | Timer 1 input (Counter/Capture/Window)<br>Timer 1 output (PDO/PWM/Buzzer)                        |
|                     | INT0     | ST            | -              | External interrupt pin                                                                           |
|                     | P60      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P60/AD3/PWMAB//SS   | AD3      | AN            | -              | ADC Input 3                                                                                      |
|                     | PWMAB    | -             | CMOS           | PWMAB output                                                                                     |
|                     | P61      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P61/AD4/PWMA        | AD4      | AN            | -              | ADC Input 4                                                                                      |
|                     | PWMA     | _             | CMOS           | PWMA output                                                                                      |



#### (Continuation)

| Name              | Function | Input<br>Type | Output<br>Type | Description                                                                                      |
|-------------------|----------|---------------|----------------|--------------------------------------------------------------------------------------------------|
|                   | P62      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P62/AD5/UART_RX   | AD5      | AN            | -              | ADC Input 5                                                                                      |
|                   | ТХ       | ST            |                | UART TX input                                                                                    |
|                   | P63      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P63/INT3/UART_RX/ | INT3     | ST            | -              | External interrupt pin                                                                           |
| Vref              | RX       | ST            | _              | UART RX input                                                                                    |
|                   | Vref     | AN            |                | Voltage reference for ADC                                                                        |
|                   | P64      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P64/AD6/PWMB      | AD6      | AN            | -              | ADC Input 6                                                                                      |
|                   | PWMB     | -             | CMOS           | PWMB output                                                                                      |
|                   | P65      | ST            | CMOS           | Bidirectional I/O pin with programmable pull-down, pull-high, open-drain, and pin change wake-up |
| P65/AD7/PWMBB     | AD7      | AN            | _              | ADC Input 7                                                                                      |
|                   | PWMBB    | -             | CMOS           | PWMBB output                                                                                     |
| P81//Reset/       | P80      | ST            | CMOS           | Bidirectional I/O pin with programmable<br>It is open-drain                                      |
| (VPP)             | /RESET   | ST            | -              | Reset pin. It is open-drain                                                                      |
|                   | (VPP)    | Power         | -              | VPP pin for Writer programming                                                                   |
| VDD               | VDD      | Power         | _              | Power                                                                                            |
| (VDD)             | VDD      | Power         | _              | VDD for Writer programming                                                                       |
| VSS               | VSS      | Power         | _              | Ground                                                                                           |
| (VSS)             | VSS      | Power         | -              | VSS for Writer programming                                                                       |



| Din Eurotion   | l             | /O Status          | Pin Control |          |      |
|----------------|---------------|--------------------|-------------|----------|------|
| Pin Function   | I/O Direction | Pin Change WK/Int. | Pull High   | Pull Low | O.D. |
| General Input  | Input         | S/W                | S/W         | S/W      | S/W  |
| General Output | Output        | Disable            | S/W         | S/W      | S/W  |
| PWM            | Output        | Disable            | S/W         | S/W      | S/W  |
| TC-IN          | Input         | Disable            | S/W         | S/W      | S/W  |
| TC-OUT         | Output        | Disable            | S/W         | S/W      | S/W  |
| RSTB (VPP pin) | Input         | Disable            | -           | S/W      | S/W  |
| EX_INT         | Input         | Disable            | S/W         | S/W      | S/W  |
| UART-TX        | Output        | Disable            | S/W         | S/W      | S/W  |
| UART-RX        | Input         | Disable            | S/W         | S/W      | S/W  |
| AD             | Input         | Disable            | Disable     | Disable  | S/W  |
| OP/VO          | Input         | Disable            | Disable     | Disable  | S/W  |
| OSCI           | Input         | Disable            | Disable     | Disable  | S/W  |
| OSCO           | Input         | Disable            | Disable     | Disable  | S/W  |

Pin control condition repeat function starting capability

 $\text{Disable} \rightarrow \text{ forced to shut off}$ 

 $\mathsf{Enable} \to \mathsf{forced} \mathsf{ to open}$ 

S/W  $\rightarrow$  The initial value in the control register is set as "Disable".

Notes:

- 1. For non-I/O function, the Pin Change Wake-up/Interrupt function should be disabled.
- 2. Priority: INMODE PIN > Analog function > Digital Function > General I/O Function



#### 5 **System Overview**

# 5.1 Memory Map



# Registers and Data RAM Memory



#### Note:

1. Flash User Program Area is protected when power-down occurs, and will not be read, written and erased from the OCDS.



# 5.2 Block Diagram



Figure 5-2 Functional Block Diagram



# 6 Functional Description

# 6.1 Operational Registers

# 6.1.1 R0 IAR (Indirect Addressing Register)

R0 is not a physically implemented register. Its major function is to perform as an indirect addressing pointer. Any instruction using R0 as a pointer actually accesses data pointed by the RAM Select Register (R4).

# 6.1.2 R1 BSR (Bank Selection Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| -     | _     | -     | SBS0  | _     | -     | _     | GBS0  |
| _     | -     | Ι     | R/W   | Ι     | -     | Ι     | R/W   |

Bits 7~5: Not used, set to "0" all the time.

Bit 4 (SBS0): Special register bank select bit. It is used to select Bank 0/1 of Special Registers R5~R4F.

0: Bank 01: Bank 1

Bits 3~1: Not used, set to "0" all the time.

**Bit 0 (GBS0):** General register bank select bit. It is used to select Bank 0~15 of general registers **R80~RFF**.

0: Bank 0

1: Bank 1

# 6.1.3 R2 PCL (Program Counter Low)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PC7   | PC6   | PC5   | PC4   | PC3   | PC2   | PC1   | PC0   |
| R/W   |

Bits 7~0 (PC7~PC0): Low byte of program counter.

- Depending on device type, R2 and hardware stack are 16-bit wide. The structure is depicted in Figure 3.
- Generate 1K×16-bit on-chip Flash ROM addresses to the relative programming instruction codes. One program page is **2048** words long.
- R2 is set as all "0"s when under RESET condition.
- "JMP" instruction allows direct loading of the lower 12 program counter bits. Thus,
   "JMP" allows PC to go to any location within a page.



- "CALL" instruction loads the lower 12 bits of the PC, and the present PC value will add 1 and is pushed into the stack. Thus, the subroutine entry address can be located anywhere within a page.
- "LJMP" instruction allows direct loading of the lower 15 program counter bits. Therefore, "LJMP" allows PC to jump to any location within 1K (2<sup>10</sup>).
- "LCALL" instruction loads the lower 16 bits of the PC, and then PC+1 is pushed into the stack. Thus, the subroutine entry address can be located anywhere within 1K (2<sup>10</sup>).
- "RET" ("RETL k", "RETI") instruction loads the program counter with the contents of the top-level stack.
- "ADD R2, A" allows a relative address to be added to the current PC, and the ninth and above bits of the PC will increase progressively.
- "MOV R2, A" allows the loading of an address from the "A" register to the lower 8 bits of the PC, and the ninth and above bits of the PC will not be changed.
- Any instruction except "ADD R2,A" that is written to R2 (e.g., "MOV R2, A", "BC R2, 6", etc.) will cause the ninth and above bits (A8~A12) of the PC not to change.
- All instructions are single instruction cycle (Fsys/2) except "LCALL" and "LJMP" instructions which require two instructions cycles.

#### EM88F711N 8-Bit Microprocessor





Figure 6-1 Program Counter Organization



# Data Memory Configuration

| Address | Bank 0                                                     | Bank 1  |
|---------|------------------------------------------------------------|---------|
| 0X00    | IAR (Indirect Addressing Register)                         |         |
| 0X01    | BSR (Bank Select Control Register)                         |         |
| 0X02    | PC (Program Counter)                                       | -       |
| 0X03    | SR (Status Register)                                       |         |
| 0X04    | RSR (RAM Select Register)                                  |         |
| 0X05    | Port 5                                                     | IOCR8   |
| 0X06    | Port 6                                                     | Unused  |
| 0X07    | Unused                                                     | Unused  |
| 0X08    | Port 8                                                     | P5PHCR  |
| 0X09    | Unused                                                     | P6PHCR  |
| 0X0A    | Unused                                                     | Unused  |
| 0x0B    | IOCR5                                                      | P5PLCR  |
| 0X0C    | IOCR6                                                      | P6PLCR  |
| 0X0D    | Unused                                                     | Unused  |
| 0X0E    | OMCR (Operating Mode Control Reg.)                         | P5HDSCR |
| 0X0F    | EIESCR (External Interrupt Edge Selection<br>Control Reg.) | P6HDSCR |
| 0X10    | WUCR1P5                                                    | Unused  |
| 0X11    | Unused                                                     | P5ODCR  |
| 0X12    | WUCR3                                                      | P6ODCR  |
| 0X13    | Unused                                                     | Unused  |
| 0X14    | SFR1 (Status Flag Reg. 1)                                  | DeadTCR |
| 0X15    | SFR2 (Status Flag Reg. 2)                                  | DeadTR  |
| 0X16    | SFR3 (Status Flag Reg. 3)                                  | PWMSCR  |
| 0X17    | SFR4 (Status Flag Reg. 4)                                  | PWMACR  |
| 0X18    | SFR5 (Status Flag Reg. 5)                                  | PRDAL   |
| 0X19    | Unused                                                     | PRDAH   |
| 0X1A    | Unused                                                     | DTAL    |
| 0X1B    | IMR1 (Interrupt Mask Reg. 1)                               | DTAH    |
| 0X1C    | IMR2 (Interrupt Mask Reg. 2)                               | TMRAL   |
| 0X1D    | IMR3 (Interrupt Mask Reg. 3)                               | TMRAH   |
| 0X1E    | IMR4 (Interrupt Mask Reg. 4)                               | PWMBCR  |
| 0X1F    | IMR5 (Interrupt Mask Reg. 5)                               | PRDBL   |
| 0X20    | Unused                                                     | PRDBH   |
| 0X21    | WDTCR                                                      | DTBL    |



| Address | Bank 0 | Bank 1 |
|---------|--------|--------|
| 0X22    | Unused | DTBH   |
| 0X23    | Unused | TMRBL  |
| 0X24    | TC1CR1 | TMRBH  |
| 0X25    | TC1CR2 | Unused |
| 0X26    | TC1DA  | Unused |
| 0X27    | TC1DB  | Unused |
| 0X28    | Unused | Unused |
| 0X29    | Unused | Unused |
| 0X2A    | Unused | Unused |
| 0x2B    | Unused | Unused |
| 0X2C    | Unused | Unused |
| 0X2D    | Unused | Unused |
| 0X2E    | Unused | Unused |
| 0X2F    | Unused | Unused |
| 0X30    | Unused | Unused |
| 0X31    | Unused | Unused |
| 0X32    | Unused | Unused |
| 0X33    | Unused | URCR   |
| 0X34    | Unused | URS    |
| 0X35    | Unused | URTD   |
| 0X36    | Unused | URRDL  |
| 0X37    | Unused | URRDH  |
| 0X38    | Unused | Unused |
| 0X39    | Unused | Unused |
| 0X3A    | Unused | Unused |
| 0x3B    | Unused | Unused |
| 0X3C    | Unused | Unused |
| 0X3D    | Unused | Unused |
| 0X3E    | ADCR1  | Unused |
| 0X3F    | ADCR2  | Unused |
| 0X40    | ADISR  | Unused |
| 0X41    | ADER1  | Unused |
| 0X42    | Unused | Unused |
| 0X43    | ADDL   | Unused |



| Address | Bank 0       | Bank 1        |
|---------|--------------|---------------|
| 0X44    | ADDH         | Unused        |
| 0X45    | ADCVL        | Unused        |
| 0X46    | ADCVH        | Unused        |
| 0X47    | Unused       | STKMON        |
| 0X48    | Unused       | РСН           |
| 0X49    | Unused       | HLVDCR        |
| 0X4A    | Unused       | Unused        |
| 0x4B    | Unused       | Unused        |
| 0X4C    | Unused       | Unused        |
| 0X4D    | Unused       | Unused        |
| 0X4E    | Unused       | Unused        |
| 0X4F    | Unused       | Unused        |
| 0X50    |              |               |
| 0X51    |              |               |
| :       | General Purp | oose Register |
| :       |              |               |
| 0X7F    |              |               |
| 0X80    |              |               |
| 0X81    |              |               |
| :       | 0            | <del>~</del>  |
| :       | Bank 0       | Bank 1        |
| :       | Ď            | Ď             |
| 0XFE    |              |               |
| 0XFF    |              |               |

Figure 6-2 Data Memory Configuration



## 6.1.4 R3 SR (Status Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| INT   | Ν     | OV    | Т     | Р     | Z     | DC    | С     |
| F     | R/W   |

Bit 7 (INT): Interrupt Enable flag

0: Interrupt masked by DISI or hardware interrupt

1: Interrupt enabled by ENI/DISI instructions

Bit 6 (N): Negative flag

The negative flag stores the state of the most significant bit of the output result

0: The result of the operation is not negative

**1**: The result of the operation is negative

#### Bit 5 (OV): Overflow flag.

OV is set when a two-complement overflow occurs as a result of an operation

- 0: No overflow occurs
- 1: Overflow occurs
- Bit 4 (T): Time-out bit.

Set to 1 with the "SLEP" and "WDTC" commands, or during power-up and reset to "0" by WDT time-out.

Bit 3 (P): Power down bit.

Set to "1" during power-on or by a "WDTC" command and reset to "0" by a "SLEP" command.

Bit 2 (Z): Zero flag.

Set to "1" if the result of an arithmetic or logic operation is zero.

Bit 1 (DC): Auxiliary carry flag

Bit 0 (C): Carry flag

#### 6.1.5 R4 RSR (RAM Select Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| RSR7  | RSR6  | RSR5  | RSR4  | RSR3  | RSR2  | RSR1  | RSR0  |
| R/W   |

Bits 7~0 (RSR7~RSR0): These bits are used to select registers (Address: 00~FF) in indirect addressing mode. For more details, refer to Figure 6-2 *Data Memory Configuration*.



# 6.1.6 Bank 0 R5 ~ R8 Port 5 ~ Port 8

R5, R6 and R8 are I/O data registers.

# 6.1.7 Bank 0 RB~RC IOCR5 ~ IOCR6

These registers are used to control the I/O port direction. They are both readable and writable.

 $\ensuremath{\textbf{0}}$  : Put the relative I/O pin as output

1: Put the relative I/O pin into high impedance (input)

## 6.1.8 Bank 0 RE OMCR (Operating Mode Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| CPUS  | IDLE  | PERCS | IIPS  | FMSF  | RCM2  | RCM1  | RCM0  |
| R/W   | R/W   | R/W   | R/W   | R     | R/W   | R/W   | R/W   |

Bit 7 (CPUS): CPU Oscillator Source Select.

0: Fs: sub-oscillator

1: Fm: main-oscillator

When CPUS=0, the CPU oscillator selects the sub-oscillator and the main oscillator is stopped.

Bit 6 (IDLE): Idle Mode Enable Bit. This bit will determine as to which mode to go to or be activated after SLEP instruction.

**0:** "IDLE=0" + SLEP instruction  $\rightarrow$  sleep mode

- **1:** "IDLE=1" + SLEP instruction  $\rightarrow$  idle mode
- Bit 5 (PERCS): Periphery Clock Source for Green and Idle mode.
  - **0:** Periphery Clock Source is Fs. Fm will be Stop at Green and Idle mode. (default)
  - 1: Periphery Clock Source is Fm. Fm will be oscillation at Green and Idle mode.



Figure 1.CPU operation mode



#### Note

(\*) Switching Operation Mode from Idle  $\rightarrow$  Normal, Idle  $\rightarrow$  Green

If the clock source of the timer is Fs, the timer/counter will continue to count in Idle mode. When the matching condition of the timer/counter occurs during Idle mode, the interrupt flag of the timer/counter will be active. The MCU will jump to the interrupt vector when the corresponding interrupt is enabled.

#### HLFS=0 (Normal)

| Emoin                     | Four | Power-on                    | Pin-Reset / WDT       |                       |  |
|---------------------------|------|-----------------------------|-----------------------|-----------------------|--|
| Fmain                     | Fsub | LVR                         | N / G / I             | S                     |  |
| RC<br>1M, 4M<br>, 8M, 10M | RC   | 16ms + WSTO +<br>8*1/Fmain  | WSTO +<br>8*1/Fmain   | WSTO +<br>8*1/Fmain   |  |
| RC<br>12M,16M, 20M        | RC   | 16ms + WSTO<br>+16*1/Fmain  | WSTO +<br>16*1/Fmain  | WSTO +<br>16*1/Fmain  |  |
| ХТ                        | RC   | 16ms + WSTO<br>+510*1/Fmain | WSTO +<br>510*1/Fmain | WSTO +<br>510*1/Fmain |  |

#### HLFS=1 (Green)

| Emoin                                      | Foub | Power-on                   | Pin-Rese        | et / WDT        |
|--------------------------------------------|------|----------------------------|-----------------|-----------------|
| Fmain                                      | Fsub | LVR                        | N / G / I       | S               |
| RC<br>1M,4M,<br>,8M<br>10M,12M,<br>16M,20M | RC   | 16ms + WSTO + 1<br>*1/Fsub | WSTO + 1*1/Fsub | WSTO + 1*1/Fsub |
| ХТ                                         | RC   | 16ms + WSTO +<br>1*1/Fsub  | WSTO + 1*1/Fsub | WSTO + 1*1/Fsub |

| Fmain                     | Fsub | $G \rightarrow N$  | I → N                 | S → N                 |
|---------------------------|------|--------------------|-----------------------|-----------------------|
| RC<br>1M, 4M<br>, 8M, 10M | RC   | WSTO + 8*1/Fmain   | WSTO + 8*1/Fmain      | WSTO + 8*1/Fmain      |
| RC<br>12M,16M,20M         | RC   | WSTO + 16*1/Fmain  | WSTO +<br>16*1/Fmain  | WSTO +<br>16*1/Fmain  |
| ХТ                        | RC   | WSTO + 510*1/Fmain | WSTO +<br>510*1/Fmain | WSTO +<br>510*1/Fmain |

| Fmain | Fsub | I → G           | S → G           |
|-------|------|-----------------|-----------------|
| RC    | PC   | WSTO + 1*1/Fsub | WSTO + 1*1/Fsub |
| ХТ    | RC   |                 |                 |

N: Normal mode WSTO: Waiting Time from Start-to-Oscillation

G: Green mode I: Idle mode S: Sleep mode



- Bit 4 (IIPS): IRC Internal power switch bit. Used in mode change. (when IRC PSS is set to "1").
  - **0:** Internal power supply on, high power consumption but short starting time.
  - 1: Internal power off, low power consumption but long start-up time.

#### Bit 3 (FMSF): Fm Stable Flag bit.

**0:** Indicate that the frequency is unstable.

1: Indicate that the frequency has stabilized.

| RCM2 | RCM1 | RCM0 | Frequency (MHz) |
|------|------|------|-----------------|
| 0    | 0    | 0    | 4 (Default)     |
| 0    | 0    | 1    | 1               |
| 0    | 1    | 0    | 8               |
| 0    | 1    | 1    | 10              |
| 1    | 0    | 0    | 12              |
| 1    | 0    | 1    | 16              |
| 1    | 1    | 0    | 20              |
| 1    | 1    | 1    |                 |

Bits 2~0 (RCM2~RCM0): Internal RC mode select bits

| 6.1.9 | Bank 0 RF EIESCR (External Interrupt Edge Select Control |
|-------|----------------------------------------------------------|
|       | Register)                                                |

| Bit 7 | Bit 6 | Bit 5   | Bit 4   | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|---------|---------|--------|--------|--------|--------|
| _     | -     | EI32ES1 | EI32ES0 | EI1ES1 | EI1ES0 | EI0ES1 | EI0ES0 |
| _     | -     | R/W     | R/W     | R/W    | R/W    | R/W    | R/W    |

Bit 7~6: Not used, set to "0" all the time

Bit 5~0(ElxES1~0): External interrupt edge select bit

| ElxES1 | ElxES0 | Interrupt Edge Select              |
|--------|--------|------------------------------------|
| 0      | 0      | Falling edge interrupt             |
| 0      | 1      | Rising edge interrupt              |
| 1      | ×      | Falling and Rising edge interrupts |

## 6.1.10 Bank 0 R10 WUCR1 (Wake-up Control Register 1)

| Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-------|-------|--------|-------|--------|--------|-------|-------|
| -     | -     | HLVDWK | ADWK  | INTWK1 | INTWK0 | _     | -     |
| _     |       | R/W    | R/W   | R/W    | R/W    | -     | -     |

Bit 7~6: Not used, set to "0" all the time



#### Bit 5 (HLVDWK): High/Low Voltage Detect Wake-up Enable Bit

- 0: Disable High/Low Voltage Detect wake-up.
- 1: Enable High/Low Voltage Detect wake-up.
- Bit 4 (ADWK): A/D Converter Wake-up Function Enable Bit
  - 0: Disable AD converter wake-up
  - 1: Enable AD converter wake-up

When the AD Complete status is used to enter an interrupt vector or to wake up the IC from sleep/idle mode with AD conversion running, the ADWK bit must be set to "Enable".

Bits 3~2 (INTWK1~0): External Interrupt (INT pin) Wake-up Function Enable Bit

0: Disable external interrupt wake-up

1: Enable external interrupt wake-up

When the External Interrupt status change is used to enter an interrupt vector or to wake up the IC from sleep/idle mode, the INTWK bits must be set to "Enable".

Bits 1~0: Not used, set to "0" all the time

#### 6.1.11 Bank 0 R11 Reserved

#### 6.1.12 Bank 0 R12 WUCR3 (Wake-up Control Register 3)

| Bit 7  | Bit 6 | Bit 5  | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0   |
|--------|-------|--------|--------|-------|-------|-------|---------|
| ICWKP8 |       | ICWKP6 | ICWKP5 |       |       |       | INTWK32 |
| R/W    |       | R/W    | R/W    |       |       |       | R/W     |

Bits 7, 5~4 (ICWKP8,6~5): (Port 8, 6~5) Pin-change Wake-up Function Enable Bit

0: Disable pin change wake-up function

- 1: Enable pin change wake-up function
- Bit 6: Not used, set to "0" all the time

Bit 3~1: Not used, set to "0" all the time

Bits 0 (INTWK7~2): External Interrupt (INT pin) Wake-up Function Enable Bit

0: Disable external interrupt wake-up

1: Enable external interrupt wake-up

When the External Interrupt status change is used to enter an interrupt vector or to wake up the IC from sleep/idle mode, the INTWK bits must be set to "Enable".

| 6.1.13 Bank 0 R14 SFR1 (Status Flag Register |
|----------------------------------------------|
|----------------------------------------------|

| Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|--------|-------|-------|-------|-------|-------|
| -     | -     | HLVDSF | ADSF  | EXSF1 | EXSF0 | -     | —     |
| -     |       | F      | F     | F     | F     | 1     | —     |





Each corresponding status flag is set to "1" when interrupt condition is triggered. Bit 7~6: Not used, set to "0" all the time.

| HLVDEN | HLVDS3~0 | HLVD Voltage Interrupt Level | HLVDSF |
|--------|----------|------------------------------|--------|
| 1      | 1111     | 4.7V                         | 1*     |
| 1      |          |                              | 1*     |
| 1      |          |                              | 1*     |
| 1      | 0000     | 2.2V                         | 1*     |
| 0      | хххх     | NA                           | 0      |

Bit 5 (HLVDSF): High/Low Voltage Detector status flag

**Bit 4 (ADSF):** Status flag for Analog-to-Digital conversion. Set when AD conversion is completed, reset by software.

Bits 3~2 (EXSF1~0): External interrupt status flag.

Bit 1: Not used, set to "0" all the time

| NOTE                                                                                |
|-------------------------------------------------------------------------------------|
| If a function is enabled, the corresponding status flag would be active whether the |
| interrupt mask is enabled or not.                                                   |

#### 6.1.14 Bank 0 R15 SFR2 (Status Flag Register 2)

| Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0   |
|-------|-------|--------|-------|-------|-------|-------|---------|
| -     |       | UERRSF | URSF  | UTSF  |       |       | TC1DASF |
| _     | _     | F      | F     | F     |       |       | F       |

Each corresponding status flag is set to "1" when interrupt condition is triggered.

Bits 7~6: Not used, set to "0" all the time

- **Bit 5 (UERRSF):** UART error-receiving Status flag. This flag is cleared by software or when UART is disabled.
- Bit 4 (URSF): UART receive mode data buffer full Status flag. This flag is cleared by software.
- Bit 3 (UTSF): UART transmit mode data buffer empty flag. This flag is cleared by software.

Bits 2~1: Not used, set to "0" all the time

Bit 0 (TC1DASF): TC1DA matches Status flag. This flag is cleared by software.



# 6.1.15 Bank 0 R16 SFR3 (Status Flag Register 3)

| Bit 7 | , | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|-------|---|-------|-------|-------|---------|---------|---------|---------|
|       |   |       |       |       | PWMBPSF | PWMBDSF | PWMAPSF | PWMADSF |
|       |   |       | F     | F     | F       | F       | F       | F       |

Bits 7~4: Not used, set to "0" all the time

**Bit 3 (PWMBPSF):** Status flag of period-matching for PWMB (Pulse Width Modulation). Set when a selected period is reached, reset by software.

**Bit 2 (PWMBDSF):** Status flag of duty-matching for PWMB (Pulse Width Modulation). Set when a selected duty is reached, reset by software.

**Bit 1 (PWMAPSF):** Status flag of period-matching for PWMA (Pulse Width Modulation). Set when a selected period is reached, reset by software.

**Bit 0 (PWMADSF):** Status flag of duty-matching for PWMA (Pulse Width Modulation). Set when a selected duty is reached, reset by software.

| NOTE                                                                         |          |
|------------------------------------------------------------------------------|----------|
| If a function is enabled, the corresponding status flag would be active when | ther the |
| interrupt mask is enabled or not.                                            |          |

## 6.1.16 Bank 0 R17 SFR4 (Status Flag Register 4)

| Bit 7  | Bit 6 | Bit 5  | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|--------|--------|-------|-------|-------|-------|
| P8ICSF |       | P6ICSF | P5ICSF |       |       |       |       |
| F      |       | F      | F      |       |       |       |       |

Bit 7 (P8ICSF): Port 8 Status flag. This flag is cleared by software.

Bits 6: Not used, set to "0" all the time

Bit 5 (P6ICSF): Port 6 Status flag. This flag is cleared by software.

Bit 4 (P5ICSF): Port 5 Status flag. This Flag is cleared by software.

Bits 3~0: Not used, set to "0" all the time

If a function is enabled, the corresponding Status flag would be active whether the interrupt mask is enabled or not.

NOTE

#### 6.1.17 Bank 0 R18 SFR5 (Status Flag Register 5)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | EXSF3 | EXSF2 |
|       |       |       |       |       |       | F     | F     |



Each corresponding Status flag is set to "1" when interrupt condition is triggered.

Bits 7~2: Not used, set to "0" all the time

Bits 1~0 (EXSF3~2): External interrupt status flag.

**NOTE** If a function is enabled, the corresponding status flag would be active regardless whether the interrupt mask is enabled or not.

# 6.1.18 Bank 0 R19 SFR6 (Status Flag Register 6)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0   |
|-------|-------|-------|-------|-------|-------|-------|---------|
| SHSF  |       |       |       |       |       |       | TC1DBSF |
| F     |       |       |       |       |       |       | F       |

Each corresponding status flag is set to "1" when interrupt condition is triggered.

Bit 7 (SHSF): System hold status flag, set when system hold occurs, reset by software.

Bits 6~1: Not used, set to "0" all the time

Bit 0 (TC1DBSF): TC1DB matches status flag, cleared by software.

#### 6.1.19 Bank0 R1A: Reserved

#### 6.1.20 Bank 0 R1B IMR1 (Interrupt Mask Register 1)

| Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|--------|-------|-------|-------|-------|-------|
| _     | -     | HLVDIE | ADIE  | EXIE1 | EXIE0 | -     | -     |
| _     |       | R/W    | R/W   | R/W   | R/W   | Ι     | -     |

Bits 7~6: Not used, set to "0" all the time.

Bit 5 (HLVDIE): HLVDSF interrupt enable bit.

**0**: Disable HLVDSF interrupt

1: Enable HLVDSF interrupt

Bit 4 (ADIE): ADSF interrupt enable bit.

0: Disable ADSF interrupt

1: Enable ADSF interrupt

Bit 3 (EXIE1): EXSF1 interrupt enable bit and /INT1 function enable bit.

0: Disable EXSF1 interrupt

1: Enable EXSF1 interrupt



Bit 2 (EXIE0): EXSF0 interrupt enable bit and /INT0 function enable bit.

0: Disable EXSF0 interrupt

1: Enable EXSF0 interrupt

Bit 1~0: Not used, set to "0" all the time

NOTE

If the interrupt mask and instruction "ENI" are enabled, the program counter would jump into the corresponding interrupt vector when the corresponding status flag is set.

# 6.1.21 Bank 0 R1C IMR2 (Interrupt Mask Register 2)

| Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|--------|-------|-------|-------|-------|-------|
| -     | -     | UERRIE | URIE  | UTIE  | -     | -     | TC1IE |
| -     |       | R/W    | R/W   | R/W   |       |       | R/W   |

Bits 7~6: Not used, set to "0" all the time.

Bit 5 (UERRIE): UART error-receiving interrupt enable bit.

0: Disable UERRSF interrupt

1: Enable UERRSF interrupt

Bit 4 (URIE): UART receive mode Interrupt enable bit.

0: Disable URSF interrupt

1: Enable URSF interrupt

Bit 3 (UTIE): UART transmit mode interrupt enable bit.

0: Disable UTSF interrupt

- 1: Enable UTSF interrupt
- Bits 2~1: Not used, set to "0" all the time.

Bit 0 (TC1IE): Interrupt enable bit.

0: Disable TC1DASF and TC1DBSF interrupt

1: Enable TC1DASF and TC1DBSF interrupt

NOTE

If the interrupt mask and instruction "ENI" are enabled, the program counter would jump to the corresponding interrupt vector when the corresponding status flag is set.

#### 6.1.22 Bank 0 R1D IMR3 (Interrupt Mask Register 3)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|-------|-------|-------|-------|---------|---------|---------|---------|
|       |       |       |       | PWMBPIE | PWMBDIE | PWMAPIE | PWMADIE |
|       |       |       |       | R/W     | R/W     | R/W     | R/W     |



Bits 7~4: Not used, set to "0" all the time

Bit 3 (PWMBPIE): PWMBPSF interrupt enable bit.

- 0: Disable period-matching of PWMB interrupt
- 1: Enable period-matching of PWMB interrupt

Bit 2 (PWMBDIE): PWMBDSF interrupt enable bit.

- **0**: Disable duty-matching of PWMB interrupt
- 1: Enable duty-matching of PWMB interrupt
- Bit 1 (PWMAPIE): PWMAPSF interrupt enable bit.
  - 0: Disable period-matching of PWMA interrupt
  - 1: Enable period-matching of PWMA interrupt

Bit 0 (PWMADIE): PWMADSF interrupt enable bit.

0: Disable duty-matching of PWMA interrupt

1: Enable duty-matching of PWMA interrupt

**NOTE** If the interrupt mask and instruction "ENI" are enabled, the program counter would jump into corresponding interrupt vector when the corresponding status flag is set.

## 6.1.23 Bank 0 R1E IMR4 (Interrupt Mask Register 4)

| Bit 7  | Bit 6 | Bit 5  | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|--------|--------|-------|-------|-------|-------|
| P8ICIE |       | P6ICIE | P5ICIE |       |       |       |       |
| R/W    |       | R/W    | R/W    |       |       |       |       |

Bits 7 (P8ICIE): Port 8 pin-change Interrupt Enable bit.

0: Disable P8ICSF interrupt

1: Enable P8ICSF interrupt

Bits 6: Not used, set to "0" all the time

Bits 5~4 (P6ICIE ~P5ICIE): Ports 6~5 pin-change Interrupt Enable bit.

0: Disable P6ICSF ~ P5ICSF interrupt

**1:** Enable P6ICSF ~ P5ICSF interrupt

Bits 3~0: Not used, set to "0" all the time

NOTE

If the interrupt mask and instruction "ENI" are enabled, the program counter would jump to the corresponding interrupt vector when the corresponding status flag is set.



# 6.1.24 Bank 0 R1F IMR5 (Interrupt Mask Register 5)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | EXIE3 | EXIE2 |
|       |       |       |       |       |       | R/W   | R/W   |

Bits 7~2: Not used, set to "0" all the time

Bits 1~0 (EXIE3~2): EXSF3~2 interrupt enable bit.

0: Disable EXSF3~2 interrupt

#### 1: Enable EXSF3~2 interrupt

| INT Pin | Enable Condition | Edge              | Digital Noise Reject |
|---------|------------------|-------------------|----------------------|
| INTX    | EXIEX            | Rising or Falling | 8/Fc or 32/Fc        |

| NOTE                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ol> <li>The compound pin used as INT pin determines whether the interrupt<br/>mask is enabled or not.</li> </ol>                                                                                  |
| <ol><li>If the interrupt mask and instruction "ENI" are enabled, the program counter would<br/>jump to the corresponding interrupt vector when the corresponding Status flag is<br/>set.</li></ol> |

## 6.1.25 Bank 0 R20 IMR6 (Interrupt Mask Register 6

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| SHIE  |       |       |       |       |       |       |       |
| R/W   |       |       |       |       |       |       |       |

Bit 7 (SHIE): SHSF Interrupt Enable Bit.

0: Disable SHSF interrupt

1: Enable SHSF interrupt

Bits 6~0: Not used, set to "0" all the time.

#### 6.1.26 Bank 0 R21 WDTCR (Watchdog Timer Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| WDTE  | FSSF  | -     | -     | PSWE  | WPSR2 | WPSR1 | WPSR0 |
| R/W   | R     | _     | _     | R/W   | R/W   | R/W   | R/W   |

Bit 7 (WDTE): Watchdog Timer Enable Bit. WDTE is both readable and writable.

0: Disable WDT

1: Enable WDT



Bit 6 (FSSF): Fs Stable Flag bit

**0**: Indicate that the frequency is unstable.

1: Indicate that the frequency has stabilized.

Bits 5~4: Not used, set to "0" all the time.

Bit 3 (PSWE): Prescaler enable bit for WDT

**0:** Prescaler disable bit. WDT rate is 1:1

1: Prescaler enable bit. WDT rate is set at Bits 2~0.

Bits 2~0 (WPSR2~ WPSR 0): WDT Prescaler Bits

| WPSR2 | WPSR1 | WPSR0 | WDT Rate |
|-------|-------|-------|----------|
| 0     | 0     | 0     | 1:2      |
| 0     | 0     | 1     | 1:4      |
| 0     | 1     | 0     | 1:8      |
| 0     | 1     | 1     | 1:16     |
| 1     | 0     | 0     | 1:32     |
| 1     | 0     | 1     | 1:64     |
| 1     | 1     | 0     | 1:128    |
| 1     | 1     | 1     | 1:256    |

| 6.1.27 | Bank 0 R24 TC1CR1 | (Timer/Counter 1 | Control Register 1) |
|--------|-------------------|------------------|---------------------|
|--------|-------------------|------------------|---------------------|

| Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|--------|-------|-------|--------|--------|--------|
| TC1S  | TC1RC | TC1SS1 |       | TC1FF | TC10MS | TC1IS1 | TC1IS0 |
| R/W   | R/W   | R/W    |       | R/W   | R/W    | R/W    | R/W    |

Bit 7 (TC1S): Timer/Counter 1 start control (main switch for all modes)

**0:** Stop and clear the counter (default)

1: Start Timer/Counter 1

Bit 6 (TC1RC): Timer 1 Read Control Bit

- 0: When this bit is set to "0", data from TC1DB cannot be read (default).
- **1:** When this bit is set to "1", data is read from TC1DB. The read data is the enumerated counting number.
- Bit 5 (TC1SS1): Timer/Counter 1 clock source select Bit 1
  - 0: Select internal clock as counting source (Fc) Fs/Fm (default)
  - **1:** Select external TC1 pin as counting source (Fc). It is used only for timer/counter mode.

Bits 4: Not used, set to "0" all the time.



Bit 3 (TC1FF): Inversion for Timer/Counter 1 as PWM or PDO mode

0: Duty is Logic 1 (default)

1: Duty is Logic 0

#### Bit 2 (TC1OMS): Timer Output Mode Select Bit

0: Repeating mode (default)

1: One-shot mode

| NOTE                                               |  |
|----------------------------------------------------|--|
| One-shot mode means the timer only counts a cycle. |  |

Bits 1~0 (TC1IS1~ TC1IS0): Timer 1 Interrupt Type Select Bits. These two bits are used when the Timer operates in Capture and PWM modes.

| TC1IS1 | TC1IS0 | Timer 1 Interrupt Type Select |  |  |  |  |  |
|--------|--------|-------------------------------|--|--|--|--|--|
| 0      | 0      | TC1DA (period) matching       |  |  |  |  |  |
| 0      | 1      | TC1DB (duty) matching         |  |  |  |  |  |
| 1      | ×      | TC1DA and TC1DB matching      |  |  |  |  |  |

## 6.1.28 Bank 0 R25 TC1CR2 (Timer/Counter 1 Control Register 2)

| Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|--------|--------|--------|--------|--------|
| TC1M2 | TC1M1 | TC1M0 | TC1SS0 | TC1CK3 | TC1CK2 | TC1CK1 | TC1CK0 |
| R/W   | R/W   | R/W   | R/W    | R/W    | R/W    | R/W    | R/W    |

#### Bits 7~5 (TC1M2~TC1M0): Timer/Counter 1 operation mode select.

| TC1M2 | TC1M1 | TC1M0 | Operating Mode Select                                                                        |  |  |  |  |  |
|-------|-------|-------|----------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0     | 0     | 0     | Timer/Counter Rising Edge                                                                    |  |  |  |  |  |
| 0     | 0     | 1     | Timer/Counter Falling Edge                                                                   |  |  |  |  |  |
| 0     | 1     | 0     | Capture Mode Rising Edge                                                                     |  |  |  |  |  |
| 0     | 1     | 1     | Capture Mode Falling Edge                                                                    |  |  |  |  |  |
| 1     | 0     | 0     | Window mode                                                                                  |  |  |  |  |  |
| 1     | 0     | 1     | Programmable Divider output                                                                  |  |  |  |  |  |
| 1     | 1     | 0     | Pulse Width Modulation output                                                                |  |  |  |  |  |
| 1     | 1     | 1     | Buzzer (output timer/counter clock source. The duty cycle of the clock source must be 50/50) |  |  |  |  |  |

fBit 4 (TC1SS0): Timer/Counter 1 clock source select bit

0: Fs is used as counting source (Fc) (default)

1: Fm is used as counting source (Fc)



| тсзскз | TC3CK2 | TC3CK1 | тсзско | Clock<br>Source    | Resolution<br>8 MHz | Max. Time<br>8 MHz | Resolution<br>16kHz | Max. Time<br>16kHz |
|--------|--------|--------|--------|--------------------|---------------------|--------------------|---------------------|--------------------|
|        |        |        |        | Normal             | Fc=8M               | Fc=8M              | F <sub>c</sub> =16K | Fc=16K             |
| 0      | 0      | 0      | 0      | Fc                 | 125ns               | 32 µs              | 62.5 µs             | 16ms               |
| 0      | 0      | 0      | 1      | F <sub>c</sub> /2  | 250ns               | 64 µs              | 125 µs              | 32ms               |
| 0      | 0      | 1      | 0      | Fc/2 <sup>2</sup>  | 500ns               | 128 µs             | 250 µs              | 64ms               |
| 0      | 0      | 1      | 1      | Fc/2 <sup>3</sup>  | 1 µs                | 256 µs             | 500 µs              | 128ms              |
| 0      | 1      | 0      | 0      | Fc/2 <sup>4</sup>  | 2 µs                | 512 µs             | 1ms                 | 256ms              |
| 0      | 1      | 0      | 1      | Fc/2 <sup>5</sup>  | 4 µs                | 1024 µs            | 2ms                 | 512ms              |
| 0      | 1      | 1      | 0      | Fc/2 <sup>6</sup>  | 8 µs                | 2048 µs            | 4ms                 | 1024ms             |
| 0      | 1      | 1      | 1      | Fc/2 <sup>7</sup>  | 16 µs               | 4096 µs            | 8ms                 | 2048ms             |
| 1      | 0      | 0      | 0      | Fc/2 <sup>8</sup>  | 32 µs               | 8192 µs            | 16ms                | 4096ms             |
| 1      | 0      | 0      | 1      | Fc/2 <sup>9</sup>  | 64 µs               | 16384 µs           | 32ms                | 8192ms             |
| 1      | 0      | 1      | 0      | Fc/2 <sup>10</sup> | 128 µs              | 32768 µs           | 64ms                | 16384ms            |
| 1      | 0      | 1      | 1      | Fc/2 <sup>11</sup> | 256 µs              | 65536 µs           | 128ms               | 32768ms            |
| 1      | 1      | 0      | 0      | Fc/2 <sup>12</sup> | 512 µs              | 131072 µs          | 256ms               | 65536ms            |
| 1      | 1      | 0      | 1      | Fc/2 <sup>13</sup> | 1.024ms             | 262144 µs          | 512ms               | 131072ms           |
| 1      | 1      | 1      | 0      | Fc/2 <sup>14</sup> | 2.048ms             | 524.288ms          | 1.024s              | 262144ms           |
| 1      | 1      | 1      | 1      | Fc/2 <sup>15</sup> | 4.096ms             | 1.048s             | 2.048s              | 524288ms           |

Bits 3~0 (TC1CK3~TC1CK0): Timer/Counter 1 clock source prescaler select

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| TC1DA7 | TC1DA6 | TC1DA5 | TC1DA4 | TC1DA3 | TC1DA2 | TC1DA1 | TC1DA0 |
| R/W    |

Bits 7~0 (TC1DA7~0): Data Buffer A of 8-bit Timer/Counter 1

6.1.30 Bank 0 R27 TC1DB (Timer/Counter 1 Data Buffer B)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| TC1DB7 | TC1DB6 | TC1DB5 | TC1DB4 | TC1DB3 | TC1DB2 | TC1DB1 | TC1DB0 |
| R/W    |

Bits 7~0 (TC1DB7~0): Data Buffer B of 8-bit Timer/Counter 1



#### NOTE

- When Timer/Counter x is used in PWM mode, the duty value stored at register TCxDB must be less than or equal to the period value stored at register TCxDA, i.e., duty ≤ period. Then the PWM waveform is generated. If the duty is greater than the period, the PWM output waveform is kept at a high voltage level.
- 2. The period value set by users is extra plus 1 in inner circuit. For example:

When the period value is set as 0x4F, the PWM waveform will actually generate 0x50 period length.

When the period value is set as 0xFF, the PWM waveform will actually generate 0x100 period length.

## 6.1.31 Bank0 R28~3D: Reserved

# 6.1.32 Bank 0 R3E ADCR1 (Analog-to-Digital Converter Control Register 1)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| CKR2  | CKR1  | CKR0  | ADRUN | ADP   | ADOM  | SHS1  | SHS0  |
| R/W   |

#### Bits 7~5 (CKR2~0): Clock Rate Select of ADC

| System<br>Mode | CKR2~0 | Operating Clock of ADC ( $F_{AD} = 1 / T_{AD}$ ) | Max. F <sub>Main</sub><br>(V <sub>DD</sub> = 2.5V ~ 3V) | Max. F <sub>Main</sub><br>(V <sub>DD</sub> = 3V ~ 5.5V) |  |
|----------------|--------|--------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------|--|
|                | 000    | F <sub>Main</sub> /16                            | 8 MHz                                                   | 16 MHz                                                  |  |
|                | 001    | F <sub>Main</sub> /8                             | 4 MHz                                                   | 16 MHz                                                  |  |
|                | 010    | F <sub>Main</sub> /4                             | 2 MHz                                                   | 8 MHz                                                   |  |
| Normal         | 011    | F <sub>Main</sub> /2                             | 1 MHz                                                   | 4 MHz                                                   |  |
| Mode           | 100    | F <sub>Main</sub> /64                            | 16 MHz                                                  | 16 MHz                                                  |  |
|                | 101    | F <sub>Main</sub> /32                            | 16 MHz                                                  | 16 MHz                                                  |  |
|                | 110    | F <sub>Main</sub> /1                             | 500kHz                                                  | 2 MHz                                                   |  |
|                | 111    | F <sub>Sub</sub>                                 | Fs                                                      | Fs                                                      |  |
| Green<br>Mode  | ххх    | Fsub                                             | Fs                                                      | Fs                                                      |  |

Bit 4 (ADRUN): ADC Starts to Run

#### In Single mode:

- **0:** Reset by hardware upon completing of the conversion, this bit cannot be reset by software.
- 1: A/D conversion starts. This bit can be set by software.

#### In Continuous mode:

- 0: ADC is stopped
- 1: ADC is running unless this bit is reset by software



## Bit 3 (ADP): ADC Power

**0:** ADC is in power-down mode.

- **1:** ADC is operating normally.
- Bit 2 (ADOM): ADC Operation Mode Select
  - **0:** ADC operates in single mode.
  - **1:** ADC operates in continuous mode.

## **Bits 1~0 (SHS1~0):** Sample and Hold Timing Select (Recommend at least 4 μs, T<sub>AD</sub>: Period of ADC Operating Clock)

| SHS1~0 | Sample and Hold Timing |
|--------|------------------------|
| 00     | 2 x T <sub>AD</sub>    |
| 01     | 4 x T <sub>AD</sub>    |
| 10     | 8 x T <sub>AD</sub>    |
| 11     | 12 x T <sub>AD</sub>   |

# 6.1.33 Bank 0 R3F ADCR2 (Analog-to-Digital Converter Control Register 2)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| -     | VPIS2 | ADIM  | ADCMS | VPIS1 | VPIS0 | VREFP | VREFN |
| -     | R/W   |

Bit 7: Not used, set to "0" all the time.

#### Bit 5 (ADIM): ADC Interrupt Mode

- **0:** Normal mode. Interrupt occurred after AD conversion is completed.
- 1: Compare mode. Interrupt occurred when the result the comparison conforms to the setting of ADCMS bits. Continuous mode is recommended.
- Bit 4 (ADCMS): ADC Compare Mode Select.

#### Compare mode:

- 0: Interrupt occurs when AD conversion data is equal to or greater than the data in ADCD register (which means when ADD ≥ ADCD, interrupt occurs).
- Interrupt occurs when AD conversion data is equal to or less than the data in ADCD register (which means when ADD ≤ ADCD, interrupt occurs).

#### Normal mode: No effect

#### Bits 6, 3 ~ 2 (VPIS2~0): Internal Positive Reference Voltage Select.



| VPIS2 | VPIS1 | VPIS0 | Reference Voltage |
|-------|-------|-------|-------------------|
| 0     | 0     | 0     | AVDD              |
| 0     | 0     | 1     | 4.096 V           |
| 0     | 1     | 0     | 3.072 V           |
| 0     | 1     | 1     | 2.048 V           |
| 1     | 0     | 0     | 2.56 V            |
| 1     | 0     | 1     | 2.56 V            |
| 1     | 1     | 0     | 2.56 V            |
| 1     | 1     | 1     | 2.56 V            |

Bit 1 (VREFP): Positive Reference Voltage Select

- **0:** Internal positive reference voltage. The actual voltage is set by VPIS1~0 bits.
- 1: From VREF pin.

Bit 0 (VREFN): Negative Reference Voltage Select

0: Common ground with internal reference voltage.

#### 1: Common ground with VREF pin.

| NOTE                                                                                                                                                                                                     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ol> <li>When using the internal voltage reference and the Code Option Word 2&lt;6&gt;<br/>(IRCIRS) is set to "1", users need to wait for at least 50 μs when the first time to</li> </ol>               |
| enable and stabilize the voltage reference. Un-stabilized reference yields inaccurate conversion result. After that, users only need to wait for 6 μs (the least) whenever switching voltage references. |
| 2 When using the internal valtage reference and the Code Option Word 2-6                                                                                                                                 |

 When using the internal voltage reference and the Code Option Word 2<6> (IRCIRS) is set to "0", users only need to wait for at least 6 µs for the internal voltage reference circuit to stabilize whenever switching voltage references.

## 6.1.34 Bank 0 R40 ADISR (Analog-to-Digital Converter Input Channel Select Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| -     | -     | -     | ADIS4 | ADIS3 | ADIS2 | ADIS1 | ADIS0 |
| -     | -     | -     | R/W   | R/W   | R/W   | R/W   | R/W   |

Bits 7~5: Not used, set to "0" all the time.

Bits 4~0 (ADIS4~0): ADC input channel select bits



| ADIS4~0 | Selected Channel | ADIS4~0 | Selected Channel     |
|---------|------------------|---------|----------------------|
| 00000   | AD0              | *10000  | 1/2 VDD Power Detect |
| 00001   | AD1              | 10001   | N/A                  |
| 00010   | AD2              | 10010   | N/A                  |
| 00011   | AD3              | 10011   | N/A                  |
| 00100   | AD4              | 10100   | N/A                  |
| 00101   | AD5              | 10101   | N/A                  |
| 00110   | AD6              | 10110   | N/A                  |
| 00111   | AD7              | 10111   | N/A                  |
| 01000   | N/A              | 11000   | N/A                  |
| 01001   | N/A              | 11001   | N/A                  |
| 01010   | N/A              | 11010   | N/A                  |
| 01011   | N/A              | 11011   | N/A                  |
| 01100   | N/A              | 11100   | N/A                  |
| 01101   | N/A              | 11101   | N/A                  |
| 01110   | N/A              | 11110   | N/A                  |
| 01111   | N/A              | 11111   | N/A                  |

\* Used for internal signal source. Users only need to set ADIS4~0=10000. These AD input channels are instantly active.

## 6.1.35 Bank 0 R41 ADER1 (Analog-to-Digital Converter Input Control Register 1)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| ADE7  | ADE6  | ADE5  | ADE4  | ADE3  | ADE2  | ADE1  | ADE0  |
| R/W   |

Bit 7 (ADE7): AD converter enable bit of P65 pin.

0: Disable ADC7, P65 acts as I/O pin

1: Enable ADC7 to act as analog input pin

Bit 6 (ADE6): AD converter enable bit of P64 pin.

0: Disable ADC6, P64 acts as I/O pin

1: Enable ADC6 to act as analog input pin

Bit 5 (ADE5): AD converter enable bit of P62 pin.

0: Disable ADC5, P62 acts as I/O pin

1: Enable ADC5 to act as analog input pin

Bit 4 (ADE4): AD converter enable bit of P61 pin.

**0**: Disable ADC4, P61 acts as I/O pin

1: Enable ADC4 to act as analog input pin



Bit 3 (ADE3): AD converter enable bit of P60 pin.

**0**: Disable ADC3, P60 acts as I/O pin

1: Enable ADC3 to act as analog input pin.

Bit 2 (ADE2): AD converter enable bit of P54 pin.

0: Disable ADC2, P54 acts as I/O pin

1: Enable ADC2 to act as analog input pin

Bit 1 (ADE1): AD converter enable bit of P53 pin.

0: Disable ADC1, P53 acts as I/O pin

1: Enable ADC1 to act as analog input pin

Bit 0 (ADE0): AD converter enable bit of P52 pin.

0: Disable ADC0, P52 acts as I/O pin

1: Enable ADC0 to act as analog input pin

#### 6.1.36 Bank 0 R42 Reserved

# 6.1.37 Bank 0 R43 ADDL (Low Byte of Analog-to-Digital Converter Data)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| ADD7  | ADD6  | ADD5  | ADD4  | ADD3  | ADD2  | ADD1  | ADD0  |
| R     | R     | R     | R     | R     | R     | R     | R     |

Bits 7~0 (ADD7~ ADD0): Low Byte of AD Data Buffer

# 6.1.38 Bank 0 R44 ADDH (High Byte of Analog-to-Digital Converter Data)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| ADD15 | ADD14 | ADD13 | ADD12 | ADD11 | ADD10 | ADD9  | ADD8  |
| R     | R     | R     | R     | R     | R     | R     | R     |

Bits 7~0 (ADD15~ ADD8): High Byte of AD Data Buffer.

The format of AD data is dependent on Code Option ADFM. The following table shows how the data justify different ADFM settings.

| ļ       | ADFM1~0 |      | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | 0       | ADDH | -     | -     | -     | -     | ADD11 | ADD10 | ADD9  | ADD8  |
| 401.1   | 0       | ADDL | ADD7  | ADD6  | ADD5  | ADD4  | ADD3  | ADD2  | ADD1  | ADD0  |
| 12 bits | 1       | ADDH | ADD11 | ADD10 | ADD9  | ADD8  | ADD7  | ADD6  | ADD5  | ADD4  |
|         |         | ADDL | -     | -     | -     | -     | ADD3  | ADD2  | ADD1  | ADD0  |



## 6.1.39 Bank 0 R45 ADCVL (Low Byte of Analog-to-Digital Converter Compare Value)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| ADCD7 | ADCD6 | ADCD5 | ADCD4 | ADCD3 | ADCD2 | ADCD1 | ADCD0 |
| R/W   |

Bits 7~0 (ADCD7~0): Low Byte Data for AD Comparison.

User should use the data format as with ADDH and ADDL registers. Otherwise, incorrect values will yield after AD comparison.

# 6.1.40 Bank 0 R46 ADCVH (High Byte of Analog-to-Digital Converter Compare Value)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|--------|--------|--------|--------|--------|--------|-------|-------|
| ADCD15 | ADCD14 | ADCD13 | ADCD12 | ADCD11 | ADCD10 | ADCD9 | ADCD8 |
| R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   |

Bits 7~0 (ADCD15~8): High Byte Data for AD Comparison

User should use the data format as with ADDH and ADDL registers. Otherwise, incorrect values will yield after AD comparison.

## 6.1.41 Bank 1 R5 IOCR8

These registers are used to control I/O port direction. They are both readable and writable.

0: Put the relative I/O pin as output

1: Put the relative I/O pin into high impedance

## 6.1.42 Bank 1 R8 P5PHCR (Port 5 Pull-high Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PH57  | PH56  | PH55  | PH54  | PH53  | PH52  | PH51  | PH50  |
| R/W   |

Bits 7~0 (PH57~PH50): Control bit used to enable pull-high of the P57~P50 pins

0: Enable internal pull-high

1: Disable internal pull-high

## 6.1.43 Bank 1 R9 P6PHCR (Port 6 Pull-high Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PH67  | PH66  | PH65  | PH64  | PH63  | PH62  | PH61  | PH60  |
| R/W   |



## Bits 7~0 (PH67~PH60): Control bit used to enable pull-high of the P67~P60 pins

- 0: Enable internal pull-high
- 1: Disable internal pull-high

## 6.1.44 Bank 1 RA Reserved

## 6.1.45 Bank 1 RB P5PLCR (Port 5 Pull-low Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PL57  | PL56  | PL55  | PL54  | PL53  | PL52  | PL51  | PL50  |
| R/W   |

Bits 7~0 (PL57~PL50): Control bit used to enable pull-low of P57~P50 pins

0: Enable internal pull-low

**1:** Disable internal pull-low

#### 6.1.46 Bank 1 RC P6PLCR (Port 6 Pull-low Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PL67  | PL66  | PL65  | PL64  | PL63  | PL62  | PL61  | PL60  |
| R/W   |

Bits 7~0 (PL67~PL60): Control bit used to enable pull-low of P67~P60 pins

0: Enable internal pull-low

1: Disable internal pull-low

#### 6.1.47 Bank 1 RD Reserved

#### 6.1.48 Bank 1 RE P5HDSCR (Port 5 High Drive/Sink Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| H57   | H56   | H55   | H54   | H53   | H52   | H51   | H50   |
| R/W   |

Bits 7~0 (H57~H50): P57~P50 high drive/sink current control bits

0: Enable high drive/sink

1: Disable high drive/sink



## 6.1.49 Bank 1 RF P6HDSCR (Port 6 High Drive/Sink Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| H67   | H66   | H65   | H64   | H63   | H62   | H61   | H60   |
| R/W   |

Bits 7~0 (H67~H60): P67~P60 high drive/sink current control bits

0: Enable high drive/sink

1: Disable high drive/sink

#### 6.1.50 Bank 1 R10 Reserved

#### 6.1.51 Bank 1 R11 P5ODCR (Port 5 Open-drain Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| OD57  | OD56  | OD55  | OD54  | OD53  | OD52  | OD51  | OD50  |
| R/W   |

#### Bits 7~0 (OD57~OD50): P57~P50 Open-drain control bits

0: Disable open-drain function

1: Enable open-drain function

## 6.1.52 Bank 1 R12 P6ODCR (Port 6 Open-drain Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| OD67  | OD66  | OD65  | OD64  | OD63  | OD62  | OD61  | OD60  |
| R/W   |

#### Bits 7~0 (OD67~OD60): P67~P60 Open-drain control bits

0: Disable open-drain function

1: Enable open-drain function

#### 6.1.53 Bank 1 R13 Reserved

#### 6.1.54 Bank 1 R14 DeadTCR (Dead Time Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|-------|-------|-------|-------|---------|---------|---------|---------|
|       |       |       |       | DEADTBE | DEADTAE | DEADTP1 | DEADTP0 |
|       |       |       |       | R/W     | R/W     | R/W     | R/W     |

Bits 7~4: Not used, set to "0" all the time

Bit 3 (DEADTBE): Enable dead-time function for PWMB and /PWMB (for dual PWM)

0: Disable (default)

1: Enable.



#### Bit 2 (DEADTAE): Enable dead-time function for PWMA and /PWMA (for dual PWM)

- 0: Disable (default)
- 1: Enable.

#### Bits 1~0 (DEADTP1~DEADTP0): Dead-time prescaler

| DEADTP1 | DEADTP0 | Prescale      |
|---------|---------|---------------|
| 0       | 0       | 1:1 (default) |
| 0       | 1       | 1:2           |
| 1       | 0       | 1:4           |
| 1       | 1       | 1:8           |

NOTE

The dead-time function is used only for dual PWM. When using single PWM function (not dual PWM), the dead-time function is always disabled.

#### 6.1.55 Bank 1 R15 DeadTR (Dead Time Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|-------|-------|-------|-------|---------|---------|---------|---------|
|       |       |       |       | DEADTR3 | DEADTR2 | DEADTR1 | DEADTR0 |
|       |       |       |       | R/W     | R/W     | R/W     | R/W     |

Bits 7~4 (DEADTR7~4): Not used, set to "0" all the time

Bits 3~0 (DEADTR3~0): The contents of the register are dead-time

#### 6.1.56 Bank 1 R16 PWMSCR (PWM Source Clock Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       | DEADS |       |       | PWMBS | PWMAS |
|       |       |       | R/W   |       |       | R/W   | R/W   |

Bits 7~5: Not used, set to "0" all the time.

Bit 4 (DEADS): Clock select for deadtime timer

0: Fs (default)

**1**: Fm

Bit 3~2: Not used, set to "0" all the time.

Bit 1 (PWMBS): Clock select for PWMB timer

0: Fs (default)

**1**: Fm



#### Bit 0 (PWMAS): Clock select for PWMA timer

0: Fs (default)

**1**: Fm

## 6.1.57 Bank 1 R17 PWMACR (PWMA Control Register)

| Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|--------|-------|--------|-------|-------|-------|-------|
| PWMAE | IPWMAE | PWMAA | IPWMAA | TAEN  | TAP2  | TAP1  | TAP0  |
| R/W   | R/W    | R/W   | R/W    | R/W   | R/W   | R/W   | R/W   |

Bit 7 (PWMAE): PWMA enable bit

0: Disable (default)

- 1: Enable. The compound pin is used as PWMA pin
- Bit 6 (IPWMAE): Inverse PWMA enable bit
  - 0: Disable (default)
  - 1: Enable. The compound pin is used as /PWMA pin
- Bit 5 (PWMAA): Active level of PWMA
  - **0**: Duty-deadtime is logic 1 (default)
  - **1**: Duty-deadtime is logic 0
- Bit 4 (IPWMAA): active level of inverse PWMA
  - 0: Period-duty-deadtime is logic 1 (default)
  - 1: Period-duty-deadtime is logic 0
- Bit 3 (TAEN): TMRA enable bit. All PWM functions are valid only as this bit is set
  - 0: TMRA is off (default value)

| PWMXEN | TXEN | Function description                                        |
|--------|------|-------------------------------------------------------------|
| 0      | 0    | Not used as PWM function; I/O pin or other functional pins. |
| 0      | 1    | Timer function; I/O pin or other functional pins.           |
| 1      | 0    | PWM function, the waveform remains at an inactive level.    |
| 1      | 1    | PWM function, the normal PWM output waveform.               |

Bits 2~0 (TAP2~TAP0): TMRA clock prescale option bits



| TAP2 | TAP1 | TAP0 | Prescale      |
|------|------|------|---------------|
| 0    | 0    | 0    | 1:1 (default) |
| 0    | 0    | 1    | 1:2           |
| 0    | 1    | 0    | 1:4           |
| 0    | 1    | 1    | 1:8           |
| 1    | 0    | 0    | 1:16          |
| 1    | 0    | 1    | 1:64          |
| 1    | 1    | 0    | 1:128         |
| 1    | 1    | 1    | 1:256         |

## 6.1.58 Bank 1 R18 PRDAL (Low byte of PWMA period)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PRDA7 | PRDA6 | PRDA5 | PRDA4 | PRDA3 | PRDA2 | PRDA1 | PRDA0 |
| R/W   |

Bits 7~0 (PRDA7~0): The contents of the register are low byte of the PWMA period.

## 6.1.59 Bank 1 R19 PRDAH (High byte of PWMA period)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | PRDA9 | PRDA8 |
|       |       |       |       |       |       | R/W   | R/W   |

Bits 7~2: Not used, set to "0" all the time.

Bits 1~0 (PRDA9~8): The contents of the register are high byte of PWMA period.

6.1.60 Bank 1 R1A DTAL (Low byte of PMWA duty)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| DTA7  | DTA6  | DTA5  | DTA4  | DTA3  | DTA2  | DTA1  | DTA0  |
| R/W   |

Bits 7~0 (DTA7~0): The contents of the register are low byte of the PWMA duty.

#### 6.1.61 Bank 1 R1B DTAH (High byte of PMWA duty)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | DTA9  | DTA8  |
|       |       |       |       |       |       | R/W   | R/W   |

Bits 7~2: Not used, set to "0" all the time.

Bits 1~0 (DTA9~8): The contents of the register are high byte of the PWMA duty.



## 6.1.62 Bank 1 R1C TMRAL (Low byte of TimerA)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| TMRA7 | TMRA6 | TMRA5 | TMRA4 | TMRA3 | TMRA2 | TMRA1 | TMRA0 |
| R     | R     | R     | R     | R     | R     | R     | R     |

**Bits 7~0 (TMRA7~0):** The contents of the register are ow byte of the PWMA timer which is counting. This is read-only.

## 6.1.63 Bank 1 R1D TMRAH (High byte of TimerA)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | TMRA9 | TMRA8 |
|       |       |       |       |       |       | R     | R     |

Bits 7~2: Not used, set to "0" all the time.

**Bits 1~0 (TMRA9~8):** The contents of the register are high byte of the PWMA timer which is counting. This is read-only.

## 6.1.64 Bank 1 R1E PWMBCR (PWMB Control Register)

| Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|--------|-------|--------|-------|-------|-------|-------|
| PWMBE | IPWMBE | PWMBA | IPWMBA | TBEN  | TBP2  | TBP1  | TBP0  |
| R/W   | R/W    | R/W   | R/W    | R/W   | R/W   | R/W   | R/W   |

Bit 7 (PWMBE): PWMB enable bit

0: Disable (default)

- 1: Enable. The compound pin is used as PWMB pin
- Bit 6 (IPWMBE): Inverse PWMB enable bit

0: Disable (default)

- 1: Enable. The compound pin is used as /PWMB pin
- Bit 5 (PWMBA): Active level of PWMB
  - 0: duty-deadtime is logic 1 (default)
  - 1: duty-deadtime is logic 0
- Bit 4 (IPWMBA): Active level of inverse PWMB

**0**: period-duty-deadtime is logic 1 (default)

1: period-duty-deadtime is logic 0

- Bit 3 (TBEN): TMRB enable bit. All PWM functions are valid only as this bit is set
  - **0**: TMRB is off (default value)
  - 1: TMRB is on



| TBP2 | TBP1 | TBP0 | Prescale      |  |  |  |  |  |  |
|------|------|------|---------------|--|--|--|--|--|--|
| 0    | 0    | 0    | 1:1 (default) |  |  |  |  |  |  |
| 0    | 0    | 1    | 1:2           |  |  |  |  |  |  |
| 0    | 1    | 0    | 1:4           |  |  |  |  |  |  |
| 0    | 1    | 1    | 1:8           |  |  |  |  |  |  |
| 1    | 0    | 0    | 1:16          |  |  |  |  |  |  |
| 1    | 0    | 1    | 1:64          |  |  |  |  |  |  |
| 1    | 1    | 0    | 1:128         |  |  |  |  |  |  |
| 1    | 1    | 1    | 1:256         |  |  |  |  |  |  |

#### Bits 2~0 (TBP2~TBP0): TMRB clock prescale option bits

6.1.65 Bank 1 R1F PRDBL (Low byte of PWMB period)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PRDB7 | PRDB6 | PRDB5 | PRDB4 | PRDB3 | PRDB2 | PRDB1 | PRDB0 |
| R/W   |

Bits 7~0 (PRDB7~0): The contents of the register are low byte of the PWMB period.

6.1.66 Bank 1 R20 PRDBH (High byte of PWMB period)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | PRDB9 | PRDB8 |
|       |       |       |       |       |       | R/W   | R/W   |

Bits 7~2: Not used, set to "0" all the time.

Bits 1~0 (PRDB9~8): The contents of the register are high byte of PWMB period.

6.1.67 Bank 1 R21 DTBL (Low byte of PMWB duty)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| DTB7  | DTB6  | DTB5  | DTB4  | DTB3  | DTB2  | DTB1  | DTB0  |
| R/W   |

Bits 7~0 (DTB7~0): The contents of the register are low byte of the PWMB duty.

6.1.68 Bank 1 R22 DTBH (High byte of PMWB duty)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | DTB9  | DTB8  |
|       |       |       |       |       |       | R/W   | R/W   |

Bits 7~2: Not used, set to "0" all the time.

Bits 1~0 (DTB9~8): The contents of the register are high byte of the PWMB duty.



## 6.1.69 Bank 1 R23 TMRBL (Low byte of TimerB)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| TMRB7 | TMRB6 | TMRB5 | TMRB4 | TMRB3 | TMRB2 | TMRB1 | TMRB0 |
| R     | R     | R     | R     | R     | R     | R     | R     |

**Bits 7~0 (TMRB7~0):** The contents of the register are low byte of the PWMB timer which is counting. This is read-only.

## 6.1.70 Bank 1 R24 TMRBH (High byte of TimerB)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       |       |       |       | TMRB9 | TMRB8 |
|       |       |       |       |       |       | R     | R     |

Bits 7~2: Not used, set to "0" all the time.

**Bits 1~0 (TMRB9~8):** The contents of the register are high byte of the PWMB timer which is counting. This is read-only.

## 6.1.71 Bank1 R25 ~ R32: (Reserved)

#### 6.1.72 Bank 1 R33 URCR (UART Control Register)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|--------|--------|--------|--------|--------|--------|-------|-------|
| UINVEN | UMODE1 | UMODE0 | BRATE2 | BRATE1 | BRATE0 | UTBE  | TXE   |
| R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R     | R/W   |

Bit 7 (UINVEN): Enable UART TXD and RXD Port Inverse Output Bit

0: Disable TXD and RXD port inverse output.

1: Enable TXD and RXD port inverse output.

#### Bits 6~5 (UMODE1~UMODE0): UART mode select bits

| UMODE1 | UMODE0 | UART Mode |
|--------|--------|-----------|
| 0      | 0      | 7-bit     |
| 0      | 1      | 8-bit     |
| 1      | 0      | 9-bit     |
| 1      | 1      | Reserved  |

Bits 4~2 (BRATE2~BRATE0): Transmit Baud rate select



| BRATE2 | BRATE1 | BRATE0 | Baud Rate | 8 MHz |  |  |
|--------|--------|--------|-----------|-------|--|--|
| 0      | 0      | 0      | Fc/13     | 38400 |  |  |
| 0      | 0      | 1      | Fc/26     | 19200 |  |  |
| 0      | 1      | 0      | Fc/52     | 9600  |  |  |
| 0      | 1      | 1      | Fc/104    | 4800  |  |  |
| 1      | 0      | 0      | Fc/208    | 2400  |  |  |
| 1      | 0      | 1      | Fc/416    | 1200  |  |  |
| 1      | 1      | 0      | Reserved  |       |  |  |
| 1      | 1      | 1      | Reserved  |       |  |  |

**Bit 1 (UTBE):** UART transfer buffer empty flag. Set to "1" when transfer buffer is empty. Reset to "**0**" automatically when writing to the URTD register. The <u>UTBE bit will be</u> <u>cleared by hardware when enabling transmission. The UTBE bit is read-only.</u> <u>Therefore, writing to the URTD register is necessary in starting transmission shifting.</u>

Bit 0 (TXE): Enable transmission

0: Disable

1: Enable

#### 6.1.73 Bank 1 R34 URS (UART Status Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| URTD8 | EVEN  | PRE   | PRERR | OVERR | FMERR | URBF  | RXE   |
| W     | R/W   | R/W   | R/W   | R/W   | R/W   | R     | R/W   |

Bit 7 (URTD8): UART Transmit Data Bit 8. Write-only.

Bit 6 (EVEN): Select parity check

0: Odd parity

1: Even parity

Bit 5 (PRE): Enable parity addition

#### 0: Disable

#### 1: Enable

- Bit 4 (PRERR): Parity error flag. Set to 1 when parity error occurred, cleared to 0 by software.
- Bit 3 (OVERR): Over running error flag. Set to 1 when overrun error occurred, cleared to 0 by software.
- **Bit 2 (FMERR):** Framing error flag. Set to 1 when framing error occurred, cleared to 0 by software.
- Bit 1 (URBF): UART read buffer full flag. Set to 1 when one character is received. Reset to 0 automatically when read from the URS register. <u>URBF will</u> <u>be cleared by hardware when enabling receiving</u>. The URBF bit is <u>read-only</u>. <u>Therefore, reading the URS register is necessary to avoid</u> <u>overrun error</u>.



#### Bit 0 (RXE): Enable receiving

0: Disable

1: Enable

## 6.1.74 Bank 1 R35 URTD (UART Transmit Data Buffer Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| URTD7 | URTD6 | URTD5 | URTD4 | URTD3 | URTD2 | URTD1 | URTD0 |
| W     | W     | W     | W     | W     | W     | W     | W     |

Bits 7~0 (URTD7~URTD0): UART transmit data buffer. Write-only.

## 6.1.75 Bank 1 R36 URRDL (UART Receive Data Low Buffer Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| URRD7 | URRD6 | URRD5 | URRD4 | URRD3 | URRD2 | URRD1 | URRD0 |
| R     | R     | R     | R     | R     | R     | R     | R     |

Bits 7~0 (URRD7~URRD0): UART Receive Data Buffer. Read-only.

## 6.1.76 Bank 1 R37 URRDH (UART Receive Data High Buffer Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| URRD8 | -     | -     | -     | -     | -     | -     | URSS  |
| R     | -     | -     | -     | -     | -     | -     | R/W   |

Bit 7 (URRD8): UART Receive Data Bit 8. Read-only.

Bits 6~1: Not used, set to "0" all the time.

Bit 0 (URSS): UART clock source select bit

0: Fc is set to Fs

1: Fc is set to Fm

## 6.1.77 Bank 1 R45 TBPTL (Table Pointer Low Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| TB7   | TB6   | TB5   | TB4   | TB3   | TB2   | TB1   | TB0   |
| R/W   |

Bits 7~0 (TB7~TB0): Table Pointer Address Bits 7~0.

## 6.1.78 Bank 1 R46 TBPTH (Table Pointer High Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| HLB   | GP    | GP    | GP    | TB11  | TB10  | TB9   | TB8   |
| R/W   |

Bit 7 (HLB): Take MLB or LSB at machine code



Bits 6~4 (GP): General-purpose read/write bits

Bits 3~0 (TB11~TB8): Table Pointer Address Bits 11~8.

6.1.79 Bank 1 R47 STKMON (Stack Monitor)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| STOV  | -     | -     | -     | -     | STL2  | STL1  | STL0  |
| R     | -     | -     | _     | -     | R     | R     | R     |

Bit 7 (STOV): Stack pointer overflow indication bit. Read-only.

Bits 6~3: Not used, set to "0" all the time.

Bits 2~0 (STL3~ STL0): Stack pointer number. Read-only.

6.1.80 Bank 1 R48 PCH (Program Counter High)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| -     | -     | -     | -     | PC11  | PC10  | PC9   | PC8   |
| _     | _     | Ι     | Ι     | R/W   | R/W   | R/W   | R/W   |

Bits 7~4: Not used, set to "0" all the time.

Bits 3~0 (PC11~PC8): Program Counter high byte.

# 6.1.81 Bank 1 R49 HLVDCR (High/Low Voltage Detector Control Register)

| Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|--------|-------|-------|-------|--------|--------|--------|--------|
| HLVDEN | IRVSF | VDSB  | VDM   | HLVDS3 | HLVDS2 | HLVDS1 | HLVDS0 |
| R/W    | R     | R     | R/W   | R/W    | R/W    | R/W    | R/W    |

Bit 7 (HLVDEN): High/Low Voltage Detector Enable Bit

0: Disable low voltage detector

1: Enable low voltage detector

Bit 6 (IRVSF): Internal Reference Voltage Stable Flag bit

1: Indicate that the voltage detect logic will generate the interrupt flag at the specified voltage range

**0**: Indicate that the voltage detect logic will not generate the interrupt flag at the specified voltage range and the HLVD interrupt should not be enabled

Bit 5 (VDSB): Voltage Detector State Bit. This is a read-only bit.

1: VDD > HLVD trip point (HLVDS<3:0>)

**0**: VDD < HLVD trip point (HLVDS<3:0>)



#### Bit 4 (VDM): Voltage Direction Magnitude Select bit

- 1: Event occurs when voltage equals or exceeds trip point (HLVDS<3:0>)
- **0**: Event occurs when voltage equals or falls below trip point (HLVDS<3:0>)

| HLVDIE | HLVDEN | VDM | IRVSF | VDSB | HLVDSF | Interrupt    |  |
|--------|--------|-----|-------|------|--------|--------------|--|
| 0      | 1      | 1   | 1     | 0->1 | 0->1   | Not happened |  |
| 0      | 1      | 1   | 1     | 1->0 | 0      | Not happened |  |
| 0      | 1      | 0   | 1     | 0->1 | 0      | Not happened |  |
| 0      | 1      | 0   | 1     | 1->0 | 0->1   | Not happened |  |
| 1      | 0      | Х   | Х     | 1    | 0      | Not happened |  |
| 1      | 1      | Х   | 0     | Х    | 0      | Not happened |  |
| 1      | 1      | 1   | 1     | 0->1 | 0->1   | Happened     |  |
| 1      | 1      | 1   | 1     | 1->0 | 0      | Not happened |  |
| 1      | 1      | 0   | 1     | 0->1 | 0      | Not happened |  |
| 1      | 1      | 0   | 1     | 1->0 | 0->1   | Happened     |  |

Bits 3~0 (HLVDS3~HLVDS0): High/Low Voltage Detector Level Bits

| HLVDS3 | HLVDS2 | HLVDS1 | HLVDS0 | HLVD Voltage Level |
|--------|--------|--------|--------|--------------------|
| 0      | 0      | 0      | 0      | 4.7V               |
| 0      | 0      | 0      | 1      | 4.5V               |
| 0      | 0      | 1      | 0      | 4.3V               |
| 0      | 0      | 1      | 1      | 4.1V               |
| 0      | 1      | 0      | 0      | 3.9V               |
| 0      | 1      | 0      | 1      | 3.7V               |
| 0      | 1      | 1      | 0      | 3.5V               |
| 0      | 1      | 1      | 1      | 3.3V               |
| 1      | 0      | 0      | 0      | 3.1V               |
| 1      | 0      | 0      | 1      | 2.9V               |
| 1      | 0      | 1      | 0      | 2.8V               |
| 1      | 0      | 1      | 1      | 2.6V               |
| 1      | 1      | 0      | 0      | 2.5V               |
| 1      | 1      | 0      | 1      | 2.4V               |
| 1      | 1      | 1      | 0      | 2.3V               |
| 1      | 1      | 1      | 1      | 2.2V               |

## 6.1.82 Bank 1 R4A~R4C: (Reserve)

## 6.1.83 Bank 0 R50~R7F, Bank 0~3 R80~RFF

All of these are 8-bit general-purpose registers.



## 6.2 WDT and Prescaler

There are two 8-bit counters available as prescalers for the WDT. The WPSR0~WPSR2 bits of the WDTCR register (Bank 0 R21) are used to determine the prescaler of WDT. The WDT and prescaler counter will be cleared by the "WDTC" and "SLEP" instructions. Figure 6-3 depicts the Block Diagram of WDT.

The Watchdog timer is a free running on-chip RC oscillator. The WDT will keep on running even after the oscillator driver has been turned off (i.e., in sleep mode). During normal operation or sleep mode, a WDT time-out (if enabled) will cause the device to reset. The WDT can be enabled or disabled at any time during normal mode by software programming. Refer to WDTE bit of WDTCR (Bank 0 R21) register. With no prescaler, the WDT time-out period is approximately 16 ms1 (one oscillator start-up timer period).



Figure 6-3 WDT Block Diagram

<sup>&</sup>lt;sup>1</sup> VDD=2.1~5.5V, Temp= -40°C~85°C, WDT Time-out period = 16ms  $\pm$  10%.



## 6.3 I/O Ports

The I/O registers, Port 5~Port A are bidirectional tri-state I/O ports. All can be pulled-high and pulled-low internally by software. In addition, they can have open-drain outputs and high sink/drive settings by software. Also, Ports 5~8 have wake-up, interrupt, and input status change interrupt functions. Each I/O pin can be defined as an "input" or "output" pin by the I/O control registers (IOC5 ~ IOCA).

The I/O registers and I/O control registers are both readable and writable. The I/O interface circuits for Port 5 ~ Port A are shown in Figure 6-4 ~ 6-7.



Note: Pull-down is not shown in the figure.

Figure 6-4 Circuit of I/O Port and I/O Control Register for Port 9~A





Note: Pull-high (down) and Open-drain are not shown in the figure.

Figure 6-5 Circuit of I/O Port and I/O Control Register for /INT



Note: Pull-high (down) and Open-drain are not shown in the figure. Figure 6-6 Circuit of I/O Port and I/O Control Register for Ports 5~8



Figure 6-7 Block Diagram of I/O Port 5~8 with Input Change Interrupt/Wake-up

| Table 1 | Usage of Ports 5~8 Input Changed Wake-up/Interrupt Function |
|---------|-------------------------------------------------------------|
|---------|-------------------------------------------------------------|

| Usage of Ports 5~8 Input Status              | s Changed Wake-up/Interrupt                        |
|----------------------------------------------|----------------------------------------------------|
| (I) Wake-up                                  | (II) Wake-up and interrupt                         |
| (a) Before Sleep                             | (a) Before Sleep                                   |
| 1. Disable WDT                               | 1. Disable WDT                                     |
| 2. Read I/O Port (MOV R6, R6)                | 2. Read I/O Port (MOV R6, R6)                      |
| 3. Execute "ENI" or "DISI"                   | 3. Execute "ENI" or "DISI"                         |
| 4. Enable wake-up bit (Set WUE6H=1, WUE6L=1) | 4. Enable wake-up bit (Set WUE6H=1, WUE6L=1)       |
| 5. Execute "SLEP" instruction                | 5. Enable interrupt (Set ICIE =1)                  |
| (b) After wake-up                            | 6. Execute "SLEP" instruction                      |
| $\rightarrow$ Next instruction               | (b) After wake-up                                  |
|                                              | 1. IF "ENI" $\rightarrow$ Interrupt vector (0006H) |
|                                              | 2. IF "DISI" $\rightarrow$ Next instruction        |



## 6.4 Reset and Wake-up

## 6.4.1 Reset

A reset is initiated by one of the following events:

- (1) Power-on reset
- (2) /RESET pin input "low"
- (3) WDT time-out (if enabled)
- (4) LVR (if enabled)

The device is kept in a reset condition for a period of approximately 16ms2 (one oscillator start-up timer period) after the reset is detected. If the /Reset pin goes "low" or WDT time-out is active, a reset is generated. In IRC mode, the reset time is WSTO and 8 clocks; in High XTAL mode, the reset time is WSTO and 510 clocks; and in low XTAL mode, the reset time is WSTO and 510 clocks (Fsub). Once a reset occurs, the following functions are performed. Refer to Figure 6-8.

- The oscillator is running, or will be started.
- The Program Counter (R2) is set to all "0".
- All I/O port pins are configured as input mode (high-impedance state).
- The Watchdog timer and prescaler are cleared.
- The control register bits are set according to the entries shown in Table 2 Summary of Register Initial Values after Reset.

Sleep (power-down) mode is asserted by executing the "SLEP" instruction. While entering sleep mode, WDT (if enabled) is cleared but keeps on running. After a wake-up is generated, the wake-up time is WSTO and 8 clocks in IRC mode, WSTO and 510 clocks in High XTAL mode, and WSTO and 510 clocks (Fsub) in low XTAL mode. The controller can be awakened by:

- (1) External reset input on /RESET pin.
- (2) WDT time-out (if enabled).
- (3) External (/INT) pin changes (if INTWKX is enabled).
- (4) Port input status changes (if ICWKPX is enabled).
- (5) High/Low Voltage Detector (if HLVDWK enable).
- (6) Completing A/D conversion (if ADWK is enabled).

The first two cases will cause the EM88F711N to reset. The T and P flags of R3 can be used to determine the source of the reset (wake-up). Case 3~8 are considered the continuation of program execution and the global interrupt ("ENI" or "DISI" being executed) determines whether or not the controller branches to the interrupt vector following a wake-up. If ENI is executed before SLEP, the instruction will begin to

<sup>&</sup>lt;sup>2</sup> VDD=2.1~5.5V, Temp=-40°C~85°C, WDT time-out period = 16ms ± 10%.



execute from the Address 0X02~0X38 by each interrupt vector after wake-up. If DISI is executed before SLEP, the execution will restart from the instruction right next to SLEP after wake-up.

Only one of Case 3~8 can be enabled before entering into sleep mode. That is,

- [a] If WDT is enabled before SLEP, the EM88F711N can only be woken up by Case 1 or Case 2. For further details, refer to Section 6.5 *Interrupt*.
- [b] If the External (INT9~0) pin change is used to wake up the EM88F711N and the INTWKX bit is enabled before SLEP, WDT must be disabled. Hence, the EM88F711N can only be woken up by Case 3.
- [c] If Port Input Status Change is used to wake up the EM88F711N and the corresponding wake-up setting is enabled before SLEP, WDT must be disabled. Hence, the EM88F711N can only be woken up by Case 4.
- [d] If High/Low voltage detector is used to wake up the EM88F711N and the HLVDWK bit of Bank 0 R10 register is enabled before SLEP, WDT must be disabled by software. Hence, the EM88F711N can only be woken up by Case 7.
- [e] If completing AD conversion is used to wake up the EM88F711N and the ADWK bit of Bank 0 R10 register is enabled before SLEP, WDT must be disabled by software. Hence, the EM88F711N can only be woken up by Case 8.



| Wake-up                              | Condition   | Sleep                               | Mode                                | Idle I                              | Mode                                | Green                | Mode                                  | Normal               | Mode                                  |
|--------------------------------------|-------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|----------------------|---------------------------------------|----------------------|---------------------------------------|
| Signal                               | Signal      | DISI                                | ENI                                 | DISI                                | ENI                                 | DISI                 | ENI                                   | DISI                 | ENI                                   |
| PWMA/B<br>(When                      | PWMxPIE = 0 |                                     |                                     | Wake-up                             | is invalid                          | Interrupt is invalid |                                       | Interrupt is invalid |                                       |
| timerA/B<br>match<br>PRDA/B)         | PWMxPIE = 1 | Wake-up                             | is invalid                          | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector |
| PWMA/B                               | PWMxDIE = 0 |                                     |                                     |                                     | is invalid                          | Interrupt            | is invalid                            | Interrupt is         | s invalid                             |
| (When<br>timerA/B<br>match<br>DTA/B) | PWMxDIE = 1 | Wake-up                             | is invalid                          | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector |
| TC1/2/3                              | TC1/2/3IE=0 |                                     | Wake-up is invalid                  |                                     | Wake-up is invalid Inte             |                      | is invalid                            | Interrupt is invalid |                                       |
| Interrupt<br>(Used as<br>Timer)      | TC1/2/3IE=1 | Wake-up                             |                                     |                                     | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector |
| TC1/2/3                              | TC1/2/3IE=0 | Wake-up                             | is invalid                          | Wake-up                             | is invalid                          | Interrupt            | is invalid                            | Interrupt is         | s invalid                             |
| Interrupt<br>(Used as<br>Counter)    | TC1/2/3IE=1 | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector |
|                                      | WTIE=0      |                                     |                                     | Wake-up                             | is invalid.                         | Interrupt            | is invalid.                           | Interrupt is         | invalid.                              |
| Watch<br>Timer                       | WTIE=1      | Wake-up                             | Wake-up is invalid                  |                                     | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction  | Interrupt<br>+<br>Interrupt<br>Vector |



| Wake-up             | Condition                                                                | Sleep                               | Mode                                | Idle I                              | Mode                                | Green               | Mode                                  | Norma               | l Mode                                |
|---------------------|--------------------------------------------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|---------------------|---------------------------------------|---------------------|---------------------------------------|
| Signal              | Signal                                                                   | DISI                                | ENI                                 | DISI                                | ENI                                 | DISI                | ENI                                   | DISI                | ENI                                   |
|                     | $INTWKx = 0, \\EXIEx = 0$                                                | Wake-up                             | is invalid                          | Wake-up                             | is invalid                          | Interrupt           | is invalid                            | Interrupt           | is invalid                            |
|                     | $  INTWKx = 0, \\ EXIEx = 1 $                                            | Wake-up                             | is invalid                          | Wake-up                             | is invalid                          | Next<br>Instruction | Interrient                            |                     | Interrupt +<br>Interrupt<br>Vector    |
| External<br>INT     | $\begin{aligned} \text{INTWKx} &= 1, \\ \text{EXIEx} &= 0 \end{aligned}$ | Wake<br>Next Inst                   |                                     | Wake<br>Next Ins                    |                                     | Interrupt           | is invalid                            | Interrupt           | is invalid                            |
|                     | INTWKx = 1,<br>EXIEx = 1                                                 | Next Interrupt                      |                                     | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector |
|                     | $\begin{aligned} ICWKPx &= 0, \\ PxICIE &= 0 \end{aligned}$              | Wake-up is invalid                  |                                     | Wake-up is invalid                  |                                     | Interrupt           | Interrupt is invalid                  |                     | is invalid                            |
|                     | ICWKPx = 0,<br>PxICIE = 1                                                | Wake-up is invalid                  |                                     | Wake-up is invalid                  |                                     | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector |
| Pin change          | ICWKPx = 1,<br>PxICIE = 0                                                | Wake up<br>+<br>Next Instruction    |                                     | Wake up<br>+<br>Next Instruction    |                                     | Interrupt           | Interrupt is invalid                  |                     | is invalid                            |
|                     | ICWKPx = 1,<br>PxICIE = 1                                                |                                     | Wake up<br>+<br>Interrupt           | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector |
|                     | ADWK = 0,<br>ADIE = 0                                                    | Wake-up                             | is invalid                          | Wake-up                             | is invalid                          | Interrupt           | is invalid                            | Interrupt           | is invalid                            |
| AD                  | ADWK = 0,<br>ADIE = 1                                                    | Wake-up                             | is invalid                          | Wake-up                             | is invalid                          | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector |
| Conversion complete | ADWK = 1,<br>ADIE = 0                                                    | Wake<br>Next Inst                   |                                     | Wake<br>Next Ins                    |                                     | Interrupt           | is invalid                            | Interrupt           | is invalid                            |
|                     | ADWK = 1,<br>ADIE = 1                                                    | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector |



| Wake-up                           | Condition                    | Sleep I                                                        | Mode              | ldle l                              | Mode                             | Green               | Mode                                  | Norma                   | I Mode                                |
|-----------------------------------|------------------------------|----------------------------------------------------------------|-------------------|-------------------------------------|----------------------------------|---------------------|---------------------------------------|-------------------------|---------------------------------------|
| Signal                            | Signal                       | DISI                                                           | ENI               | DISI                                | ENI                              | DISI                | ENI                                   | DISI                    | ENI                                   |
| UART                              | UTIE = 0                     |                                                                |                   |                                     |                                  | Interrupt           | is invalid.                           | Interrupt is invalid.   |                                       |
| Transmit<br>complete<br>Interrupt | UTIE = 1                     | Wake-up i                                                      | s invalid         | Wake-up                             | is invalid                       | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instructio<br>n | Interrupt<br>+<br>Interrupt<br>Vector |
| UART<br>Receive                   |                              |                                                                |                   |                                     |                                  | Interrupt           | is invalid                            | Interrupt               | is invalid                            |
| data<br>Buffer full<br>Interrupt  | URIE = 1                     | Wake-up i                                                      | s invalid         | Wake-up                             | is invalid                       | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instructio<br>n | Interrupt<br>+<br>Interrupt<br>Vector |
| UART                              | UERRIE = 0                   |                                                                |                   |                                     |                                  | Interrupt           | is invalid                            | Interrupt               | is invalid                            |
| Receive<br>Error<br>Interrupt     | UERRIE = 1                   | Wake-up i                                                      | is invalid Wake-נ |                                     | is invalid                       | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instructio<br>n | Interrupt<br>+<br>Interrupt<br>Vector |
|                                   | HLVDWK =<br>0,<br>HLVDIE = 0 | Wake-up i                                                      | s invalid         | Wake-up                             | is invalid                       | Interrupt           | is invalid                            | Interrupt               | is invalid                            |
| High /<br>Low                     | HLVDWK =<br>0,<br>HLVDIE = 1 | Wake-up i                                                      | s invalid         | Wake-up                             | is invalid                       | Next<br>Instruction | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instructio<br>n | Interrupt<br>+<br>Interrupt<br>Vector |
| Voltage<br>Detector               | HLVDWK =<br>1,<br>HLVDIE = 0 | Wake<br>+<br>Next Inst                                         | -                 | Wak<br>H<br>Next Ins                | F                                | Interrupt           | is invalid                            | Interrupt               | is invalid                            |
|                                   | HLVDWK =<br>1,<br>HLVDIE = 1 | Wake up Wake up<br>+ +<br>Next Interrupt<br>Instruction Vector |                   | Wake up<br>+<br>Next<br>Instruction | Wake up<br>+ +<br>Next Interrupt |                     | Interrupt<br>+<br>Interrupt<br>Vector | Next<br>Instructio<br>n | Interrupt<br>+<br>Interrupt<br>Vector |
| Low<br>Voltage<br>Reset           |                              | Wake up                                                        | + Reset           | Wake up                             | + Reset                          | Re                  | set                                   | Re                      | set                                   |
| WDT<br>Timeout                    |                              | Wake up                                                        | + Reset           | Wake up                             | + Reset                          | Re                  | set                                   | Re                      | set                                   |



## 6.4.2 Status of RST, T, and P of the Status Register

A reset condition is initiated by the following events:

- 1. Power-on condition
- 2. High-low-high pulse on /RESET pin
- 3. Watchdog timer time-out
- 4. When LVR occurs

The values of T and P listed in Table 4 are used to check how the processor wakes up. Table 4 shows the events that may affect the status of T and P.

#### Table 4 Values of RST, T and P after reset

| Reset Type                              | Т  | Р  |
|-----------------------------------------|----|----|
| Power-on                                | 1  | 1  |
| /RESET during Operating mode            | *P | *P |
| /RESET wake-up during Sleep mode        | 1  | 0  |
| WDT during Operating mode               | 0  | *P |
| WDT wake-up during Sleep mode           | 0  | 0  |
| Wake-up on pin change during Sleep mode | 1  | 0  |
|                                         | 4  |    |

\*P: Previous status before reset

#### Table 5 Status of T and P Being Affected by Events

| Event                                   | Т | P  |
|-----------------------------------------|---|----|
| Power-on                                | 1 | 1  |
| WDTC instruction                        | 1 | 1  |
| WDT time-out                            | 0 | *P |
| SLEP instruction                        | 1 | 0  |
| Wake-up on pin change during Sleep mode | 1 | 0  |
|                                         | ÷ |    |

\*P: Previous value before reset



Figure 6-8 Block Diagram of Controller Reset



## Table 3 Summary of Register Initial Values after Reset

Legend: U: Unknown or don't care

C: Same with Code option

*P:* Previous value before reset*t:* Check Table 4

| Address | Bank Name | Reset Type                 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-----------|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
|         |           | Bit Name                   | -     | -     | -     | -     | -     | -     | -     | -     |
|         | Bank 0/1  | Power-on                   | U     | U     | U     | U     | U     | U     | U     | U     |
| 0x00    | R0        | /RESET and WDT             | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         | IAR       | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | Ρ     | Р     | Ρ     | Ρ     | Р     |
|         |           | Bit Name                   | -     | -     | -     | SBS0  | -     | -     | -     | GBS0  |
|         | Bank 0/1  | Power-on                   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01    | R1        | /RESET and WDT             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         | BSR       | Wake-up from<br>Sleep/Idle | 0     | 0     | 0     | Ρ     | 0     | 0     | 0     | Р     |
|         |           | Bit Name                   | PC7   | PC6   | PC5   | PC4   | PC3   | PC2   | PC1   | PC0   |
|         | Bank 0/1  | Power-on                   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x02    | R2        | /RESET and WDT             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         | PCL       | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Р     |
|         |           | Bit Name                   | INT   | Ν     | OV    | Т     | Р     | Z     | DC    | С     |
|         | Bank 0/1  | Power-on                   | 0     | U     | U     | 1     | 1     | U     | U     | U     |
| 0x03    | R3        | /RESET and WDT             | 0     | Р     | Ρ     | t     | t     | Ρ     | Ρ     | Р     |
|         | SR        | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | t     | t     | Ρ     | Ρ     | Р     |
|         |           | Bit Name                   | RSR7  | RSR6  | RSR5  | RSR4  | RSR3  | RSR2  | RSR1  | RSR0  |
|         | Bank 0/1  | Power-on                   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 0x04    | R4        | /RESET and WDT             | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         | RSR       | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     |
|         |           | Bit Name                   | P57   | P56   | P55   | P54   | P53   | P52   | P51   | P50   |
|         | Bank 0    | Power-on                   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0X05    | R5        | /RESET and WDT             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         | Port 5    | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | Ρ     | Р     | Ρ     | Ρ     | Р     |



| Address | Bank Name | Reset Type                 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-----------|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
|         |           | Bit Name                   | P67   | P66   | P65   | P64   | P63   | P62   | P61   | P60   |
|         | Bank 0    | Power-on                   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x06    | R6        | /RESET and WDT             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         | Port 6    | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Р     |
|         |           | Bit Name                   | P77   | P76   | P75   | P74   | P73   | P72   | -     | -     |
|         | Bank 0    | Power-on                   | 0     | 0     | 0     | 0     | 0     | 0     | U     | U     |
| 0x07    | R7        | /RESET and WDT             | 0     | 0     | 0     | 0     | 0     | 0     | U     | U     |
|         | Port 7    | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | U     | U     |
|         |           | Bit Name                   |       |       |       |       |       |       | P81   | 0     |
|         | Bank 0    | Power-on                   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x08    | R8        | /RESET and WDT             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         | Port 8    | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     | Ρ     |
|         |           | Bit Name                   |       |       |       | IOC54 | IOC53 | IOC52 | IOC51 | IOC50 |
|         | Bank 0    | Power-on                   | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 1     |
| 0X0B    | RB        | /RESET and WDT             | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 1     |
|         | IOCR5     | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Р     | Р     | Р     | Ρ     | Ρ     | Р     |
|         |           | Bit Name                   |       |       | IOC65 | IOC64 | IOC63 | IOC62 | IOC61 | IOC60 |
|         | Bank 0    | Power-on                   | 0     | 0     | 1     | 1     | 1     | 1     | 1     | 1     |
| 0x0C    | RC        | /RESET and WDT             | 0     | 0     | 1     | 1     | 1     | 1     | 1     | 1     |
|         | IOCR6     | Wake-up from<br>Sleep/Idle | Ρ     | Ρ     | Р     | Р     | Р     | Ρ     | Р     | Р     |



| Address | Bank Name    | Reset Type                 | Bit 7      | Bit 6 | Bit 5       | Bit 4       | Bit 3      | Bit 2      | Bit 1  | Bit 0       |
|---------|--------------|----------------------------|------------|-------|-------------|-------------|------------|------------|--------|-------------|
|         |              | Bit Name                   | CPUS       | IDLE  | PERCS       | IIPS        | FMSF       | RCM2       | RCM1   | RCM0        |
|         | Bank 0       | Power-on                   | 1          | 1     | 0           | 0           | 0          | С          | С      | С           |
| 0x0E    | RE           | /RESET and WDT             | 1          | 1     | 0           | 0           | 0          | С          | С      | С           |
|         | OMCR         | Wake-up from<br>Sleep/Idle | Р          | Ρ     | Р           | Ρ           | Р          | Ρ          | Р      | Р           |
|         | Bank 0       | Bit Name                   |            |       | El32E<br>S1 | El32E<br>S0 | EI1ES<br>1 | EI1ES<br>0 | EI0ES1 | EI0ES0      |
| 0x0F    | Bank 0<br>RF | Power-on                   | 0          | 0     | 1           | 1           | 1          | 1          | 1      | 1           |
| UXUF    | EIESCR       | /RESET and WDT             | 0          | 0     | 1           | 1           | 1          | 1          | 1      | 1           |
|         |              | Wake-up from<br>Sleep/Idle | Ρ          | Ρ     | Р           | Ρ           | Ρ          | Ρ          | Ρ      | Р           |
|         |              | Bit Name                   |            |       | HLVDW<br>K  | ADWK        | INTWK1     | INTWK0     | -      | -           |
| 0.40    | Bank 0       | Power-on                   | 0          | 0     | 0           | 0           | 0          | 0          | U      | U           |
| 0x10    | R10<br>WUCR1 | /RESET and WDT             | 0          | 0     | 0           | 0           | 0          | 0          | U      | U           |
|         |              | Wake-up from<br>Sleep/Idle | 0          | Ρ     | Р           | Ρ           | Ρ          | Ρ          | U      | U           |
|         |              | Bit Name                   | ICWKP<br>8 | -     | ICWKP<br>6  | ICWKP<br>5  | -          | -          | -      | INTWK<br>32 |
| 0.40    | Bank 0       | Power-on                   | 0          | 0     | 0           | 0           | 0          | 0          | 0      | 0           |
| 0x12    | R12<br>WUCR3 | /RESET and WDT             | 0          | 0     | 0           | 0           | 0          | 0          | 0      | 0           |
|         | Wooks        | Wake-up from<br>Sleep/Idle | Ρ          | 0     | Ρ           | Ρ           | 0          | 0          | 0      | Ρ           |
|         |              | Bit Name                   | -          |       | HLVDSF      | ADSF        | EXSF1      | EXSF0      |        | TCSF        |
|         | Bank 0       | Power-on                   | U          | 0     | 0           | 0           | 0          | 0          | 0      | 0           |
| 0X14    | R14          | /RESET and WDT             | U          | 0     | 0           | 0           | 0          | 0          | 0      | 0           |
|         | SFR1         | Wake-up from<br>Sleep/Idle | U          | Р     | Р           | Ρ           | Ρ          | Ρ          | Ρ      | Р           |



| Address | Bank Name                                  | Reset Type                 | Bit 7  | Bit 6 | Bit 5  | Bit 4  | Bit 3       | Bit 2       | Bit 1       | Bit 0       |
|---------|--------------------------------------------|----------------------------|--------|-------|--------|--------|-------------|-------------|-------------|-------------|
|         |                                            | Bit Name                   | -      | -     | UERRSF | URSF   | UTSF        | -           | -           | TC1DA<br>SF |
| 0)/45   |                                            | Power-on                   | U      | U     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X15    |                                            | /RESET and WDT             | U      | U     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | 15Bank 0<br>R15<br>SFR216Bank 0<br>R16<br> | Wake-up from<br>Sleep/Idle | U      | U     | Р      | Ρ      | Ρ           | 0           | 0           | Ρ           |
|         |                                            | Bit Name                   |        |       |        |        | PWMBP<br>SF | PWMBDS<br>F | PWMA<br>PSF | PWMA<br>DSF |
| 0740    |                                            | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X16    |                                            | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | 0110                                       | Wake-up from<br>Sleep/Idle | 0      | 0     | 0      | 0      | Ρ           | Р           | Ρ           | Р           |
|         |                                            | Bit Name                   | P8ICSF | -     | P6ICSF | P5ICSF | -           | -           | -           | -           |
|         | Bank 0                                     | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X17    |                                            | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | SFR4                                       | Wake-up from<br>Sleep/Idle | Р      | 0     | Р      | Ρ      | 0           | 0           | 0           | 0           |
|         |                                            | Bit Name                   |        |       |        |        |             |             | EXSF3       | EXSF2       |
|         | Bank 0                                     | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X18    |                                            | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | SFR5                                       | Wake-up from<br>Sleep/Idle | 0      | 0     | 0      | 0      | 0           | 0           | Ρ           | Ρ           |
|         |                                            | Bit Name                   | SHSF   |       |        |        |             |             |             | TC1DB<br>SF |
| 0710    |                                            | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X19    |                                            | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | 01110                                      | Wake-up from<br>Sleep/Idle | Ρ      | 0     | 0      | 0      | 0           | 0           | 0           | Ρ           |
|         |                                            | Bit Name                   |        |       | HLVDIE | ADIE   | EXIE1       | EXIE0       |             |             |
|         | Bank 0                                     | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X1B    |                                            | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | IMR1                                       | Wake-up from<br>Sleep/Idle | 0      | 0     | Р      | Р      | Р           | Р           | 0           | 0           |
|         |                                            | Bit Name                   | -      | -     | UERRSF | URIE   | UTIE        | -           | -           | TC1IE       |
|         |                                            | Power-on                   | U      | U     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X1C    |                                            | /RESET and WDT             | U      | U     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | IMR2                                       | Wake-up from<br>Sleep/Idle | U      | U     | Р      | Р      | Р           | 0           | 0           | Ρ           |



| Address | Bank Name     | Reset Type                 | Bit 7  | Bit 6 | Bit 5  | Bit 4  | Bit 3       | Bit 2       | Bit 1       | Bit 0       |
|---------|---------------|----------------------------|--------|-------|--------|--------|-------------|-------------|-------------|-------------|
|         |               | Bit Name                   |        |       |        |        | PWMBP<br>IE | PWMBDI<br>E | PWMA<br>PIE | PWMA<br>DIE |
| 0X1D    | Bank 0<br>R1D | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| UXID    | IMR3          | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         |               | Wake-up from<br>Sleep/Idle | 0      | 0     | 0      | 0      | Р           | Р           | Р           | Р           |
|         |               | Bit Name                   | P8ICIE |       | P6ICIE | P5ICIE |             |             |             |             |
|         | Bank 0        | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X1E    | R1E           | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | IMR4          | Wake-up from<br>Sleep/Idle | Р      | 0     | Р      | Ρ      | 0           | 0           | 0           | 0           |
|         |               | Bit Name                   |        |       |        |        |             |             | EXIE3       | EXIE2       |
|         | Bank 0        | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X1F    | R1F           | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | IMR5          | Wake-up from<br>Sleep/Idle | 0      | 0     | 0      | 0      | 0           | 0           | Ρ           | Ρ           |
|         |               | Bit Name                   | SHIE   |       |        |        |             |             |             |             |
|         | Bank 0        | Power-on                   | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
| 0X20    | R20           | /RESET and WDT             | 0      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |
|         | IMR6          | Wake-up from<br>Sleep/Idle | Ρ      | 0     | 0      | 0      | 0           | 0           | 0           | 0           |



| Address | Bank Name | Reset Type                 | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------|-----------|----------------------------|--------|--------|--------|--------|--------|--------|--------|--------|
|         |           | Bit Name                   | WDTE   | FSSF   |        |        | PSWE   | WPSR2  | WPSR1  | WPSR0  |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| 0X21    | R21       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|         | WDTCR     | Wake-up from<br>Sleep/Idle | Ρ      | Р      | 0      | 0      | Ρ      | Ρ      | Ρ      | Ρ      |
|         |           | Bit Name                   | TC1S   | TC1RC  | TC1SS1 |        | TC1FF  | TC10MS | TC1IS1 | TC1IS0 |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| 0X24    | R24       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|         | TC1CR1    | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Р      | 0      | Ρ      | Ρ      | Ρ      | Р      |
|         |           | Bit Name                   | TC1M2  | TC1M1  | TC1M0  | TC1SS0 | TC1CK3 | TC1CK2 | TC1CK1 | TC1CK0 |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| 0X25    | R25       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|         | TC1CR2    | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Р      |
|         | Bank 0    | Bit Name                   | TC1DA7 | TC1DA6 | TC1DA5 | TC1DA4 | TC1DA3 | TC1DA2 | TC1DA1 | TC1DA0 |
|         |           | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| 0X26    | R26       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|         | TC1DA     | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Р      | Ρ      | Ρ      | Ρ      | Ρ      | Р      |
|         |           | Bit Name                   | TC1DB7 | TC1DB6 | TC1DB5 | TC1DB4 | TC1DB3 | TC1DB2 | TC1DB1 | TC1DB0 |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| 0X27    | R27       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|         | TC1DB     | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Р      |
|         |           | Bit Name                   | CKR2   | CKR1   | CKR0   | ADRUN  | ADP    | ADOM   | SHS1   | SHS0   |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| 0X3E    | R3E       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|         | ADCR1     | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Р      |
|         |           | Bit Name                   | CALI   | VPIS2  | ADIM   | ADCMS  | VPIS1  | VPIS0  | VREFP  | VREFN  |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| 0X3F    | R3F       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|         | ADCR2     | Wake-up from<br>Sleep/Idle | Ρ      | Р      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Р      |

#### EM88F711N 8-Bit Microprocessor



| Address | Bank Name | Reset Type                 | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2                                                                                                                                                                                         | Bit 1                                                                                                                                                                                                                                                                                                                                                                                                     | Bit 0 |
|---------|-----------|----------------------------|--------|--------|--------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|         |           | Bit Name                   | -      | -      | -      | ADIS4  | ADIS3  | ADIS2                                                                                                                                                                                         | ADIS1                                                                                                                                                                                                                                                                                                                                                                                                     | ADIS0 |
|         | Bank 0    | Power-on                   | U      | U      | U      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
| 0X40    | R40       | /RESET and WDT             | U      | U      | U      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
|         | ADISR     | Wake-up from<br>Sleep/Idle | U      | U      | U      | Ρ      | Ρ      | Ρ                                                                                                                                                                                             | ADIS1         0         0         ADE1         ADE1         ADE1         O         ADD1         P         ADD1         U         U         O         ADD9         U         P         ADCV1         O         O         ADCV1         P         P         ADCV1 | Р     |
|         |           | Bit Name                   | ADE7   | ADE6   | ADE5   | ADE4   | ADE3   | ADE2                                                                                                                                                                                          | ADE1                                                                                                                                                                                                                                                                                                                                                                                                      | ADE0  |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
| 0X41    | R41       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
|         | ADER1     | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ                                                                                                                                                                                             | Ρ                                                                                                                                                                                                                                                                                                                                                                                                         | Р     |
|         |           | Bit Name                   | ADD7   | ADD6   | ADD5   | ADD4   | ADD3   | ADD2                                                                                                                                                                                          | ADD1                                                                                                                                                                                                                                                                                                                                                                                                      | ADD0  |
|         | Bank 0    | Power-on                   | U      | U      | U      | U      | U      | U                                                                                                                                                                                             | U                                                                                                                                                                                                                                                                                                                                                                                                         | U     |
| 0X43    | R43       | /RESET and WDT             | U      | U      | U      | U      | U      | U                                                                                                                                                                                             | U                                                                                                                                                                                                                                                                                                                                                                                                         | U     |
|         | ADDL      | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | OOOOOOOOPPPPADE3ADE2ADE1AOOOOOOOOOOOOPPPAOOOOPPPAOOOOPPPAOOOOPPPAOOADD2ADD1ADD3ADD2ADD1AOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOAOOOA< | Р                                                                                                                                                                                                                                                                                                                                                                                                         |       |
|         |           | Bit Name                   | ADD15  | ADD14  | ADD13  | ADD12  | ADD11  | ADD10                                                                                                                                                                                         | ADD9                                                                                                                                                                                                                                                                                                                                                                                                      | ADD8  |
|         | Bank 0    | Power-on                   | U      | U      | U      | U      | U      | U                                                                                                                                                                                             | U                                                                                                                                                                                                                                                                                                                                                                                                         | U     |
| 0X44    | R44       | /RESET and WDT             | U      | U      | U      | U      | U      | U                                                                                                                                                                                             | U                                                                                                                                                                                                                                                                                                                                                                                                         | U     |
|         | ADDH      | Wake-up from<br>Sleep/Idle | Ρ      | Р      | Ρ      | Ρ      | Ρ      | Ρ                                                                                                                                                                                             | Ρ                                                                                                                                                                                                                                                                                                                                                                                                         | Р     |
|         |           | Bit Name                   | ADCV7  | ADCV6  | ADCV5  | ADCV4  | ADCV3  | ADCV2                                                                                                                                                                                         | ADCV1                                                                                                                                                                                                                                                                                                                                                                                                     | ADCV0 |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
| 0X45    | R45       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
|         | ADCVL     | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ                                                                                                                                                                                             | Ρ                                                                                                                                                                                                                                                                                                                                                                                                         | Р     |
|         |           | Bit Name                   | ADCV15 | ADCV14 | ADCV13 | ADCV12 | ADCV11 | ADCV10                                                                                                                                                                                        | ADCV9                                                                                                                                                                                                                                                                                                                                                                                                     | ADCV8 |
|         | Bank 0    | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
| 0X46    | R46       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 0     |
|         | ADCVH     | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Р      | Р                                                                                                                                                                                             | Р                                                                                                                                                                                                                                                                                                                                                                                                         | Ρ     |



| Address | Bank Name                                                                                                                                                                                                                                                                                                     | Reset Type     | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bit 1 | Bit 0 |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|-------|-------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|
|         |                                                                                                                                                                                                                                                                                                               | Bit Name       |       |       |       |       |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | IOC81 | IOC80 |
|         | Bank 1                                                                                                                                                                                                                                                                                                        | Power-on       | 0     | 0     | 0     | 0     | 0     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
| 0X05    | Bank 1<br>RS<br>IOCR8Bit NameI<br>Power-on00000000RESET and WDT00000000000RESET and WDT000000000000RESET and WDT111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111 <td>0</td> <td>1</td> <td>1</td> | 0              | 1     | 1     |       |       |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |       |
|         | IOCR8                                                                                                                                                                                                                                                                                                         |                | 0     | 0     | 0     | 0     | 0     | IOC81           0         1           0         1           0         1           0         P           0         PH52         PH51           1         1         1           1         1         1           1         1         1           P         PH61         1           P         PH62         PH61           1         1         1           P         P         P           PL52         PL51         1           1         1         1           P         P         P           PL52         PL51         1           1         1         1           P         P         P           PL62         PL61         1           1         1         1           P         P         P           P         P         P           I         1         1           P         P         P           I         1         1           P         P         P           I         1         1 | Р     |       |
|         |                                                                                                                                                                                                                                                                                                               | Bit Name       | PH57  | PH56  | PH55  | PH54  | PH53  | PH52                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PH51  | PH50  |
|         | Bank 1                                                                                                                                                                                                                                                                                                        | Power-on       | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
| 0X08    |                                                                                                                                                                                                                                                                                                               | /RESET and WDT | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
|         | P5PHCR                                                                                                                                                                                                                                                                                                        |                | Р     | Ρ     | Р     | Ρ     | Р     | Ρ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Ρ     | Р     |
|         |                                                                                                                                                                                                                                                                                                               | Bit Name       | PH67  | PH66  | PH65  | PH64  | PH63  | PH62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PH61  | PH60  |
|         | Bank 1                                                                                                                                                                                                                                                                                                        | Power-on       | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
| 0X09    |                                                                                                                                                                                                                                                                                                               | /RESET and WDT | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
|         | P6PHCR                                                                                                                                                                                                                                                                                                        | -              | Р     | Р     | Р     | Ρ     | Ρ     | Ρ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Ρ     | Р     |
|         |                                                                                                                                                                                                                                                                                                               | Bit Name       | PL57  | PL56  | PL55  | PL54  | PL53  | PL52                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PL51  | PL50  |
|         | Bank 1                                                                                                                                                                                                                                                                                                        | Power-on       | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
| 0X0B    |                                                                                                                                                                                                                                                                                                               | /RESET and WDT | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
|         | P5PLCR                                                                                                                                                                                                                                                                                                        |                | Ρ     | Ρ     | Р     | Ρ     | Ρ     | Ρ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Ρ     | Р     |
|         |                                                                                                                                                                                                                                                                                                               | Bit Name       | PL67  | PL66  | PL65  | PL64  | PL63  | PL62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PL61  | PL60  |
|         |                                                                                                                                                                                                                                                                                                               | Power-on       | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
| 0X0C    |                                                                                                                                                                                                                                                                                                               | /RESET and WDT | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
|         | P6PLCR                                                                                                                                                                                                                                                                                                        | -              | Р     | Ρ     | Р     | Ρ     | Р     | Ρ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Р     | Р     |
|         |                                                                                                                                                                                                                                                                                                               | Bit Name       | HDS57 | HDS56 | HDS55 | HDS54 | HDS53 | HDS52                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | HDS51 | HDS50 |
|         | Bank 1                                                                                                                                                                                                                                                                                                        | Power-on       | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
| 0X0E    |                                                                                                                                                                                                                                                                                                               | /RESET and WDT | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
|         | P5HDSCR                                                                                                                                                                                                                                                                                                       |                | Ρ     | Ρ     | Р     | Ρ     | Ρ     | Ρ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Ρ     | Р     |
|         |                                                                                                                                                                                                                                                                                                               | Bit Name       | HDS67 | HDS66 | HDS65 | HDS64 | HDS63 | HDS62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | HDS61 | HDS60 |
|         |                                                                                                                                                                                                                                                                                                               | Power-on       | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
| 0X0F    |                                                                                                                                                                                                                                                                                                               | /RESET and WDT | 1     | 1     | 1     | 1     | 1     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1     | 1     |
|         | P6HDSCR                                                                                                                                                                                                                                                                                                       |                | Р     | Р     | Р     | Ρ     | Ρ     | Ρ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Р     | Р     |



| Address | Bank Name               | Reset Type                 | Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3       | Bit 2       | Bit 1       | Bit 0       |
|---------|-------------------------|----------------------------|-------|--------|-------|--------|-------------|-------------|-------------|-------------|
| 0X11    | Bank 1<br>R11<br>P5ODCR | Bit Name                   | OD57  | OD56   | OD55  | OD54   | OD53        | OD52        | OD51        | OD50        |
|         |                         | Power-on                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-up from<br>Sleep/Idle | Ρ     | Ρ      | Ρ     | Ρ      | Ρ           | Ρ           | Р           | Р           |
| 0X12    | Bank 1<br>R2<br>P6ODCR  | Bit Name                   | OD67  | OD66   | OD65  | OD64   | OD63        | OD62        | OD61        | OD60        |
|         |                         | Power-on                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-up from<br>Sleep/Idle | Р     | Р      | Р     | Р      | Р           | Р           | Р           | Р           |
| 0X14    | BANK 1, R14<br>DeadTCR  | Bit Name                   |       |        |       |        | DEADTB<br>E | DEADTA<br>E | DEADTP<br>1 | DEADT<br>P0 |
|         |                         | Power-On                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | 0      | Р           | Ρ           | Р           | Р           |
| 0X15    | BANK 1, R15<br>DeadTR   | Bit Name                   |       |        |       |        | DEADT<br>R3 | DEADT<br>R2 | DEADT<br>R1 | DEADT<br>R0 |
|         |                         | Power-On                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | 0      | Ρ           | Ρ           | Р           | Р           |
| 0X16    | BANK 1, R16<br>PWMSCR   | Bit Name                   |       |        |       | DEADS  |             |             | PWMBS       | PWMAS       |
|         |                         | Power-On                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | Ρ      | 0           | 0           | Р           | Р           |
| 0X17    | BANK 1, R17<br>PWMACR   | Bit Name                   | PWMAE | IPWMAE | PWMAA | IPWMAA | TAEN        | TAP2        | TAP1        | TAP0        |
|         |                         | Power-On                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-Up from<br>Sleep/Idle | Ρ     | Ρ      | Р     | Ρ      | Р           | Ρ           | Р           | Р           |
| 0X18    | BANK 1, R18<br>PRDAL    | Bit Name                   | PRDA7 | PRDA6  | PRDA5 | PRDA4  | PRDA3       | PRDA2       | PRDA1       | PRDA0       |
|         |                         | Power-On                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-Up from<br>Sleep/Idle | Ρ     | Р      | Ρ     | Ρ      | Ρ           | Ρ           | Р           | Р           |
| 0X19    | BANK 1, R19<br>PRDAH    | Bit Name                   |       |        |       |        |             |             | PRDA9       | PRDA8       |
|         |                         | Power-On                   | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0           | 0           | 0           | 0           |
|         |                         | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | 0      | 0           | 0           | Ρ           | Р           |



#### (Continuation)

| Address                   | Bank Name      | Reset Type                 | Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------------------------|----------------|----------------------------|-------|--------|-------|--------|-------|-------|-------|-------|
|                           |                | Bit Name                   | DTA7  | DTA6   | DTA5  | DTA4   | DTA3  | DTA2  | DTA1  | DTA0  |
|                           | BANK 1, R1A    | Power-On                   | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
| 0X1A                      | DTAL           | /RESET and WDT             | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
|                           |                | Wake-Up from<br>Sleep/Idle | Ρ     | Р      | Ρ     | Ρ      | Ρ     | Ρ     | Ρ     | Р     |
|                           |                | Bit Name                   |       |        |       |        |       |       | DTA9  | DTA8  |
|                           | BANK 1, R1B    | Power-On                   | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
| 0X1B                      | DTAH           | /RESET and WDT             | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
|                           |                | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | 0      | 0     | 0     | Ρ     | Р     |
|                           |                | Bit Name                   | TMRA7 | TMRA6  | TMRA5 | TMRA4  | TMRA3 | TMRA2 | TMRA1 | TMRA0 |
|                           | BANK 1, R1C    | Power-On                   | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 1     |
| 0X1C                      | TMRAL          | /RESET and WDT             | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 1     |
|                           |                | Wake-Up from<br>Sleep/Idle | Р     | Р      | Ρ     | Р      | Р     | Р     | Р     | Р     |
| 0X1D BANK 1, R1D<br>TMRAH | Bit Name       |                            |       |        |       |        |       | TMRA9 | TMRA8 |       |
|                           | Power-On       | 0                          | 0     | 0      | 0     | 0      | 0     | 0     | 0     |       |
|                           | /RESET and WDT | 0                          | 0     | 0      | 0     | 0      | 0     | 0     | 0     |       |
|                           |                | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | 0      | 0     | 0     | Р     | Р     |
|                           |                | Bit Name                   | PWMBE | IPWMBE | PWMBA | IPWMBA | TBEN  | TBP2  | TBP1  | TBP0  |
|                           | BANK 1, R1E    | Power-On                   | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
| 0X1E                      | PWMBCR         | /RESET and WDT             | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
|                           |                | Wake-Up from<br>Sleep/Idle | Р     | Р      | Ρ     | Р      | Р     | Р     | Р     | Р     |
|                           |                | Bit Name                   | PRDB7 | PRDB6  | PRDB5 | PRDB4  | PRDB3 | PRDB2 | PRDB1 | PRDB0 |
|                           | BANK 1, R1F    | Power-On                   | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
| 0X1F                      | PRDBL          | /RESET and WDT             | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
|                           |                | Wake-Up from<br>Sleep/Idle | Р     | Р      | Ρ     | Ρ      | Р     | Р     | Ρ     | Р     |
|                           |                | Bit Name                   |       |        |       |        |       |       | PRDB9 | PRDB8 |
|                           | BANK 1, R20    | Power-On                   | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
| 0X20                      | PRDBH          | /RESET and WDT             | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
|                           |                | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | 0      | 0     | 0     | Ρ     | Р     |
|                           |                | Bit Name                   | DTB7  | DTB6   | DTB5  | DTB4   | DTB3  | DTB2  | DTB1  | DTB0  |
|                           | BANK 1, R21    | Power-On                   | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
| 0X21                      | DTBL           | /RESET and WDT             | 0     | 0      | 0     | 0      | 0     | 0     | 0     | 0     |
|                           | DIBL           | Wake-Up from<br>Sleep/Idle | 0     | 0      | 0     | 0      | Ρ     | Ρ     | Ρ     | Ρ     |



#### (Continuation)

| Address | Bank Name                  | Reset Type                 | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|---------|----------------------------|----------------------------|--------|--------|--------|--------|--------|--------|-------|-------|
|         |                            | Bit Name                   |        |        |        |        |        |        | DTB9  | DTB8  |
|         | BANK 1, R22                | Power-On                   | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
| 0X22    | DTBH                       | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
|         |                            | Wake-Up from<br>Sleep/Idle | 0      | 0      | 0      | 0      | 0      | 0      | Ρ     | Р     |
|         |                            | Bit Name                   | TMRB7  | TMRB6  | TMRB5  | TMRB4  | TMRB3  | TMRB2  | TMRB1 | TMRB0 |
|         | BANK 1, R23                | Power-On                   | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
| 0X23    | TMRBL                      | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
|         |                            | Wake-Up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ     | Р     |
|         |                            | Bit Name                   |        |        |        |        |        |        | TMRB9 | TMRB8 |
|         | BANK 1, R24                | Power-On                   | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
| 0X24    | TMRBH                      | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
|         |                            | Wake-Up from<br>Sleep/Idle | 0      | 0      | 0      | 0      | 0      | 0      | Ρ     | Р     |
|         | Bank 1<br>0X33 R33<br>URCR | Bit Name                   | UINVEN | UMODE1 | UMODE0 | BRATE2 | BRATE1 | BRATE0 | UTBE  | TXE   |
|         |                            | Power-on                   | 0      | 0      | 0      | 0      | 0      | 0      | 1     | 0     |
| 0X33    |                            | /RESET and WDT             | 0      | 0      | 0      | 0      | 0      | 0      | 1     | 0     |
|         |                            | Wake-up from<br>Sleep/Idle | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ      | Ρ     | Р     |
|         |                            | Bit Name                   | URTD8  | EVEN   | PRE    | PRERR  | OVERR  | FMERR  | URBF  | RXE   |
|         | Bank 1                     | Power-on                   | U      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
| 0X34    | R34                        | /RESET and WDT             | Р      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
|         | URS                        | Wake-up from<br>Sleep/Idle | Р      | Р      | Р      | Ρ      | Ρ      | Р      | Ρ     | Р     |
|         |                            | Bit Name                   | URTD7  | URTD6  | URTD5  | URTD4  | URTD3  | URTD2  | URTD1 | URTD0 |
|         | Bank 1                     | Power-on                   | U      | U      | U      | U      | U      | U      | U     | U     |
| 0X35    | R35                        | /RESET and WDT             | Р      | Р      | Р      | Р      | Р      | Р      | Р     | Р     |
|         | URTD                       | Wake-up from<br>Sleep/Idle | Р      | Р      | Р      | Р      | Р      | Р      | Р     | Р     |
|         |                            | Bit Name                   | URRD7  | URRD6  | URRD5  | URRD4  | URRD3  | URRD2  | URRD1 | URRD0 |
|         | Bank 1                     | Power-on                   | U      | U      | U      | U      | U      | U      | U     | U     |
| 0X36    | R36                        | /RESET and WDT             | Р      | Р      | Р      | Р      | Р      | Р      | Р     | Р     |
|         | URRDL                      | Wake-up from<br>Sleep/Idle | Р      | Р      | Р      | Ρ      | Ρ      | Ρ      | Р     | Р     |
|         |                            | Bit Name                   | URRD8  | -      | -      | -      | -      | -      | -     | -     |
|         | Bank 1                     | Power-on                   | U      | U      | U      | U      | U      | U      | U     | U     |
| 0X37    | R37                        | /RESET and WDT             | Р      | U      | U      | U      | U      | U      | U     | U     |
|         | URRDH                      | Wake-up from<br>Sleep/Idle | Р      | U      | U      | U      | U      | U      | U     | U     |



#### (Continuation)

| Address   | Bank Name    | Reset Type                 | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-----------|--------------|----------------------------|--------|-------|-------|-------|--------|--------|--------|--------|
|           |              | Bit Name                   | TB7    | TB6   | TB5   | TB4   | TB3    | TB2    | TB1    | TB0    |
|           | Bank 1       | Power-on                   | 0      | 0     | 0     | 0     | 0      | 0      | 0      | 0      |
| 0X45      | R45          | /RESET and WDT             | 0      | 0     | 0     | 0     | 0      | 0      | 0      | 0      |
|           | TBPTL        | Wake-up from<br>Sleep/Idle | Р      | Ρ     | Ρ     | Ρ     | Р      | Ρ      | Р      | Р      |
|           |              | Bit Name                   | HLB    | GP    | GP    | GP    | TB11   | TB10   | TB9    | TB8    |
|           | Bank 1       | Power-on                   | 0      | 0     | 0     | 0     | 0      | 0      | 0      | 0      |
| 0X46      | R46          | /RESET and WDT             | 0      | 0     | 0     | 0     | 0      | 0      | 0      | 0      |
|           | TBPTH        | Wake-up from<br>Sleep/Idle | Р      | Ρ     | Ρ     | Р     | Р      | Р      | Р      | Р      |
|           |              | Bit Name                   | STOV   | -     | -     | -     | STL3   | STL2   | STL1   | STL0   |
|           | Bank 1       | Power-on                   | 0      | U     | U     | U     | 0      | 0      | 0      | 0      |
| 0X47      | R47          | /RESET and WDT             | 0      | U     | U     | U     | 0      | 0      | 0      | 0      |
|           | STKMON       | Wake-up from<br>Sleep/Idle | Р      | U     | U     | U     | Р      | Ρ      | Р      | Р      |
|           | Bank 1       | Bit Name                   | -      | -     | -     | -     | PC11   | PC10   | PC9    | PC8    |
|           |              | Power-on                   | U      | U     | U     | U     | 0      | 0      | 0      | 0      |
| 0X48      | R48          | /RESET and WDT             | U      | U     | U     | U     | 0      | 0      | 0      | 0      |
|           | PCH          | Wake-up from<br>Sleep/Idle | U      | U     | U     | U     | Р      | Ρ      | Р      | Р      |
|           |              | Bit Name                   | HLVDEN | IRVSF | VDSB  | VDM   | HLVDS3 | HLVDS2 | HLVDS1 | HLVDS0 |
|           | Bank 1       | Power-on                   | 0      | 0     | 1     | 0     | 1      | 1      | 1      | 1      |
| 0X49      | R49          | /RESET and WDT             | 0      | 0     | 1     | 0     | 1      | 1      | 1      | 1      |
|           | HLVDCR       | Wake-up from<br>Sleep/Idle | Р      | Ρ     | Ρ     | Ρ     | Р      | Р      | Р      | Р      |
|           |              | Bit Name                   | -      | -     | -     | -     | -      | -      | -      | -      |
| 0X50      | Bank 0       | Power-on                   | U      | U     | U     | U     | U      | U      | U      | U      |
| 0X7F      | P50, P7E     | /RESET and WDT             | Р      | Р     | Р     | Р     | Р      | Р      | Р      | Р      |
|           | 0X7F R50~R7F | Wake-up from<br>Sleep/Idle | Р      | Р     | Р     | Р     | Р      | Р      | Р      | Р      |
|           |              | Bit Name                   | -      | -     | -     | -     | -      | -      | -      | -      |
| 0X80      | Bank 0~3     | Power-on                   | U      | U     | U     | U     | U      | U      | U      | U      |
| ~<br>0XFF | R80~RFF      | /RESET and WDT             | Р      | Р     | Р     | Р     | Р      | Р      | Р      | Р      |
| 0,41      |              | Wake-up from<br>Sleep/Idle | Р      | Ρ     | Р     | Ρ     | Р      | Р      | Р      | Р      |



# 6.5 Interrupt

| The EM88F711N has 14 interru | upts (4 external.  | 10 internal    | ) as listed below: |
|------------------------------|--------------------|----------------|--------------------|
|                              | apio ( i oktornui, | 10 millionnai, |                    |

| Interr            | upt Source         | Enable Condition         | Int. Flag          | Int. Vector | Priority |
|-------------------|--------------------|--------------------------|--------------------|-------------|----------|
| Internal/External | Reset              | -                        | -                  | 0           | High 0   |
| External          | INT                | ENI + EXIE=1             | EXSF               | 2           | 1        |
| External          | Pin change         | ENI +ICIE=1              | ICSF               | 4           | 2        |
| Internal          | HLVD               | ENI+HLVDEN &<br>HLVDIE=1 | HLVDSF             | 8           | 4        |
| Internal          | AD                 | ENI + ADIE=1             | ADSF               | 10          | 5        |
| Internal          | TC1                | ENI + TC1IE=1            | TC1DASF<br>TC1DBSF | 12          | 6        |
| Internal          | PWMPA              | ENI+PWMPAIE=1            | PWMPASF            | 14          | 7        |
| Internal          | PWMDA              | ENI+PWMDAIE=1            | PWMDASF            | 16          | 8        |
| Internal          | PWMPB              | ENI+PWMPBIE=1            | PWMPBSF            | 24          | 9        |
| Internal          | PWMDB              | ENI+PWMDBIE=1            | PWMDBSF            | 26          | 10       |
| Internal          | UART Receive error | ENI+UERRIE=1             | UERRSF             | 2E          | 11       |
| Internal          | UART Receive       | ENI + URIE=1             | URSF               | 30          | 12       |
| Internal          | UART Transmit      | ENI + UTIE=1             | UTSF               | 32          | 13       |
| External          | System hold        | ENI + SHIE=1             | SHSF               | 34          | 14       |

Bank 0 R15~R1A are the interrupt status registers that record the interrupt requests in relative flags/bits. Bank 0 R1B~R20 are the Interrupt Mask registers. The global interrupt is enabled by the ENI instruction and is disabled by the DISI instruction. When one of the enabled interrupts occurs, the next instruction will be fetched from their individual addresses. The interrupt flag bit must be cleared by instructions before leaving the interrupt service routine and before interrupts are enabled to avoid recursive interrupts.

The flag (except ICSF bit delete) in the Interrupt Status Register is set regardless of the status of its mask bit or the execution of ENI. The RETI instruction ends the interrupt routine and enables the global interrupt (the execution of ENI).

External interrupt is equipped with digital noise rejection circuit (input pulse of less than **4 system clock time** is eliminated as noise), **but in Low XTAL oscillator (LXT) mode, the noise rejection circuit is disabled**. When an interrupt (Falling edge) is generated by the External interrupt (when enabled), the next instruction will be fetched from Address 0X02H.

Before the interrupt subroutine is executed, the contents of ACC, R3 (Bit 0~Bit 4) and R4 registers are saved by hardware. If another interrupt occurs, the ACC, R3 (Bit 0~Bit 4) and R4 registers will be replaced by the new interrupt. After the interrupt service routine is finished, ACC, R3 (Bit 0~Bit 4) and R4 are restored.





Figure 6-9a Interrupt Input Circuit



Figure 6-9b Interrupt Backup Diagram



| R_BANK  | Address | Name   | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|---------|---------|--------|--------|--------|--------|--------|--------|--------|-------|-------|
| Bank 0  | 0x3E    | ADCR1  | CKR2   | CKR1   | CKR0   | ADRUN  | ADP    | ADOM   | SHS1  | SHS0  |
| Dalik V | UXSE    | ADCKI  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   |
| Bank 0  | 0x3F    | ADCR2  | -      | VPIS2  | ADIM   | ADCMS  | VPIS1  | VPIS0  | VREFP | VREFN |
| Dalik V | UX3F    | ADCKZ  | -      | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   |
| Bank 0  | 0 0x40  | ADISR  | -      | -      | -      | ADIS4  | ADIS3  | ADIS2  | ADIS1 | ADIS0 |
| Dalik V | 0240    | ADISK  | -      | -      | -      | R/W    | R/W    | R/W    | R/W   | R/W   |
| Bank 0  | 0x41    | ADER1  | ADE7   | ADE6   | ADE5   | ADE4   | ADE3   | ADE2   | ADE1  | ADE0  |
| Dalik V | 0741    | ADENT  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   |
| Bank 0  | 0x43    | ADDL   | ADD7   | ADD6   | ADD5   | ADD4   | ADD3   | ADD2   | ADD1  | ADD0  |
| Dalik V | 0743    | ADDE   | R      | R      | R      | R      | R      | R      | R     | R     |
| Bank 0  | 0x44    | ADDH   | ADD15  | ADD14  | ADD13  | ADD12  | ADD11  | ADD10  | ADD9  | ADD8  |
| Dalik U | 0744    | ADDH   | R      | R      | R      | R      | R      | R      | R     | R     |
| Bank 0  | 0x45    | ADCVL  | ADCD7  | ADCD6  | ADCD5  | ADCD4  | ADCD3  | ADCD2  | ADCD1 | ADCD0 |
| Dalik U | 0743    | ADCVL  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   |
| Bank 0  | 0x46    | ADCVH  | ADCD15 | ADCD14 | ADCD13 | ADCD12 | ADCD11 | ADCD10 | ADCD9 | ADCD8 |
| Dalik U | 0740    | ADCVII | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   |
| Bank 0  | 0x15    | SFR1   | -      | -      | -      | ADSF   | -      | -      | -     | -     |
| Dalik V | UXIS    | SFKI   | -      | -      | -      | R/W    | -      | -      | -     | -     |
| Bank 0  | 0v1B    | IMR1   | -      | -      | -      | ADIE   | -      | -      | -     | -     |
| Dalik V | 0x1B    |        | -      | -      | -      | R/W    | -      | -      | -     | -     |

# 6.6 A/D Converter



Figure 6-10 ADC Functional Block Diagram



This is a 12-bit successive approximation register analog-to-digital converter (SAR ADC). There are two reference voltages for SAR ADC. The positive reference voltage can select internal AVDD, internal voltage sources or external input pin by setting the VREFN, VREFP and VPIS2~0 bits in ADCR2. Connecting to external positive reference voltage provides more accuracy than using internal AVDD.

# 6.6.1 ADC Data Register

When the AD conversion is completed, the result is loaded to the ADDH and ADDL. And the ADSF is set if ADIE is enabled.

## 6.6.2 A/D Sampling Time

The accuracy, linearity, and speed of the successive approximation AD converter are dependent on the properties of the ADC. The source impedance and the internal sampling impedance directly affect the time required to charge the sample and hold capacitor. The application program controls the length of the sample time to meet the specified accuracy. The maximum recommended impedance for the analog source is  $10k\Omega$  at VDD = 5V. After the analog input channel is selected; this acquisition time must be done before AD conversion can be started.

## 6.6.3 A/D Conversion Time

CKR2~0 select the conversion time (TAD). This allows the MCU to run at maximum frequency without sacrificing the accuracy of AD conversion. The following tables show the relationship between  $T_{AD}$  and the maximum operating frequencies. The  $T_{AD}$  is 0.5 µs for 3V~5.5V and 2 µs for 2.5V~3V.

| System<br>Mode | CKR[2:0] | Operating Clock<br>of ADC<br>(Fad = 1 / Tad) | Max. F <sub>Main</sub><br>(V <sub>DD</sub> = 3V ~ 5.5V) | Max. F <sub>Main</sub><br>(V <sub>DD</sub> = 2.5V ~ 3V) |
|----------------|----------|----------------------------------------------|---------------------------------------------------------|---------------------------------------------------------|
|                | 000      | F <sub>Main</sub> / 16                       | 16 MHz                                                  | 8 MHz                                                   |
|                | 001      | F <sub>Main</sub> / 8                        | 16 MHz                                                  | 4 MHz                                                   |
|                | 010      | F <sub>Main</sub> / 4                        | 8 MHz                                                   | 2 MHz                                                   |
| Normal         | 011      | F <sub>Main</sub> / 2                        | 4 MHz                                                   | 1 MHz                                                   |
| Mode           | 100      | F <sub>Main</sub> / 64                       | 16 MHz                                                  | 16 MHz                                                  |
|                | 101      | F <sub>Main</sub> / 32                       | 16 MHz                                                  | 16 MHz                                                  |
|                | 110      | F <sub>Main</sub> / 1                        | 2 MHz                                                   | 0.5 MHz                                                 |
|                | 111      | F <sub>Sub</sub>                             | Fs                                                      | Fs                                                      |
| Green Mode     | xxx      | $F_{Sub}$                                    | Fs                                                      | Fs                                                      |

\* Conversion Time = Sample and Hold (SHS[1:0]=10, 8 \*  $T_{AD}$ ) + 12 \* Bit Conversion Time (12 \*  $T_{AD}$ ) + Delay Time between setting ADSTART bit and starting first  $T_{AD}$ .



#### 6.6.4 ADC Operation during Sleep Mode

In order to obtain a more accurate ADC value and reduce power consumption, the AD conversion remains operational during sleep mode. As the SLEP instruction is executed, all the MCU operations will stop except for the Oscillator, TC1, PWMA~C and AD conversion.

The AD Conversion is considered completed as determined by:

- 1. The ADRUN bit of the Bank 0-R3E register is cleared to "0".
- 2. The ADSF bit of the Bank 0-R14 register is set to "1".
- 3. The ADWK bit of the Bank 0-R10 register is set to "1" and wakes up from ADC conversion (where it remains in operation during sleep mode).
- 4. Wake up and execute the next instruction if the ADIE bit of the Bank 0-R1B is enabled and the "DISI" instruction is executed.
- 5. Wake up and enter into interrupt vector if the ADIE bit of Bank 0-R1B is enabled and the "ENI" instruction is executed.
- 6. Enter into an interrupt vector if the ADIE bit of the Bank 0-R1B is enabled and the "ENI" instruction is executed.

The results are fed into the ADDL and ADDH registers when the conversion is completed. If the ADWK is enabled, device will wake up. Otherwise, the AD conversion will be shut off, no matter what the status of the ADP bit is.

#### 6.6.5 Programming Process/Considerations

Follow these steps to obtain data from the ADC:

- 1. AD pins that are not data-converted must be set as high-impedance inputs and can not be set as output pins (Pull-High or Pull-Low).
- 2. Write to the ADCR1/ADCR2 register to configure the AD module:
  - a) Define the AD conversion clock rate (CKR2~0)
  - b) Select the VREFS input source of the ADC
  - c) Set the ADP bit to "1" to begin sampling
- 3. Select the ADC input channel (ADIS4~0)
- 4. Enable the corresponding AD conversion pin (ADER1~2) to the ADC input channel selected in Step 3.
- 5. If the wake-up function is used, set the ADWK bit to "1".
- 6. If the interrupt function is used, set the ADIE bit to "1".
- 7. If the interrupt function is used, set an "ENI" instruction.
- 8. Set the ADRUN bit to "1"
- 9. Write "SLEP" instruction or Polling.



- 10. Wait for either Wake-up or for the ADRUN bit to be cleared to "**0**", and the Status flag (ADSF) is set "**1**", or ADC interrupt occurs.
- 11. Read the ADDL and ADDH conversion data registers. If the ADC input channel changes at this time, the ADDL and ADDH values can be cleared to "**0**".
- 12. Clear the status flag (ADSF).
- 13. Turn off the selected AD conversion pin function (ADER1~2).
- 14. If necessary, proceed to the next conversion program and jump to Step 3 or 4. At least two  $T_{AD}$  are required before the next acquisition starts. On the other hand, the timing setting ADRUN = 1 must be later than the timing setting ADP=1, and the difference between the two timing is also two  $T_{AD}$ .

For actual program settings, refer to the section in red in the program demonstration.

# If the procedure described above is not followed, the AD conversion value may not come out as expected.

#### X Note:

- 1. In order to obtain accurate values, it is necessary to avoid any data transfer in I/O pins during AD conversion.
- 2. Order of setting the register
  - Before setting the AD conversion pins (ADER1~2), the corresponding input channel (ADISR) and ADC power supply (ADP = 1) must be set.
  - After the AD conversion is completed, turn off the AD conversion pin function (ADER1~2).
- 3. AD pins that are not data-converted must be set as high-impedance input pins. For example, if P52, P53, and P54 (AD0~2) are AD pins, P53 and P54 must be set as high-impedance input pins to begin P53 AD data conversion. Similarly, to begin P53 AD data conversion, P52 and P54 must be set as high-impedance input pins. [P52, P53, and P54 can be set as high-impedance input pins during program initialization]

#### 6.6.6 Programming Process for Detecting Internal VDD

VDD is detected within the operation, as described in the previous section, the difference is that before starting the ADC conversion, the first detection of VDD is ready. Therefore, in detecting VDD:

It should be noted that before starting the AD conversion operation, the channel has to be switched to 1/2VDD, the voltage divider needs to be started before AD can be converted. Several points to note are that, precise conversion values can be added in the VDD Pin capacitance, or more than twice the conversion, taking the average of the last few strokes data in order to increase the reliability of the data.

Note that usually before VDD is detected, the channel cannot be switched to 1/2VDD. As there has always been a DC current consumption, the channel must be switched to



another channel analog multiplexer, and it will be shut out of the resistor divider. User attention is required.



Figure 6-11 ADC and VDD Detection Block Diagram

.5



#### 6.6.7 Sample Demo Programs

#### A. Define System Control Registers

| IAR == 0X00    | ; Indirect addressing register |
|----------------|--------------------------------|
| SR == 0X03     | ; Status register              |
| WUCR1 == 0x10  | ; Wakeup Control Register 1    |
| ADWK ==WUCR1.4 |                                |
| SFR1 == 0x14   | ; Status Flag Register 1       |
| ADSF == SFR1.4 |                                |
| IMR1 == 0x1B   | ; Interrupt Mask Register 1    |
| ADIE == IMR1.4 |                                |

#### **B. Define I/O Control Registers**

| PORT5 == 0X05 |   |     |         |          |    |      |  |
|---------------|---|-----|---------|----------|----|------|--|
| IOCR5 == 0x0B | ; | I/0 | Control | Register | of | Port |  |

#### C. ADC Control Register

ADCR1 == 0x3E ; ADC Control Register 1 CKR2 == ADCR1.7 CKR1 == ADCR1.6 CKR0 == ADCR1.5 ADRUN == ADCR1.4 ADP == ADCR1.3 ADOM == ADCR1.2 SHS1 == ADCR1.1 SHS0 == ADCR1.0 ; ADC input Channel select register ADISR == 0x40; ADC Input Control Register 1 ADER1 == 0x41ADER2 == 0x42; ADC Input Control Register 2 ; The contents are the results of ADC[7:0] ADDL == 0x43ADDH == 0x44; The contents are the results of ADC[11:8] D. Define General Register ADCTMPO == 0x50; ADCTMP1 == 0x51; E. Program Starts ORG 0x00 ; Initial address ; JMP INITIAL



```
ORG 0x12
                    ; ADC Interrupt vector
JMP ADC Int
;
; (User program section)
;
ADC Int:
MOV A, ADDH
                    ; To read high byte of AD data buffer
MOV ADCTMP0, A
MOV A, ADDL
                    ; To read low byte of AD data buffer
MOV ADCTMP1, A
BC
    ADSF
                    ; To clear the ADSF bit
BC ADER1, 2
                    ; Disable P54(AD2) to act as analog
                     ; input pin
RETI
INITIAL:
MOV A,@0xFF
                  ; To define PORT5 as an input pin
MOV IOCR5, A
MOV A, @OB00001000 ; AD power on (ADP=1), and set clock
                     ; rate at fosc/16
MOV ADCR1, A
                     ; Enable the ADWK wake-up function of ADC
BS
    ADWK
                     ; Enable the ADIE interrupt function
BS
    ADIE
ENI
                     ; Enable the interrupt function
En ADC:
                     ;
MOV A, @0x02
                    ; To define AD2 as an analog input
MOV ADISR, A
    ADER1, 2
                    ; To Enable P54(AD2) as an analog
BS
                     ; input channel
ΒS
    ADRUN
                    ; Start to run the ADC
SLEP
; If the interrupt function is employed, the following nine lines
```

; (User program section)

may be ignored

;



;

| POLL | ING:      |   |                                              |
|------|-----------|---|----------------------------------------------|
| JBS  | ADSF      | ; | To check the ADSF bit continuously           |
| JMP  | POLLING   | ; | ADRUN bit will be set 1 as the AD conversion |
|      |           | ; | is completed                                 |
| MOV  | A, ADDH   | ; | To read high byte of AD data buffer          |
| MOV  | ADCTMP0,A |   |                                              |
| MOV  | A, ADDL   | ; | To read low byte of AD data buffer           |
| MOV  | ADCTMP1,A |   |                                              |
| BC   | ADSF      | ; | To clear the ADSF bit                        |
|      |           |   |                                              |
| BC   | ADER1, 2  | ; | Disable P54(AD2) to act as analog input pin  |



# 6.7 Timer

Timer 1 can be one 8-bit up-counter.

| R_BANK  | Address | Name   | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0   |
|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|---------|
| Bank 0  | 0x24    | 704004 | TC1S   | TC1RC  | TC1SS1 | TC1MOD | TC1FF  | TC10MS | TC1IS1 | TC1IS0  |
| Dalik U | 0224    | TC1CR1 | R/W    | R/W    | R/W    | R/W    | R      | R/W    | R/W    | R/W     |
| Bank 0  | 0x25    | TC1CR2 | TC1M2  | TC1M1  | TC1M0  | TC1SS0 | TC1CK3 | TC1CK2 | TC1CK1 | TC1CK0  |
| Dalik V | 0723    | TUTURZ | R/W     |
| Bank 0  | 0x26    | TC1DA  | TC1DA7 | TC1DA6 | TC1DA5 | TC1DA4 | TC1DA3 | TC1DA2 | TC1DA1 | TC1DA0  |
| Dalik V | 0720    |        | R/W     |
| Bank 0  | 0x27    | TC1DB  | TC1DB7 | TC1DB6 | TC1DB5 | TC1DB4 | TC1DB3 | TC1DB2 | TC1DB1 | TC1DB0  |
| Dalik V | 0721    |        | R/W     |
| Bank 0  | 0x15    | SFR2   | -      | -      | -      | -      | -      | -      | -      | TC1DASF |
| Dalik V | 0213    | SFRZ   | -      | -      | -      | -      | -      | -      | -      | F       |
| Bank 0  | 0x19    | SFR6   | -      | -      | -      | -      | -      | -      | -      | TC1DBSF |
| Dalik V | 0713    | SFRU   | -      | -      | -      | -      | -      | -      | -      | F       |
| Bank 0  | 0x1C    | C IMR2 | -      | -      | -      | -      | -      | -      | -      | TC1DIE  |
| Dallk V |         | IIVINZ | -      | -      | -      | -      | -      | -      | -      | R/W     |



# 6.7.1 Timer/Counter Mode



Figure 6-12a Timer/Counter Mode Block Diagram

In Timer/Counter mode, counting up is performed using internal clock or TCx pin. When the contents of the up-counter match with the TCxDA, an interrupt is generated and the counter is cleared. Counting up resumes after the counter is cleared. The current contents of the up-counter are loaded into TCxDB by setting TCxRC to "1".



Figure 6-12b Timer/Counter Mode Waveform



6.7.2 Window Mode

Figure 6-13a Window Mode Block Diagram

In Window mode, counting up is performed on a rising edge of the pulse that is logical AND of an internal clock and the TCx pin (window pulse). When the contents of the up-counter match with the TCxDA, interrupt is generated and the counter is cleared. The frequency (window pulse) must be less than the selected internal clock.

| TCx pin        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Internal clock |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Up-counter     | $ \underbrace{\begin{array}{c} 0 \\ 1 \\ \end{array}}_{\text{cc}} \underbrace{\begin{array}{c} 0 \\ 1 \\ 1 \\ 1 \\ \end{array}}_{\text{cc}} \underbrace{\begin{array}{c} 0 \\ 1 \\ 1 \\ 1 \\ 1 \\ \end{array}}_{\text{cc}} \underbrace{\begin{array}{c} 0 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\$ |
| TCxDA          | X_n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| TCx interrupt  | match counter clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Figure 6-13b Window Mode Waveform





6.7.3 Capture Mode

Figure 6-14a Capture Mode Block Diagram

In Capture mode, the pulse width, period and duty of the TCx input pin are measured and can be used to decode the remote-control signal. The counter is free running by the internal clock. On a rising (falling) edge of TCx pin, the contents of the counter are loaded into TCxDA, then the counter is cleared and an interrupt is generated. On a falling (rising) edge of TC1 pin, the contents of the counter are loaded into TCxDB. At this time, the counter is still counting. Once the next rising edge of TCx pin is triggered, the contents of the counter are loaded into TCxDA, the counter is cleared and interrupt is generated again. If overflow before the edge is detected, the FFH is loaded into TCxDA and an overflow interrupt is generated. During interrupt processing, it can be determined whether or not there is an overflow by checking if the TCxDA value is FFH. After an interrupt (capture to TCxDA or overflow detection) is generated, capture and overflow detections are halted until TCxDA is read out.

- (1) Normal action
- (2) Cannot be interrupted
- (3) Signal less than 2 timer clk cannot be identified
- (4) DA overflow
- (5) DB overflow
- (6) DB overflow after the need for signal rise edge will be re-counted



Figure 6-14b Capture Mode Waveform





### 6.7.4 Programmable Divider Output Mode and Pulse Width Modulation Mode

Figure 6-15a PDO/PWM Mode Block Diagram

#### Programmable Divider Output (PDO)

In Programmable Divider Output (PDO) mode, counting up is performed using the internal clock. The contents of TCxDA are compared with the contents of the up-counter. The F/F output is toggled and the counter is cleared each time a match is found. The F/F output is inverted and output to PDO pin. This mode can generate 50% of duty pulse output. The PDO pin is initialized to "**0**" during reset. A TCx interrupt is generated each time the PDO output is toggled.



Figure 6-15b PDO Mode Waveform



#### Pulse Width Modulation (PWM)

In Pulse Width Modulation (PWM) Output mode, counting up is performed using the internal clock with prescaler. The Duty of PWMx is controlled by TCxDB, and the period of PWMx is controlled by TCxDA. Pulse at the PWMx pin is held to high level as long as TCxS=1 or timerx matches TCxDA; meanwhile, the pulse is held to low level as long as Timerx matches TCxDB. Once TCxFF is set to 1, PWMx signal is inverted, a TCx interrupt is generated and defined by TCxIS. On the other hand, although TCxDA and TCxDB can be written anytime, the data of TCxDA and TCxDB are latched only when writing TCxDA0. Therefore, new duty and new period of PWM appear at the PMW pin in the last period–match.





#### 6.7.5 Buzzer Mode

The TCx pin outputs the clock after dividing the frequency.





|        |         | 0.0     |       | (Fuise |       | Iodulati |         |         |         |         |
|--------|---------|---------|-------|--------|-------|----------|---------|---------|---------|---------|
| R_BANK | Address | Name    | Bit 7 | Bit 6  | Bit 5 | Bit 4    | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
| Bank 0 | 0x16    | SFR3    |       |        |       |          | PWMBPSF | PWMBDSF | PWMAPSF | PWMADSF |
|        |         |         |       |        |       |          | F       | F       | F       | F       |
| Bank 0 | 0x1D    | IMR3    |       |        |       |          | PWMBPIE | PWMBDIE | PWMAPIE | PWMADIE |
|        |         |         |       |        |       |          | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x14    | DeadTCR |       |        |       |          | DEADTBE | DEADTAE | DEADTP1 | DEADTP0 |
|        |         |         |       |        |       |          | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x15    | DeadTR  |       |        |       |          | DEADTR3 | DEADTR2 | DEADTR1 | DEADTR0 |
|        |         |         |       |        |       |          | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x16    | PWMSCR  |       |        |       | DEADS    |         |         | PWMBS   | PWMAS   |
|        |         |         |       |        |       | R/W      |         |         | R/W     | R/W     |
| Bank 1 | 0x17    | PWMACR  | PWMAE | IPWMAE | PWMAA | IPWMAA   | TAEN    | TAP2    | TAP1    | TAP0    |
|        |         |         | R/W   | R/W    | R/W   | R/W      | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x18    | PRDAL   | PRDA7 | PRDA6  | PRDA5 | PRDA4    | PRDA3   | PRDA2   | PRDA1   | PRDA0   |
|        |         |         | R/W   | R/W    | R/W   | R/W      | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x19    | PRDAH   |       |        |       |          |         |         | PRDA9   | PRDA8   |
|        |         |         |       |        |       |          |         |         | R/W     | R/W     |
| Bank 1 | 0x1A    | DTAL    | DTA7  | DTA6   | DTA5  | DTA4     | DTA3    | DTA2    | DTA1    | DTA0    |
|        |         |         | R/W   | R/W    | R/W   | R/W      | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x1B    | DTAH    |       |        |       |          |         |         | DTA9    | DTA8    |
|        |         |         |       |        |       |          |         |         | R/W     | R/W     |
| Bank 1 | 0x1C    | TMRAL   | TMRA7 | TMRA6  | TMRA5 | TMRA4    | TMRA3   | TMRA2   | TMRA1   | TMRA0   |
|        |         |         | R     | R      | R     | R        | R       | R       | R       | R       |
| Bank 1 | 0x1D    | TMRAH   |       |        |       |          |         |         | TMRA9   | TMRA8   |
|        |         |         |       |        |       |          |         |         | R       | R       |
| Bank 1 | 0x1E    | PWMBCR  | PWMBE | IPWMBE | PWMBA | IPWMBA   | TBEN    | TBP2    | TBP1    | TBP0    |
|        |         |         | R/W   | R/W    | R/W   | R/W      | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x1F    | PRDBL   | PRDB7 | PRDB6  | PRDB5 | PRDB4    | PRDB3   | PRDB2   | PRDB1   | PRDB0   |
|        |         |         | R/W   | R/W    | R/W   | R/W      | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x20    | PRDBH   |       |        |       |          |         |         | PRDB9   | PRDB8   |
|        |         |         |       |        |       |          |         |         | R/W     | R/W     |
| Bank 1 | 0x21    | DTBL    | DTB7  | DTB6   | DTB5  | DTB4     | DTB3    | DTB2    | DTB1    | DTB0    |
|        |         |         | R/W   | R/W    | R/W   | R/W      | R/W     | R/W     | R/W     | R/W     |
| Bank 1 | 0x22    | DTBH    |       |        |       |          |         |         | DTB9    | DTB8    |
|        |         |         |       |        |       |          | 1       |         | R/W     | R/W     |
| Bank 1 | 0x23    | TMRBL   | TMRB7 | TMRB6  | TMRB5 | TMRB4    | TMRB3   | TMRB2   | TMRB1   | TMRB0   |
|        |         |         | R     | R      | R     | R        | R       | R       | R       | R       |
| Bank 1 | 0x24    | TMRBH   |       |        |       |          |         |         | TMRB9   | TMRB8   |
|        |         |         |       |        |       |          |         |         | R       | R       |

# 6.8 PWM (Pulse Width Modulation)



#### 6.8.1 Overview

In PWM mode, a PWM output up to 10-bit resolution is produced (see Functional Block Diagram). A PWM output consists of a time period and a duty cycle, and it keeps the output high. The baud rate of the PWM is the inverse of the time period. Figure 25~28 (*PWM Output Timing*) depict the relationships between a time period and a duty cycle.



Figure 2. The PWM Functional Block Diagram

PWM and /PWM (inverted PWM) can be used individually or used as dual PWM. When used individually, the definitions of active level between PWM and /PWM are somewhat different.

For example, set period and duty cycle (period > duty), PWMXE=1/0 and IPWMXE=0/1, PWMXA = 1/0, IPWMXA=1/0, and finally set TXEN = 1. The following figures show PWM output timing according to different PWMXA and IPWMXA settings.

















Figure 6.PWM Output Timing (PWMXA=1 and IPWMXA=1)

For the shut-off of the operating PWM function, refer to Figure 31.



### 6.8.2 Increment Timer Counter (TMRX: TMRAH/TMRAL or TMRBH/TMRBL)

TMRX are 10-bit clock counters with programmable prescaler. They are designed for the PWM module as baud rate clock generators. TMR can be read-only. If employed, they can be turned off for power saving by setting the TAEN bit [BANK1-R1A <3>], TBEN bit [BANK1-R21<3>], TCEN bit [BANK1-R28<3>], or TDEN bit [BANK1-R2F <3>] to 0.

TMRA, TMRB, TMRC, and TMRD are internal designs and cannot be set.

## 6.8.3 PWM Time Period (PRDX: PRDAL/H or PRDBL/H)

The PWM period is 10-bit resolution. The PWM time period is defined by writing to the PRDX register. When TMRX is equal to PRDX, the following events occur on the next increment cycle:

- TMRX is cleared
- The PWMX pin is set to 1

**NOTE**The PWM output will not be set, if the duty cycle is 0

The PWMXIF pin is set to 1

The following formula describes how to calculate the PWM time period:

$$Period = (PRDX + 1) \times \left(\frac{1}{F_{osc}}\right) \times \frac{CLKS}{2} \times (TMRX \ prescale \ value)$$

Example:

PRDX = 49; Fosc = 4 MHz; TMRX (0, 0, 0) = 1 : 1,

CLKS bit of the Code Option Register = 0 (two oscillator periods);

Then

Period = 
$$(49+1) \times \left(\frac{1}{4M}\right) \times \frac{2}{2} \times 1 = 12.5 \mu s$$

## 6.8.4 PWM Duty Cycle (DTX: DTAH/DTAL or DTBH/DTBL)

The PWM duty cycle is defined by writing to the DTX register, and is latched from DTX to DLX while TMRX is cleared. When DLX is equal to TMRX, the PWMX pin is cleared. DTX can be loaded anytime. However, it cannot be latched into DLX until the current value of DLX is equal to TMRX.

The following formula describes how to calculate the PWM duty cycle:



Duty cycle = 
$$(DTX) \times \left(\frac{1}{F_{osc}}\right) \times \frac{CLKS}{2} \times (TMRX \ prescale \ value)$$

Example:

DTX = 10; Fosc = 4 MHz; TMRX (0, 0, 0) = 1 : 1, CLKS bit of the Code Option Register = 0 (two oscillator periods);

Then

Duty cycle = 
$$(10) \times \left(\frac{1}{4M}\right) \times \frac{2}{2} \times 1 = 2.5 \mu s$$

#### 6.8.5 Dual PWM function

It consists of a complementary PWM (i.e., PWMX and /PWMX), one outputs PWM signal and the other outputs inverted PWM signals, which outputs any pulse width signal user wish by programming relative control registers.

The dead time mode is supported. It means that the complementary PWM signals can be controlled to get a time interval that the complementary PWM signals will not be intersected.

The following Figure 27 ~ 29 show the dual PWM output waveform.

Disable dead time control (DEADTXE = 0). Set period and duty cycle (period > duty). Set PWMXE & IPWMXE =1, PWMXA = 0/1, IPWMXA = 0/1, and finally set TXEN = 1.



*Figure 7.* Dual PWMX output waveform (DEADTXE = 0)

Set dead time > 0 (set dead time prescaler if required). Enable dead time control (DEADTXE = 1). Set period and duty cycle (period > duty). Set PWMXE & IPWMXE =1, PWMXA = 0, IPWMXA = 0, and finally set TXEN = 1. For the loading of a new duty, period, and dead time value at run time, refer to subchapter *PWM Programming Process/Steps*.



Figure 8. Dual PWMX output waveform (DEADTXE = 1, Dead Time > 0)

## 6.8.6 PWM Programming Process/Steps

- 1. Load the PWM duty cycle to DT.
- 2. Load the PWM dead-time cycle (only for dual PWM function).
- 3. Load the PWM time period to PRD.
- 4. Enable the interrupt function by writing Bank0-R1D, if required.
- 5. Load a desired value for the timer prescaler.
- 6. Set active level of duty of PWM.
- 7. Enable PWMX function, i.e., enable PWMXE control bit. (If using dual PWM function, enable IPWMXE control bit too)
- 8. Finally, enable TMRX function, i.e., enable TXEN control bit.

If the application needs to change PWM duty, period, and dead-time cycle at run time, refer to the following programming steps:

- 1. Load new duty and dead-time cycle (if using dual PWM function) at any time.
- Load new period cycle. The loading order must be taken care. As the low byte of PWM period cycle is assigned a value, the new PWM cycle is loaded into circuit.
- 3. The circuit would automatically update the new duty, period, and dead-time cycle to generate new PWM waveform at the next PWM cycle.



| R BAN       | Addr.    | Name   | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0  |     |     |
|-------------|----------|--------|--------|--------|--------|--------|--------|--------|-------|--------|-----|-----|
| _           |          |        | -      | -      | UERRSF | URSF   | UTSF   | -      | -     | -<br>- |     |     |
| Bank 0      | 0x16     | SFR2   | -      | -      | R/W    | R/W    | R/W    | -      | -     | -      |     |     |
| Bank 0      | 0x1C     | IMR2   | -      | -      | UERRIE | URIE   | UTIE   | -      | -     | -      |     |     |
| Dank U      | UXIC     | IIVIKZ | -      | -      | R/W    | R/W    | R/W    | -      | -     | -      |     |     |
| Bank 1 0X33 | 0X33     | URCR   | UINVEN | UMODE1 | UMODE0 | BRATE2 | BRATE1 | BRATE0 | UTBE  | TXE    |     |     |
| Dalik I     | 0733     | UNCK   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W    |     |     |
| Bank 1      | 0X34     | URS    | URTD8  | EVEN   | PRE    | PRERR  | OVERR  | FMERR  | URB   | RXE    |     |     |
| Dalik I     | 0734     | 013    | W      | R/W    | R/W    | R/W    | R/W    | R/W    | R     | R/W    |     |     |
| Bank 1      | 0x35     | URTD   | URTD7  | URTD6  | URTD5  | URTD4  | URTD3  | URTD2  | URT   | URT    |     |     |
| Dalik I     | 0,33     | UNID   | W      | W      | W      | W      | W      | W      | W     | W      |     |     |
| Bank 1      | c 1 0X36 | 0736   | 0736   | URRDL  | URRD7  | URRD6  | URRD5  | URRD4  | URRD3 | URRD2  | URR | URR |
| Dalik I     |          |        | R      | R      | R      | R      | R      | R      | R     | R      |     |     |
| Bank 1      | 0X37     | URRDH  | URRD8  | -      | -      | -      | -      | -      | -     | -      |     |     |
| Ballk I     | 0//0/    | UNIDIT | R      | -      | -      | -      | -      | -      | -     | -      |     |     |

# 6.9 UART (Universal Asynchronous Receiver/Transmitter)



Registers for UART Circuit

Figure 6-16 UART Functional Block Diagram

In Universal Asynchronous Receiver Transmitter (UART), each transmitted or received character is individually synchronized by framing it with a start bit and stop bit.

Full duplex data transfer is possible since the UART has independent transmit and receive sections. Double buffering for both sections allows the UART to be programmed for continuous data transfer.

The figure below shows the general format of one character sent or received. The communication channel is normally held in the marked state (high). Character transmission or reception starts with a transition to the space state (low).



The first bit transmitted or received is the start bit (low). It is followed by the data bits, in which the least significant bit (LSB) comes first. The data bits are followed by the parity bit. If present, then the stop bit or bits (high) confirm the end of the frame.

In receiving, the UART synchronizes on a falling edge of the start bit. When two or three "0" are detected during three samples, it is recognized as normal start bit and the receiving operation is started.



Figure 6-17 Data Format in UART

#### 6.9.1 UART Mode

There are three UART modes. Mode 1 (7 bits data) and Mode 2 (8 bits data) allow the addition of a parity bit. The parity bit addition is not available in Mode 3. Figure 6-18a below shows the data format in each mode.



Figure 6-18a UART Model

## 6.9.2 Transmitting

In transmitting serial data, the UART operates as follows:

- 1. Set the TXE bit of the URCR1 register to enable the UART transmission function.
- 2. Write data into the URTD register and the UTBE bit of the URCR register will be cleared by hardware.
- 3. Then start transmitting.
- 4. Serially transmitted data are transmitted in the following order from the TX pin.
- 5. Start bit: one "**0**" bit is output.



- 6. Transmit data: 7, 8 or 9 bits data are output from the LSB to the MSB.
- 7. Parity bit: one parity bit (odd or even selectable) is output.
- 8. Stop bit: one "1" bit (stop bit) is output.

Mark state: output "1" continues until the start bit of the next transmitted data.

After transmitting the stop bit, the UART generates an UTSF interrupt (if enabled).

#### 6.9.3 Receiving

In receiving, the UART operates as follows:

- 1. Set the RXE bit of the URS register to enable the UART receiving function. The UART monitors the RX pin and synchronizes internally when it detects a start bit.
- 2. Receive data is shifted into the URRD register in the order from LSB to MSB.
- 3. The parity bit and the stop bit are received. After one character is received, the URBF bit of the URS register will be set to "1". This means UART interrupt will occur.
- 4. The UART makes the following checks:
  - (a) Parity check: The received data with number of "1" must match the even or odd parity setting of the EVEN bit in the URS register.
  - (b) Frame check: The start bit must be "0" and the stop bit must be "1".
  - (c) Overrun check: The URBF bit of the URS register must be cleared (that means the URRD register should be read out) before the next received data is loaded into the URRD register.

If any checks failed, the UERRSF interrupt will be generated (if enabled), and an error flag is indicated in PRERR, OVERR or FMERR bit. The error flag should be cleared by software, otherwise, UERRSF interrupt will occur when the next byte is received.

5. Read received data from URRD register. And URBF bit will be set by hardware.

#### 6.9.4 Baud Rate Generator

The baud rate generator is comprised of a circuit that generates a clock pulse to determine the transfer speed for transmission/reception in the UART.

The BRATE2~BRATE0 bits of the URC register can determine the desired baud rate.

#### 6.9.5 UART Timing

1. Transmission Counter Timing:





Figure 6-18b UART Timing Diagrams



| R_BANK | Address | Name   | Bit 7  | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2  | Bit 1  | Bit0   |
|--------|---------|--------|--------|-------|--------|-------|--------|--------|--------|--------|
|        | 0.40    |        | HLVDEN | IRVSF | VDSB   | VDM   | HLVDS3 | HLVDS2 | HLVDS1 | HLVDS0 |
| Bank 1 | 0x49    | HLVDCR | R/W    | R     | R      | R/W   | R/W    | R/W    | R/W    | R/W    |
|        |         |        |        |       | HLVDSF |       |        |        |        |        |
| Bank 0 | 0x14    | SFR    |        |       | R/W    |       |        |        |        |        |
| Denk 0 | 0.4D    |        |        |       | HLVDIE |       |        |        |        |        |
| Bank 0 | 0x1B    | IMR    |        |       | R/W    |       |        |        |        |        |
| Bank 0 | 0x10    |        |        |       | HLVDWK |       |        |        |        |        |
|        |         | WUCR   |        |       | R/W    |       |        |        |        |        |

# 6.10 HLVD (High / Low Voltage Detector)

Under unstable power source condition, such as external power noise interference or EMS test condition, a violent power vibration could occur. At the time, the VDD could become unstable as it could be operating below working voltage. When the system supply voltage (VDD) falls below operating voltage, the IC kernel will automatically keep all register statuses.

The following steps are needed to set up HLVD function:

- 1. Set HLVDEN to "1", then use Bits 3~0 (HLVDS3~HLVDS0) of Register Bank 1 R49 to set the HLVD interrupt level
- 2. Wait for HLVD interrupt to occur
- 3. Clear HLVD interrupt flag

The internal HLVD module uses the internal circuit to fit. When user set HLVDEN to enable the HLVD module, the current consumption will increase to 70  $\mu$ A.

During sleep mode, HLVD module continues to operate. If the device voltage drops slowly and crosses the detect point, HLVDSF bit will be set and the device will not wake up from Sleep mode. Until another wake-up source wakes up EM88F711N, HLVD interrupt flag will remain as the prior status.

When the system resets, the HLVD flag will be cleared.

Figure 6-30 illustrates HLVD module detecting an external voltage.

When VDD drops yet not below VLVD, HLVDSF remains at "0".

When VDD drops below VDB, HLVDSF is set to "1". If global ENI is enabled, HLVDSF will be set to "1" as well, and the next instruction will branch to the interrupt vector. The HLVD interrupt flag is cleared to "0" by software.

When VDD drops below  $V_{RESET}$  yet for less than 10  $\mu$ s, the system will keep all the register statuses and the system halts but oscillation is active. When VDD drops below





 $V_{RESET}$  and for more than 40  $\mu$ s, a system RESET will occur. Refer to Section 6.5.1 *Reset description.* 



# 6.11 Oscillator

### 6.11.1 Oscillator Modes

The EM88F711N can be operated in two different oscillator modes which are Internal RC oscillator mode (IRC) and XTAL oscillator mode (XT). Users need to set the main-oscillator modes by selecting the OSC2~OSC0, and set the sub-oscillator modes by selecting the FSS0 in the Code Option register to complete the overall oscillator mode setting. Table 6~8 depict how these four modes are defined.

The up-limited operating frequency of crystal/resonator on different VDD is listed in Table 6.

| Main-oscillator Mode                                                       | OSC2 | OSC1 | OSC0 |
|----------------------------------------------------------------------------|------|------|------|
| IRC (Internal RC oscillator mode) (default)<br>RCOUT (P51) acts as I/O pin | 0    | 0    | 0    |
| IRC (Internal RC oscillator mode)<br>RCOUT (P51) acts as clock output pin  | 0    | 0    | 1    |
| HXT1 (High XTAL1 oscillator mode)<br>Frequency range: 12~20MHz             | 0    | 1    | 0    |
| HXT2(High XTAL2 oscillator mode)<br>Frequency range: 6~12MHz               | 0    | 1    | 1    |
| XT (XTAL oscillator mode)<br>Frequency range: 1~6MHz                       | 1    | 0    | 0    |
| LXT1 (Low XTAL1 oscillator mode)<br>Frequency range: 100K~1MHz             | 1    | 0    | 1    |
| Reserve                                                                    | 1    | 1    | Х    |

#### Table 6 Main-oscillator modes defined by OSC2 ~ OSC0

#### Table 9 Summary of Maximum Operating Speeds

| Conditions                 | VDD | Fxt max. (MHz) |
|----------------------------|-----|----------------|
|                            | 2.2 | 8.0            |
| Two cycles with two clocks | 3.3 | 16.0           |
|                            | 5.0 | 20.0           |

## 6.11.2 Crystal Oscillator/Ceramic Resonators (XTAL)

In most applications, Pin OSCI and Pin OSCO can be connected with a crystal or ceramic resonator to generate oscillation and such circuitries are depicted in the following figures. The same thing applies whether it is in HXT or LXT mode. Table 10 provides the recommended values of C1 and C2. Since each resonator has its own attribute, user should refer to its specification for appropriate values of C1 and C2. The serial resistor, RS, may be necessary for AT strip-cut crystal or under low-frequency mode.





Figure 6-31 Crystal/Resonator Circuits

| Oscillator Type                         | Frequency Mode      | Frequency | C1 (pF) | C2 (pF) |
|-----------------------------------------|---------------------|-----------|---------|---------|
|                                         |                     | 100kHz    | 60pF    | 60pF    |
|                                         | LXT                 | 200kHz    | 60pF    | 60pF    |
|                                         | (100K~1 MHz)        | 455kHz    | 40pF    | 40pF    |
| Main-oscillator<br>(Ceramic Resonators) |                     | 1.0 MHz   | 30pF    | 30pF    |
|                                         |                     | 1.0 MHz   | 30pF    | 0pF     |
|                                         | HXT2<br>(1M~6 MHz)  | 2.0 MHz   | 30pF    | 30pF    |
|                                         | (101-0 10112)       | 4.0 MHz   | 20pF    | 20pF    |
|                                         |                     | 100kHz    | 60pF    | 60pF    |
|                                         | LXT<br>(100K~1 MHz) | 200kHz    | 60pF    | 60pF    |
|                                         |                     | 455kHz    | 40pF    | 40pF    |
|                                         |                     | 1.0 MHz   | 30pF    | 30pF    |
|                                         |                     | 1.0 MHz   | 30pF    | 30pF    |
|                                         | хт                  | 2.0 MHz   | 30pF    | 30pF    |
| Main-oscillator<br>(Crystal Oscillator) | (1M~6 MHz)          | 4.0 MHz   | 20pF    | 20pF    |
|                                         |                     | 6.0 MH    | 0F      | 30pF    |
|                                         |                     | 6.0 MHz   | 30pF    | 30pF    |
|                                         | HXT2<br>(6M~12 MHz) | 8.0 MHz   | 20pF    | 20pF    |
|                                         |                     | 12.0 MHz  | 30pF    | 30pF    |
|                                         | HX1                 | 12.0 MHz  | 30pF    | 30pF    |
|                                         | (12M~16 MHz)        | 16.0 MHz  | 20pF    | 20pF    |

#### Table 10 Capacitor Select Guide for Crystal Oscillator or Ceramic Resonator

## 6.11.3 Internal RC Oscillator Mode

EM88F711N offers a versatile internal RC mode with default frequency value of 4MHz. The Internal RC oscillator mode has multiple frequencies (20MHz, 16MHz, 12MHz, 10MHz, 8MHz, 4MHz and 1 MHz) that can be set by Code Options RCM1 and RCM0. All four main frequencies can be calibrated by programming the Code Option bits: C6~C0. The table below describes a typical instance of the calibration.



|                          | Drift Rate                   |                        |         |       |  |  |  |  |
|--------------------------|------------------------------|------------------------|---------|-------|--|--|--|--|
| Internal RC<br>Frequency | Temperature<br>(-40°C∼+85°C) | Voltage<br>(2.2V~5.5V) | Process | Total |  |  |  |  |
| 1 MHz                    | ±2%                          | ±1%                    | ±1%     | ±4%   |  |  |  |  |
| 4 MHz                    | ±2%                          | ±1%                    | ±1%     | ±4%   |  |  |  |  |
| 8 MHz                    | ±2%                          | ±1%                    | ±1%     | ±4%   |  |  |  |  |
| 10MHz                    | ±2%                          | ±1%                    | ±1%     | ±4%   |  |  |  |  |
| 12MHz                    | ±2%                          | ±1%                    | ±1%     | ±4%   |  |  |  |  |
| 16 MHz                   | ±2%                          | ±1%                    | ±1%     | ±4%   |  |  |  |  |
| 20MHz                    | ±2%                          | ±1%                    | ±1%     | ±4%   |  |  |  |  |

#### Internal RC Drift Rate (Ta=25°C, VDD=5V, VSS=0V)

**Note:** These are theoretical values provided for reference only. Actual values may vary depending on the actual process.

# 6.12 Power-on Considerations

No microcontroller is guaranteed to operate properly before the power supply stabilizes to a steady state. The EM88F711N is equipped with a built-in Power-On Voltage Detector (POVD) with a detect level of 2.0V. It will work well if VDD rises fast enough (0.05V/ms or less). However, in many critical applications, extra devices are still required to assist in solving power-up problems.

# 6.13 External Power-on Reset Circuit

The circuits shown in Figure 6-32 implement an external RC to generate a reset pulse. The pulse width (time constant) should be kept long enough for VDD to reach the minimum operating voltage. Apply this circuit when the power supply has a slow rising time. Since the current leakage from the /RESET pin is about  $\pm 5 \ \mu$ A, it is recommended that R should not be greater than 40 K $\Omega$  in order for the /RESET pin voltage to remain below 0.2V. The diode (D) acts as a short circuit at the moment of power-down. The capacitor (C) will discharge rapidly and fully. The current-limited resistor (Rin) will prevent high current or ESD (electrostatic discharge) from flowing to Pin /RESET.







# 6.14 Residue-Voltage Protection

When the battery is replaced, device power (VDD) is taken off but residue-voltage remains. The residue-voltage may trip below VDD minimum, but not to zero. This condition may cause a poor power-on reset. Figure 6-33a and 6-33b show how to build and accomplish a proper residue-voltage protection circuit.



Figure 6-33a Residue Voltage Protection Circuit 1



Figure 6-33b Residue Voltage Protection Circuit 2



### 6.15 Code Option

| Word 0   |        |         |         |        |         |        |             |      |  |  |
|----------|--------|---------|---------|--------|---------|--------|-------------|------|--|--|
|          | Bit 15 | Bit 14  | Bit 13  | Bit 12 | Bit11   | Bit10  | Bit9        | Bit8 |  |  |
| Mnemonic | -      | -       | -       | IODG1  | IODG0   | HLFS   | HLP         | LVR1 |  |  |
| 1        | High   | High    | High    | High   | High    | Green  | Low<br>PWR  | High |  |  |
| 0        | Low    | Low     | Low     | Low    | Low     | Normal | High<br>PWR | Low  |  |  |
| Default  | 0      | 0       | 0       | 0      | 0       | 0      | 0           | 0    |  |  |
|          | Bit7   | Bit6    | Bit5    | Bit4   | Bit3    | Bit2   | Bit1        | Bit0 |  |  |
| Mnemonic | LVR0   | RESETEN | ENWDT   | NRHL   | NRE     | -      | -           | -    |  |  |
| 1        | High   | /RST    | Enable  | 8/fc   | Disable |        | High        |      |  |  |
| 0        | Low    | P81     | Disable | 32/fc  | Enable  | Low    |             |      |  |  |
| Default  | 0      | 0       | 0       | 0      | 0       | 0      |             |      |  |  |

#### 6.15.1 Code Option Register (Word 0)

Bits 15~13: Not used, set to "0" all the time.

Bits 12~11 (IODG1~IODG0): UART pin deglitch time select bits.

| IODG1~0 | UART pin deglitch time    |
|---------|---------------------------|
| 00      | 50ns@5v,Typical (default) |
| 01      | 200ns@5v,Typical          |
| 10      | 400ns@5v,Typical          |
| 11      | no deglitch               |

Bit 10 (HLFS): Reset to Normal or Green Mode Select Bit

1: CPU is selected as Green mode when a reset occurs.

0: CPU is selected as Normal mode when a reset occurs. (default)

Bit 9 (HLP): Power Consumption Select

1: Low power consumption, apply to working frequencies at 1MHz or below 1MHz

 $\ensuremath{\textbf{0}}$  : High power consumption, apply to working frequencies above 1MHz

Bits 8~7 (LVR1~LVR0): Low Voltage Reset enable bit.

| LVR1, LVR0 | *VDD Reset Level              | VDD Release Level |  |  |  |  |  |
|------------|-------------------------------|-------------------|--|--|--|--|--|
| 00         | NA (Power on reset) (default) |                   |  |  |  |  |  |
| 01         | 2.5V                          | 2.7V              |  |  |  |  |  |
| 10         | 3.5V                          | 3.7V              |  |  |  |  |  |
| 11         | 4.0V                          | 4.2V              |  |  |  |  |  |

Note: If VDD < 2.7V and remains for about 5us, IC will be reset.

If VDD < 3.7V and remains for about 5us, IC will be reset.

If VDD < 4.2V and remains for about 5us, IC will be reset.

Bit 6 (RESETEN): P81/RESET pin select bit

1: Enable, P81 as RESET pin.

0: Disable, P81 as I/O pin (default)

Bit 5 (ENWDT): WDT enable bit

1: Enable



0: Disable (default)

Bit 4 (NRHL): Noise rejection high/low pulse define bit.

1: Pulses equal to 8/Fc [s] are regarded as signal

0: Pulses equal to 32/Fc [s] are regarded as signal (default)

<Note> In Low XTAL oscillator (LXT) mode, the high/low pulses of noise rejection are always 8/Fm.

Bit 3 (NRE): Noise rejection enable bit

1: Disable.

**0:** Enable (default). **But in Green, Idle, and Sleep modes, the noise rejection circuit is always disabled.** 

Bits 2~0: Not used, set to "0" all the time.

6.15.2 Code Option Register (Word 1)

| Word 1   |        |        |        |        |       |       |      |      |  |  |
|----------|--------|--------|--------|--------|-------|-------|------|------|--|--|
|          | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit11 | Bit10 | Bit9 | Bit8 |  |  |
| Mnemonic | -      | -      | FSS    | -      | -     | -     | -    | -    |  |  |
| 1        | High   | High   | High   | High   | High  | High  | High | High |  |  |
| 0        | Low    | Low    | Low    | Low    | Low   | Low   | Low  | Low  |  |  |
| Default  | 0      | 0      | 0      | 0      | 0     | 0     | 0    | 0    |  |  |
|          | Bit7   | Bit6   | Bit5   | Bit4   | Bit3  | Bit2  | Bit1 | Bit0 |  |  |
| Mnemonic | -      | RCM2   | RCM1   | RCM0   | OSC2  | OSC1  | OSC0 | -    |  |  |
| 1        | High   | High   | High   | High   | High  | High  | High | High |  |  |
| 0        | Low    | Low    | Low    | Low    | Low   | Low   | Low  | Low  |  |  |
| Default  | 0      | 0      | 0      | 0      | 0     | 0     | 0    | 0    |  |  |

Bits 15~14: Not used, set to "0" all the time.

Bit 13 (FSS): Sub-oscillator mode select bit.

0: 16kHz (WDT frequency)

1: 128kHz.

Bit 7~12: Not used, set to "0" all the time.

Bits 6~4 (RCM2~RCM0): IRC frequency select.

\* Corresponding with control registers Bank0 RE RCM2~RCM0

| RCM2 | RCM1 | RCM0 | Frequency (MHz) |
|------|------|------|-----------------|
| 0    | 0    | 0    | 4(default)      |
| 0    | 0    | 1    | 1               |
| 0    | 1    | 0    | 8               |
| 0    | 1    | 1    | 10              |
| 1    | 0    | 0    | 12              |
| 1    | 0    | 1    | 16              |
| 1    | 1    | 0    | 20              |
| 1    | 1    | 1    | Reserve         |



| Main-oscillator mode                                                       | OSC2 | OSC1 | OSC0 |
|----------------------------------------------------------------------------|------|------|------|
| IRC (Internal RC oscillator mode) (default)<br>RCOUT (P51) acts as I/O pin | 0    | 0    | 0    |
| IRC (Internal RC oscillator mode)<br>RCOUT (P51) acts as clock output pin  | 0    | 0    | 1    |
| HXT1 (High XTAL1 oscillator mode)<br>Frequency range: 12~20MHz             | 0    | 1    | 0    |
| HXT2(High XTAL2 oscillator mode)<br>Frequency range: 6~12MHz               | 0    | 1    | 1    |
| XT (XTAL oscillator mode)<br>Frequency range: 1~6MHz                       | 1    | 0    | 0    |
| LXT1 (Low XTAL1 oscillator mode)<br>Frequency range: 100K~1MHz             | 1    | 0    | 1    |
| Reserve                                                                    | 1    | 1    | Х    |

Bit 0: Not used, set to "0" all the time.

#### 6.15.3 Code Option Register (Word 2)

|          | Word 2    |         |        |        |       |       |      |      |  |  |  |  |
|----------|-----------|---------|--------|--------|-------|-------|------|------|--|--|--|--|
|          | Bit 15    | Bit 14  | Bit 13 | Bit 12 | Bit11 | Bit10 | Bit9 | Bit8 |  |  |  |  |
| Mnemonic | -         | SHEN    | SHCLK1 | SHCLK0 |       |       |      |      |  |  |  |  |
| 1        | High      | Disable | High   | High   |       |       |      |      |  |  |  |  |
| 0        | Low       | Enable  | Low    | Low    |       |       |      |      |  |  |  |  |
| Default  | 0         | 0       | 0      | 0      | 0     | 0     | 0    | 0    |  |  |  |  |
|          | Bit7      | Bit6    | Bit5   | Bit4   | Bit3  | Bit2  | Bit1 | Bit0 |  |  |  |  |
| Mnemonic | IRCPSS    | -       | -      |        | -     | -     | -    | -    |  |  |  |  |
| 1        | VDD       | -       | -      |        | -     | -     | -    |      |  |  |  |  |
| 0        | Int. Vref | -       | -      |        | -     | -     | -    | -    |  |  |  |  |
| Default  | 0         | 0       | 0      | 0      | 0     | 0     | 0    | 0    |  |  |  |  |

Bit 15: Not used, set to "0" all the time.

Bit 14 (SHEN): System hold enable bit.

1: Disable

0: Enable

Bits 13~12 (SHCLK1~SHCLK0): System hold clock select bits (extra 128 kHz source)

| SHCLK1~0 | System hold clock  |  |  |  |  |
|----------|--------------------|--|--|--|--|
| 00       | 8 clocks (default) |  |  |  |  |
| 01       | 4 clocks           |  |  |  |  |
| 10       | 16 clocks          |  |  |  |  |
| 11       | 32 clocks          |  |  |  |  |

Bits 11~8: Not used, set to "0" all the time.

Bit 7 (IRCPSS): IRC Power Source Select

1: VDD

0: Internal reference (default)

Bits 6~0: Not used, set to "0" all the time.



|          | Word 3       |        |             |        |       |       |      |              |  |  |  |
|----------|--------------|--------|-------------|--------|-------|-------|------|--------------|--|--|--|
|          | Bit 15       | Bit 14 | Bit 13      | Bit 12 | Bit11 | Bit10 | Bit9 | Bit8         |  |  |  |
| Mnemonic | -            | EFTIM  | -           | -      | ADFM  | -     | -    | IRCOMS       |  |  |  |
| 1        | High         | Heavy  | High        | High   | High  | High  | High | Slowdow<br>n |  |  |  |
| 0        | Low          | Light  | Low         | Low    | Low   | Low   | Low  | Speedup      |  |  |  |
| Default  | 0            | 0      | 0           | 0      | 0     | 0     | 0    | 0            |  |  |  |
|          | Bit7         | Bit6   | Bit5        | Bit4   | Bit3  | Bit2  | Bit1 | Bit0         |  |  |  |
| Mnemonic | RLEN         |        | ID5         | ID4    | ID3   | ID2   | ID1  | ID0          |  |  |  |
| 1        | Reload       | High   |             |        |       |       |      |              |  |  |  |
| 0        | No<br>Reload | Low    | Customer ID |        |       |       |      |              |  |  |  |
| Default  | 0            | 0      |             |        |       |       |      |              |  |  |  |

| 6.15.4 Co | de Option | Register | (Word 3) |
|-----------|-----------|----------|----------|
|-----------|-----------|----------|----------|

Bit 15: Not used, set to "0" all the time.

Bit 14 (EFTIM): Low Pass Filter (0: heavy, 1: light)

1: Pass ~ 10MHz (heavy LPS)

0: Pass ~ 25MHz (light LPS) (default)

Bits 13~12: Not used, set to "0" all the time.

**Bit 11 (ADFM):** This bit controls the format of AD data buffer (ADDH & ADDL). Refer to the following table.

|              | ADF | М    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------------|-----|------|-------|-------|-------|-------|-------|-------|-------|-------|
|              | 0   | ADDH |       |       |       |       | ADD11 | ADD10 | ADD9  | ADD8  |
| 0<br>12 bits | 0   | ADDL | ADD7  | ADD6  | ADD5  | ADD4  | ADD3  | ADD2  | ADD1  | ADD0  |
|              | 1   | ADDH | ADD11 | ADD10 | ADD9  | ADD8  | ADD7  | ADD6  | ADD5  | ADD4  |
|              | 1   | ADDL |       |       |       |       | ADD3  | ADD2  | ADD1  | ADD0  |

Note: Do not use if the hardware bits are set to "0".

If ADFM=0, ADDH<7:4> = 0000.

Bits 10~9: Not used, set to "0" all the time.

Bit 8 (IRCOMS): IRC Oscillation Mode Select bit (Not for Customer).

**1:** IRC oscillation frequency is slowed down to the set value.

0: IRC oscillation frequency is speeded up to the set value. (Default)

#### Maximum Operating Speed

|     | IRCOMS=0       | IRCOMS=1       |
|-----|----------------|----------------|
| VDD | Fxt max. (MHz) | Fxt max. (MHz) |
| 2.2 | 8.0            | 4.0            |
| 3.3 | 16.0           | 10.0           |
| 5.0 | 20.0           | 12.0           |



Bit 7 (RLEN): Reload Enable

1: Program code reloaded

0: No reload function

Bit 6: Not used, set to "0" all the time.

Bits 5~0 (ID5~ID0): Customer's ID Code

#### 6.15.5 Code Option Register (Word D)

|          | Word D |        |        |        |       |       |      |      |  |
|----------|--------|--------|--------|--------|-------|-------|------|------|--|
|          | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit11 | Bit10 | Bit9 | Bit8 |  |
| Mnemonic |        |        | SC5    | SC4    | SC3   | SC2   | SC1  | SC0  |  |
| 1        | High   | High   | High   | High   | High  | High  | High | High |  |
| 0        | Low    | Low    | Low    | Low    | Low   | Low   | Low  | Low  |  |
| Default  | 0      | 0      | 0      | 0      | 0     | 0     | 0    | 0    |  |
|          | Bit7   | Bit6   | Bit5   | Bit4   | Bit3  | Bit2  | Bit1 | Bit0 |  |
| Mnemonic |        | C6     | C5     | C4     | C3    | C2    | C1   | C0   |  |
| 1        | High   | High   | High   | High   | High  | High  | High | High |  |
| 0        | Low    | Low    | Low    | Low    | Low   | Low   | Low  | Low  |  |
| Default  | 0      | 0      | 0      | 0      | 0     | 0     | 0    | 0    |  |

Bits 15~14: Not used, set to "0" all the time.

**Bits 13~8 (SC5~SC0):** Trim bits of sub-frequency IRC. These are automatically set by writer and eUIDE II.

Bit 7: Not used, set to "0" all the time.

Bits 6~0 (C6~C0): IRC trim bits. These are automatically set by writer and eUIDE II.



### 6.16 Instruction Set

Each instruction in the instruction set is a 15-bit word divided into an OP code and one or more operands. Normally, all instructions are executed within one single instruction cycle (one instruction consists of 2 oscillator periods), unless the program counter is changed by instruction "MOV R2,A", "ADD R2,A", or by instructions of arithmetic or logic operation on R2 (e.g. "SUB R2,A", "BS(C) R2,6", "CLR R2", etc.). In this case, the execution takes two instruction cycles.

If for some reasons, the specification of the instruction cycle is not suitable for certain applications, try modifying the instruction as follows:

The conditional skip ("JBS", "JBC", "JZ", "JZA", "DJZ", "DJZA") commands which were tested to be true, are executed within two instruction cycles. The instructions that are written to the program counter also take two instruction cycles.

In addition, the instruction set has the following features:

- (1) Every bit of any register can be set, cleared, or tested directly (except for read-only)
- (2) The I/O register can be regarded as general register. That is, the same instruction can operate on I/O register.

#### Instruction Set Convention:

- **R** = Register designator that specifies which one of the registers (including operation and general-purpose registers) is to be utilized by the instruction.
- **b** = Bit field designator that selects the value for the bit located in the register R and which affects the operation.

| Mnemonic | Operation                                                | Status Affected                                           |
|----------|----------------------------------------------------------|-----------------------------------------------------------|
| NOP      | No Operation                                             | None                                                      |
| DAA      | Decimal Adjust A                                         | С                                                         |
| SLEP     | $0 \rightarrow WDT$ , Stop oscillator                    | T,P                                                       |
| WDTC     | $0 \rightarrow WDT$                                      | T,P                                                       |
| ENI      | Enable Interrupt                                         | None                                                      |
| DISI     | Disable Interrupt                                        | None                                                      |
| RET      | [Top of Stack] $\rightarrow$ PC                          | None                                                      |
| RETI     | [Top of Stack] $\rightarrow$ PC, Enable Interrupt        | None                                                      |
| RESET    | Software Device Reset                                    | ALL Registers<br>= Reset Value<br>Flags*<br>= Reset Value |
| TBWR     | Table Writer Start instruction                           | None                                                      |
| INT k    | $PC+1 \rightarrow [SP], k^{*}2 \rightarrow PC$           | None                                                      |
| BTG R,b  | Bit Toggle R ;/(R <b>)-&gt;R<b><br/>*Range R0~RF</b></b> | None                                                      |
| MOV R,A  | $A \rightarrow R$                                        | None                                                      |
| CLRA     | $0 \rightarrow A$                                        | Z                                                         |
| CLR R    | $0 \rightarrow R$                                        | Z                                                         |
| SUB A,R  | $R-A \rightarrow A$                                      | Z, C, DC                                                  |



| Mnemonic | Operation                                                                                           | Status Affected |
|----------|-----------------------------------------------------------------------------------------------------|-----------------|
|          | -                                                                                                   |                 |
| SUB R,A  | $R-A \rightarrow R$                                                                                 | Z, C, DC        |
| DECA R   | $R-1 \rightarrow A$                                                                                 | Z               |
| DEC R    | $R-1 \rightarrow R$                                                                                 | Z               |
| OR A,R   | $A \lor R \rightarrow A$                                                                            | Z               |
| OR R,A   | $A \lor R \to R$                                                                                    | Z               |
| AND A,R  | $A \& R \rightarrow A$                                                                              | Z               |
| AND R,A  | $A \& R \rightarrow R$                                                                              | Z               |
| XOR A,R  | $A \oplus R \to A$                                                                                  | Z               |
| XOR R,A  | $A \oplus R \to R$                                                                                  | Z               |
| ADD A,R  | $A + R \rightarrow A$                                                                               | Z, C, DC        |
| ADD R,A  | $A + R \rightarrow R$                                                                               | Z, C, DC        |
| MOV A,R  | $R \rightarrow A$                                                                                   | Z               |
| MOV R,R  | $R \rightarrow R$                                                                                   | Z               |
| COMA R   | $/R \rightarrow A$                                                                                  | Z               |
| COM R    | $/R \rightarrow R$                                                                                  | Z               |
| INCA R   | $R+1 \rightarrow A$                                                                                 | Z               |
| INC R    | $R+1 \rightarrow R$                                                                                 | Z               |
| DJZA R   | $R-1 \rightarrow A$ , skip if zero                                                                  | None            |
| DJZ R    | $R-1 \rightarrow R$ , skip if zero                                                                  | None            |
|          | $R(n) \rightarrow A(n-1),$                                                                          |                 |
| RRCA R   | $R(0) \rightarrow C, C \rightarrow A(7)$                                                            | C               |
| RRC R    | $ \begin{array}{c} R(n) \to R(n\text{-}1), \\ R(0) \to C, C \to R(7) \end{array} $                  | С               |
| RLCA R   | $ \begin{array}{c} R(n) \to A(n+1), \\ R(7) \to C,  C \to A(0) \end{array} $                        | С               |
| RLC R    | $ \begin{array}{c} R(n) \rightarrow R(n+1), \\ R(7) \rightarrow C, C \rightarrow R(0) \end{array} $ | С               |
| SWAPA R  | $R(0-3) \rightarrow A(4-7),$<br>$R(4-7) \rightarrow A(0-3)$                                         | None            |
| SWAP R   | $R(0-3) \leftrightarrow R(4-7)$                                                                     | None            |
| JZA R    | R+1 $\rightarrow$ A, skip if zero                                                                   | None            |
| JZ R     | $R+1 \rightarrow R$ , skip if zero                                                                  | None            |
| BC R,b   | $0 \rightarrow R(b)$                                                                                | None            |
| BS R,b   | $1 \rightarrow R(b)$                                                                                | None            |
| JBC R,b  | if R(b)=0, skip                                                                                     | None            |
| JBS R,b  | if R(b)=1, skip                                                                                     | None            |
| CALL k   | $PC+1 \rightarrow [SP],$<br>(Page, k) $\rightarrow PC$                                              | None            |
| JMP k    | $(Page, k) \rightarrow PC$                                                                          | None            |
| MOV A,k  | $k \rightarrow A$                                                                                   | None            |
| JER      | Compare R with ACC, Skip =                                                                          | None            |
| JGE R    | Compare R with ACC, Skip >                                                                          | None            |
| JLE R    | Compare R with ACC Skip <                                                                           | None            |
| OR A,k   | $A \lor k \rightarrow A$                                                                            | Z               |
| JEk      | Compare K with ACC, Skip =                                                                          | None            |
| JL K     | $[ROM[(TABPTR)] \rightarrow R, A$                                                                   | INGINE          |
| TBRDA R  | $A \leftarrow \text{program code (low byte)};$                                                      | None            |
|          | $R \leftarrow \text{program code (low byte)},$                                                      |                 |
| AND A,k  | $A \& k \rightarrow A$                                                                              | Z               |
| AND A,K  | $A \propto K \rightarrow A$ Jump to K if Carry                                                      | <u> </u>        |
| SJC k    |                                                                                                     | None            |
|          | *Range [Address <u>+</u> 128]                                                                       |                 |
| SJNC k   | Jump to K if Not Carry<br>*Range [Address <u>+</u> 128]                                             | None            |
| SJZ k    | Jump to K if Zero                                                                                   | None            |



| Mnemonic | Operation                                                                         | Status Affected |
|----------|-----------------------------------------------------------------------------------|-----------------|
|          | *Range [Address <u>+</u> 128]                                                     |                 |
| XOR A,k  | $A \oplus k \to A$                                                                | Z               |
| SJNZ k   | Jump to K if Not Zero<br>*Range [Address <u>+</u> 128]                            | None            |
| RRA R    | $R(n) \rightarrow A(n-1),  R(0) \rightarrow A(7)$                                 | N               |
| RR R     | $R(n) \to R(n-1),  R(0) \to R(7)$                                                 | N               |
| RETLk    | $k \rightarrow A$ ,<br>[Top of Stack] $\rightarrow PC$                            | None            |
| XCH R    | $R \longleftrightarrow A$                                                         | None            |
| RLA R    | $R(n) \rightarrow A(n+1),  R(7) \rightarrow A(0)$                                 | N               |
| RL R     | $R(n) \rightarrow R(n+1),  R(7) \rightarrow R(0)$                                 | Ν               |
| SUB A,k  | $k-A \rightarrow A$                                                               | Z, C, DC        |
| SUBB A,R | $R-A-/C \rightarrow A$                                                            | Z, C, DC, OV, N |
| SUBB R,A | $R-A-/C \rightarrow R$                                                            | Z, C, DC, OV, N |
| SBANK k  | K->R1(4)                                                                          | None            |
| GBANK k  | K->R1(0)                                                                          | None            |
| LCALL k  | Next instruction: k kkkk kkkk kkkk<br>PC+1 $\rightarrow$ [SP], k $\rightarrow$ PC | None            |
| LJMP k   | Next instruction: k kkkk kkkk kkkk Kkkk Kkkk kkkk                                 | None            |
| TBRD R   | $ROM[(TABPTR)] \rightarrow R$                                                     | None            |
| ADD A,k  | $k+A \rightarrow A$                                                               | Z, C, DC        |
| NEG R    | 2-complement, /R +1 $\rightarrow$ R                                               | Z,C,DC,OV,N     |
| ADC A,R  | $A+R+C \rightarrow A$                                                             | Z,C,DC,OV,N     |
| ADC R,A  | $A+R+C \rightarrow R$                                                             | Z,C,DC,OV,N     |

# 7 Absolute Maximum Ratings

| Items                  |          | Rating |          |
|------------------------|----------|--------|----------|
| Temperature under bias | -40°C    | to     | 85°C     |
| Storage temperature    | -65°C    | to     | 150°C    |
| Input voltage          | VSS-0.3V | to     | VDD+0.5V |
| Output voltage         | VSS-0.3V | to     | VDD+0.5V |
| Operating Voltage      | 2.2V     | to     | 5.5V     |
| Operating Frequency    | DC       | to     | 20 MHz   |



# 8 DC Electrical Characteristics

VDD=5.0V, VSS=0V, Ta=25°C

| Symbol | Parameter                                         | Condition                                        | Min.   | Тур. | Max.     | Unit |
|--------|---------------------------------------------------|--------------------------------------------------|--------|------|----------|------|
|        | XTAL: VDD to 3V                                   | Two cycles with two clocks                       | DC     | 8    | -        | MHz  |
|        | XTAL: VDD to 5V                                   |                                                  | DC     | 16   | -        | MHz  |
| Fxt    | IRC: VDD to 5V                                    | 4 MHz, 1 MHz, 8kHz, 10MHz, 12MHz, 16 MHz, 20MHz, | -      | F    | -        | Hz   |
|        | IRC: VDD=5V, 25°C                                 | use UWTR                                         | -1%    | F    | +1%      | Hz   |
|        | IRC: VDD=5V, 25°C                                 | use NUWTR                                        | -2%    | F    | +2%      | Hz   |
| IIL    | Input Leakage Current for input pins              | VIN = VDD, VSS                                   | -1     | 0    | 1        | μA   |
| IRCE   | Internal RC oscillator error per stage            | -                                                | -      | ±1   | -        | %    |
| IRC1   | IRC:VDD to 5V                                     | RCM2~RCM1=000                                    |        | 4    |          | MHz  |
| IRC2   | IRC:VDD to 5V                                     | RCM2~RCM1=001                                    |        | 1    |          | MHz  |
| IRC3   | IRC:VDD to 5V                                     | RCM2~RCM1=010                                    |        | 6    |          | MHz  |
| IRC4   | IRC:VDD to 5V                                     | RCM2~RCM1=011                                    |        | 8    |          | MHz  |
| IRC5   | IRC:VDD to 5V                                     | RCM2~RCM1=100                                    |        | 12   |          | MHz  |
| IRC6   | IRC:VDD to 5V                                     | RCM2~RCM1=101                                    |        | 16   |          | MHz  |
| IRC7   | IRC:VDD to 5V                                     | RCM2~RCM1=110                                    |        | 20   |          | MHz  |
| VIH1   | Input High Voltage (Schmitt Trigger)              | Ports 5, 6, 7, 8                                 | 0.7VDD | _    | VDD+0.3V | V    |
| VIL1   | Input Low Voltage (Schmitt Trigger)               | Ports 5, 6, 7, 8                                 | -0.3V  | _    | 0.3VDD   | V    |
| VIHT1  | Input High Threshold Voltage<br>(Schmitt Trigger) | /RESET                                           | 0.7VDD | _    | VDD+0.3V | V    |
| VILT1  | Input Low Threshold Voltage<br>(Schmitt Trigger)  | /RESET                                           | -0.3V  | _    | 0.3VDD   | V    |
| VIHT2  | Input High Threshold Voltage<br>(Schmitt Trigger) | INT                                              | 0.7VDD | _    | VDD+0.3V | V    |
| VILT2  | Input Low Threshold Voltage<br>(Schmitt Trigger)  | INT                                              | -0.3V  | _    | 0.3VDD   | V    |
| VIHX1  | Clock Input High Voltage                          | OSCI in crystal mode                             | 2.9    | 3.0  | 3.1      | V    |
| VILX1  | Clock Input Low Voltage                           | OSCI in crystal mode                             | 1.7    | 1.8  | 1.9      | V    |
| IOH1   | High Drive Current 1 (Ports 5~8)                  | VOH = VDD-0.1VDD                                 | -2.7   | -4.5 | -        | mA   |
| IOH2   | High Drive Current 2 (Ports 5~8)                  | VOH = VDD-0.1VDD                                 | -4.8   | -8   | -        | mA   |
| IOL1   | Low Sink Current 1 (Ports 5~8)                    | VOL = GND+0.1VDD                                 | 8.4    | 14   | -        | mA   |
| IOL2   | Low Sink Current 2 (Ports 5~8)                    | VOL = GND+0.1VDD                                 | 16.8   | 28   | _        | mA   |
| IPH    | Pull-high current                                 | Pull-high active, input pin @<br>VSS             | 47     | -72  | 97       | μA   |
| IPL    | Pull-low current                                  | Pull-low active, input pin @ VDD                 | 27     | 52   | 77       | μA   |



| Symbol | Parameter                                                           | Condition                                                                                                   | Min. | Тур. | Max. | Unit |
|--------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------|------|------|------|
| LVR1   | Low voltage reset                                                   | Ta = 25°C                                                                                                   | 2.41 | 2.7  | 2.99 | V    |
|        | Level 1 (2.7V)                                                      | Ta = -40°C ~ 85°C                                                                                           | 2.14 | 2.7  | 3.25 | V    |
| LVR2   | Low voltage reset                                                   | Ta = 25°C                                                                                                   | 3.1  | 3.5  | 3.92 | V    |
| LVNZ   | VR2Level 2 ( $3.5V$ )Ta = -40°C ~ 85°CVP3Low voltage resetTa = 25°C |                                                                                                             | 2.73 | 3.5  | 4.25 | V    |
| LVR3   |                                                                     | Ta = 25°C                                                                                                   | 3.56 | 4.0  | 4.43 | V    |
| LVKJ   | Level 3 (4.0V)                                                      | Ta = -40°C ~ 85°C                                                                                           | 3.16 | 4.0  | 4.81 | V    |
| ISB1   | Power-down current                                                  | Ta=25°C, /RESET= 'High', Fm & Fs off<br>All input and I/O pins at VDD,<br>Output pin floating, WDT disabled | Ι    | 1    | 2    | μΑ   |
| 1301   | (Sleep mode)                                                        | Ta=85°C, /RESET= 'High', Fm & Fs off<br>All input and I/O pins at VDD,<br>Output pin floating, WDT disabled | -    | 2    | 2.5  | μΑ   |
| ISB2   | Power-down current<br>(Sleep mode)                                  | /RESET= 'High', Fm & Fs off<br>All input and I/O pins at VDD, output pin floating,<br>WDT enabled           | -    | 4.2  | -    | μΑ   |
| ISB3   | Power-down current<br>(Idle mode)                                   | /RESET= 'High', Fm off, Fs=16KHz (IRC type),<br>output pin floating, WDT enabled, PERCS=0                   | -    | 5.6  | -    | μA   |
| ISB4   | Power-down current<br>(Idle mode)                                   | /RESET= 'High', Fm off, Fs=128KHz (IRC type),<br>output pin floating, WDT enabled, PERCS=0                  | Ι    | 19   | -    | μΑ   |
| ISB5   | Power-down current<br>(Idle mode)                                   | /RESET= 'High', Fm off, Fs=16KHz (IRC type),<br>output pin floating, WDT enabled, PERCS=1                   | -    | 22   | -    | μA   |
| ICC1   | Operating supply current<br>(Green mode)                            | /RESET= 'High', Fm off, Fs=16kHz<br>(IRC type), output pin floating, WDT enabled                            | Ι    | 12.8 | -    | μΑ   |
| ICC2   | Operating supply current<br>(Green mode)                            | /RESET= 'High', Fm off, Fs=128kHz<br>(IRC type), Output pin floating, WDT enabled                           | _    | 17.6 | -    | μA   |
| ICC4   | Operating supply current (Normal mode)                              | /RESET= 'High', Fm=4 MHz (Crystal type), Fs on, output pin floating, WDT enabled                            | 1    | 1.6  | _    | mA   |
| ICC5   | Operating supply current (Normal mode)                              | /RESET= 'High', Fm=4 MHz (IRC type), Fs on, output pin floating, WDT enabled                                | -    | 1.5  | _    | mA   |
| ICC6   | Operating supply current (Normal mode)                              | /RESET= 'High', Fm=10 MHz<br>(Crystal type), Fs on, output pin floating,<br>WDT enabled                     | -    | 3.6  | -    | mA   |
| ICC7   | Operating supply current (Normal mode)                              | /RESET= 'High', Fm=16 MHz (IRC type), Fs on, output pin floating, WDT enabled                               | _    | 4.6  | -    | mA   |
| ICC8   | Operating supply current (Normal mode)                              | /RESET= 'High', Fm=16 MHz (Crystal type),<br>Fs on, output pin floating, WDT enabled                        | -    | 5.7  | _    | mA   |

\* These parameters are characterized but not tested.

\*\* Data in the Minimum, Typical, and Maximum ("Min.", "Typ.", "Max.") columns are based on characterization results at 25°C. These data are for design reference only and have not been tested.



### 8.1 AD Converter Characteristics

| Sy             | mbol                     | Parameter                                            | Condition                                                                          | Min. | Тур.      | Max.                                                                                                                                                                                                                                                                                                                      | Unit |
|----------------|--------------------------|------------------------------------------------------|------------------------------------------------------------------------------------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| V,             | AREF                     | Analog reference                                     | $V_{\text{AREF}}$ - $V_{\text{ASS}} \ge 2.5 V$                                     | 2.5  | -         | VDD                                                                                                                                                                                                                                                                                                                       | V    |
| V              | ASS                      | voltage                                              | $VAREF-VASS \leq 2.3V$                                                             | VSS  | -         | VSS                                                                                                                                                                                                                                                                                                                       | V    |
| ١              | /AI                      | Analog input voltage                                 | _                                                                                  | VASS | -         | VAREF                                                                                                                                                                                                                                                                                                                     | V    |
| IAI1           | lvdd                     | Analog supply current                                | $V_{AREF} = VDD = 5.5V$<br>$V_{ASS} = VSS = 0V$                                    | -    | -         | 1000                                                                                                                                                                                                                                                                                                                      | μΑ   |
|                | lvref                    | 5 11 5                                               | FS=100kHz, FIN=1kHz<br>(VREF is internal VDD)                                      | -    | -         | 10                                                                                                                                                                                                                                                                                                                        | μA   |
| IAI2           | lvdd                     | Analog supply current                                | $V_{AREF} = VDD = 5.5V$<br>$V_{ASS} = VSS = 0V$<br>FS=100kHz, FIN=1kHz             | _    | _         | 600                                                                                                                                                                                                                                                                                                                       | μΑ   |
|                | lvref                    |                                                      | (VREF is external VREF pin)                                                        | -    | -         | VDD           VSS           VAREF           1000           10           600           400           ±4           ±1           ±8           ±4           10              -           -           -           -           -           -           -           -           -           -           -           -           - | μA   |
| I              | NL                       | Integral nonlinearity                                | V <sub>AREF</sub> = VDD = 5V<br>V <sub>ASS</sub> = VSS = 0V<br>FS=100kHz, FIN=1kHz | _    | _         | ±4                                                                                                                                                                                                                                                                                                                        | LSB  |
| C              | NL                       | Differential nonlinear                               | V <sub>AREF</sub> = VDD = 5V<br>V <sub>ASS</sub> = VSS = 0V<br>FS=100kHz, FIN=1kHz | _    | _         | ±1                                                                                                                                                                                                                                                                                                                        | LSB  |
| F              | SE                       | Full scale error                                     | V <sub>AREF</sub> = VDD = 5V<br>V <sub>ASS</sub> = VSS = 0V, Fs=100kHz             | _    | _         | ±8                                                                                                                                                                                                                                                                                                                        | LSB  |
| (              | DE                       | Offset error                                         | V <sub>AREF</sub> = VDD = 5V<br>V <sub>ASS</sub> = VSS = 0V, Fs=100kHz             | _    | -         | ±4                                                                                                                                                                                                                                                                                                                        | LSB  |
| -              | ZAI                      | Recommended<br>impedance of analog<br>voltage source | _                                                                                  | _    | _         | 10                                                                                                                                                                                                                                                                                                                        | kΩ   |
| т              | AD                       | A/D clock duration                                   | VDD = 3V~5.5V<br>V <sub>ASS</sub> = VSS = 0V, FIN=1kHz                             | 0.5  | -         | _                                                                                                                                                                                                                                                                                                                         | μS   |
| I              | AD                       | A/D CIOCK duration                                   | VDD = 2.5V~3V<br>V <sub>ASS</sub> = VSS = 0V, FIN=1kHz                             | 2    | -         | -                                                                                                                                                                                                                                                                                                                         | μS   |
| -              |                          |                                                      | VDD = 3V~5.5V<br>V <sub>ASS</sub> = VSS = 0V                                       | 4    | -         | -                                                                                                                                                                                                                                                                                                                         | μs   |
|                | SH                       | Sample and Hold time                                 | VDD = 2.5V~3V<br>V <sub>ASS</sub> = VSS = 0V                                       | 16   | -         | -                                                                                                                                                                                                                                                                                                                         | μs   |
| Т              | TCN $VDD = 2.5V \sim 5V$ |                                                      |                                                                                    | _    | Tsh+12TAD | -                                                                                                                                                                                                                                                                                                                         | TAD  |
| A <sub>1</sub> | /2VDD                    | Accuracy for 1/2VDD                                  |                                                                                    | _    | ±2        | -                                                                                                                                                                                                                                                                                                                         | %    |

#### Note:

- 1. FS is Sample Rate or conversion rate. FIN is freq. of input test sine wave
- 2. The parameters are theoretical values and have not been tested. Such parameters are for design reference only.
- 3. There is no current consumption when ADC is off other than minor leakage current.
- 4. AD conversion result will not decrease when the input voltage is increased, and there is no missing code.
- 5. These parameters are subject to change without further notice.
- \* These parameters are characterized but not tested.
- \* Data in the Minimum, Typical and Maximum ("Min", "Typ", "Max") columns are based on characterization results at 25°C. These data are for design guidance only and have not been tested.



### 8.2 HLVD Characteristics

VDD=5V, VSS=0V, Ta=25°C

| Symbol | Parameter              | Test condition         | Min. | Тур.  | Max. | Unit |
|--------|------------------------|------------------------|------|-------|------|------|
| IHLVD  | HLVD Operation current | HLVD Enable,<br>VDD=5V |      | 9.2   | 11   | μA   |
| ΔV     | Detect level variation |                        |      | ±0.15 |      | V    |
| VHYST  | Hysteresis             |                        | 50   | 100   | 150  | mV   |
| TVREF  | VREF stable time       | HLVD Enable,<br>VDD=5V |      | 30    | 60   | μS   |

\* These parameters are characterized but not tested.

\* Data in the Minimum, Typical and Maximum ("Min", "Typ", "Max") columns are based on characterization results at 25°C. These data are for design guidance only and have not been tested.

### 8.3 1/2VDD Characteristics

|                                | 100-01, 100-01, 10-20 0                                               |                                   |           |              |             |      |
|--------------------------------|-----------------------------------------------------------------------|-----------------------------------|-----------|--------------|-------------|------|
| symbol                         | parameter                                                             | condition                         | Min.      | Тур.         | Max.        | Unit |
| VDD                            | power supply                                                          |                                   | 2.4       | 5            | 5.5         | V    |
| Ivdda                          | DC supply current                                                     | VDDA=5V                           |           | 34.72        | 42          | uA   |
| lpd                            | power down current                                                    |                                   |           | 0.001        | < 0.1       | uA   |
| Warn-up time<br>for ADC sample | time ready for voltage<br>reference<br>(VREF1_2VDD)                   | CL=12.8PF<br>(ADC sample loading) |           | 2.8**        | 4           | us   |
| Warn-up time<br>for TE testing | time ready for voltage<br>reference to TE testing<br>(VREF1_2VDD_PAD) | CL=100PF<br>(TE testing loading)  |           | 18**         | 25          | us   |
| VREF1_2VDD                     | 1/2 VDD voltage output                                                |                                   | Typ<br>1% | (1/2)VD<br>D | Typ.+<br>1% | V    |

VDD=5V, VSS=0V, Ta=25°C

\* These parameters are characterized but not tested.

\* Data in the Minimum, Typical and Maximum ("Min", "Typ", "Max") columns are based on characterization results at 25°C. These data are for design guidance only and have not been tested.





### 8.4 VREF Characteristics

VDD=5V, VSS=0V, Ta=25°C

| symbol       | parameter                | condition                             | Min.     | Тур.      | Max.    | Unit |
|--------------|--------------------------|---------------------------------------|----------|-----------|---------|------|
| VDD          | power supply             |                                       | 2.2      |           | 5.5     | V    |
| lvdd         | DC supply current        | BG_PD=0<br>VREF_PD=0                  |          | 250       | 400     | uA   |
| Tresponse    | Response time            | Trim bit and VREF select setting time |          | 10**      | 20      | us   |
| More up time | ime reference            | EN_LPF=0                              |          | 10        | 20      | us   |
| Warn-up time |                          | EN_LPF=1                              |          | 1**       | 1.5     | ms   |
|              |                          |                                       | 2.02752  | 2.048     | 2.06848 |      |
| Vref         | Voltago reference output |                                       | 2.53404  | 2.560     | 2.58560 | V    |
|              | Voltage reference output |                                       | 3.04128  | 3.072     | 3.10272 |      |
|              |                          |                                       | 4.05504  | 4.096     | 4.13696 |      |
| Vdd_min      | Minimum power supply     |                                       | Vref+0.1 | Vref+0.2* |         | V    |

\*Vdd\_min: can work at (Vref+0.1V), but has a poor PSRR.

\* These parameters are characterized but not tested.

\* Data in the Minimum, Typical and Maximum ("Min", "Typ", "Max") columns are based on characterization results at 25°C. These data are for design guidance only and have not been tested.

#### Notes:

- 1. The parameters are theoretical values and have not been tested. Such parameters are for design reference only.
- 2. These parameters are subject to change without prior notice.



# **9** AC Electrical Characteristics

Ta=25°C, VDD=5V ± 5%, VSS=0V

| Symbol        | Parameter                               | Conditions             | Min. | Тур.        | Max. | Unit |
|---------------|-----------------------------------------|------------------------|------|-------------|------|------|
| Dclk          | Input CLK duty cycle                    | _                      | 45   | 50          | 55   | %    |
| T I I I I A T |                                         | Crystal type           | 125  | _           | DC   | ns   |
| Tins          | Instruction Cycle Time                  | IRC type               | 125  | _           | DC   | ns   |
| Ttcx          | TCX Input Period                        | _                      | Tins | -           | -    | ns   |
| Tpor          | Delay time after Power-on-Reset release | 16kHz                  | -    | 16±3%       | -    | ms   |
|               |                                         | Crystal type, HLFS=1   | -    | WSTO+510/Fm | -    | _    |
| Trstrl        | Delay time after /RESET,                | IRC type, HLFS=1       | -    | WSTO+8/Fm   | -    | -    |
| IISUI         | WDT and LVR release                     | Crystal type, HLFS=0   | -    | WSTO+510/Fs | -    | -    |
|               |                                         | IRC type, HLFS=0       | _    | WSTO+8/Fs   | -    | -    |
| Trsth         | Hold time after /RESET and LVR reset    | _                      | _    | 1           | _    | μs   |
| Twdt          | Watchdog timer period                   | 16kHz                  | -    | 16±3%       | -    | ms   |
| Tset          | Input pin set-up time                   | _                      | -    | 0           | -    | ns   |
| Thold         | Input pin hold time                     | _                      | 15   | 20          | 25   | ns   |
| Tdelay        | Output pin delay time                   | Cload=20pF<br>Rload=1M | _    | 20          | _    | ns   |

**Note:** \* **Tpor** and **Twdt** are 16+/- 10% ms at Ta = -40° ~ 85°C, and VDD = 2.1~5.5V \*\* WSTO: Waiting time of Start-to-Oscillation

1. These parameters are hypothetical (not tested) and are provided for design reference only.

2. Data under Minimum, Typical and Maximum (Min., Typ. and Max.) columns are based on hypothetical results at 25°C. These data are for design reference only and have not been tested or verified.



# **10 Timing Diagrams**

#### AC Test Input/Output Waveform



**Note:** AC Testing: Inputs are driven at VDD-0.5V for logic "1," and VSS+0.5V for logic "0" Timing measurements are made at 0.75VDD for logic "1," and 0.25VDD for logic "0"

Figure 10-1a AC Test Input/Output Waveform Timing Diagram

#### **Reset Timing**



Figure 10-1b Reset Timing Diagram



# APPENDIX

# A Ordering and Manufacturing Information





# B Package Type

| Flash MCU     | Package Type | Pin Count | Package Size |
|---------------|--------------|-----------|--------------|
| EM88F711ND14  | DIP          | 14        | 300 mil      |
| EM88F711NSO14 | SOP          | 14        | 150 mil      |
| EM88F711NMS10 | MSOP         | 10        | 118 mil      |
| EM88F711ND8   | DIP          | 8         | 300 mil      |
| EM88F711NSO8  | SOP          | 8         | 150mil       |

These are Green products which do not contain hazardous substances and comply with the third edition of Sony SS-00259 standard.

Pb content is less than 100ppm and complies with Sony specifications.

| Part No.                                   | EM88F711NxJ / xS |
|--------------------------------------------|------------------|
| Electroplate type                          | Pure Tin         |
| Ingredient (%)                             | Sn:100%          |
| Melting point (°C)                         | 232°C            |
| Electrical resistivity ( $\mu\Omega$ -cm ) | 11.4             |
| Hardness (hv)                              | 8~10             |
| Elongation (%)                             | >50%             |



# **C** Package Information

### C.1 EM88F711ND14



Figure C-1 EM88F711N 14-pin DIP Package Type



EM88F711N 8-BIT Micro-controller

### C.2 EM88F711NSO14



Figure C-2 EM88F711N 14-pin SOP Package Type



# C.3 EM88F711NMS10



Figure C-3 EM88F711N 10-pin MSOP Package Type



### C.4 EM88F711ND8



Figure C-4 EM88F711N 8-pin DIP Package Type



# C.5 EM88F711NSO8



Figure C-5 EM88F711N 8-pin SOP Package Type



# D Quality Assurance and Reliability

| Test Category                            | Test Conditions                                                                                                                                                                                             | Remarks                                                      |  |  |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|
| Solderability                            | Solder temperature=245±5°C, for 5 seconds up to the stopper using a rosin-type flux                                                                                                                         |                                                              |  |  |
|                                          | Step 1: TCT, 65°C (15 min)~150°C (15 min), 10 cycles                                                                                                                                                        |                                                              |  |  |
|                                          | Step 2: Bake at 125°C, TD (endurance)=24 hrs                                                                                                                                                                | _                                                            |  |  |
|                                          | Step 3: Soak at 30°C/60% , TD (endurance)=192 hrs                                                                                                                                                           |                                                              |  |  |
| Pre-condition                            | Step 4: IR flow 3 cycles<br>(Pkg thickness $\ge 2.5$ mm or<br>Pkg volume $\ge 350$ mm <sup>3</sup> 225 $\pm$ 5°C)<br>(Pkg thickness $\le 2.5$ mm or<br>Pkg volume $\le 350$ mm <sup>3</sup> 240 $\pm$ 5°C ) | For SMD IC (such as SOP, QFP, SOJ, etc)                      |  |  |
| Temperature cycle test                   | -65°C (15mins)~150°C (15min), 200 cycles                                                                                                                                                                    |                                                              |  |  |
| Pressure cooker test                     | TA =121°C, RH=100%, pressure = 2 atm,<br>TD (endurance)= 96 hrs                                                                                                                                             |                                                              |  |  |
| High temperature /<br>High humidity test | TA=85°C , RH=85% , TD (endurance)=168 , 500 hrs                                                                                                                                                             |                                                              |  |  |
| High-temperature storage life            | TA=150°C, TD (endurance)=500, 1000 hrs                                                                                                                                                                      |                                                              |  |  |
| High-temperature<br>operating life       |                                                                                                                                                                                                             |                                                              |  |  |
| Latch-up                                 | TA=25°C, VDD=Max. operating voltage, 800mA/40V                                                                                                                                                              |                                                              |  |  |
| ESD (HBM) TA=25°C, ≥   ± 4KV             |                                                                                                                                                                                                             | IP_ND,OP_ND,IO_ND<br>IP_NS,OP_NS,IO_NS<br>IP_PD,OP_PD,IO_PD, |  |  |
| ESD (MM)                                 | TA=25°C, ≥   ± 400V                                                                                                                                                                                         | IP_PS,OP_PS,IO_PS,<br>VDD-VSS(+),VDD_VSS<br>(-) mode         |  |  |

### **D.1 Address Trap Detect**

An address trap detect is one of the MCU embedded fail-safe functions that detects MCU malfunction caused by noise or the like. Whenever the MCU attempts to fetch an instruction from a certain section of ROM, an internal recovery circuit is automatically started. If a noise-caused address error is detected, the MCU will repeat execution of the program until the noise is eliminated. The MCU will then continue to execute the next program.



# E ED712N & HVBRG & UBRG connection



ED712N



HVBRG



UBRG+HVBRG



ED712N+UBRG+HVBRG

