

Version: 0.1

Release Date: November 26, 2015

Specifications are subject to change without notice.

Copyright © 2015 Analutions,Inc.

This document contains information that is proprietary to Analutions, Inc.

Unauthorized reproduction of this information in whole or in part is strictly prohibited.

### Low-power Multifunctional Energy Metering SoC

## **Revision History**

| Date       | Version | Description     |
|------------|---------|-----------------|
| 2015.11.26 | 0.1     | Initial release |

### **General Description**

AL6111A is a single-phase energy metering SoC chip, featuring very low-power consumption and high performance. It integrates the analog front end, energy metering architecture, enhanced 8052 MCU core, RTC (Real-time Clock), WDT (Watchdog Timer), Flash memory, RAM, and LCD driver. It can be used for the single-phase multi-functional energy meter applications.

#### **Features**

- Wide supply voltage range: 3.3 V to 5 V
- Reference voltage: 1.185 V (Typical drift 10 ppm/°C)
- Low power operation with power-saving modes
  - Full operation: 5.5 mA
  - Sleep mode: 12 μA
- 64-lead RoHs LQFP package
- Operating temperature range:
   -40 ~ +85°C
- Energy metering features:
  - 4 independent oversampling Σ/Δ
     ADCs:
    - One voltage channel, two current channels, and one multifunctional channel for various signal measurements
  - High metering accuracy:
    - ✓ Exceeds IEC 62053/ANSI C12.20 Standards
    - Less than 0.1% error on active energy metering over dynamic range of 5000:1
    - ✓ Less than 0.1% error on reactive energy metering over dynamic range of 3000:1
    - ✓ Less than 0.5% error on

- current/voltage RMS calculation over dynamic range of 1000:1
- Various measurements:
  - Raw waveform and DC component of current and voltage signals
  - Line frequency, temperature, and battery voltage measurements
- CF pulse output and interrupt with configurable pulse width
- Programmable threshold for no-load detection
- Digital phase compensation
- MCU and peripherals:
  - 8052 MCU core, up to 26 MHz/6.5 MIPS
  - 64-KB Flash, 4-KB RAM
  - Crystal anti-failure supported
  - Integrated Real-Time Clock (RTC) and temperature sensor
  - Up to 4 UART serial interfaces, one supporting IR communication
  - 1 GPSI (General-Purpose Serial Interface), I<sup>2</sup>C compliant



#### **Low-power Multifunctional Energy Metering SoC**

- Up to 43 programmable GPIOs, 10 timers
- LCD driver:
  - ✓ Up to 4×24, 6×22, or 8×20 segments
  - ✓ 1/3 bias or 1/4 bias ratio
  - ✓ Configurable frame frequency
  - ✓ Configurable drive voltage over a range of 2.7 V ~ 3.3 V,

resolution of 100 mV/lsb

- Wake-up from I/O, Rx, RTC, and CF pulse
- Independent Watch-Dog Timer (WDT)
- Debugging via JTAG interfaces in real-time



- 3 -

## **Table of Contents**

| Re  | vision l | Histo | ory                                                     |    |
|-----|----------|-------|---------------------------------------------------------|----|
| Ge  | neral D  | escri | iption                                                  | 2  |
| Fe  | atures.  |       |                                                         | 2  |
| Та  | ble of C | onte  | ents                                                    | 4  |
| Fig | gure Lis | t     |                                                         | 8  |
| Та  | ble List |       |                                                         | 11 |
| 1.  | Elec     | trica | ıl Characteristics                                      | 18 |
|     | 1.1.     | Abs   | solute Maximum Ratings                                  | 18 |
|     | 1.2.     | Ene   | ergy Metering Specifications                            | 18 |
|     | 1.3.     | Ana   | alog Specifications                                     | 19 |
|     | 1.4.     | Dig   | gital Interface Specifications                          | 21 |
|     | 1.5.     | Mer   | mory Specifications                                     | 21 |
|     | 1.6.     | GPS   | SI Timing Specifications                                | 22 |
| 2.  | Pin      | Desc  | criptions                                               | 24 |
| 3.  | Fun      | ction | nal Block Diagram                                       | 32 |
| 4.  | 805      | 2 MC  | CU Core Architecture                                    | 33 |
|     | 4.1.     | Mer   | mory Map                                                | 33 |
|     | 4.2.     | IRA   | AM (Internal RAM) and SFRS (Special Function Registers) | 33 |
|     | 4.3.     | Dat   | ta Memory                                               | 39 |
|     | 4.4.     | Pro   | ogram Memory                                            | 43 |
| 5.  | Res      | et    |                                                         | 47 |
|     | 5.1.     | Lev   | /el 3                                                   | 49 |
|     | 5.2.     | Lev   | /el 2                                                   |    |
|     | 5.2      | 2.1.  | Power Supply Restoration                                | 49 |
|     | 5.2      | 2.2.  | IO Wakeup Input                                         | 49 |
|     | 5.2      | 2.3.  | RTC Wakeup                                              |    |
|     | 5.2      | 2.4.  | CF Pulse Wakeup Event                                   |    |
|     | 5.3.     | Lev   | /el 1                                                   | 50 |
|     | 5.3      | 3.1.  | RSTn Pin Input (RSTn Pin Reset)                         |    |
|     | 5.3      | 3.2.  | Power-On Reset (POR) and Brown-Out Reset (BOR)          |    |
|     | 5.3      | 3.3.  | WDT Overflow                                            |    |
|     | 5.4.     | Reg   | gisters                                                 | 52 |
| 6.  | Cloc     |       |                                                         |    |
|     | 6.1.     |       | Clock                                                   |    |
|     | 6.2.     | OS    | C Clock                                                 | 57 |

|    | 6.3.   | PLL Clock                                               | 58  |
|----|--------|---------------------------------------------------------|-----|
|    | 6.4.   | Switching Source for CLK1 and CLK2                      | 59  |
|    | 6.4    | 1.1. Normal Operation                                   | 59  |
|    | 6.4    | 1.2. Quick Operation                                    | 60  |
|    | 6.4    | 1.3. Normal Operation v.s. Quick Operation              | 60  |
|    | 6.5.   | Registers                                               | 63  |
| 7. | Oper   | rating Mode                                             | 69  |
|    | 7.1.   | Power Consumption                                       | 69  |
|    | 7.1    | 1.1. OSC State                                          | 70  |
|    | 7.1    | L.2. Working State                                      | 71  |
|    | 7.1    | 1.3. Sleeping State                                     | 71  |
|    | 7.2.   | Registers                                               | 75  |
| 8. | Pow    | ver Supply                                              | 78  |
|    | 8.1.   | 3.3-V Regulator Circuit (LDO33)                         | 78  |
|    | 8.2.   | Digital Power Supply                                    | 79  |
|    | 8.3.   | Power Supply Supervisor                                 | 79  |
|    | 8.4.   | Batteries Supply                                        | 80  |
| 9. | Com    | nparator                                                | 81  |
| 10 | . Ener | rgy Metering                                            | 83  |
|    | 10.1.  | Accessing to Registers for Energy-metering Architecture |     |
|    | 10.2.  | Metering Clock                                          |     |
|    | 10.3.  | Reference Voltage                                       | 87  |
|    | 10.4.  | Analog Inputs                                           | 87  |
|    | 10.5.  | Analog-to-Digital Conversion                            | 89  |
|    | 10.6.  | Switch of Current Channels                              | 90  |
|    | 10.7.  | Phase Compensation                                      | 91  |
|    | 10.8.  | Digital Programmable Gain Amplifier                     | 92  |
|    | 10.9.  | Current Detection                                       | 94  |
|    | 10.10. | RMS Calculation and Calibration                         | 95  |
|    | 10.11. | Apparent Power Calculation                              | 96  |
|    | 10.12. | Power Calculation and Calibration                       | 96  |
|    | 10.    | .12.1. Active Power Calculation and Calibration         | 97  |
|    | 10.    | .12.2. Reactive Power and Calibration                   | 98  |
|    | 10.13. | Energy Accumulation and CF Pulse Output                 | 98  |
|    | 10.    | .13.1. Energy Accumulation                              | 99  |
|    | 10.    | .13.2. Energy Pulse Generation and CF Pulse Output      | 99  |
|    | 10.14. | No-Load Detection                                       | 101 |
|    | 10.15. | Line Frequency Measurement                              | 102 |
|    | 10.16. | 5 · · · · · · · · · · · · · · · · · · ·                 |     |
|    | 10.    | .16.1. Architecture of M Channel                        | 103 |
| 11 | . Inte | errupt                                                  | 104 |
|    | 11.1.  | Interrupt Sources                                       | 104 |
|    | 11.2.  | Interrupt Control Registers                             | 110 |
|    | 11.3.  | Interrupt Processing                                    | 113 |

|     | 11.4.  | Extended Interrupts                    | 114 |
|-----|--------|----------------------------------------|-----|
|     | 11.    | .4.1. Interrupt 8                      | 114 |
|     | 11.    | 4.2. Interrupt 9                       | 115 |
|     | 11.    | 1.4.3. Interrupt 10                    | 117 |
|     | 11.    | 4.4. Interrupt 11                      | 119 |
| 12. | HAD    | RT/Timers                              | 122 |
| 12. | 12.1.  | •                                      |     |
|     |        | 2.1.1. TimerA                          |     |
|     |        | 2.1.2. Timer0/Timer1/Timer2            |     |
|     |        | UART                                   |     |
|     |        | 2.2.1. UART1                           |     |
|     |        | 2.2.2. Extended UART Serial Interfaces |     |
|     |        |                                        |     |
| 13. |        | neral-Purpose Serial Interface (GPSI)  |     |
|     | 13.1.  | Frame Structure                        |     |
|     | 13.2.  | Serial Clock Generation                |     |
|     | 13.3.  | Receive and Transmit Data              | _   |
|     | 13.4.  | GPSI Interrupt                         |     |
|     | 13.5.  | For I <sup>2</sup> C Application       | 154 |
|     | 13.6.  | Registers                              | 156 |
| 14. | LCD    | ) Driver                               | 158 |
|     | 14.1.  | Pins for LCD Driver                    | 158 |
|     | 14.2.  | LCD Timing                             | 159 |
|     | 14.3.  | LCD Waveform Voltage                   | 159 |
|     | 14.4.  | Display RAM                            | 159 |
|     | 14.5.  | LCD Drive Waveform                     | 163 |
|     | 14.6.  | Registers                              | 168 |
| 15. | CDI    | [0                                     | 171 |
| 13. | 15.1.  | P0                                     |     |
|     | 15.1.  | P1                                     |     |
|     | 15.2.  | P2                                     |     |
|     | 15.4.  | P3                                     |     |
|     | 15.5.  | P4                                     |     |
|     | 15.6.  | P5                                     |     |
|     | 15.7.  | P6                                     |     |
|     | 15.7.  | P7                                     |     |
|     | 15.9.  | P8                                     |     |
|     | 15.10. |                                        |     |
|     |        |                                        |     |
| 16. | Wat    | tchdog Timer (WDT)                     |     |
|     | 16.1.  | Clock for WDT                          | 191 |
|     | 16.2.  | Clearing WDT                           | 192 |
|     | 16.3.  | WDT Overflow Reset                     | 192 |
| 17. | Real   | nl-Time Clock (RTC)                    | 193 |
| _/' |        | Reading and Writing of RTC Registers   |     |
|     |        |                                        |     |

|    | 17.    | 1.1.     | Writing of RTC                    | 194 |
|----|--------|----------|-----------------------------------|-----|
|    | 17.    | 1.2.     | Reading of RTC                    |     |
|    | 17.2.  | Timin    | ıg                                | 194 |
|    | 17.3.  |          | nterrupts                         |     |
|    |        | 3.1.     | RTC Illegal Data Interrupt        |     |
|    | 17.    | 3.2.     | Pulse Output Interrupt per Second | 195 |
|    | 17.4.  | PLL C    | Counter                           |     |
|    | 17.5.  | Regis    | ters                              | 196 |
| 18 | . Regi | isters . |                                   | 200 |
|    | 18.1.  | Analo    | g Control Registers               | 200 |
|    | 18.2.  | Meter    | ring Control Registers            | 207 |
|    | 18.3.  | Meter    | ring Data Registers               | 213 |
|    | 18.4.  | Calibr   | ration Registers                  | 217 |
| 19 | . Outl | ine Dir  | mensions                          | 220 |

## **Figure List**

| Figure 1-1 Timing Diagram                                                                           | 23 |
|-----------------------------------------------------------------------------------------------------|----|
| Figure 2-1 Pin Assignment                                                                           | 24 |
| Figure 3-1 Functional Block Diagram                                                                 | 32 |
| Figure 4-1 IRAM and SFRS                                                                            | 34 |
| Figure 4-2 Data Memory                                                                              | 39 |
| Figure 4-3 Flash Memory and Program Memory Area                                                     | 44 |
| Figure 5-1 Reset Unit Diagram                                                                       | 47 |
| Figure 5-2 RSTn Pin Reset Timing                                                                    | 51 |
| Figure 5-3 Power-on Reset Timing                                                                    | 51 |
| Figure 6-1 Clock System Architecture                                                                | 57 |
| Figure 6-2 Enabling PLL Circuit and Clock Source Switchover to PLL in Quick Operation               | 62 |
| Figure 6-3 Clock Source Switchover to OSC, Disabling PLL Circuit, Disabling CLK1 in Quick Operation |    |
| Figure 7-1 Go to Sleeping State (Normal Method, Disable PLL Clock)                                  | 73 |
| Figure 7-2 Go to Sleeping State (Normal Method, PLL Clock Holds on)                                 | 74 |
| Figure 7-3 Go to LPM1 state (Quick Method)                                                          | 75 |
| Figure 8-1 Power Supply Architecture                                                                | 78 |
| Figure 8-2 LDO33 Output and 5V Power Input                                                          | 79 |
| Figure 8-3 LDO33 output and the Load Current                                                        | 79 |
| Figure 8-4 Relationship between VDCIN Input Signal and States of Flag Bits PWRUP and PWRDN          | 80 |
| Figure 9-1 Comparator Architecture                                                                  | 81 |
| Figure 10-1 Digital Signal Processing in Energy-metering Architecture                               | 84 |
| Figure 10-2 CT for Current channel                                                                  | 87 |
| Figure 10-3 Shunt Resistor Network for Current Channel                                              | 87 |
| Figure 10-4 Analog Input of Voltage                                                                 | 88 |
| Figure 10-5 Exchange of Current Channels                                                            | 90 |
| Figure 10-6 Phase Compensation Schematics                                                           | 91 |
| Figure 10-7 Digital Inputs                                                                          | 92 |
|                                                                                                     |    |

| Figure 10-8 RMS Calculation and Calibration                                    | 96  |
|--------------------------------------------------------------------------------|-----|
| Figure 10-9 Signal Processing for Active Power Calculation and Calibration     | 97  |
| Figure 10-10 Signal Processing for Reactive Power Calculation and Calibration  | 98  |
| Figure 10-11 Energy Accumulation and CF Pulse Output                           | 99  |
| Figure 10-12 Signal Processing for Line Frequency Measurement                  | 102 |
| Figure 10-13 M Channel Architecture                                            | 103 |
| Figure 10-14 Signal Processing in M Channel                                    | 103 |
| Figure 11-1 Interrupt Logic                                                    | 109 |
| Figure 11-2 Interrupt Processing                                               | 113 |
| Figure 12-1 TimerA Architecture                                                | 123 |
| Figure 12-2 Operation Modes for TimerA                                         | 125 |
| Figure 12-3 Configuring Output Frequency in Continuous Mode                    | 126 |
| Figure 12-4 Output on Pin TA1 in Up Mode                                       | 131 |
| Figure 12-5 Output on Pin TA1 in Continuous Mode                               | 131 |
| Figure 12-6 Output on Pin TA1 in Up/Down Mode                                  | 132 |
| Figure 12-7 Timer 0/1, Mode 0/1                                                | 136 |
| Figure 12-8 Timer 0/1, Mode 2                                                  | 137 |
| Figure 12-9 Timer 0, Mode 3                                                    | 138 |
| Figure 12-10 Timer2, 16-bit Timer/ Counter in Capture Mode                     | 140 |
| Figure 12-11 Timer2, 16-Bit Timer/Counter in Auto-Reload Mode                  | 141 |
| Figure 13-1 Frame Structure on SDA                                             | 152 |
| Figure 13-2 Receive and Transmit Data                                          | 154 |
| Figure 13-3 Read Operation                                                     | 155 |
| Figure 13-4 Write Operation                                                    | 155 |
| Figure 14-1 LCD Driver Block Diagram                                           | 158 |
| Figure 14-2 LCD Drive Waveform When LCD Panel of 1/4 Duty and 1/3 Bias Applied | 164 |
| Figure 14-3 LCD Drive Waveform When LCD Panel of 1/6 Duty and 1/3 Bias Applied | 165 |
| Figure 14-4 LCD Drive Waveform When LCD Panel of 1/8 Duty and 1/3 Bias Applied | 166 |
| Figure 14-5 LCD Drive Waveform When LCD Panel of 1/8 Duty and 1/4 Bias Applied | 167 |
| Figure 15-1 Architecture of P0.0                                               | 172 |
| Figure 15-2 Architecture of P0.1/P0.2/P0.3                                     | 172 |

| Figure 15-3 Architecture of Each Port of Group P1P1 | 173 |
|-----------------------------------------------------|-----|
| Figure 15-4 Architecture of Each Port of Group P2P2 | 176 |
| Figure 15-5 Architecture of Each Port of Group P3P3 | 179 |
| Figure 15-6 Architecture of Each Port of Group P4P4 | 180 |
| Figure 15-7 Architecture of Each Port of Group P5P5 | 182 |
| Figure 15-8 Architecture of Each Port of Group P6P6 | 183 |
| Figure 15-9 Architecture of Each Port of Group P7P7 | 185 |
| Figure 15-10 Architecture of Each Port of Group P8  | 186 |
| Figure 16-1 WDT Overflow Reset                      | 192 |
| Figure 17-1 Architecture of RTC                     | 193 |
| Figure 19-1 Outline Dimensions                      | 220 |

### Low-power Multifunctional Energy Metering SoC

## **Table List**

| Table 1-1 Absolut Maximum Ratings                                                | 18 |
|----------------------------------------------------------------------------------|----|
| Table 4-1 Select a Register Bank                                                 | 33 |
| Table 4-2 Special Function Registers (SFRS)                                      | 35 |
| Table 4-3 Allocation of Info Area                                                | 40 |
| Table 4-4 Flash Control Register 1 (FCtrl1, 0x0402)                              | 43 |
| Table 4-5 Code Bank Register (CBANK, SFR 0xA0)                                   | 44 |
| Table 4-6 Programming Flash Memory                                               | 45 |
| Table 5-1 Circuits to Be Reset                                                   | 48 |
| Table 5-2 System State Register, Systate (SFR 0xA1)                              | 52 |
| Table 5-3 P0 IO Wakeup Flag Register (IOWKDET, SFR 0xAF)                         | 53 |
| Table 5-4 IO Wakeup Edge Control Register (IOEDG, SFR 0xC7)                      | 53 |
| Table 5-5 IO Wakeup Control Register (IOWK, SFR 0xC9)                            | 54 |
| Table 5-6 Set RTC Wake-Up Interval                                               | 54 |
| Table 5-7 RTC Seconds Wake-up Interval Configuration Register (SECINT, SFR 0xDF) | 55 |
| Table 6-1 Comparing Normal, Quick, and Combination Operations                    | 61 |
| Table 6-2 Clock Switchover Control Register (SysCtrl, SFR 0x80)                  | 63 |
| Table 6-3 Peripheral Control Register 0 (PRCtrl0, 0x2D00)                        | 64 |
| Table 6-4 Peripheral Control Register 1 (PRCtrl1, 0x2D01)                        | 65 |
| Table 6-5 Register 1 to Adjust OSC Clock Frequency                               | 65 |
| Table 6-6 Register 2 to Adjust OSC Clock Frequency                               | 66 |
| Table 6-7 PLL Clock State Register (PLLLCK, SFR 0xA3)                            | 66 |
| Table 6-8 Register 1 to Adjust Clock Frequency of Specific Functional Blocks     | 67 |
| Table 6-9 Register 2 to Adjust Clock Frequency of Specific Functional Blocks     | 68 |
| Table 6-10 OSC Clock State Register                                              | 68 |
| Table 7-1 Factors Affecting Power Consumption of Each Unit                       | 69 |
| Table 7-2 OSC State of System                                                    | 70 |
| Table 7-3 Configuration for Sleeping State                                       | 74 |
| Table 7-4 Register for Clock Control                                             | 75 |
|                                                                                  |    |

| Table 7-5 Register to Indicate Power Supply State                                   | 77  |
|-------------------------------------------------------------------------------------|-----|
| Table 9-1 Registers Related to Comparator, CB                                       | 81  |
| Table 10-1 Buffer Registers and Data to Be Written or Read                          | 85  |
| Table 10-2 Configuration of CLK2                                                    | 86  |
| Table 10-3 Analog PGA Gain Configuration for Current and Voltage Analog Input       | 88  |
| Table 10-4 Enable/Disable ADCs                                                      | 89  |
| Table 10-5 Control Bit for Switching Current Signals                                | 90  |
| Table 10-6 $f_{smpl}$ Determines Phase Compensation Resolution and Correction Range | 92  |
| Table 10-7 Registers for Phase Compensation                                         | 92  |
| Table 10-8 Enable/Disable Digital Inputs                                            | 93  |
| Table 10-9 DPGA Gain Selection for Digital Signals                                  | 93  |
| Table 10-10 Configuring for RMS Calculation and Calibration                         | 95  |
| Table 10-11 Functions of E2 Path                                                    | 97  |
| Table 10-12 Register Configuration for Energy Accumulation                          | 99  |
| Table 10-13 Configurations for Energy Pulse Generation Rate and CF Pulse Output     | 100 |
| Table 10-14 Configure for No-Load Detection                                         | 102 |
| Table 11-1 Interrupt Sources                                                        | 106 |
| Table 11-2 IE (SFR 0xA8)                                                            | 110 |
| Table 11-3 EIE (SFR 0xE8)                                                           | 110 |
| Table 11-4 EXIF (SFR 0x91)                                                          | 111 |
| Table 11-5 EICON (SFR 0xD8)                                                         | 111 |
| Table 11-6 IP (SFR 0xB8)                                                            | 112 |
| Table 11-7 EIP (SFR 0xF8)                                                           | 112 |
| Table 11-8 Interrupt Events to Trigger Interrupt 8                                  | 114 |
| Table 11-9 Extended Interrupt Flag (Request) Register (ExInt2IFG, 0x2840)           | 114 |
| Table 11-10 Extended Interrupt Input Type Register (ExInt2IN, 0x2841)               | 115 |
| Table 11-11 Extended Interrupt Output Type Register (ExInt2OUT, 0x2842)             | 115 |
| Table 11-12 Extended Interrupt Enable Register (ExInt2IE, 0x2843)                   | 115 |
| Table 11-13 Extended Interrupt Pending Register (ExInt2OV, 0x2844)                  | 115 |
| Table 11-14 Interrupt Event to Trigger Interrupt 9                                  | 116 |
| Table 11-15 Extended Interrupt Flag (Request) Register (ExInt3IFG, 0x2848)          | 116 |

| Table 11-16 Extended Interrupt Input Type Register (ExInt3IN, 0x2849)       | 116 |
|-----------------------------------------------------------------------------|-----|
| Table 11-17 Extended Interrupt Output Type Register (ExInt3OUT, 0x284A)     | 116 |
| Table 11-18 Extended Interrupt Enable Register (ExInt3IE, 0x284B)           | 117 |
| Table 11-19 Extended Interrupt Pending Register (ExInt3OV, 0x284C)          | 117 |
| Table 11-20 Interrupt Events to Trigger Interrupt 10                        | 117 |
| Table 11-21 Extended Interrupt Flag (Request) Register (ExInt4IFG, 0x2850)  | 118 |
| Table 11-22 Extended Interrupt Input Type Register (ExInt4IN, 0x2851)       | 118 |
| Table 11-23 Extended Interrupt Output Type Register (ExInt4OUT, 0x2852)     | 118 |
| Table 11-24 Extended Interrupt Enable Register (ExInt4IE, 0x2853)           | 119 |
| Table 11-25 Extended Interrupt Pending Register (ExInt4OV, 0x2854)          | 119 |
| Table 11-26 Interrupt Events to Trigger Interrupt 11                        | 119 |
| Table 11-27 Extended Interrupt Flag (Request) Register (ExInt5IFG, 0x28A2)  | 120 |
| Table 11-28 Extended Interrupt Input Type Register (ExInt5IN, 0x28A3)       | 120 |
| Table 11-29 Extended Interrupt Output Type Register (ExInt5OUT, 0x28A4)     | 120 |
| Table 11-30 Extended Interrupt Enable Register (ExInt5IE, 0x28A5)           | 120 |
| Table 11-31 Extended Interrupt Pending Register (ExInt5OV, 0x28A6)          | 121 |
| Table 12-1 TimerA-Related Registers                                         | 123 |
| Table 12-2 Timer A Counter/Timer Register (TAR, 0x2902~0x2903)              | 124 |
| Table 12-3 Timer A Control Register (TACTL, 0x2900)                         | 124 |
| Table 12-4 Timer A Compare/Capture Control Registers (0x2904~0x2909)        | 127 |
| Table 12-5 Bit Description of CKCON (SFR 0x8E)                              | 132 |
| Table 12-6 Timer0/1 Mode Control Special Function Register (TMOD, SFR 0x89) | 133 |
| Table 12-7 Timer0/1 Control Special Function Register (TCON, SFR 0x88)      | 134 |
| Table 12-8 Timer2 Control Special Function Register (T2CON, SFR 0xC8)       | 139 |
| Table 12-9 Timer 2 Mode                                                     | 140 |
| Table 12-10 UART1 Control Special Function Register (SCON1, SFR 0xC0)       | 142 |
| Table 12-11 Extended UART Serial Interfaces Registers                       | 143 |
| Table 12-12 UARTx Control/Status Register (TCON2/TCON4/TCON5)               | 144 |
| Table 12-13 UARTx Timers Mode Control Register (TMOD2/TMOD4/TMOD5)          | 144 |
| Table 12-14 UARTx Control Register (SCON2/SCON4/SCON5)                      | 145 |
| Table 12-15 UARTx Buffer Register (SBUF2/SBUF4/SBUF5)                       | 146 |

| Table 12-16 TXD2 Type Register (Txd2FS, 0x28CF)                                     | 147   |
|-------------------------------------------------------------------------------------|-------|
| Table 12-17 Carrier Wave Generation Registers                                       | 147   |
| Table 12-18 UART Modes                                                              | 147   |
| Table 13-1 Description of Different Frame Structures                                | 153   |
| Table 13-2 Register to Disable or Enable GPSI                                       | 156   |
| Table 13-3 GPSI Control Register (SICFG, 0x2F01)                                    | 156   |
| Table 13-4 GPSI Timer Divider Registers (SITHH/SITHL, 0x2F03/0x2F02)                | 157   |
| Table 13-5 GPSI Data Register (SIDAT, 0x2F04)                                       | 157   |
| Table 13-6 GPSI Communication Flag Register (SIFLG, 0x2F05)                         | 157   |
| Table 14-1 VLCD to Configuration of [LDO3SEL<2:0>] and [VLCD]                       | 159   |
| Table 14-2 RAM Byte Allocation for Segments of LCD Panel of 1/4 Duty                | 160   |
| Table 14-3 RAM Byte Allocation for Segments of LCD Panel of 1/6Duty When 6COMTYPE=  |       |
|                                                                                     |       |
| Table 14-4 RAM Byte Allocation for Segments of LCD Panel of 1/6 Duty When 6COMTYPE: |       |
| Table 14-5 RAM Byte Allocation for Segments of LCD Panel of 1/8 Duty                |       |
| Table 14-6 LCD Control Register (LCDCtrl, 0x2C1E)                                   | 168   |
| Table 14-7 Enable/Disable CLK3                                                      | 168   |
| Table 14-8 Register to Select Bias Mode                                             | 169   |
| Table 14-9 LCD Waveform Voltage Configuration 1                                     | 169   |
| Table 14-10 LCD Waveform Voltage Configuration 2                                    | 169   |
| Table 14-11 SEG Control Registers (R/W)                                             | 170   |
| Table 15-1 P0 Output Enable Register (P0OE, 0x28A8)                                 | . 172 |
| Table 15-2 P0 Input Enable Register (P0IE, 0x28A9)                                  | . 172 |
| Table 15-3 P0 Output Data Register (P0OD, 0x28AA)                                   | 172   |
| Table 15-4 P0 Input Data Register (P0ID, 0x28AB)                                    | 173   |
| Table 15-5 P1 Output Enable Register (P10E, 0x28AC)                                 | . 174 |
| Table 15-6 P1 Input Enable Register (P1IE, 0x28AD)                                  | 174   |
| Table 15-7 P1 Output Data Register (P1OD, 0x28AE)                                   | . 174 |
| Table 15-8 P1 Input Data Register (P1ID, 0x28AF)                                    | 174   |
| Table 15-9 P1.1 Special Function Register (P11FS, 0x28C5, R/W)                      | 175   |
| Table 15-10 P1.2 Special Function Register (P12FS, 0x28C6, R/W)                     | 175   |



| Table 15-11 P1.3 Special Function Register (P13FS, 0x28C7, R/W) | 175 |
|-----------------------------------------------------------------|-----|
| Table 15-12 P1.4 Special Function Register (P14FS, 0x28C8)      | 176 |
| Table 15-13 P2 Output Enable Register (P2OE, 0x28B0)            | 176 |
| Table 15-14 P2 Input Enable Register (P2IE, 0x28B1)             | 177 |
| Table 15-15 P2 Output Data Register (P2OD, 0x28B2)              | 177 |
| Table 15-16 P2 Input Data Register (P2ID, 0x28B3)               | 177 |
| Table 15-17 P2.0 Special Function Register (P20FS, 0x28C9, R/W) | 177 |
| Table 15-18 P2.1 Special Function Register (P21FS, 0x28CA, R/W) | 178 |
| Table 15-19 P2.4 Special Function Register (P24FS, 0x28CD, R/W) | 178 |
| Table 15-20 P2.5 Special Function Register (P25FS, 0x28CE, R/W) | 178 |
| Table 15-21 РЗ Output Enable Register (РЗОЕ, 0х28В4)            | 179 |
| Table 15-22 P3 Input Enable Register (P3IE, 0x28B5)             | 179 |
| Table 15-23 P3 Output Data Register (P3OD, 0x28B6)              | 179 |
| Table 15-24 P3 Input Data Register (P3ID, 0x28B7)               | 179 |
| Table 15-25 P4 Output Enable Register (P40E, 0x28B8)            | 180 |
| Table 15-26 P4 Input Enable Register (P4IE, 0x28B9)             | 181 |
| Table 15-27 P4 Output Data Register (P4OD, 0x28BA)              | 181 |
| Table 15-28 P4 Input Data Register (P4ID, 0x28BB)               | 181 |
| Table 15-29 P5 Output Enable Register (P50E, 0x28BC)            | 182 |
| Table 15-30 P5 Input Enable Register (P5IE, 0x28BD)             | 182 |
| Table 15-31 P5 Output Data Register (P5OD, 0x28BE)              | 182 |
| Table 15-32 P5 Input Data Register (P5ID, 0x28BF)               | 183 |
| Table 15-33 P6 Output Enable Register (P60E, 0x28C0)            | 183 |
| Table 15-34 P6 Input Enable Register (P6IE, 0x28C1)             | 184 |
| Table 15-35 P6 Output Data Register (P6OD, 0x28C2)              | 184 |
| Table 15-36 P6 Input Data Register (P6ID, 0x28C3)               | 184 |
| Γable 15-37 P7 Output Enable Register (P70E, 0x28D5)            | 185 |
| Table 15-38 P7 Input Enable Register (P7IE, 0x28D6)             | 185 |
| Table 15-39 P7 Output Data Register (P7OD, 0x28D7)              | 185 |
| Table 15-40 P7 Input Data Register (P7ID, 0x28D8)               | 186 |
| Table 15-41 P8 Output Enable Register (P80E, 0x28D9)            | 187 |

| Table 15-42 P8 Input Enable Register (P8IE, 0x28DA)                               | 187 |
|-----------------------------------------------------------------------------------|-----|
| Table 15-43 P8 Output Data Register (P8OD, 0x28DB)                                | 187 |
| Table 15-44 P8 Input Data Register (P8ID, 0x28DC)                                 | 187 |
| Table 15-45 P9 Output Enable Register (P90E, SFR 0xA4)                            | 188 |
| Table 15-46 P9 Input Enable Register (P9IE, SFR 0xA5)                             | 188 |
| Table 15-47 P9 Output Data Register (P9OD, SFR 0xA6)                              | 188 |
| Table 15-48 P9 Input Data Register (P9ID, SFR 0xA7)                               | 189 |
| Table 15-49 P9 Special Function Register (P9FS, SFR 0xAD)                         | 189 |
| Table 16-1 Enable/Disable CLK4                                                    | 191 |
| Table 17-1 RTC Password Enable Register (RTCPEN, SFR 0x90)                        | 196 |
| Table 17-2 RTC Password Register (RTCPWD, SFR 0x97)                               | 196 |
| Table 17-3 RTC Wakeup Interval Register (INTRTC, SFR 0x96)                        | 196 |
| Table 17-4 RTC Seconds Wake-up Interval Configuration Register (SECINT, SFR 0xDF) | 197 |
| Table 17-5 Flag Bit of RTC Wakeup Event                                           | 197 |
| Table 17-6 RTC Calibration Registers (RTCCH/RTCCL, SFR 0x94/0x95)                 | 197 |
| Table 17-7 RTC Data Reading Enable Register (RDRTC, SFR 0xDA)                     | 198 |
| Table 17-8 PLL Clock Divider Registers (DIVTHH/DIVTHM/DIVTHL, SFR 0xDB/0xDC/0xD   | -   |
|                                                                                   |     |
| Table 17-9 PLL Counter State Register (PLLCNT, SFR 0xDE)                          |     |
| Table 17-10 RTC Timing Registers                                                  |     |
| Table 18-1 ADC Control Register 0 (CtrlADC0, 0x2858)                              |     |
| Table 18-2 ADC Control Register 2 (CtrlADC2, 0x285A)                              |     |
| Table 18-3 Battery Discharge Control Register (CtrlBAT, 0x285C)                   | 201 |
| Table 18-4 LCD Driver Voltage Control Register (CtrlLCDV, 0x285E)                 | 202 |
| Table 18-5 Crystal Control Register 1 (CtrlCry1, 0x2860)                          | 202 |
| Table 18-6 Crystal Control Register 2 (CtrlCry2, 0x2861)                          | 203 |
| Table 18-7 ADC Control Register 5 (CtrlADC5, 0x2863)                              | 203 |
| Table 18-8 ADC Control Register 6 (CtrlADC6, 0x2864)                              | 204 |
| Table 18-9 Channel M Control Register (CtrlM, 0x2865)                             | 204 |
| Table 18-10 LDO Control Register (CtrlLDO, 0x2866)                                | 204 |
| Table 18-11 Clock Control Register (CtrlCLK, 0x2867)                              | 205 |

| Table 18-12 PLL Control Register (CtrlPLL, 0x2868)                       | 205 |
|--------------------------------------------------------------------------|-----|
| Table 18-13 Analog Circuits State Register (ANState, 0x286B)             | 206 |
| Table 18-14 PM Control Register 1 (PMCtrl1, 0x2878)                      | 207 |
| Table 18-15 PM Control Register 2 (PMCtrl2, 0x2879)                      | 208 |
| Table 18-16 PM Control Register 3 (PMCtrl3, 0x287A)                      | 208 |
| Table 18-17 Phase Compensation Control Register 1 (PHCCtrl1, 0x287B)     | 209 |
| Table 18-18 Phase Compensation Control Register 2 (PHCCtrl2, 0x287C)     | 209 |
| Table 18-19 PM Control Register 4 (PMCtrl4, 0x287D)                      | 210 |
| Table 18-20 CF Pulse Output Control Register (CFCtrl, 0x287E)            | 211 |
| Table 18-21 No-Load Detection Indication Register (CRPST, 0x287F)        | 212 |
| Table 18-22 Current Detection Control Register (IDET, 0x2886)            | 212 |
| Table 18-23 Signal Waveform Registers (R/W)                              | 213 |
| Table 18-24 Power and RMS Registers (R/W)                                | 214 |
| Table 18-25 Energy Accumulators and Energy Pulse Counters (R/W)          | 215 |
| Table 18-26 Line Frequency Register (DATAFREQ, 0x10FD)                   | 216 |
| Table 18-27 Data Registers for Channel M                                 | 216 |
| Table 18-28 Registers for Gain Calibration (R/W)                         | 217 |
| Table 18-29 Registers for Power Offset Calibration (R/W)                 | 217 |
| Table 18-30 Band-pass Filter Coefficient Register (0x10EF, R/W)          | 218 |
| Table 18-31 Energy Threshold Registers and Constant Power Register (R/W) | 218 |
| Table 18-32 Threshold Register for Current Detection (R/W)(R/W)          | 219 |

#### 1. Electrical Characteristics

#### 1.1. Absolute Maximum Ratings

While the operating circumstance exceeding "Absolute Maximum Ratings", it may cause the permanent damage to the device.

**Table 1-1 Absolut Maximum Ratings** 

| Parameter                         | Min. | Max. | Unit | Description        |
|-----------------------------------|------|------|------|--------------------|
| Analog Power Supply               | -0.3 | +8.0 | V    | Relative to ground |
| Analog Current Input              | -0.3 | +5.0 | V    | Relative to ground |
| Analog Voltage Input              | -0.3 | +5.0 | V    | Relative to ground |
| Operating Temperature             | -40  | +85  | °C   |                    |
| Storage Temperature               | -40  | +125 | °C   |                    |
| Junction Temperature              | _    | 150  | °C   |                    |
| Lead Temperature (Soldering, 10s) | -    | 300  | °C   |                    |

### 1.2. Energy Metering Specifications

All typical specifications are at TA = 25 °C, VDD5 = 5.0 V  $\pm 10\%$ , and  $f_{MTCLK}$  = 3.2768 MHz, unless otherwise noted.

**Table 1-2 Energy Metering Specifications** 

| Parameter                    | Тур.  | Unit   | Description                  |
|------------------------------|-------|--------|------------------------------|
| Phase Error between Channels |       |        |                              |
| PF = 0.8 Capacitive          | ±0.05 | Degree | 37° phase lead in current    |
| PF = 0.5 Inductive           | ±0.05 | Degree | 60° phase lag in current     |
| Active Energy Metering       |       |        |                              |
| Error                        | 0.1   | %      | Dynamic range of 5000:1@25°C |
| Bandwidth                    | 1.6   | kHz    |                              |
| Reactive Energy Metering     |       | •      |                              |
| Error                        | 0.1   | %      | Dynamic range of 3000:1@25°C |

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Parameter                        | Тур. | Unit   | Description                          |
|----------------------------------|------|--------|--------------------------------------|
| Bandwidth                        | 1.6  | kHz    |                                      |
| Apparent Power Metering          |      |        |                                      |
| Error                            | 0.5  | %      | Dynamic range of 1000:1@25°C         |
| Voltage/Current RMS Metering     |      |        |                                      |
| Error                            | 0.5  | %      | Dynamic range of 1000:1@25°C         |
| Bandwidth                        | 1.6  | kHz    |                                      |
| CF Pulse Output                  |      |        |                                      |
| Maximum Output Frequency         | 6.4  | kHz    |                                      |
| Duty Cycle                       | 50%  |        | When active high pulse width < 80 ms |
| Active High Pulse Width          | 80   | ms     | Configurable                         |
| Frequency Measurement Resolution | 0.05 | Hz/Isb | Measurement range: 35 Hz ~ 75 Hz     |
| Temperature Measurement Error    | ±1   | °C     | Measurement range: -40 °C ~ +85 °C   |

## 1.3. Analog Specifications

All maximum and minimum specifications apply to the entire recommended operation range (T = -40 °C  $\sim$  +85 °C, VDD5 = 3.3 V or 5.0 V  $\pm$ 10%), unless otherwise noted. All typical specifications are at TA = 25 °C and VDD5 = 5.0 V  $\pm$ 10%, unless otherwise noted.

**Table 1-3 Analog Specifications** 

| Parameter                        | Min. | Тур. | Max. | Unit | Description                                                                         |  |
|----------------------------------|------|------|------|------|-------------------------------------------------------------------------------------|--|
|                                  | 3.6  | 5.0  | 5.5  | V    | 5.0 V powered                                                                       |  |
| Analog Power Supply (VDD5)       | 2.5  | 3.3  | 3.6  | V    | 3.3 V powered                                                                       |  |
| LDO3.3 Output                    |      |      |      |      |                                                                                     |  |
| Voltage                          | 2.8  | 3.3  | 3.5  | V    | $V_{VDD5} \ge 4.0 \text{ V}$ $I_{L33} = 16 \text{ mA}$ Programmable                 |  |
| Load Current (I <sub>L33</sub> ) |      |      | 30   | mA   | Current dissipated on IOs should not be over the maximum driving capacity of LDO33. |  |
| Digital Power Supply             |      |      |      |      |                                                                                     |  |
| Voltage                          | 1.3  | 1.8  | 2.0  | V    | Programmable                                                                        |  |

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| LOW-powe                               | 51 IYIQ | aitiiuii | CUOII        | ai Eilei | gy Metering 30C              |
|----------------------------------------|---------|----------|--------------|----------|------------------------------|
| Parameter                              | Min.    | Тур.     | Max.         | Unit     | Description                  |
| Load Current (I <sub>LD</sub> )        |         |          | 35           | mA       |                              |
| POR/BOR Detection Threshold (DVCC)     |         | 1.4      |              | V        | Error: ±10%                  |
| Power-Down Detection Threshold (VDCIN) | )       |          |              |          | _                            |
| Maximum Signal Level                   | 0       |          | VDD          | V        |                              |
| Input Impedance (DC)                   |         | 1.5      |              | Μ'Ω      |                              |
| Detection Threshold for PWRDN          |         | 1.0      |              | V        |                              |
| Detection Threshold for PWRUP          |         | 1.1      |              | V        |                              |
| Analog Inputs                          |         |          |              |          |                              |
| Maximum Signal Levels                  | -200    |          | +200         | mV       | Peak value                   |
| ADC Performance                        |         |          |              |          |                              |
| DC Offset                              |         |          | 15           | mV       |                              |
| Effective Bits                         |         | 20       |              | BIT      | Sign bits are excluded.      |
| Bandwidth (-3dB)                       |         | 1.6      |              | kHz      |                              |
| ADC Operating Current                  |         |          |              |          |                              |
| Voltage Channel                        |         | 307      |              | μΑ       |                              |
| Current Channel                        |         | 485      |              | μΑ       | f <sub>ADC</sub> = 819.2 kHz |
| Measurement Channel                    |         | 238      |              | μΑ       |                              |
| On-Chip Crystal Oscillator             |         |          |              |          |                              |
| Crystal Frequency                      |         | 32.768   |              | kHz      |                              |
| On-Chip Reference (Band Gap)           |         |          |              |          |                              |
| Reference Error                        | -18     |          | 18           | mV       |                              |
| Power Supply Rejection Ratio           |         | 80       |              | dB       |                              |
| Temperature Coefficient                |         | 10       | 30           | ppm/°C   |                              |
| Output Voltage                         |         | 1.185    |              | V        |                              |
| Analog Comparator, CB                  |         |          |              |          |                              |
| Input Voltage                          | 0       |          | VDD5<br>-0.8 | V        |                              |
| Load Current                           |         | 186.2    |              | nA       | Bias current = 20 nA         |
| Delay Time                             | 2.7     | 3.0      | 4.0          | μs       | Square wave = 50 kHz         |
|                                        |         |          |              |          |                              |

#### Low-power Multifunctional Energy Metering SoC

| Parameter    | Min. | Тур.  | Max. | Unit | Description           |
|--------------|------|-------|------|------|-----------------------|
| Load Current |      | 664.6 |      | nA   | Bias current = 200 nA |
| Delay Time   | 0.20 | 0.37  | 0.60 | μs   | Square wave = 50 kHz  |

#### 1.4. Digital Interface Specifications

All maximum and minimum specifications apply to the entire recommended operation range (T = -40 °C  $\sim$  +85°C, VDD5 = 3.3 V or 5.0 V  $\pm$ 10%), unless otherwise noted.

**Table 1-4 Digital Interface Specifications** 

| Parameter                            | Min. | Тур. | Max. | Unit | Description                                                                  |
|--------------------------------------|------|------|------|------|------------------------------------------------------------------------------|
| Digital IO, Output                   |      |      |      |      |                                                                              |
| Output High Voltage, V <sub>OH</sub> | 2.4  |      |      | V    | The 12-mA current will not cause any                                         |
| I <sub>SOURCE</sub>                  |      | 10   | 12   | mA   | damage to the chip in a short period of                                      |
| Output Low Voltage, V <sub>OL</sub>  |      |      | 0.4  | V    | time. But, the current of more than  10 mA for a long duration may cause the |
| I <sub>SINK</sub>                    |      | 10   | 12   | mA   | damage to the chip.                                                          |
| Digital IO, Input                    |      | •    |      | •    |                                                                              |
| Input High Voltage, V <sub>INH</sub> | 2.0  |      |      | V    |                                                                              |
| Input Low Voltage, V <sub>INL</sub>  |      |      | 0.8  | V    |                                                                              |

#### 1.5. Memory Specifications

All maximum and minimum specifications apply over the entire recommended operation range (T = -40 °C  $\sim$  85°C, VDD5 = 3.3 V or 5.0 V  $\pm$ 10%), unless otherwise noted. All typical specifications are at TA = 25°C, VDD5 = 5.0 V  $\pm$ 10%, or f<sub>MCU</sub> = 13.1072 MHz, unless otherwise noted.

**Table 1-5 Memory Specifications** 

| Parameter            | Min.  | Тур. | Max. | Unit  | Description     |
|----------------------|-------|------|------|-------|-----------------|
| Flash Memory         |       |      |      |       |                 |
| Read Pulse Width     |       | 76   |      | ns    |                 |
| Endurance            | 20000 |      |      | cycle | -40 °C ~ +85 °C |
| Data Retention       | 100   |      |      | year  | 25 °C           |
| Data Retention       | 10    |      |      | year  | 85 °C           |
| Write Time, per byte |       | 40   |      | μs    |                 |

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Parameter                   | Min. | Тур. | Max. | Unit | Description         |
|-----------------------------|------|------|------|------|---------------------|
| Page Erase Time (512 bytes) |      | 40   |      | ms   |                     |
| Mass Erase Time             |      | 40   |      | ms   |                     |
| RAM                         |      |      |      |      |                     |
| Data Retention Voltage      | 1.62 |      |      | V    | DVCC output voltage |

## 1.6. GPSI Timing Specifications

All maximum and minimum specifications apply to the entire recommended operation range (T = -40 °C  $\sim$  +85 °C, VDD5 = 3.3 V or 5.0 V  $\pm$ 10%), unless otherwise noted.

**Table 1-6 GPSI Timing Specifications** 

| Parame              | ter                                                                 | Min.  | Max. | Unit |
|---------------------|---------------------------------------------------------------------|-------|------|------|
| f <sub>SCL</sub>    | SCL frequency                                                       |       | 400  | kHz  |
| t <sub>HD;STA</sub> | START condition hold time (Then, the first SCL pulse is generated.) | 1.875 |      | μs   |
| t <sub>LOW</sub>    | SCL low pulse width                                                 | 1.25  |      | μs   |
| t <sub>HIGH</sub>   | SCL high pulse width                                                | 1.25  |      | μs   |
| t <sub>SU;STA</sub> | RESTART condition setup time                                        | 0.625 |      | μs   |
| t <sub>HD;DAT</sub> | Data hold time                                                      | 0.625 |      | μs   |
| t <sub>SU;DAT</sub> | Data setup time                                                     | 0.625 |      | μs   |
| t <sub>r</sub>      | Rising time of both SDA and SCL                                     |       | 50   | ns   |
| t <sub>f</sub>      | Falling time of both SDA and SCL                                    |       | 50   | ns   |
| t <sub>SU;STO</sub> | STOP condition setup time                                           | 0.625 |      | μs   |
| t <sub>BUF</sub>    | Bus free time between STOP condition and START condition            |       | N/A  |      |
| t <sub>SP</sub>     | Pulse width of spike suppressed                                     |       | N/A  |      |

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC



**Figure 1-1 Timing Diagram** 

### 2.Pin Descriptions



Figure 2-1 Pin Assignment

**Table 2-1 Pin Descriptions** (Pin type: "O"=Output, "I"= Input, "P"=Power, "G"=Ground)

| No. | Mnemonic | Туре | Description                                                                                                                                                                                                                                                                                                   |
|-----|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | СТО      | 0    | 32768-Hz crystal output  Connect a 32768-Hz crystal around this pin and pin "CTI" to generate OSC clock                                                                                                                                                                                                       |
| 2   | VDCIN    | I    | Power supply supervisor input  When the input voltage on this pin is higher than 1.1 V, the chip will be powered by 5.0-V main power. When the input voltage on this pin is lower than 1.0 V, the chip will be powered by batteries. Or the power supply will be switched from 5.0-V main power to batteries. |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|     | Low-power Multifulfictional Effergy Metering Soc |      |                                                                                                                                                               |  |  |  |
|-----|--------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| No. | Mnemonic                                         | Туре | Description                                                                                                                                                   |  |  |  |
|     |                                                  |      | Analog input for the battery voltage measurement in various Measurement (M) Channels                                                                          |  |  |  |
| 3   | BAT                                              | I    | The input voltage signal into this pin to be measured must be in the range of -200 mV $\sim$ 3.8 V.                                                           |  |  |  |
|     |                                                  |      | When no battery is used, it is mandatory to make this pin floated. But do not connect it to the ground.                                                       |  |  |  |
| 4   | V3V                                              | I    | It is recommended to connect this pin to the ground.                                                                                                          |  |  |  |
|     |                                                  |      | Digital power output                                                                                                                                          |  |  |  |
| 5   | DVCC                                             | P    | The internal Power-on Reset (PoR) circuit supervises the output voltage on this pin: When the voltage is lower than 1.4 V, a Power-on Reset (PoR) will occur. |  |  |  |
|     |                                                  |      | Connect a $\geq$ 4.7-µF decoupling capacitor in parallel with a 0.1-µF decoupling capacitor around this pin, and then connect it to the digital ground        |  |  |  |
|     |                                                  |      | Regulated 3.3-V analog voltage output                                                                                                                         |  |  |  |
| 6   | LD033                                            | P    | Connect a $\geq$ 4.7-µF decoupling capacitor in parallel with a 0.1-µF decoupling capacitor around this pin, and then connect it to the analog ground         |  |  |  |
|     |                                                  |      | When the chip is 3.3 V powered, it is recommended to directly externally connect this pin to pin "VDD5".                                                      |  |  |  |
|     |                                                  |      | Power supply                                                                                                                                                  |  |  |  |
| 7   | VDD5                                             | Р    | Connect a 10- $\mu\text{F}$ decoupling capacitor to this pin, and then connect it to the ground                                                               |  |  |  |
|     |                                                  |      | When the chip is 3.3-V powered, it is recommended to directly externally connect this pin to pin "LDO33".                                                     |  |  |  |
| 8   | AVSS                                             | G    | Analog ground                                                                                                                                                 |  |  |  |
|     |                                                  |      | On-chip reference                                                                                                                                             |  |  |  |
| 9   | REF                                              | I/O  | Connect a 1.0- $\mu F$ decoupling capacitor to this pin, and then connect it to the ground                                                                    |  |  |  |
| 10  | UP                                               | I    | Positive input for Voltage Channel                                                                                                                            |  |  |  |
| 11  | UN                                               | I    | Negative input for Voltage Channel                                                                                                                            |  |  |  |
| 12  | IAP                                              | I    | Positive input for Current Channel IA                                                                                                                         |  |  |  |
| 13  | IAN                                              | I    | Negative input for Current Channel IA                                                                                                                         |  |  |  |
| 14  | IBN                                              | I    | Negative input for Current Channel IB                                                                                                                         |  |  |  |

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|     |                               |      | -power multifulfictional Effergy metering Soc                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|-----|-------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| No. | Mnemonic                      | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| 15  | IBP                           | I    | Positive input for Current Channel IB                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| 1.0 |                               |      | "Logic 0 input" to force the system into debugging mode                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 16  | MODE1                         | I    | "Logic 1 input" to force the system into metering mode                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 17  | P0.0<br>TDO                   | I/O  | this pin is used as a General-Purpose Input/Output (GPIO) port by efault. But when "logic 0" is input to the pin "MODE1", this pin will be sed as a JTAG port for the test data output (TDO).                                                                                                                                                                                                                                                                                        |  |  |  |  |
| 18  | P0.1<br>TDI                   | I/O  | This pin is used as a General-Purpose Input/Output (GPIO) by default. But when "logic 0" is input to the pin "MODE1", this pin will be used as a JTAG port for the test data input (TDI).                                                                                                                                                                                                                                                                                            |  |  |  |  |
| 19  | P0.2<br>WAKEUP3               | I/O  | This pin is used as a General-Purpose Input/Output (GPIO) port by default.  When the bit "IOPO" (bit1 of IOWK, SFR 0xC9) is set to '1', this pin will be used for the IO wakeup input, active on either transition (Configurable).                                                                                                                                                                                                                                                   |  |  |  |  |
|     | TMS                           |      | When "logic 0" is input to the pin "MODE1", this pin will be used as a JTAG port for the test mode selection (TMS).                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 20  | P0.3<br>WAKEUP4<br>TCK        | I/O  | This pin is used as a General-Purpose Input/Output (GPIO) port.  When the bit "IOPO" (bit1 of IOWK, SFR 0xC9) is set to '1', this pin will be used for the IO wakeup input, active on either transition (Configurable).  When "logic 0" is input to the pin "MODE1", this pin will be used as a JTAG port for the test clock input (TCK).                                                                                                                                            |  |  |  |  |
| 21  | P1.4 TXD5 INT1 PLLDIV WAKEUP1 | I/O  | The functions of this pin can be configured by the register "P14FS (0x28C8)":  General-Purpose Input/Output (GPIO) port  Transmitter data output of UART5  IO interrupt input 1, active on high-to-low transition  Pulse output proportional to the divided PLL clock frequency, which can be configured to output pulses of 1s width from the PLL counter  Besides, this pin can be used to wake up the system from the sleeping state, active on either transition (Configurable). |  |  |  |  |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|     |            |      | power materializational Energy metering soc                                                                                                                           |  |  |  |  |
|-----|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| No. | Mnemonic   | Туре | Description                                                                                                                                                           |  |  |  |  |
|     |            |      | The functions of this register can be configured by the register "P13FS" (0x28C7):                                                                                    |  |  |  |  |
|     |            |      | - General-Purpose Input/Output (GPIO) port                                                                                                                            |  |  |  |  |
|     | P1.3       |      | - Receiver data input of UART5                                                                                                                                        |  |  |  |  |
|     | RXD5       |      | - IO interrupt input 0, active on high-to-low transition                                                                                                              |  |  |  |  |
|     | INTO       |      | - Configurable CF pulse output                                                                                                                                        |  |  |  |  |
| 22  | CFx        | I/O  | - Pulse per second (PPS) output from the RTC                                                                                                                          |  |  |  |  |
|     | SP         | 1,0  | On calibrating RTC, every 30 seconds, from the 1 <sup>st</sup> to 29 <sup>th</sup> second, an un-calibrated pulse is output every second, and in the 30 <sup>th</sup> |  |  |  |  |
|     | PLLDIV     |      | second, a calibrated pulse is output which averages the cycle of each pulse in the 30 seconds to be 1 second.                                                         |  |  |  |  |
|     | WAKEUP2    |      | <ul> <li>Pulse output proportional to the divided PLL clock frequency, which can be configured to output pulses of 1s width from the PLL counter</li> </ul>           |  |  |  |  |
|     |            |      | Besides, this pin can be used to wake up the system from the sleeping state, active on either transition (Configurable).                                              |  |  |  |  |
|     | P1.2       |      | The functions of this pin can be configured by the register "P12FS (0x28C6)":                                                                                         |  |  |  |  |
|     | TXD1       |      | - General-Purpose Input/Output (GPIO) port                                                                                                                            |  |  |  |  |
| 23  | T2EX       | I/O  | - Transmitter data output of UART1                                                                                                                                    |  |  |  |  |
|     | INT3       |      | - Timer2 capture or reload trigger input                                                                                                                              |  |  |  |  |
|     |            |      | - IO interrupt input 3, active on high-to-low transition                                                                                                              |  |  |  |  |
|     |            |      | The functions of this pin can be configured by the register "P11FS (0x28C5)":                                                                                         |  |  |  |  |
|     | P1.1       |      | - General-Purpose Input/Output (GPIO) port                                                                                                                            |  |  |  |  |
| 24  | RXD1<br>T1 | I/O  | - Receiver data input of UART1                                                                                                                                        |  |  |  |  |
|     | INT2       |      | - Timer1 external input                                                                                                                                               |  |  |  |  |
|     | 1111 4     |      | - IO interrupt input 2, active on high-to-low transition                                                                                                              |  |  |  |  |
| 25  | P9.6       | 1/0  | The functions of this pin can be configured by the register "P9FS (SFR 0xAD)":                                                                                        |  |  |  |  |
| 25  | CF1        | I/O  | - General-Purpose Input/Output (GPIO) port (Fast IO)                                                                                                                  |  |  |  |  |
|     |            |      | - CF pulse output of E1 path                                                                                                                                          |  |  |  |  |

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|     |          | LOW  | -power multifunctional Energy Metering Soc                                                                                                                          |  |  |  |  |  |  |
|-----|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| No. | Mnemonic | Туре | Description                                                                                                                                                         |  |  |  |  |  |  |
|     | P9.5     |      | The functions of this pin can be configured by the register "P9FS (SFR 0xAD)":                                                                                      |  |  |  |  |  |  |
| 26  | CF2      | I/O  | - General-Purpose Input/Output (GPIO) port (Fast IO)                                                                                                                |  |  |  |  |  |  |
|     |          |      | CF pulse output of E2 path                                                                                                                                          |  |  |  |  |  |  |
|     |          |      | The functions of this pin can be configured by the register "P9FS (SFR 0xAD)":                                                                                      |  |  |  |  |  |  |
| 27  | P9.3     | I/O  | - General-Purpose Input/Output (GPIO) port (Fast IO)                                                                                                                |  |  |  |  |  |  |
|     | PLLDIV   |      | <ul> <li>Pulse output proportional to the divided PLL clock frequency,<br/>which can be configured to output pulses of 1s width from the PLL<br/>counter</li> </ul> |  |  |  |  |  |  |
| 20  | P3.0     |      |                                                                                                                                                                     |  |  |  |  |  |  |
| 28  | СОМ0     |      |                                                                                                                                                                     |  |  |  |  |  |  |
| 20  | P3.1     | I/O  |                                                                                                                                                                     |  |  |  |  |  |  |
| 29  | COM1     |      | These pins are used as General-Purpose Input/Output (GPIO) ports                                                                                                    |  |  |  |  |  |  |
|     | P3.2     |      | default. And they also can be used as backplanes of the LCD driver.                                                                                                 |  |  |  |  |  |  |
| 30  | COM2     |      |                                                                                                                                                                     |  |  |  |  |  |  |
| 21  | P3.3     |      |                                                                                                                                                                     |  |  |  |  |  |  |
| 31  | СОМЗ     |      |                                                                                                                                                                     |  |  |  |  |  |  |
|     | P4.0     |      |                                                                                                                                                                     |  |  |  |  |  |  |
| 32  | SEG0     |      | This min is used as Consum! Dumases Institute (CDIO) most but                                                                                                       |  |  |  |  |  |  |
|     | COM4     | 1/0  | This pin is used as General-Purpose Input/Output (GPIO) port by default, as SEG output for the LCD driver when bits "LCDTYPE"                                       |  |  |  |  |  |  |
|     | P4.1     | I/O  | (bit[5:4] of LCDCtrl, 0x2C1E) are cleared, or as backplanes of the LCD driver when bits "LCDTYPE" are set to '1', '2', or '3'.                                      |  |  |  |  |  |  |
| 33  | SEG1     |      | driver when bits LCDTTPL are set to 1, 2, or 3.                                                                                                                     |  |  |  |  |  |  |
|     | COM5     |      |                                                                                                                                                                     |  |  |  |  |  |  |
|     | P5.0     |      |                                                                                                                                                                     |  |  |  |  |  |  |
| 34  | SEG8     |      | This min is used as Consumb Dumases Institute (CDIO) most but                                                                                                       |  |  |  |  |  |  |
|     | СОМ6     |      | This pin is used as General-Purpose Input/Output (GPIO) port by default, as SEG output for the LCD driver when bits "LCDTYPE"                                       |  |  |  |  |  |  |
|     | P5.1     | I/O  | (bit[5:4] of LCDCtrl, 0x2C1E) are cleared or set to '1'; or as                                                                                                      |  |  |  |  |  |  |
| 35  | SEG9     |      | backplanes of the LCD driver when bits "LCDTYPE" are set to '2' or '3'.                                                                                             |  |  |  |  |  |  |
|     | COM7     |      |                                                                                                                                                                     |  |  |  |  |  |  |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|     |          | LOW  | -power multifulfictional Effergy metering Soc                                                                  |  |  |  |  |
|-----|----------|------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|
| No. | Mnemonic | Туре | Description                                                                                                    |  |  |  |  |
|     | P5.2     |      |                                                                                                                |  |  |  |  |
| 36  | SEG10    |      |                                                                                                                |  |  |  |  |
|     | P5.3     |      |                                                                                                                |  |  |  |  |
| 37  | SEG11    |      |                                                                                                                |  |  |  |  |
|     | P5.4     |      |                                                                                                                |  |  |  |  |
| 38  | SEG12    |      | These pins are used as General-Purpose Input/Output (GPIO) ports by                                            |  |  |  |  |
|     | P5.5     | I/O  | default; or SEG output for the LCD driver when the corresponding bits in SEG control registers are set to 1 s. |  |  |  |  |
| 39  | SEG13    |      |                                                                                                                |  |  |  |  |
|     | P5.6     |      |                                                                                                                |  |  |  |  |
| 40  | SEG14    |      |                                                                                                                |  |  |  |  |
|     | P5.7     |      |                                                                                                                |  |  |  |  |
| 41  | SEG15    |      |                                                                                                                |  |  |  |  |
| 42  | DVSS     | G    | Digital ground                                                                                                 |  |  |  |  |
|     | P6.2     |      |                                                                                                                |  |  |  |  |
| 43  | SEG18    |      |                                                                                                                |  |  |  |  |
|     | P6.3     | _    |                                                                                                                |  |  |  |  |
| 44  | SEG19    |      |                                                                                                                |  |  |  |  |
|     | P6.4     |      |                                                                                                                |  |  |  |  |
| 45  | SEG20    |      | These pins are used as General-Purpose Input/Output (GPIO) ports by                                            |  |  |  |  |
|     | P6.5     | I/O  | default; or SEG output for the LCD driver when the corresponding bits in SEG control registers are set to 1 s. |  |  |  |  |
| 46  | SEG21    |      |                                                                                                                |  |  |  |  |
|     | P6.6     |      |                                                                                                                |  |  |  |  |
| 47  | SEG22    |      |                                                                                                                |  |  |  |  |
|     | P6.7     |      |                                                                                                                |  |  |  |  |
| 48  | SEG23    |      |                                                                                                                |  |  |  |  |
|     | P7.6     |      |                                                                                                                |  |  |  |  |
| 49  | SEG30    | ]    | These pins are used as General-Purpose Input/Output (GPIO) ports by                                            |  |  |  |  |
|     | P7.7     | I/O  | default; or SEG output for the LCD driver when the corresponding bits in SEG control registers are set to 1s.  |  |  |  |  |
| 50  | SEG31    |      |                                                                                                                |  |  |  |  |

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|     |                            |      | power maintainctional Energy metering Soc                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|-----|----------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| No. | Mnemonic                   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| F4  | P7.8                       |      |                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 51  | SEG32                      |      |                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|     | P7.9                       |      |                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 52  | SEG33                      |      |                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|     | P8.0                       |      |                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 53  | SEG34                      |      |                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 54  | P9.0<br>TA0<br>SEG35       | I/O  | The functions of this pin can be configured by the register "P9FS (SFR 0xAD)":  General-Purpose Input/Output (GPIO) port (Fast IO)  TimerA port 0, to input/output the signals for TimerA Compare/Capture Module 0                                                                                                                                                                                           |  |  |  |  |
|     |                            |      | Besides, this pin can be used for SEG output for the LCD driver.                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 55  | SEG38<br>M1<br>CMPB        |      | These pins are used for SEG output for the LCD driver, for analog input for various measurements in Channel M, or for analog input to the analog comparator CB for comparison. The input voltage signal into                                                                                                                                                                                                 |  |  |  |  |
|     | SEG39                      | I/O  | this pin to be measured must be in the range of -200 mV $\sim$ 3.4 V.                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
| 56  | M2                         |      | When these pins are used for analog input to Channel M or the analog                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|     | СМРВ                       |      | comparator CB, the SEG output on these pins must be disabled.                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| 57  | P9.1<br>TA1<br>SDSP<br>SDA | I/O  | The functions of this pin can be configured by the register "P9FS (SFR 0xAD)":  General-Purpose Input/Output (GPIO) port (Fast IO)  TimerA port 1, to input/output the signals for TimerA Compare/Capture Module 1  This pin can be used for reference pulse input of exact 1s width.  When the bit "GPSI" (bit6 of PRCtrl0, 0x2D00) is set to '1', this pin will be used for serial data delivery for GPSI. |  |  |  |  |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|     | Low-power Multifulfictional Effergy Metering Soc |      |                                                                                                                                                               |  |  |  |  |  |  |  |
|-----|--------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| No. | Mnemonic                                         | Туре | Description                                                                                                                                                   |  |  |  |  |  |  |  |
|     |                                                  |      | The functions of this pin can be configured by the register "P9FS (SFR 0xAD)":                                                                                |  |  |  |  |  |  |  |
|     | P9.2                                             |      | - General-Purpose Input/Output (GPIO) port (Fast IO)                                                                                                          |  |  |  |  |  |  |  |
| 58  | TA2<br>SCL                                       | I/O  | <ul> <li>TimerA port 2, to input/output the signals for TimerA</li> <li>Compare/Capture Module 2</li> </ul>                                                   |  |  |  |  |  |  |  |
|     |                                                  |      | When the bit "GPSI" (bit6 of PRCtrl0, 0x2D00) is set to '1', this pin will be used for the serial clock delivery for GPSI.                                    |  |  |  |  |  |  |  |
|     | D2 F                                             |      | The functions of this pin can be configured by the register "P25FS (0x28CE)":                                                                                 |  |  |  |  |  |  |  |
| 59  | P2.5                                             | I/O  | - General-Purpose Input/Output (GPIO) port                                                                                                                    |  |  |  |  |  |  |  |
|     | TXD2                                             |      | <ul> <li>Transmitter data output of UART2</li> <li>It can be configured to transmit 38-kHz carrier wave.</li> </ul>                                           |  |  |  |  |  |  |  |
|     | P2.4<br>RXD2                                     |      | The functions of this pin can be configured by the register "P24FS (0x28CD)":                                                                                 |  |  |  |  |  |  |  |
| 60  |                                                  | I/O  | - General-Purpose Input/Output (GPIO) port                                                                                                                    |  |  |  |  |  |  |  |
| 00  |                                                  | 170  | <ul> <li>Receiver data input of UART2</li> <li>When this pin is used for the IR communication, it should be externally connected to a demodulator.</li> </ul> |  |  |  |  |  |  |  |
|     | P2.1                                             |      | The functions of this pin can be configured by the p2.1 register "P21FS (0x28CA)":                                                                            |  |  |  |  |  |  |  |
| 61  | TXD4                                             | I/O  | - General-Purpose Input/Output (GPIO) port                                                                                                                    |  |  |  |  |  |  |  |
|     | Т0                                               |      | - Transmitter data output of UART4                                                                                                                            |  |  |  |  |  |  |  |
|     |                                                  |      | - Timer0 external input                                                                                                                                       |  |  |  |  |  |  |  |
|     | P2.0                                             |      | The functions of this pin can be configured by the register "P20FS (0x28C9)":                                                                                 |  |  |  |  |  |  |  |
| 63  | RXD4                                             |      | - General-Purpose Input/Output (GPIO) port                                                                                                                    |  |  |  |  |  |  |  |
| 62  | T2                                               | I/O  | - Receiver data input of UART4                                                                                                                                |  |  |  |  |  |  |  |
|     | osc                                              |      | - Timer2 external input                                                                                                                                       |  |  |  |  |  |  |  |
|     |                                                  |      | OSC clock waveform output                                                                                                                                     |  |  |  |  |  |  |  |
| 63  | RSTn                                             | I    | Reset input, low active Hold LOW at least 5 ms to generate a signal to reset the system                                                                       |  |  |  |  |  |  |  |
| 64  | СТІ                                              | I    | 32768-Hz crystal input Connect a 32768-Hz crystal around this pin and pin "CTO" to generate a clock signal OSC                                                |  |  |  |  |  |  |  |

## 3. Functional Block Diagram



Figure 3-1 Functional Block Diagram

#### 4.8052 MCU Core Architecture

#### 4.1. Memory Map

AL6111A contains three memory blocks:

- Internal SRAM (IRAM) with 256 bytes in size, sharing the upper 128 bytes of its addresses with Special Function Registers (SFRs)
- Internal extended RAM (XRAM) with 4 KB in size and the memory of peripherals sharing the data memory area at addresses 0000h ~ FFFFh
- On-chip Flash memory with 64 KB in size mapping the program memory area at addresses 0000h  $\sim$  FFFFh

# 4.2. IRAM (Internal RAM) and SFRS (Special Function Registers)

The 256-byte internal SRAM (IRAM), located at addresses  $00h \sim FFh$ , is composed of two parts: The lower 128-byte RAM and the upper 128-byte RAM. When the output voltage of DVCC is higher than 1.62 V, IRAM will hold the data even if MCU is reset to its default state.

The lower 128-byte internal RAM contains three distinct blocks: Register Bank  $0 \sim 3$  (00h  $\sim 1$ Fh), Bit Address Area (20h  $\sim 2$ Fh) and General RAM Area (30h  $\sim 7$ Fh). All the lower 128-byte internal RAM can be accessed by direct or indirect addressing.

Register Bank 0 ~ 3, 32 bytes from 00h to 1Fh, each is composed of 8 registers, R0 ~ R7. Users can configure bit4 (RS1) and bit3 (RS0) of the register "PSW" (SFR 0xD0, Program Status Word SFR) to select the register bank to be used. By default Register Bank 0 is used.

Table 4-1 Select a Register Bank

| Register            | Bit                 | Default | Description                                         |
|---------------------|---------------------|---------|-----------------------------------------------------|
|                     |                     |         | To select a register bank to be used                |
| Program Status Word | 1 27                |         | 00: Register Bank 0, located at addresses 00h ~ 07h |
| PSW                 | bit[4:3]<br>RS1/RS0 | 0       | 01: Register Bank 1, located at addresses 08h ~ 0Fh |
| SFR 0xD0            |                     |         | 10: Register Bank 2, located at addresses 10h ~ 17h |
|                     |                     |         | 11: Register Bank 3, located at addresses 18h ~ 1Fh |

- Bit Address Area ( $20h \sim 2Fh$ ), each with bit addresses from 00h to 7Fh, is bit addressable.
- General RAM, from 30h to 7Fh, can be directly addressed.



#### Low-power Multifunctional Energy Metering SoC

The upper 128-byte internal RAM, located at addresses  $80h \sim FFh$ , shares its addresses with a group of specific internal registers (Special Function Registers, SFRS), but they are accessed in different ways. SFRs are accessed via the direct addressing, but the upper 128-byte internal RAM is accessed via the indirect addressing.



Figure 4-1 IRAM and SFRS

## AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

**Table 4-2 Special Function Registers (SFRS)** 

| Addr. | Register | bit 7  | bit 6 | bit 5 | bit 4 | bit 3 | bit 2  | bit 1  | bit 0  |
|-------|----------|--------|-------|-------|-------|-------|--------|--------|--------|
| 80h   | SysCtrl  | MEAFRQ | FWC   | FSC   | PMG   | LCDG  | SLEEP1 | SLEEP0 | MCUFRQ |
| 81h   | SP       | -      | -     | -     | -     | -     | -      | -      | -      |
| 82h   | DPL0     | -      | -     | -     | -     | -     | -      | -      | -      |
| 83h   | DPH0     | -      | -     | -     | -     | -     | -      | -      | -      |
| 84h   | DPL1     | -      | -     | -     | -     | -     | -      | -      | -      |
| 85h   | DPH1     | -      | -     | -     | -     | -     | -      | -      | -      |
| 86h   | DPS      | 0      | 0     | 0     | 0     | 0     | 0      | 0      | SEL    |
| 87h   | PCON     | SMOD0  | -     | 1     | 1     | GF1   | GF0    | STOP   | IDLE   |
| 88h   | TCON     | TF1    | TR1   | TF0   | TR0   | IE1   | IT1    | IE0    | IT0    |
| 89h   | TMOD     | GATE   | C/T   | M1    | M0    | GATE  | C/T    | M1     | МО     |
| 8Ah   | TL0      | -      | -     | -     | -     | -     | -      | -      | -      |
| 8Bh   | TL1      | -      | -     | -     | -     | -     | -      | -      | -      |
| 8Ch   | TH0      | -      | -     | -     | -     | -     | -      | -      | -      |
| 8Dh   | TH1      | -      | -     | -     | -     | -     | -      | -      | -      |
| 8Eh   | CKCON    | -      | -     | T2M   | T1M   | ТОМ   | MD2    | MD1    | MD0    |
| 8Fh   | SPCFNC   | 0      | 0     | 0     | 0     | 0     | 0      | 0      | WRS    |
| 90h   | RTCPEN   | -      | -     | -     | -     | -     | -      | -      | -      |
| 91h   | EXIF     | IE5    | IE4   | IE3   | IE2   | 1     | 0      | 0      | 0      |

|       |          |       | Low power fractional Energy free |        |       |        |        |        |        |  |
|-------|----------|-------|----------------------------------|--------|-------|--------|--------|--------|--------|--|
| Addr. | Register | bit 7 | bit 6                            | bit 5  | bit 4 | bit 3  | bit 2  | bit 1  | bit 0  |  |
| 92h   | Reserved | -     | -                                | -      | -     | -      | -      | -      | -      |  |
| 93h   | RTCYC    | Y80   | Y40                              | Y20    | Y10   | Y8     | Y4     | Y2     | Y1     |  |
| 94h   | RTCCH    | -     | -                                | C13    | C12   | C11    | C10    | C9     | C8     |  |
| 95h   | RTCCL    | C7    | C6                               | C5     | C4    | С3     | C2     | C1     | C0     |  |
| 96h   | INTRTC   | -     | -                                | -      | -     | -      | RTC2   | RTC1   | RTC0   |  |
| 97h   | RTCPWD   |       | -                                | -      | -     | -      | -      | -      | WE     |  |
| 98h   | Reserved | -     | -                                | -      | -     | -      | -      | -      | -      |  |
| 99h   | Reserved | -     | -                                | -      | -     | -      | -      | -      | -      |  |
| 9Ah   | RTCSC    | -     | S40                              | S20    | S10   | S8     | S4     | S2     | S1     |  |
| 9Bh   | RTCMiC   | -     | M40                              | M20    | M10   | M8     | M4     | M2     | M1     |  |
| 9Ch   | RTCHC    | -     | -                                | H20    | H10   | Н8     | H4     | H2     | H1     |  |
| 9Dh   | RTCDC    | -     | -                                | D20    | D10   | D8     | D4     | D2     | D1     |  |
| 9Eh   | RTCWC    | -     | -                                | -      | -     | W8     | W4     | W2     | W1     |  |
| 9Fh   | RTCMoC   | -     | -                                | -      | Mo10  | Mo8    | Mo4    | Mo2    | Mo1    |  |
| A0h   | CBANK    | -     | -                                | -      | -     | -      | -      | B1     | В0     |  |
| A1h   | Systate  | -     | IOP14                            | POR    | -     | IO     | RTC/CF | PWRDN  | PWRUP  |  |
| A2h   | Reserved | -     | -                                | -      | -     | -      | -      | -      | -      |  |
| A3h   | PLLLCK   | -     | -                                | -      | -     | -      | -      | -      | PLLLCK |  |
| A4h   | P9OE     | -     | P960EN                           | P950EN |       | P930EN | P920EN | P910EN | P900EN |  |

| Addr. | Register | bit 7     | bit 6     | bit 5     | bit 4     | bit 3     | bit 2     | bit 1     | bit 0     |
|-------|----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| A5h   | P9IE     | -         | P96INEN   | P95INEN   |           | P93INEN   | P92INEN   | P91INEN   | P90INEN   |
| A6h   | P9OD     | -         | -         | -         | -         | -         | -         | -         | -         |
| A7h   | P9ID     | -         | -         | -         | -         | -         | -         | -         | -         |
| A8h   | IE       | EA        | ES1       | ET2       | ES0       | ET1       | EX1       | ET0       | EX0       |
| A9h   | Reserved | -         | -         | -         | -         | -         | -         | -         | -         |
| AAh   | Reserved | -         | -         | -         | -         | -         | -         | -         | -         |
| ABh   | Reserved | -         | -         | -         | -         | -         | -         | -         | -         |
| ACh   | Reserved | -         | -         | -         | -         | -         | -         | -         | -         |
| ADh   | P9FS     | -         | P96FNC    | P95FNC    |           | P93FNC    | P92FNC    | P91FNC    | P90FNC    |
| AEh   | Reserved | -         | -         | -         | -         | -         | -         | -         | -         |
| AFh   | IOWKDET  | -         | -         | -         | -         | CFWK      | P03WK     | P02WK     | IOP14     |
| B8h   | IP       | 1         | PS1       | PT2       | PS0       | PT1       | PX1       | PT0       | PX0       |
| C0h   | SCON1    | SM0_1     | SM1_1     | SM2_1     | REN_1     | TB8_1     | RB8_1     | TI_1      | RI_1      |
| C1h   | SBUF1    | -         | -         | -         | -         | -         | -         | -         | -         |
| C7h   | IOEDG    | P03EDG<1> | P03EDG<0> | P02EDG<1> | P02EDG<0> | P14EDG<1> | P14EDG<0> | P13EDG<1> | P13EDG<0> |
| C8h   | T2CON    | TF2       | EXF2      | -         | -         | EXEN2     | TR2       | C/T2      | CP/RL2    |
| C9h   | IOWK     | -         | -         | -         | -         | -         | CFWKEN    | IOP0      | IORSTN    |
| CAh   | RCAP2L   | -         | -         | -         | -         | -         | -         | -         | -         |
| CBh   | RCAP2H   | -         |           | -         | -         | -         | -         | -         | -         |

|       | 1        | •     | •     |       |       |       |       | 9, -  |       |
|-------|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| Addr. | Register | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |
| CCh   | TL2      | -     | -     | -     | -     | -     | -     | -     | -     |
| CDh   | TH2      | -     | -     | -     | -     | -     | -     | -     | -     |
| CEh   | WDTEN    | -     | -     | -     | -     | -     | -     | -     | -     |
| CFh   | WDTCLR   | -     | -     | -     | -     | -     | -     | -     | -     |
| D0h   | PSW      | CY    | AC    | -     | RS1   | RS0   | OV    | -     | P     |
| D8h   | EICON    | SMOD1 | 1     | -     | -     | PFI   | 0     | 0     | 0     |
| D9h   | Reserved | -     | -     | -     | -     | -     | -     | -     | -     |
| DAh   | RDRTC    | -     | -     | -     | -     | -     | -     | -     | -     |
| DBh   | DIVTHH   | DIV23 | DIV22 | DIV21 | DIV20 | DIV19 | DIV18 | DIV17 | DIV16 |
| DCh   | DIVTHM   | DIV15 | DIV14 | DIV13 | DIV12 | DIV11 | DIV10 | DIV9  | DIV8  |
| DDh   | DIVTHL   | DIV7  | DIV6  | DIV5  | DIV4  | DIV3  | DIV2  | DIV1  | DIV0  |
| DEh   | PLLCNT   | -     | -     | -     | -     | -     | -     | STT1  | STT0  |
| DFh   | SECINT   | -     | 1     | SEC5  | SEC4  | SEC3  | SEC2  | SEC1  | SEC0  |
| E0h   | ACC      | -     | -     | -     | -     | -     | -     | -     | -     |
| E8h   | EIE      | 1     | 1     | 1     | EWDI  | EX5   | EX4   | EX3   | EX2   |
| F0h   | В        | -     | -     | -     | -     | -     | -     | -     | -     |
| F8h   | EIP      | 1     | 1     | 1     | PWDI  | PX5   | PX4   | PX3   | PX2   |

# 4.3. Data Memory

XRAM with 4096 bytes in size and peripherals registers are mapped to the data storage space.

XRAM is located at addresses 0000h  $\sim$  0FFFh that can be accessed without limit. The content of XRAM cannot be reset by any reset event, and it will hold the data until the output voltage of DVCC is lower than 1.62 V.

Data storage space, except for the contents of XRAM, all of the peripherals registers can be reset, among them, the LCD, GPIO, Analog control and power metering related registers can only be reset to the default value of the level 1, other registers will be reset to the default value of the grade 1/2/3. The contents of the Info area will not be reset; however, after a level 1 reset event, the data needs to be within the scope of the stable time of 2 ms, that is, after MCU start normal execution program in a Flash.



Figure 4-2 Data Memory

# Low-power Multifunctional Energy Metering SoC

Table 4-3 Allocation of Info Area

| Starting Address | Functional Description | Number<br>of Byte | Endianness    |
|------------------|------------------------|-------------------|---------------|
| 0x 401           | Noted additionally     | 2                 | Little-endian |
| 0x 403           | Noted additionally     | 2                 | Little-endian |
| 0x 405           | Noted additionally     | 2                 | Little-endian |
| 0x 407           | Noted additionally     | 4                 | Little-endian |
| 0x 40B           | Noted additionally     | 1                 | Little-endian |
| 0x 40C           | Noted additionally     | 4                 | Little-endian |
| 0x 410           | Noted additionally     | 2                 | Little-endian |
| 0x 412           | Noted additionally     | 2                 | Little-endian |
| 0x 414           | Noted additionally     | 1                 | Little-endian |
| 0x 415           | Noted additionally     | 1                 | Little-endian |
| 0x 416           | Noted additionally     | 2                 | Little-endian |
| 0x 418           | Noted additionally     | 1                 | Little-endian |
| 0x 419           | Noted additionally     | 1                 | Little-endian |
| 0x 41A           | Noted additionally     | 2                 | Little-endian |
| 0x 41C           | Noted additionally     | 1                 | Little-endian |
| 0x 41D           | Noted additionally     | 1                 | Little-endian |
| 0x 41E           | Noted additionally     | 2                 | Little-endian |
| 0x420            | а                      | 4                 | Little-endian |
| 0x 424           | b                      | 4                 | Little-endian |
| 0x 428           | С                      | 4                 | Little-endian |
| 0x 42C           | d                      | 4                 | Little-endian |
| 0x 430           | е                      | 4                 | Little-endian |
| 0x 434           | ADD33 verification     | 2                 | Little-endian |
| 0x 436           | Reserved               | 2                 | Little-endian |
| 0x 438           | a                      | 4                 | Little-endian |
| 0x 43C           | b                      | 4                 | Little-endian |
| 0x 440           | С                      | 4                 | Little-endian |
| 0x 444           | d                      | 4                 | Little-endian |

| Starting Address | Functional Description                | Number<br>of Byte | Endianness    |
|------------------|---------------------------------------|-------------------|---------------|
| 0x 448           | е                                     | 4                 | Little-endian |
| 0x 44C           | ADD33 verification                    | 2                 | Little-endian |
| 0x 44E           | Reserved                              | 2                 | Little-endian |
| 0x 450           | а                                     | 4                 | Little-endian |
| 0x 454           | b                                     | 4                 | Little-endian |
| 0x 458           | С                                     | 4                 | Little-endian |
| 0x 45C           | d                                     | 4                 | Little-endian |
| 0x 460           | е                                     | 4                 | Little-endian |
| 0x 464           | ADD33 verification                    | 2                 | Little-endian |
| 0x 466           | Reserved                              | 2                 | Little-endian |
| 0x 468           | Reserved                              | 4                 | Little-endian |
| 0x 46C           | Reserved                              | 2                 | Little-endian |
| 0x 46E           | Reserved                              | 2                 | Little-endian |
| 0x 470           | Reserved                              | 4                 | Little-endian |
| 0x 474           | Reserved                              | 2                 | Little-endian |
| 0x 476           | Reserved                              | 2                 | Little-endian |
| 0x 478           | Reserved                              | 4                 | Little-endian |
| 0x 47C           | Reserved                              | 2                 | Little-endian |
| 0x 47E           | Reserved                              | 2                 | Little-endian |
| 0x 480           | Backup 1 of temperature deviation     | 2                 | Big-endian    |
| 0x 482           | ADD33 verification                    | 2                 | Big-endian    |
| 0x 484           | Backup 2 of temperature deviation     | 2                 | Big-endian    |
| 0x 486           | ADD33 verification                    | 2                 | Big-endian    |
| 0x 488           | Backup 3 of temperature deviation     | 2                 | Big-endian    |
| 0x 48A           | ADD33 verification                    | 2                 | Big-endian    |
| 0x 48C           | Backup 1 of RTC temperature deviation | 2                 | Big-endian    |

|                  | zon ponter marenamee                                    | ionai En          | ergy rietering e |
|------------------|---------------------------------------------------------|-------------------|------------------|
| Starting Address | Functional Description                                  | Number<br>of Byte | Endianness       |
| 0x 48E           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 490           | Backup 2 of RTC temperature deviation                   | 2                 | Big-endian       |
| 0x 492           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 494           | Backup 3 of RTC temperature deviation                   | 2                 | Big-endian       |
| 0x 496           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 498           | Backup 1 of parabolic coefficient $B_{para}$ of crystal | 20                | Big-endian       |
| 0x 4AC           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 4AE           | Backup 2 of parabolic coefficient $B_{para}$ of crystal | 20                | Big-endian       |
| 0x 4C2           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 4C4           | Backup 3 of parabolic coefficient $B_{para}$ of crystal | 20                | Big-endian       |
| 0x 4D8           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 4DA           | Backup 1 of crystal fixed-point temperature             | 2                 | Big-endian       |
| 0x 4DC           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 4DE           | Backup 2 of crystal fixed-point temperature             | 2                 | Big-endian       |
| 0x 4E0           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 4E2           | Backup 3 of crystal fixed-point temperature             | 2                 | Big-endian       |
| 0x 4E4           | ADD33 verification                                      | 2                 | Big-endian       |
| 0x 4E6           | Reserved                                                | 2                 | Big-endian       |
| 0x 4E8           | Standard RTC capturing value                            | 4                 | Big-endian       |
| 0x 4EC           | Target chip RTC capturing value                         | 4                 | Big-endian       |
| 0x 4F0           | Reserved                                                | 4                 | Big-endian       |
| 0x 4F4           | SD502 version number                                    | 4                 | Big-endian       |

| Starting Address | Functional Description                                    | Number<br>of Byte | Endianness |
|------------------|-----------------------------------------------------------|-------------------|------------|
| 0x 4F8           | Ambient temperature during temperature calibration        | 4                 | Big-endian |
| 0x 4FC           | Temperature of target chip before temperature calibration | 4                 | Big-endian |
| 0x 500           | Reserved                                                  | 256               |            |

<sup>\*</sup>Users can read of these bytes and obtain the recommended configuration of the analog control registers, and then write them to the analog control registers.

# 4.4. Program Memory

In AL6111A, the 64-KB on-chip Flash memory (Including program encryption bytes) and the Flash control registers are mapped to the program memory area at addresses  $0000h \sim FFFFh$ . The Flash control registers, mapped at addresses 0x0401 and 0x0402 of the program memory area, determine the programming mode and power consumption of the Flash memory.

The third page of the Flash memory, at addresses  $0400h \sim 05FFh$ , is pre-burned with the codes by the manufacturer. Therefore, this area cannot be used for the user codes.

Table 4-4 Flash Control Register 1 (FCtrl1, 0x0402)

| 0x0402,  | 0x0402, R/W, Flash Control Register 1, FCtrl1 |         |                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|----------|-----------------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| bit      |                                               | Default | Description                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| bit7     | -                                             | -       | Set this bit to '1' to activate the write operation of other bits                                                                                                                                                                                                          |  |  |  |  |  |  |
| bit6     | CKSL                                          | 0       | When the MCU clock frequency ( $f_{MCU}$ ) is 3.2768 MHz, clear this bit to enable programming, page erase, and mass erase of Flash memory.  When $f_{MCU}$ is 13.1072 MHz, set this bit to '1' to enable the programming, page erase, and mass erase of the Flash memory. |  |  |  |  |  |  |
| bit[5:0] | Reserved                                      | 0       | These bits must hold their default values for the proper operation.                                                                                                                                                                                                        |  |  |  |  |  |  |

<sup>\*\*</sup>See "測量溫度" for details of parameter A, B, C, D, E, and temperature error.

<sup>\*\*\*</sup>When users are using the crystals provided by Vango, they can read these addresses to obtain the details of crystal frequency deviation  $\Delta$ , parabolic coefficient  $B_{para}$ , and turnover temperature of the crystal, to calibrate RTC. See the corresponding application notes for details.



Figure 4-3 Flash Memory and Program Memory Area

The 64-KB on-chip Flash memory of AL6111A is featured with the write protection, program encryption, and ISP (In-System Programming) and IAP (In-Application Programming) supported.

The 8052 MCU core of AL6111A can address up to 64-KB program memory area, 0000h ~ FFFFh, but the Flash memory can store up to 64-KB codes. In order to execute the program with more than 64-KB in size, the code banking technique is used. By using this technique, the program can be divided into no more than four parts with no more than 64-KB codes each, and is allocated at different parts of the Flash memory:

- Common Area, at addresses 0000h ~ 7FFFh: To allocate the common codes, such as interrupt vectors, reset vectors, bank switching routines, interrupt service routines, and so on. It is always mapped to the program memory area at addresses 0000h ~ 7FFFh.
- Code Area, at addresses 8000h~1FFFFh: To allocate the application codes; Bank 1, at addresses 8000h ~ FFFFh; Bank2, at addresses 10000h ~ 17FFFh; Bank 3, at addresses 18000h ~ 1FFFFh. Each bank can be mapped to the program memory area at addresses 8000h ~ FFFFh, and the processor can access the register "CBANK" (SFR 0xA0) to switch the banks and execute the codes.

Table 4-5 Code Bank Register (CBANK, SFR 0xA0)

| SFR 0xA  | SFR 0xA0, R/W, Code Bank Register, CBANK |         |             |  |  |  |  |
|----------|------------------------------------------|---------|-------------|--|--|--|--|
| Bit      |                                          | Default | Description |  |  |  |  |
| bit[7:2] | Reserved                                 | 0       |             |  |  |  |  |

### Low-power Multifunctional Energy Metering SoC

#### SFR 0xA0, R/W, Code Bank Register, CBANK

| Bit             |  | Default | Description                                                                                                    |
|-----------------|--|---------|----------------------------------------------------------------------------------------------------------------|
|                 |  |         | To select code bank to be mapped to the code area of the program memory space at addresses 8000h $\sim$ FFFFh. |
| bit[1:0] B<1:0> |  | 1       | 01: Bank 1                                                                                                     |
|                 |  |         | 10: Bank 2                                                                                                     |
|                 |  |         | 11: Bank 3                                                                                                     |

In AL6111A, the on-chip Flash memory is divided into 256 pages with 512 bytes each. The codes in the Flash memory can be read, erased, or programmed in pages or mass erased.

When the low logic level is input on the pin "MODE1", the chip will be in the debugging mode. In this mode, the 4 pins of Group P0 work as JTAG interfaces. Users can use the DLL codes and simulators provided by Vango to download and debug the applications in Keil  $\mu$ Vision IDE or IAR IDE via the JTAG interfaces.

#### Notes:

In the debugging mode, the system cannot get to LPM1 state or LPM2 state, and the reset events, POR/BOR and WDT overflow, are masked. In the sleeping state, a power supply restoration event will occur immediately when the system goes to the debugging mode.

In the debugging mode, the TCK speed limit is 400 Kbps by default. The command "0x22" can increase it to the current PLL clock frequency, and the command "0x23" can recover it.

No capacitors should be connected to the JTAG interfaces to avoid the download failure of codes.

There is an encryption bit (bit0 of byte located at address 0x0400) in the Flash memory. The configuration of this bit has effects on the access to the Flash memory. When the logic high level is input on the pin "MODE1", the chip will be in the metering mode. In this mode, the on-chip Flash memory is IAP-supportive, and the access to the Flash memory will not be affected by the encryption bit configuration. When the logic high level is input on the pin "MODE1", the chip will be in the metering mode. In this mode, the on-chip Flash memory is IAP- supportive and ISP-supportive, and the encryption bit configuration will affect the access to the Flash memory.

**Table 4-6 Programming Flash Memory** 

| <b>D</b>           |                 | Write '0' to encryption bit |       |          |               | Write '1' to encryption bit |       |      |               |
|--------------------|-----------------|-----------------------------|-------|----------|---------------|-----------------------------|-------|------|---------------|
| Programming method | Flash memory    | Mass<br>erase               | Write | Read     | Page<br>erase | Mass<br>erase               | Write | Read | Page<br>erase |
| In debugging       | 00000h ~ 17FFFh | ,                           | Х     | Х        | X             | · √                         | √     | √    | ,             |
| mode               | 18000h ~ 1FFFFh | V                           | Х     | <b>√</b> | Х             |                             |       |      | V             |



|               |                 |     |          |          |          | AL61: | L1A C    | atas     | heet     |
|---------------|-----------------|-----|----------|----------|----------|-------|----------|----------|----------|
|               | Low-po          | wer | Multif   | functi   | ional    | Energ | y Met    | ering    | SoC      |
| IAP in normal | 00000h ~ 003FFh | V   | Х        | <b>√</b> | Х        | X     | X        | <b>√</b> | Х        |
| mode          | 00400h ~ 1FFFFh | X   | <b>√</b> | <b>√</b> | <b>√</b> |       | <b>√</b> | <b>√</b> | <b>√</b> |

Note:

After ISP, input logic low to the pin "RSTn" or power on the chip again to activate the ISP read encryption.

## 5.Reset

In AL6111A, all circuits, except for the RTC calibration registers, RTC timing registers, IRAM, XRAM, and Info area, can be reset to their default states by an event of a specific reset level. Three levels of events are designed to reset different circuits of the system, including:

- Level 3: The lowest level, debugging reset instruction. When the event of this level occurs, MCU, interrupt management circuits, timers, UART interfaces, and GPSI interfaces will be reset to their default states;
- Level 2: The middle level, including power supply restoration (Power up), IO wakeup input, RTC wakeup event, and CF pulse wakeup event. When an event of this level occurs, Clock Switchover Control Register (SysCtrl, SFR 0x80), IO Wakeup Control Register (IOWK, SFR 0xC9), IO Wakeup Edge Control Register (IOEDG, SFR 0xC7), Flash control registers, watch-dog timer, and all the circuits that can be reset by events of Level 3 will be reset to their default states.
- Level 1: The highest level, including the "RSTn" pin input signal (RSTn pin reset), Power-On Reset (POR), Brown-Out Reset (BOR), and WDT overflow event. When an event of this level occurs, the LCD driver, General-Purpose I/O (GPIO) ports, System State Register (Systate, SFR 0xA1), PO IO Wakeup Flag Register (IOWKDET, SFR 0xAF), analog control registers, the global energy metering architecture, and all the circuits that can be reset by events of Level 2 will be reset to their default states.

In AL6111A, the reset management circuits are designed by following the rule: A reset event of higher level can reset the circuits that can be reset by the lower level reset events, but not vice versa.



Figure 5-1 Reset Unit Diagram

Table 5-1 Circuits to Be Reset

|                                  |                         | Reset by          |                   |                   |  |
|----------------------------------|-------------------------|-------------------|-------------------|-------------------|--|
| Unit                             |                         | Events of Level 1 | Events of Level 2 | Events of Level 3 |  |
| MCU                              |                         | V                 | √                 | √                 |  |
| Interrupts                       |                         | V                 | V                 | √                 |  |
| Timers                           |                         | V                 | V                 | √                 |  |
| UART                             |                         | V                 | V                 | √                 |  |
| GPSI                             |                         | V                 | V                 | √                 |  |
| Flash Control                    | Registers               | √                 | √                 | X                 |  |
| SysCtrl (SFR                     | 0×80)                   | V                 | V                 | X                 |  |
| IOEDG (SFR (                     | 0xC7)                   | V                 | V                 | X                 |  |
| IOWK (SFR 0                      | xC9)                    | √                 | √                 | X                 |  |
| WDT                              |                         | √                 | √                 | X                 |  |
| Systate (SFR                     | 0xA1)                   | √                 | X                 | X                 |  |
| IOWKDET (SF                      | R 0xAF)                 | √                 | X                 | X                 |  |
| Global Energ                     | y Metering Architecture | √                 | X                 | X                 |  |
| Analog Contro                    | ol Registers            | V                 | X                 | X                 |  |
| LCD Driver                       |                         | V                 | X                 | X                 |  |
| General-Purpose I/O Ports (GPIO) |                         | V                 | X                 | X                 |  |
| Calibration Registers            |                         | X                 | X                 | X                 |  |
| RTC                              | Timing Registers        | X                 | X                 | X                 |  |
|                                  | Other Registers         | √                 | X                 | X                 |  |
| IRAM                             |                         | Х                 | X                 | Х                 |  |
| XRAM                             |                         | Х                 | X                 | Х                 |  |

| 11                          | Reset by          |                   |                   |  |
|-----------------------------|-------------------|-------------------|-------------------|--|
| Unit                        | Events of Level 1 | Events of Level 2 | Events of Level 3 |  |
| Info Area (0x3000 ~ 0x33FF) | Х                 | Х                 | Х                 |  |

### 5.1. Level 3

In AL6111A, only the debugging reset instruction is designed as the reset event of Level 3. It can reset MCU, interrupt management circuits, timers, UART interfaces and GPSI interfaces.

When logic '0' is input to the pin "MODE1", the system will enter the debugging mode. In this mode, when the debugging operation is enabled or the tab "Reset" in IDE is clicked, a debugging reset instruction will be executed to reset MCU and its peripherals.

#### 5.2. Level 2

In AL6111A, power supply restoration, IO wake-up input, RTC wake-up event, and CF pulse wakeup event are designed as the reset events of Level 2.

By default any event of this level can wake up the system from LPM1 state or LPM2 state and reset the system to the OSC state. But if the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) is set to '1', any event of this level can wake up the system without reset. That is, the event can wake up the system from the sleeping state but not reset the system to the OSC state. In this case, after the wakeup, MCU keeps on executing programs; all circuits go back where the system enters the sleeping state, but bit[2:1] (SLEEP1 and SLEEP0) and bit[6:5] (FWC and FSC) are cleared. When "IORSTN" (bit0 IOWK, SFR 0 xc9) is cleared, the dormancy awakening events can be reset by level 3 reset circuit, reset events can reset the clock switch control register (SysCtrl, SFR 0 x80), IO sleep wake up edge selection register (IOEDG, SFR 0 xc7), IO dormancy awakening control register (IOWK, SFR 0 xc9), FLASH control registers, and WDT. Please refer to Table 5-1 for the detailed information.

### **5.2.1. Power Supply Restoration**

In AL6111A, when the voltage on the pin "VDCIN" rises from lower than 1.0 V to higher than 1.1 V, or when the voltage on the pin "VDCIN" is higher than 1.1 V after any reset event of Level 1, a power supply restoration event will occur. By default this event wakes up the chip and reset it to the OSC state, and the reset signal holds 8 OSC clock cycles.

#### 5.2.2. IO Wakeup Input

In AL6111A, 4 pins, "WAKEUP1 (P1.4), WAKEUP2 (P1.3), WAKEUP3 (P0.2), and WAKEUP4 (P0.3)", can



#### Low-power Multifunctional Energy Metering SoC

be used to wake up the chip from the LPM1 state or LPM2 state. Pins "WAKEUP1" and "WAKEUP2" can be used for the wakeup input all the time, but pins "WAKEUP3" and "WAKEUP4" can be used for the wakeup input only when the bit "IOP0" (bit1 of IOWK, SFR 0xC9) is set to '1'. The wakeup input on these 4 I/O ports are independent.

If the 4 I/O ports are set to "Input enabled" before the chip enters the LPM1 state or LPM2 state, a transition (Either high-to-low or low-to-high, with more than 4 OSC clock cycles on both levels) on the pin in the LPM1 state or LPM2 state can wake up the system. Users can configure the register "IOEDG" (SFR 0xC7) to determine the active edge for the IO wakeup event. Any IO wakeup event can set the bit "IO" (bit3 of Systate, SFR 0xA1) to '1'. When the bit "IO" is set to '1', users can read bits "IOP14, P02WK, and P03WK" (bit[0:2] of IOWKDET, SFR 0xAF) to detect the transition on which pin wakes up the system.

By default a transition on any one of the 4 I/O ports can wake up the system and reset it to the OSC state. To lower the power consumption, users can set the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) to '1' to wake up the system without reset.

#### 5.2.3. RTC Wakeup

In AL6111A, the RTC can wake up the system from the LPM1 state at an interval set at registers "INTRTC (SFR 0x96) and SECINT (SFR 0xDF)". When the system is woken up by an RTC event, the bit "RTC/CF" (bit2 of Systate, SFR 0xA1) will be set to '1', but the bit "CFWK" (bit3 of IOWKDET, SFR 0xAF) will be cleared. Please refer to Figure 5-1 for the detailed information.

By default the RTC wakeup event can wake up the system from the LPM1 state and reset it to the OSC state. The reset signal holds 8 OSC clock cycles. To lower the power consumption, users can set the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) to '1' to wake up the system without reset.

#### 5.2.4. CF Pulse Wakeup Event

In AL6111A, the system may be woken up from the LPM1 state by the CF pulse output if the CF pulse output is enabled (CFENR = 1 or CFEN = 1, bit[5:4] of PMCtrl4, 0x287D), and the CF pulse output is enabled to be a wakeup event (CFWKEN = 1, bit2 of IOWK, SFR 0xC9) before the system enters the LPM1 state. When a CF pulse wakeup event occurs, both bits "RTC/CF" (bit2 of Systate, SFR 0xA1) and "CFWK" (bit3 of IOWKDET, SFR 0xAF) are set to 1s.

By default the CF pulse wakeup event can wake up the system from the LPM1 state and reset it to the OSC state. To lower the power consumption, users can set the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) to '1' to wake up the system without reset.

### 5.3. Level 1

In AL6111A, WDT overflow, RSTn pin input signal, power-on (POR), and brown out (BOR) are designed as the reset events of Level 1. When any one of these reset events occurs, the bit "POR" (bit5 of Systate, SFR 0xA1) will be set to '1'.



### 5.3.1. RSTn Pin Input (RSTn Pin Reset)

Holding logic low on the pin "RSTn" for more than 5 ms can trigger an RSTn pin reset signal to reset the system. After the logic is pulled high, the reset signal holds 4 more OSC clock cycles (About 122  $\mu$ s) and then is released.

To prevent from the static disturbance, the input signal on the pin "RSTn" will be filtered based on the RC clock.



Figure 5-2 RSTn Pin Reset Timing

# 5.3.2. Power-On Reset (POR) and Brown-Out Reset (BOR)

In AL6111A, the output voltage of the digital power supply (Via pin "DVCC") is monitored by the power-on/brown-out reset circuit.

On power-up, a power-on reset signal will be generated to reset the system when the output voltage of pin DVCC is lower than 1.4 V. The system will stay in the reset state for 4 more OSC clock cycles (About 122 µs) even when the voltage on the pin "DVCC" is higher than 1.4 V.

On power-down, when the output voltage on the pin "DVCC" is lower than 1.4 V, the brown-out reset circuit will generate a reset signal to reset the system.

When logic "0" is input to the pin "MODE1", this reset event will be masked.



Figure 5-3 Power-on Reset Timing

#### 5.3.3. WDT Overflow

In AL6111A, when the WDT overflows, a reset signal is generated and resets the system. The system will exit from the reset state in 8 RC clock cycles (About 250  $\mu$ s).

When logic '0' is input to the pin "MODE1", this reset event will be masked.

# 5.4. Registers

Table 5-2 System State Register, Systate (SFR 0xA1)

| SFR 0xA        | SFR 0xA1, R, System State Register, Systate |                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|----------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit            | Default                                     | Description                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| bit[7:6]       |                                             | Reserved                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| bit5<br>POR    | 0                                           | When this bit is read out as '1', it indicates the system is reset by an event of Level 1: POR/BOR, RSTn pin reset, or WDT overflow event. This bit will be cleared when a reset event of other levels occurs.                                                                                                                                                                                         |  |  |  |  |  |
| bit4           | 0                                           | Reserved                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| bit3           | 0                                           | When this bit is read out as `1', it indicates the system is woken up from the LPM1 state or LPM2 state by an IO wakeup event.                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| bit2<br>RTC/CF | 0                                           | When this bit is read out as '1', but the bit "CFWK" (bit3 of IOWKDET, SFR 0xAF) is cleared, it indicates the system is woken up from the LPM1 state by the RTC wakeup event.  If both this bit and bit "CFWK" are set to 1s, it indicates the system is woken up from the LPM1 state by the CF pulse wakeup event.                                                                                    |  |  |  |  |  |
| bit1<br>PWRDN  | 0                                           | When the input voltage on the pin "VDCIN" is lower than 1.0 V, this bit is read out as '1', indicating that the system is powered down. If the power down interrupt is enabled, an interrupt will be triggered when this bit is read out as '1'.  When the input voltage on the pin "VDCIN" is higher than 1.1 V, this bit holds its default value, indicating there is no power-down event occurring. |  |  |  |  |  |
| bit0<br>PWRUP  | 0                                           | When the input voltage on the pin "VDCIN" is higher than 1.1 V, this bit is read out as '1', indicating that the system is powered up by the AC power supply.  When the input voltage on pin VDCIN is lower than 1.0 V, this bit holds its default value, indicating the system is powered up by batteries.                                                                                            |  |  |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

Table 5-3 P0 IO Wakeup Flag Register (IOWKDET, SFR 0xAF)

| SFR 0xAF, R, P0 IO Wakeup Flag Register, IOWKDET |                                                                                     |     |         |                                                                                                                                                                                                                |  |
|--------------------------------------------------|-------------------------------------------------------------------------------------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit                                              |                                                                                     | R/W | Default | Description                                                                                                                                                                                                    |  |
| bit[7:2]                                         | Reserved                                                                            | -   | -       |                                                                                                                                                                                                                |  |
| bit3                                             | CFWK                                                                                | R   | 0       | If this bit is set to '1' when the bit "RTC/CF" (bit2 of Systate, SFR 0xA1) is read out as '1', it indicates the system is woken up from the LPM1 state by the CF pulse wakeup event.                          |  |
| bit2                                             | P03WK                                                                               | R   | 0       | If this bit is set to '1' when the bit "IO" (bit3 of Systate, SFR 0xA1) is read out as '1', it indicates the system is woken up from the LPM1 state or LPM2 state by a transition on the pin "WAKEUP4" (P0.3). |  |
| bit1                                             | P02WK                                                                               | R   | 0       | If this bit is set to '1' when the bit "IO" (bit3 of Systate, SFR 0xA1) is read out as '1', it indicates the system is woken up from the LPM1 state or LPM2 state by a transition on the pin "WAKEUP3" (P0.2). |  |
| bit0                                             | IOP14                                                                               | R   | 0       | If this bit is set to '1' when the bit "IO" (bit3 of Systate, SFR 0xA1) is read out as '1', it indicates the system is woken up from the LPM1 state or LPM2 state by a transition on the pin "WAKEUP1" (P1.4). |  |
| When an                                          | When an event of reset Level 1 occurs, this register is reset to its default state. |     |         |                                                                                                                                                                                                                |  |

Table 5-4 IO Wakeup Edge Control Register (IOEDG, SFR 0xC7)

| SFR 0xC  | SFR 0xC7, R/W, IO Wakeup Edge Control Register, IOEDG |     |         |                                                                                                                                       |  |  |
|----------|-------------------------------------------------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit      |                                                       | R/W | Default | Description                                                                                                                           |  |  |
| bit[7:6] | P03EDG                                                | R/W | 0       | Trigger type selection for the pin "WAKEUP4" (P0.3)  00/11: High-to-low transition  01: Low-to-high transition  10: Either transition |  |  |
| bit[5:4] | P02EDG                                                | R/W | 0       | Trigger type selection for the pin "WAKEUP3" (P0.2)  00/11: High-to-low transition  01: Low-to-high transition  10: Either transition |  |  |
| bit[3:2] | P14EDG                                                | R/W | 0       | Trigger type selection for the pin "WAKEUP1" (P1.4)  00/11: High-to-low transition  01: Low-to-high transition                        |  |  |

# Low-power Multifunctional Energy Metering SoC

| SFR 0xC         | SFR 0xC7, R/W, IO Wakeup Edge Control Register, IOEDG |         |             |                                                                                                                |  |  |
|-----------------|-------------------------------------------------------|---------|-------------|----------------------------------------------------------------------------------------------------------------|--|--|
| Bit R/W Default |                                                       | Default | Description |                                                                                                                |  |  |
|                 |                                                       |         |             | 10: Either transition                                                                                          |  |  |
| bit[1:0]        | P13EDG                                                | R/W     | 0           | Trigger type selection for the pin "WAKEUP2" (P1.3)  00/11: High-to-low transition  01: Low-to-high transition |  |  |
|                 |                                                       |         |             | 10: Either transition                                                                                          |  |  |

#### Table 5-5 IO Wakeup Control Register (IOWK, SFR 0xC9)

| SFR 0xC  | SFR 0xC9, R/W, IO Wakeup Control Register, IOWK |     |         |                                                                                                                                                                                                                                                                                                                                         |  |  |
|----------|-------------------------------------------------|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit      |                                                 | R/W | Default | Description                                                                                                                                                                                                                                                                                                                             |  |  |
| bit[7:3] | Reserved                                        | -   | -       |                                                                                                                                                                                                                                                                                                                                         |  |  |
| bit2     | CFWKEN                                          | R/W | 0       | <ul><li>1: Enable CF pulse output to wake up the system from LPM1 state</li><li>0: Disable CF pulse output to wake up the system from LPM1 state</li></ul>                                                                                                                                                                              |  |  |
| bit1     | IOP0                                            | R/W | 0       | 1: Enable IO wakeup event on either pin "WAKEUP4" (P0.3) or "WAKEUP3" (P0.2)  0: Disable IO wakeup event on either pin "WAKEUP4" (P0.3) or "WAKEUP3" (P0.2)                                                                                                                                                                             |  |  |
| bit0     | IORSTN                                          | R/W | 0       | 1: IO event wakes up but not reset the system. After the wakeup, MCU keeps on executing programs; all circuits go back where the system enters the sleeping state, but bit[2:1] (SLEEP1 and SLEEP0) and bit[6:5] (FWC and FSC) are cleared.  0: IO event wakes up and reset the system. After the wakeup, the system goes to OSC state. |  |  |

#### **Table 5-6 Set RTC Wake-Up Interval**

| SFR 0x96, RTC Wake-up Interval Register, INTRTC |          |         |     |               |  |  |  |
|-------------------------------------------------|----------|---------|-----|---------------|--|--|--|
| Bit                                             |          | Default | R/W | Description   |  |  |  |
| bit[7:3]                                        | Reserved | 0       | R/W |               |  |  |  |
|                                                 |          |         |     | 000: 1 second |  |  |  |
|                                                 |          |         |     | 001: 1 minute |  |  |  |
| bit[2:0]                                        | RTC<2:0> | 0       | R/W | 010: 1 hour   |  |  |  |
|                                                 |          |         |     | 011: 1 day    |  |  |  |
|                                                 |          |         |     | 100: 500 ms   |  |  |  |



# **Low-power Multifunctional Energy Metering SoC**

#### SFR 0x96, RTC Wake-up Interval Register, INTRTC

|     | _       |     |              |
|-----|---------|-----|--------------|
| Bit | Default | R/W | Description  |
|     |         |     | 101: 250 ms  |
|     |         |     | 110: 125 ms  |
|     |         |     | 111: 62.5 ms |

#### Table 5-7 RTC Seconds Wake-up Interval Configuration Register (SECINT, SFR 0xDF)

| SFR 0xD  | SFR 0xDF, R/W, RTC Seconds Wake-up Interval Configuration Register, SECINT |         |                                                                                                                                                                                                                                                                              |  |  |  |
|----------|----------------------------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit      | R/W                                                                        | Default | Description                                                                                                                                                                                                                                                                  |  |  |  |
| bit7     | R/W                                                                        | 0       | Reserved                                                                                                                                                                                                                                                                     |  |  |  |
| bit6     | R/W                                                                        | 0       | It is mandatory to set the register "INTRTC" (SFR 0x96) to 0x07, and then set this bit to '1' to enable writing of bit[5:0] of this register.                                                                                                                                |  |  |  |
| bit[5:0] | R/W                                                                        | 0       | To set interval in unit of second for RTC to wake up the system from LPM1 state. The actual wakeup interval is equal to (bit[5:0]+1) seconds, of which bit[5:0] can be set to $1 \sim 63$ (Decimal).  Setting these bits to '0' (Decimal) forces the interval to be 62.5 ms. |  |  |  |

# 6.Clock

In AL6111A, there are three clock generation circuits:

- The RC oscillator circuit is used to generate an RC clock (RCCLK). This circuit will stop running only when the chip is powered off.
- The crystal oscillator circuit is used to generate an OSC clock (OSCCLK). Generally, this circuit will stop running only when the chip is powered off, but it also will stop running in some special circumstances. This circuit is monitored by the OSC monitoring circuit sourced by RC clock. When this oscillator circuit stops running, RC clock will replace OSC clock to source all circuits that are sourced by the OSC clock, and the monitoring circuit will stimulate the crystal oscillator circuit until it runs again.
- The phase-locked loop (PLL) circuit is used to generate a PLL clock (PLLCLK). The PLL locks onto a multiple of the OSCCLK frequencies to provide a stable clock: PLLCLK. This circuit can be disabled.

The above three clocks can work as the clock sources for the functional units:

- Clock 1 (CLK1) provides clock pulses for MCU (Including MCU, RAM, Flash memory, interrupt circuits, timers/UART serial interfaces, GPSI and IO ports). The OSC clock and PLL clock can be the optional source for CLK1. This clock is enabled by default, and it can be disabled.
- Clock 2 (CLK2) provides clock pulses for the energy metering architecture. The OSC clock and PLL clock can be the optional source for CLK2. This clock is enabled by default, but it can be disabled.
- Clock 3 (CLK3) provides clock pulses for the LCD driver. The OSC clock is the source of this clock, and this clock is enabled by default, but it can be disabled only when PLL clock is selected as the source for CLK1 and CLK2.
- Clock 4 (CLK4) provides clock pulses for WDT. The RC clock is the source of this clock. This clock is disabled and enabled together with CLK1.
- Clock 5 (CLK5) provides clock pulses for RTC. The OSC clock is the source of this clock. This clock cannot be disabled.

Figure 6-1 illustrates the architecture of the clock system of AL6111A.

#### Low-power Multifunctional Energy Metering SoC



**Figure 6-1 Clock System Architecture** 

### 6.1. RC Clock

In AL6111A, there is an embedded RC oscillator circuit. It can generate an independent 32-kHz RC clock. It is the clock source for Clock 4 (CLK4) that provides clock pulses for WDT. The RC oscillator circuit will not stop running until the chip is powered off, but CLK4 can be enabled or disabled together with CLK1.

There is a circuit monitoring the crystal oscillation and stimulating the oscillator to run again when it stops working. This circuit is sourced by the RC clock. When the crystal oscillator circuit stops running, the RC clock will immediately replace it to be the clock source for all circuits that are sourced by OSC clock. Users can read bit "OSC" (bit7 of ANState, 0x286B) to detect whether the crystal stops running and has been replaced by RC clock to source all circuits.

### 6.2. OSC Clock

In AL6111A, there is an embedded oscillator circuit with fixed capacitance of 12.5 pF. Connect this circuit to a 32768-Hz crystal around the pins, CTO and CTI, to compose a crystal oscillator circuit to generate a 32768 Hz OSC clock, an optional clock source for CLK1, CLK2, CLK3, and CLK5. Users can configure the register "P20FS" (0x28C9) to measure the OSC clock waveform via pin P2.0. The clock frequency can be adjusted finely via configuring register "CtrlCry1" (0x2860) for the resistance and

#### Low-power Multifunctional Energy Metering SoC

capacitance in the embedded oscillator circuit or connecting some additional capacitors around pins "CTO and CTI". If the RTC is used, bit XTRSEL[2:0] (bit[2:0] of CtrlCry1, 0x2860) must be set to "0b011". It consumes 0.6  $\mu$ A by default.

Generally, this circuit will not stop running until the chip is powered off, but some factors may cause the oscillator circuit to stop running. There is a circuit monitoring the crystal oscillation and stimulating it to run again when it stops working. This circuit is sourced by the RC clock. When the crystal oscillator circuit stops running, the RC clock will immediately replace it to be the clock source for all circuits that are sourced by OSC clock. Users can read bit "OSC" (bit7 of ANState, 0x286B) to detect whether the crystal stops running and has been replaced by RC clock to source all circuits.

#### 6.3. PLL Clock

The PLL circuit locks onto a multiple of the OSC clock frequencies to provide some stable clock pulses, "MEA\_PLL, MCU\_PLL, and ADC\_PLL", for the energy metering architecture, MCU and its peripherals, and ADCs.

Start MCU and then enable the PLL circuit. When the PLL circuit is disabled, it will output the 32768-Hz OSC clock.

Users can enable the PLL circuit, and select the PLL clock as the source for CLK1 and CLK2. Please follow the steps:

- 1. Access to the register "CtrlCLK" (0x2867) to enable the PLL circuit, and configure the frequency of MCUCLK and MTCLK
- 2. Wait for the configuration till the PLL is locked. MCU can access to the register "PLLLCK" (SFR 0xA3) and read the bit "PLLLCK" to detect the state of the PLL circuit.
- 3. When the PLL circuit is locked, set the bit "MCUFRQ" or "MEAFRQ" (bit0 or bit7 of SysCtrl, SFR 0x80) to '1' to select the PLL clock as the source for CLK1 or CLK2. This duration only spends one PLL clock cycle.

Users must follow the steps to reconfigure the MTCLK frequency or MCUCLK frequency when PLL circuit is enabled:

- 1. Access to the register "SysCtrl" (SFR 0x80) to select the OSC clock as the source for CLK1 or CLK2
- 2. Access to the register "CtrlCLK" (0x2867) to adjust the frequency of MTCLK or MCUCLK
- 3. Access to the register "SysCtrl" (SFR 0x80) to select the PLL clock as the source for CLK1 or CLK2

AL6111A is 50/60Hz-power-line supportive. By default the chip is applied to 50Hz-power-line. Users can set the bit "PLLSEL" (bit5 of CtrlPLL, 0x2868) to '1' to configure the chip for the application in 60-Hz power grid. The PLL clock frequency in 60-Hz power grid is 1.2 times of that in 50-Hz power grid. In 60-Hz power grid, the parameters related to the clock frequency, such as the baud rate and timers, must be reconfigured. If not specifically noted, all information related to clock frequency in this datasheet will only be applied to 50-Hz power grid.

In the full-speed operation, the MCUCLK frequency is 13.1072 MHz, the MTCLK frequency is 3.2768 MHz, and ADCCLK frequency is 819.2 kHz which is a quarter of the MTCLK frequency. The typical



load current in the full-speed operation is 5.5 mA.

# 6.4. Switching Source for CLK1 and CLK2

In AL6111A, there are two methods on switching the source for CLK1, and only one method on switching the source for CLK2.

- Normal operation
   In this mode, MCU needs to access some registers to select the clock source for CLK1 or CLK2, and/or to disable/enable the clock.
- Quick operation
  In this mode, only one register is needed by MCU to access to trigger the hardware to enable/disable the PLL circuit, select the source for CLK1, and/or enable/disable CLK1. If this method is used to disable CLK1, the system will enter LPM1 state, but not LPM2 state. If the chip is used for a low-power application, this method will be recommended.

### 6.4.1. Normal Operation

#### 6.4.1.1. Switching Source for CLK1 and Disable CLK1

When the RSTn pin reset, POR/BOR, or WDT overflow reset occurs, the analog control registers and the register "SysCtrl" (SFR 0x80) will be reset to their default states, which means that the PLL circuit will be disabled and CLK1 will be enabled and sourced by OSC clock. After the reset, access the analog control registers to enable the PLL circuit and configure the frequency of MCUCLK, and then set the bit "MCUFRQ" (bit0 of SysCtrl, SFR 0x80) to '1' to select PLL clock as the source for CLK1. Only one OSC clock cycle is needed for all the above processes.

It is mandatory to enable the PLL circuit before writing '1' to the bit "MCUFRQ" to select the source for CLK1. When CLK1 is sourced by PLL clock, PLL clock frequency will automatically change to 32768 Hz if the PLL circuit is anomaly disabled, but the bit "MCUFRQ" is still read out as '1'. In this condition, MCU must read the bit "PLLLCK" (bit0 of PLLLCK, SFR 0xA3) to detect the state of the PLL circuit.

When CLK1 is sourced by PLL clock, clear the bit "MCUFRQ" (bit0 of SysCtrl, SFR 0x80) to select OSC clock as the source for CLK1. This switchover needs no more than one OSC clock cycle. In this period, the write operation on the analog control registers is invalid. MCU can keep on reading this bit once immediately clearing it. If this bit is read out as '0', it indicates the switchover is finished.

When CLK1 is sourced by OSC clock, and the bit "PWRUP" (bit0 of Systate, SFR 0xA1) is read out as '0', write '1' to the bit "SLEEP0" or "SLEEP1" (bit1 or bit2 of SysCtrl, SFR 0x80) to disable CLK1 to force the system to enter the LPM2 state or LPM1 state. When CLK1 is disabled, MCU, including MCU, RAM, Flash memory, interrupt circuits, timers, UART interfaces, and GPIO ports, will stop working.

#### 6.4.1.2. Switching Source for CLK2 and Disable CLK2

When the RSTn pin reset, POR/BOR, or WDT overflow reset occurs, the analog control registers and the register "SysCtrl" (SFR 0x80) will be reset to their default states, which means the PLL circuit will be disabled; CLK2 will be enabled and sourced by OSC clock. After the reset, access to the analog control registers to enable the PLL circuit and configure the frequency of MTCLK, and then set the bit "MEAFRQ" (bit7 of SysCtrl, SFR 0x80) to '1' to select PLL clock as the source for CLK2. Only one OSC clock cycle is needed for all the above processes.

It is mandatory to enable the PLL circuit and then write '1' to the bit "MEAFRQ" to select the source for CLK2. When CLK2 is sourced by PLL clock, PLL clock frequency will automatically change to 32768 Hz if the PLL circuit is anomaly disabled, but the bit "MEAFRQ" is still read out as '1'. In this condition, MCU must read the bit "PLLLCK" (bit0 of PLLLCK, SFR 0xA3) to detect the state of the PLL circuit.

When CLK2 is sourced by PLL clock, clear the bit "MEAFRQ" (bit7 of SysCtrl, SFR 0x80) to select OSC clock as the source for CLK2. This switchover needs no more than one OSC clock cycle. In this period, the write operation on the analog control registers is invalid. MCU can keep on reading this bit once immediately clearing it. When this bit is read out as '0', it indicates the switchover is finished.

When CLK2 is sourced by OSC clock, write '1' to the bit "PMG" (bit4 of SysCtrl, SFR 0x80) to disable CLK2. When CLK2 is disabled, the energy metering architecture will stop working.

#### 6.4.2. Quick Operation

This mode is applied to disable/enable the PLL circuit, select the source for CLK1, and enable/disable CLK1. In this mode, only the register "SysCtrl" (SFR 0x80) needs to be accessed.

When the RSTn pin reset, POR/BOR, WDT overflow reset, power supply restoration event, or IO/RTC wakeup event occurs, the bits "FWC and FSC" (bit6 and bit5 of SysCtrl, SFR 0x80) will be reset to 0s. Thus, the program determines the state of the system, including the PLL circuit and the clock source for CLK1.

Clear the bit "FSC", and then write '1' to the bit "FWC", to enable the PLL circuit and select the PLL clock as the source for CLK1 automatically. In this condition, the PLL clock frequency is 3.2768 MHz. The source for CLK1 will be switched to PLL clock immediately once '1' is written to the bit "FWC".

When the bit "PWRUP" (bit0 of Systate, SFR 0xA1) is read out as '0', write '1' to the bit "FSC" whatever the bit "FWC" is, to select the OSC clock to be the source for CLK1, to disable the PLL circuit, to disable CLK1, and to force the system to enter the LPM1 state.

## 6.4.3. Normal Operation v.s. Quick Operation

When the RSTn pin reset, POR/BOR, WDT overflow reset, power supply restoration event, or IO/RTC wakeup event occurs, the system will get into a temporary state in which the OSC clock is used as the clock source for CLK1 and the energy accumulation unit can only accumulate a constant. In this state, the system consumes some power that should be diminished for the low-power-consumption applications. In the power-down state, the process of disabling the circuits consumes some power that should also be



#### Low-power Multifunctional Energy Metering SoC

diminished.

In the normal operation, applications need to access analog control registers to get the system out of the temporary state or to disable the circuits in the power-down state. But in the quick operation, only the bits "FSC/FWC" need to be accessed. Thus, completing the above implementation in the quick operation is preferred.

But, as stated above, the clock source switchover in the normal operation and quick operation may affect each other:

- If the bits "FSC/FWC" are set to "0b01", the configuration of the register "CtrlCLK" (0x2867) and the bit "MCUFRQ" (bit0 of SysCtrl, SFR 0x80) cannot be activated, and the PLL clock frequency holds 3.2768 MHz.
- If the bit "MCUFRQ" is read out as '1', clearing the bits "FSC/FWC" cannot switch the clock source for CLK1.

To prevent MCU from the mis-operation, MCU can combine both methods, the combination operation: To enable the PLL circuit and switch the source for CLK1 in the quick operation to lower power consumption; and then, to hold PLL clock frequency in normal operation.

In Table 6-1, the normal, quick and combination operations are compared.

Table 6-1 Comparing Normal, Quick, and Combination Operations

| Operation                                                                  | Normal Operation                                                                                        | Quick<br>Operation | Combination<br>Operation |
|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------------|--------------------------|
| Enable PLL, and switch the source for CLK1 to PLL clock                    | Access the analog control registers, and enable the PLL circuit  MCUFRQ = 1                             | FWC = 1            | FWC = 1<br>MCUFRQ = 1    |
| Switch source for CLK1 to OSC clock, disable PLL circuit, and disable CLK1 | MCUFRQ = 0 While(MCUFRQ == 1){;} access the analog control registers and disable PLL circuit SLEEP0 = 1 | FSC = 1            | MCUFRQ = 0<br>FSC = 1    |

The arrow in Figure 6-2 indicates the process from the IO wake-up event to completing the clock source switchover of CLK1 to the 3.2768-MHz PLL clock, in the quick operation or combination operation, which lasts  $800 \sim 900 \, \mu s$ , including the time to reset, to execute the initial long jump instruction, and to write '1' into FWC.



Figure 6-2 Enabling PLL Circuit and Clock Source Switchover to PLL in Quick Operation

The arrows in Figure 6-3 indicate the process from the clock source switchover of CLK1 to OSC clock to disabling CLK1, in quick or combination operation, which lasts less than 30  $\mu$ s.



Figure 6-3 Clock Source Switchover to OSC, Disabling PLL Circuit, Disabling CLK1 in Quick Operation

# 6.5. Registers

Table 6-2 Clock Switchover Control Register (SysCtrl, SFR 0x80)

| SFR 0x80, R/W, Clock Switchover Control Register, SysCtrl |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Default                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| 0                                                         | To select the clock source for CLK2  0: OSC clock  1: PLL clock  This bit is writable and readable. Configure this bit to switch the clock source for CLK2, and read this bit to acquire the current clock source for CLK2.                                                                                                                                                                                                                                 |  |  |  |  |  |
| 0                                                         | Only when the bit FSC is cleared be the configuration of FWC activated.  When the bit "FSC" is cleared, write '1' to this bit to enable the PLL circuit to start running and output a 3.2768-MHz PLL clock, and to select this clock to be the clock source for CLK1.  When the bit "FSC" is cleared, write '1' to the bit "FWC", the clock setting will be locked. Writing '0' to the bit "FWC" will unlock the clock setting without switching the clock. |  |  |  |  |  |
| 0                                                         | Write '1' to this bit to select the OSC clock as the clock source for CLK1, to disable the PLL clock, and to disable CLK1.  If the bit "PWRUP" is read out as '0', setting this bit to '1' will make the system enter the LPM1 state, but not the LPM2 state. If the bit "PWRUP" is read out as '1', setting this bit to '1' cannot force the system enter the LPM1 state.                                                                                  |  |  |  |  |  |
| 0                                                         | Set this bit to `1' to stop CLK2. By default this clock is running.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| 0                                                         | Set this bit to '1' to stop CLK3. By default this clock is running.  Only when the PLL clock is selected as the clock source for CLK1 and CLK2, can CLK3 be stopped.                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 0                                                         | <ul> <li>When the bit "PWRUP" is read out as '0', write '0' to the bit "MCUFRQ", and then:</li> <li>Set "SLEEP1" and "SLEEP0" to "0b11" or "0b01" to stop CLK1 (Together with CLK4) and force the system to enter the LPM1 state</li> <li>Set "SLEEP1" and "SLEEP0" to "0b10" to stop CLK1 (Together with CLK4) and force the system to enter the LPM2 state</li> </ul>                                                                                     |  |  |  |  |  |
|                                                           | Default           0           0           0           0                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |

#### SFR 0x80, R/W, Clock Switchover Control Register, SysCtrl

| Bit            | Default | Description                                                                                                                                                                                                                  |
|----------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit0<br>MCUFRQ | 0       | To select the clock source for CLK1.  0: OSC clock  1: PLL clock  This bit is writable and readable. Configure this bit to switch the clock source for CLK1, and read this bit to acquire the current clock source for CLK1. |

When the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) is set to '1', any wakeup event can wake up the system from the sleeping state without resetting the system. After the wakeup, MCU keeps on executing programs; all circuits hold their states where they are before sleeping; only bit[2:1] (SLEEP1 and SLEEP0) and bit[6:5] (FWC and FSC) are cleared.

Table 6-3 Peripheral Control Register 0 (PRCtrl0, 0x2D00)

| 0x2D00, R/W, Peripheral Control Register 0, PRCtrl0 |          |     |                         |                                        |
|-----------------------------------------------------|----------|-----|-------------------------|----------------------------------------|
| Bit                                                 |          | R/W | R/W Default Description |                                        |
| bit7                                                | Reserved | -   | 0                       | -                                      |
|                                                     |          |     |                         | To enable or disable GPSI              |
| bit6                                                | GPSI     | R/W | 0                       | 1: Enable                              |
|                                                     |          |     |                         | 0: Disable                             |
| bit5                                                | Reserved | -   | 0                       | -                                      |
|                                                     |          |     |                         | To enable or disable GPIOs Group P9    |
| bit4                                                | P9       | R/W | 0                       | 1: Disable                             |
|                                                     |          |     |                         | 0: Enable                              |
|                                                     |          |     |                         | To enable or disable GPIOs Group P0~P8 |
| bit3                                                | P0P8     | R/W | 0                       | 1: Disable                             |
|                                                     |          |     |                         | 0: Enable                              |
| bit[2:1]                                            | Reserved | -   | 0                       | -                                      |
|                                                     |          |     |                         | To enable or disable TimerA            |
| bit0                                                | TimerA   | R/W | 0                       | 1: Disable                             |
|                                                     |          |     |                         | 0: Enable                              |

# **Low-power Multifunctional Energy Metering SoC**

Table 6-4 Peripheral Control Register 1 (PRCtrl1, 0x2D01)

| 0x2D | 0x2D01, R/W, Peripheral Control Register 1, PRCtrl1 |     |         |                                   |  |
|------|-----------------------------------------------------|-----|---------|-----------------------------------|--|
| Bit  |                                                     | R/W | Default | Description                       |  |
|      |                                                     |     |         | To enable or disable UART5        |  |
| bit7 | UART5                                               | R/W | 0       | 1: Disable                        |  |
|      |                                                     |     |         | 0: Enable                         |  |
|      |                                                     |     |         | To enable or disable UART4        |  |
| bit6 | UART4                                               | R/W | 0       | 1: Disable                        |  |
|      |                                                     |     |         | 0: Enable                         |  |
| bit5 | Reserved                                            | -   | 0       | -                                 |  |
|      |                                                     |     |         | To enable or disable UART2        |  |
| bit4 | UART2                                               | R/W | 0       | 1: Disable                        |  |
|      |                                                     |     |         | 0: Enable                         |  |
|      |                                                     |     |         | To enable or disable Interrupt 11 |  |
| bit3 | ExInt5                                              | R/W | 0       | 1: Disable                        |  |
|      |                                                     |     |         | 0: Enable                         |  |
|      |                                                     |     |         | To enable or disable Interrupt 10 |  |
| bit2 | ExInt4                                              | R/W | 0       | 1: Disable                        |  |
|      |                                                     |     |         | 0: Enable                         |  |
|      |                                                     |     |         | To enable or disable Interrupt 9  |  |
| bit1 | ExInt3                                              | R/W | 0       | 1: Disable                        |  |
|      |                                                     |     |         | 0: Enable                         |  |
|      |                                                     |     |         | To enable or disable Interrupt 8  |  |
| bit0 | ExInt2                                              | R/W | 0       | 1: Disable                        |  |
|      |                                                     |     |         | 0: Enable                         |  |

#### Table 6-5 Register 1 to Adjust OSC Clock Frequency

| 0x2860, R/W, Crystal Control Register 1, CtrlCry1 |          |   |                                                                                                                                 |  |  |
|---------------------------------------------------|----------|---|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit Default Description                           |          |   |                                                                                                                                 |  |  |
| bit[7:5]                                          | Reserved | 0 | These bits must hold their default values for proper operation.                                                                 |  |  |
| bit4                                              | CSEL 0   |   | The fixed capacitance in the crystal oscillator circuit is 12.5 pF. Set this bit to '1' to decrease the capacitance by 2.35 pF. |  |  |



| 0x2860, R/W, Crystal Control Register 1, CtrlCry1 |             |         |                                                                                                                                                                                                    |  |  |  |  |
|---------------------------------------------------|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit                                               |             | Default | Description                                                                                                                                                                                        |  |  |  |  |
| bit3                                              | Reserved    | 0       | These bits must hold their default values for proper operation.                                                                                                                                    |  |  |  |  |
|                                                   | XTRSEL[2:0] | 0       | To adjust the resistance of the resistors in the internal crystal oscillator circuit. When RTC is used, these bits must be set to "0b011", and the oscillation monitoring circuit must be enabled. |  |  |  |  |
| F:#[3.0]                                          |             |         | Set the bit "XTRSEL[2]" to '1' to increment the resistance to P end by 400 $k\Omega.$                                                                                                              |  |  |  |  |
| bit[2:0]                                          |             |         | XTRSEL[2:0] to adjust the resistance to N end:                                                                                                                                                     |  |  |  |  |
|                                                   |             |         | 00/01: hold the resistance to N end.                                                                                                                                                               |  |  |  |  |
|                                                   |             |         | 10: Increment by 128 kΩ                                                                                                                                                                            |  |  |  |  |
|                                                   |             |         | 11: Increment by 64 kΩ                                                                                                                                                                             |  |  |  |  |

#### Table 6-6 Register 2 to Adjust OSC Clock Frequency

| 0x2861, R/W, Crystal Control Register 2, CtrlCry2 |               |         |                                                                                                                                                                                                                      |  |  |
|---------------------------------------------------|---------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                                               |               | Default | Description                                                                                                                                                                                                          |  |  |
| bit7                                              | Reserved      | 0       |                                                                                                                                                                                                                      |  |  |
| bit6                                              | bit6 Reserved |         | This bit must hold its default value for proper operation. By default this function is disabled.                                                                                                                     |  |  |
| bit5                                              | XRESETEN      | 0       | Set this bit to '1' to enable the oscillation monitor                                                                                                                                                                |  |  |
| bit4                                              | Reserved      | 0       |                                                                                                                                                                                                                      |  |  |
| bit[3:2]                                          | CMPSSELB<1:0> | 0       | To select the analog input to the comparator, CB  00: M2 for positive input; REF_LP for negative input;  01: M1 for positive input; REF_LP for negative input;  10/11: M2 for positive input; M1 for negative input. |  |  |
| bit[1:0] Reserved                                 |               | 0       | These bits must hold their default values for proper operation.                                                                                                                                                      |  |  |

#### Table 6-7 PLL Clock State Register (PLLLCK, SFR 0xA3)

| SFR 0xA3, R, PLL Clock State Register, PLLLCK |          |   |                                                                                                  |  |  |  |
|-----------------------------------------------|----------|---|--------------------------------------------------------------------------------------------------|--|--|--|
| Bit Default Description                       |          |   |                                                                                                  |  |  |  |
| bit[7:1]                                      | Reserved | 0 |                                                                                                  |  |  |  |
| bit0                                          | PLLLCK   | 0 | When this bit is read out as `1', it indicates that the PLL has locked onto a certain frequency. |  |  |  |



# Low-power Multifunctional Energy Metering SoC

Table 6-8 Register 1 to Adjust Clock Frequency of Specific Functional Blocks

| 0x2867, R/W, Clock Control Register, CtrlCLK |                |         |                                                                                                                         |  |  |  |
|----------------------------------------------|----------------|---------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit                                          |                | Default | Description                                                                                                             |  |  |  |
| bit7                                         | PLLPDN         | 0       | To enable the PLL circuit  0: Disable  1: Enable  Enable the BandGap circuit, and then enable the PLL circuit.          |  |  |  |
| bit6                                         | BGPPDN         | 0       | To enable the BandGap circuit.  0: Disable  1: Enable  Enable the BandGap circuit, and then enable the PLL circuit.     |  |  |  |
| bit[5:4]                                     | ADCLKSEL[1:0]  | 0       | To configure the sampling frequency of the oversampling ADCs (ADCCLK).  Base: 204.8 kHz  00: ×1  01: ×2  10: ×4         |  |  |  |
| bit[3:2]                                     | MEACLKSEL[1:0] | 0       | To configure the clock frequency for the energy metering architecture (MTCLK).  Base: 819.2 kHz  00: ×1  01: ×2  10: ×4 |  |  |  |
| bit[1:0]                                     | MCUCLKSEL[1:0] | 0       | To configure the clock frequency for the MCU (MCUCLK).  Base: 819.2 kHz.  00: ×1  01: ×2  10: ×4  11: ×8                |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

Table 6-9 Register 2 to Adjust Clock Frequency of Specific Functional Blocks

| 0x2868, R/W, PLL Control Register, CtrlPLL |          |         |                                                                                                  |  |  |  |
|--------------------------------------------|----------|---------|--------------------------------------------------------------------------------------------------|--|--|--|
| Bit Default                                |          | Default | Description                                                                                      |  |  |  |
| bit7                                       | MCU26M   | 0       | When the bit "MCU13M" is set to '1', set this bit to '1' to double the MCUCLK frequency further. |  |  |  |
| bit6                                       | MCU13M   | 0       | Set this bit to '1' to double MCUCLK frequency                                                   |  |  |  |
| bit5                                       | PLLSEL   | 0       | To apply the chip to 50-Hz or 60-Hz power grid  0: 50 Hz  1: 60 Hz                               |  |  |  |
| bit[4:0]                                   | Reserved | 0       | These bits must hold their default values for proper operation.                                  |  |  |  |

#### **Table 6-10 OSC Clock State Register**

| 0x286B   | 0x286B, R, Analog Circuits State Register, ANState |         |                                                                                                                                                                                                                        |  |  |  |
|----------|----------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit      |                                                    | Default | Description                                                                                                                                                                                                            |  |  |  |
| bit7     | OSC                                                | 0       | To indicate the state of the OSC clock  0: The crystal is working.  1: The crystal stops running, and all the circuits, including PLL circuit, sourced by the OSC clock now is being sourced by the internal RC clock. |  |  |  |
| bit6     | oit6 Reserved -                                    |         |                                                                                                                                                                                                                        |  |  |  |
| bit5     | СОМРВ                                              | 0       | To indicate the output of the comparator, CB  1: The positive input is higher than the negative input.  0: The negative input is higher than the positive input.                                                       |  |  |  |
| bit[4:2] | Reserved                                           | 5       | It is read out as "0x5".                                                                                                                                                                                               |  |  |  |
| bit[1:0] | Reserved                                           | -       |                                                                                                                                                                                                                        |  |  |  |

# 7. Operating Mode

AL6111A has three system states according to the state of Clock 1:

- OSC state: When a reset event of Level 1 or Level 2 occurs, the system will go to the OSC state, in which Clock 1 runs and is sourced by OSC clock.
- Working state: The PLL circuit is enabled, and the PLL clock is used as the source for Clock 1.
- Sleeping state: When the bit "PWRUP" (bit0 of Systate, SFR 0xA1) is cleared, select OSC clock as the source for Clock 1 and disable Clock 1, and then the system will enter the sleeping state. By default the chip will be woken up with reset and forced to go back to OSC state. But when the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) is set to '1', the chip will be woken up without reset, which means the chip will be woken up and go back to where it enters the sleeping state except that bits "SLEEP1, SLEEP0, FWC and FSC" (bits of SysCtrl, SFR 0x80) are cleared to 0s. The sleeping state is classified into 2 states: LPM1 state and LPM2 state. An IO/ RTC wakeup event, CF pulse output, or a power supply restoration event can wake up the system from the LPM1 state. An IO wakeup event or a power supply restoration event can wake up the system from the LPM2 state.

## 7.1. Power Consumption

In AL6111A, there are a lot of functional units, some of which can be disabled, but others cannot. The power consumption of these units may be affected by the digital power supply or the clock frequency as shown in Table 7-1.

**Table 7-1 Factors Affecting Power Consumption of Each Unit** 

|                                 |                     | Stoppable | Factors Affecting Power Consumption |                                 |  |
|---------------------------------|---------------------|-----------|-------------------------------------|---------------------------------|--|
| Unit                            | State at Powered On |           | Clock<br>Frequency                  | Operation Voltage (DVCC Output) |  |
| LDO33                           | On                  | No        | No                                  | No                              |  |
| Digital Power Supply<br>Circuit | On                  | No        | No                                  | No                              |  |
| OSC                             | On                  | No        | No                                  | No                              |  |
| MCU                             | On                  | Yes       | Yes                                 | Yes                             |  |
| REF_LP                          | On                  | No        | No                                  | No                              |  |

|                                        |                                                          | Stoppable | Factors Affecting Power Consumption |                                 |
|----------------------------------------|----------------------------------------------------------|-----------|-------------------------------------|---------------------------------|
| Unit                                   | State at Powered On                                      |           | Clock<br>Frequency                  | Operation Voltage (DVCC Output) |
| RTC                                    | On                                                       | No        | No                                  | No                              |
| PLL                                    | Off                                                      | Yes       | No                                  | No                              |
| BandGap                                | Off                                                      | Yes       | No                                  | No                              |
| Power Supervisor                       | On                                                       | No        | No                                  | No                              |
| Temperature<br>Measurement Circuit     | Off                                                      | Yes       | No                                  | No                              |
| Battery Voltage<br>Measurement Circuit | Off                                                      | Yes       | No                                  | No                              |
| LCD Driver                             | COM/SEG driver circuit is disabled, and CLK3 is running. | Yes       | No                                  | No                              |
| ADCs                                   | Off                                                      | Yes       | Yes                                 | No                              |
| Energy Metering<br>Architecture        | Digital signal inputs are disabled, and CLK2 is running. | Yes       | Yes                                 | No                              |

#### **7.1.1. OSC State**

When a reset event of Level 1 or Level 2 occurs, the system will be reset to the OSC state. In this state, LDO33 is enabled, the OSC clock is used as the source for CLK1, and MCU runs.

**Table 7-2 OSC State of System** 

| Module                       | State When Powered On | Stoppable | State in OSC State |
|------------------------------|-----------------------|-----------|--------------------|
| LDO33                        | On                    | No        | On                 |
| Digital Power Supply Circuit | On                    | No        | On                 |
| OSC                          | On                    | No        | On                 |

| Module | State When Powered On | Stoppable | State in OSC State |
|--------|-----------------------|-----------|--------------------|
| мси    | On                    | Yes       | On                 |
| REF_LP | On                    | No        | On                 |
| RTC    | On                    | No        | On                 |

### 7.1.2. Working State

In the OSC state, enable the PLL circuit, select the PLL clock to work as the source for CLK1, and then the system will enter the working state.

In the working state, users can configure the MCU clock (CLK1) frequency, and enable the required ADCs, the energy metering architecture, the LCD driver, and MCU and its peripherals according to the application.

### 7.1.3. Sleeping State

When the bit "PWRUP" (bit0 of Systate, SFR 0xA1) is read out as '0', switch the source for CLK1 to the OSC clock and then disable CLK1, then the system will go to the sleeping state.

There are two types of sleeping state: LPM1 state and LPM2 state.

In the LPM1 state or LPM2 state, RTC holds on; the memories, MCU, and its peripherals stop working; but the LCD driver and the energy metering architecture will not stop working until they are disabled. If ADCs, PLL circuit, LCD driver, and energy metering architecture are disabled, and IOs are set to "Output, disabled; input, masked" before entering the LPM1 state or LPM2 state, the system will consume the lowest power.

In the LPM1 state, if IO/RTC wakeup event, CF pulse output, or power supply restoration event occurs, the system will be woken up and go back to the OSC state by default. In the LPM2 state, only an IO wakeup event or power supply restoration event can wake up the system and reset it to the OSC state by default. When the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) is set to '1', any wakeup event can wake up the system from the LPM1 state or LPM2 state only without resetting the system to the OSC state. In this condition, the chip will go back where it enters the sleeping state, except that bit[6:5] (FWC and FSC) and bit[2:1] (SLEEP1 and SLEEP0) will be cleared to 0s.

If the pin "WAKEUP1, WAKEUP2, WAKEUP3, or WAKEUP4" is set to "Input enabled" before the system enters the LPM1 state or LPM2 state, a transition (Either high-to-low or low-to-high, with more than 4 OSC clock cycles on both levels) on the pin in the LPM1 state or LPM2 state can wake up the system. By default ports "P0.2 and P0.3" are not used for the wakeup event input. Users must configure the bit "IOP0" (bit1 of IOWK, SFR 0xC9) to '1' to set both pins for the wakeup input. When the bit "IO" (bit3 of Systate, SFR 0xA1) is set to '1', read states of bits "IOP14" (bit0 of IOWKDET, SFR 0xAF), "P02WK" (bit1 of IOWKDET, SFR 0xAF), and "P03WK" (bit2 of IOWKDET, SFR 0xAF) to detect which IO wakeup event wakes up the

## Low-power Multifunctional Energy Metering SoC

chip from the sleeping state.

If both bits "RTC" (bit2 of Systate, SFR A1) and "CFWK" (bit3 of IOWKDET, SFR 0xAF) are set to 1s, it indicates that the system will be woken up by the CF pulse output. If the bit "RTC" is set to '1', but "CFWK" is cleared, it indicates that an RTC wakeup event will occur.

## 7.1.3.1. Sleep/Wake-Up

In AL6111A, there are two methods to wake up the system from the sleeping state or make the system go to the sleeping state: normal method and quick method.

#### 1. Normal Method

The normal method for wakeup/sleep switchover is totally controlled by the program.

When the PLL clock is enabled and works as the source for the MCU clock (CLK1), users can follow the steps illustrated in Figure 7-1 to force both MCU and energy metering architecture to go to the sleeping state, or force MCU to go to the sleeping state only but leave the energy metering architecture to accumulate a constant for energy metering.

## Low-power Multifunctional Energy Metering SoC



Figure 7-1 Go to Sleeping State (Normal Method, Disable PLL Clock)

When the PLL clock is enabled and works as the source for the MCU clock (CLK1), users can follow the steps illustrated in Figure 7-2 to force MCU to go to the sleeping state only but leave the energy metering architecture work normally.

## **Low-power Multifunctional Energy Metering SoC**



Figure 7-2 Go to Sleeping State (Normal Method, PLL Clock Holds on)

**Table 7-3 Configuration for Sleeping State** 

| Register         | SLEEP1 (Bit 2) | SLEEPO (Bit1) | System State |
|------------------|----------------|---------------|--------------|
|                  | 0              | 1             | LPM1 state   |
| SysCtrl SFR 0x80 | 1              | 1             | LPM1 state   |
| STR 0X00         | 1              | 0             | LPM2 state   |

In the LPM1 state or LPM2 state, when the IO/RTC wakeup event, CF pulse output, or power supply restoration event occurs, the system will be woken up from the sleeping state. If the wakeup with reset mode is applied, after the reset, users should use the normal operation to enable the PLL circuit and select it as the source for CLK1 to make the system go to the working state.

#### 2. Quick Method

In AL6111A, the quick method can force the system to go to the LPM1 state, but not the LPM2 state.

When the PLL clock is enabled and works as the source for the MCU clock (CLK1), users can follow the steps illustrated in Figure 7-3 to force both MCU and energy metering architecture to go to the LPM1 state, or force MCU to go to the LPM1 state only but leave the energy metering architecture to accumulate a constant for energy metering. In this case, the PLL clock will be disabled definitely.

## Low-power Multifunctional Energy Metering SoC



Figure 7-3 Go to LPM1 state (Quick Method)

In the LPM1 state, the IO/RTC wakeup event, CF pulse output, or power supply restoration event can wake up the system. If the wakeup with reset mode is applied, users should use the quick operation to enable the PLL circuit and switch the source for CLK1 to make the system go to the working state.

# 7.2. Registers

**Table 7-4 Register for Clock Control** 

| SFR 0x80       | SFR 0x80, R/W, Clock Switchover Control Register, SysCtrl |                                                                                                                                                                                                                             |  |  |  |  |  |
|----------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit            | Default                                                   | Description                                                                                                                                                                                                                 |  |  |  |  |  |
| bit7<br>MEAFRQ | 0                                                         | To select the clock source for CLK2  0: OSC clock  1: PLL clock  This bit is writable and readable. Configure this bit to switch the clock source for CLK2, and read this bit to acquire the current clock source for CLK2. |  |  |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

#### SFR 0x80, R/W, Clock Switchover Control Register, SysCtrl

| Bit    | Default | Description                                                                                                                                                                                                                                   |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         | Only when the bit "FSC" is cleared, is the configuration of "FWC" activated.                                                                                                                                                                  |
| bit6   | 0       | When the bit "FSC" is cleared, write '1' to the bit "FWC" to enable the PLL circuit to start running and output a 3.2768-MHz PLL clock, and to source CLK1.                                                                                   |
| FWC    |         | When the bit "FSC" is cleared, write '1' to the bit "FWC", the clock setting will be locked. Writing '0' to the bit "FWC" will unlock the clock setting without switching the clock.                                                          |
| bit5   |         | Write '1' to this bit to select the OSC clock as the clock source for CLK1, to disable the PLL clock, and to disable CLK1.                                                                                                                    |
| FSC    | 0       | If the bit "PWRUP" is read out as '0', setting this bit to '1' will make the system enter the LPM1 state, but not LPM2 state. If the bit "PWRUP" is read out as '1', setting this bit to '1' cannot force the system to enter the LPM1 state. |
| bit4   | 0       | Set this bit to '1' to stop CLK2                                                                                                                                                                                                              |
| PMG    | 0       | By default this clock is running.                                                                                                                                                                                                             |
| bit3   |         | Set this bit to '1' to stop CLK3. By default this clock is running.                                                                                                                                                                           |
| LCDG   | 0       | Only when the PLL clock is selected as the clock source for CLK1 and CLK2, can CLK3 be stopped.                                                                                                                                               |
| bit2   |         | When the bit "PWRUP" is read out as '0', write '0' to the bit "MCUFRQ", and then:                                                                                                                                                             |
| SLEEP1 | 0       | - Set "SLEEP1" and "SLEEP0" to "0b11" or "0b01" to stop CLK1 (Together with                                                                                                                                                                   |
| bit1   | O       | CLK4) and force the system to enter the LPM1 state  - Set "SLEEP1" and "SLEEP0" to "0b10" to stop CLK1 (Together with CLK4) and                                                                                                               |
| SLEEP0 |         | force the system to enter the LPM2 state                                                                                                                                                                                                      |
|        |         | To select the clock source for CLK1                                                                                                                                                                                                           |
| bit0   |         | 0: OSC clock                                                                                                                                                                                                                                  |
| MCUFRQ | 0       | 1: PLL clock                                                                                                                                                                                                                                  |
|        |         | This bit is writable and readable. Configure this bit to switch the clock source for CLK1, and read this bit to acquire the current clock source for CLK1.                                                                                    |

When the bit "IORSTN" (bit0 of IOWK, SFR 0xC9) is set to '1', any wakeup event can wake up the system from the sleeping state without resetting the system. After the wakeup, MCU keeps on executing programs; all circuits hold their states where they are before sleeping; only bit[2:1] (SLEEP1 and SLEEP0) and bit[6:5] (FWC and FSC) are cleared.

## Low-power Multifunctional Energy Metering SoC

#### Table 7-5 Register to Indicate Power Supply State

#### SFR 0xA1, R, System State Register, Systate Bit **Default Description** bit[7:6] Reserved When this bit is read out as '1', it indicates the system is reset by an event of Level 1: bit5 0 POR/BOR, RSTn pin reset, or WDT overflow event. This bit will be cleared when a POR reset event of other levels occurs. 0 bit4 Reserved bit3 When this bit is read out as '1', it indicates the system is woken up from the LPM1 0 state or LPM2 state by an IO wakeup event. IO When this bit is read out as '1', but bit "CFWK" (bit3 of IOWKDET, SFR 0xAF) is cleared, it indicates the system is woken up from the LPM1 state by the RTC wakeup bit2 event. 0 RTC/CF If both this bit and bit "CFWK" are set to 1s, it indicates the system is woken up from the LPM1 state by the CF pulse wakeup event. When the input voltage on the pin "VDCIN" is lower than 1.0 V, this bit will be read out as '1', indicating that the system is powered down. If the power down interrupt is bit1 enabled, an interrupt will be triggered when this bit is read out as '1'. 0 **PWRDN** When the input voltage on the pin "VDCIN" is higher than 1.1 V, this bit will hold its default value, indicating there is no power-down event occurring. When the input voltage on the pin "VDCIN" is higher than 1.1 V, this bit is read out as bit0 '1', indicating that the system is powered up by the AC power supply. 0 **PWRUP** When the input voltage on the pin "VDCIN" is lower than 1.0 V, this bit will hold its default value, indicating the system is powered up by batteries.

# 8. Power Supply

AL6111A supports 5 V or 3.3 V power input on the pin "VDD5". The power supply is supervised continuously. The internal analog circuits and General-Purpose I/O (GPIO) ports are powered by the 3.3-V regulator circuit (3.3V-LDO), and the LDO33 output voltage powers the peripheral circuits; the energy metering architecture and PLL circuit are powered by the digital power supply circuit.

There is an internal power detection circuit in AL6111A. By default this circuit is enabled. When the chip is 3.3 V powered, users must set the bit "PDDET" (bit7 of CtrlLDO, 0x2866) to '1' to disable this circuit to protect the battery from current leakage when a battery is connected. When the chip is 5 V powered, this bit must hold its default value.



Figure 8-1 Power Supply Architecture

Note: the AL6111A internal have a power detection circuit. The circuit is opened by default. When the system is composed of 3.3 V power supply, the user must Set PDDET bits (bit7 CtrlLDO, 0 x2866) 1, disable power detection circuit, or when a battery connection to the battery leakage may occur. System consists of 5 v power supply must be cleard, at this time there will be no battery leakage risk

# 8.1. 3.3-V Regulator Circuit (LDO33)

In AL6111A, the analog circuits and the GPIO ports are powered by the 3.3-V regulator circuit (LDO33), and the LDO33 output voltage powers the peripheral circuits. This LDO33 will not stop working until the chip is powered off. The LDO33 output voltage can be configurable via the bits "LDO3SEL" (bit[5:3] of CtrlLDO, 0x2866).

LDO33 has a driving capability of 30 mA. When the load current through the analog circuits and the GPIO ports is less than 30 mA, the LDO33 output voltage holds 3.3 V; when the load current is higher than 30 mA, the higher the load current is, the lower voltage the LDO33 will output.



### Low-power Multifunctional Energy Metering SoC

It is recommended to externally decouple the pin "LDO33" with a  $\geq$  4.7- $\mu$ F capacitor in parallel with a 0.1- $\mu$ F capacitor.



0 Decrease of LDO33 Output Voltage (%) -2 -6 When the load current through the -8 analog circuit and IOs is higher than -10 30mA, the increase of loading -12 current leads to the decrease of the -14 LDO33 output voltage -16 -18 0 10 20 30 40 60 50 Load Current (mA)

Figure 8-2 LDO33 Output and 5V Power Input

Figure 8-3 LDO33 output and the Load Current

## 8.2. Digital Power Supply

In AL6111A, the PLL clock generation circuit and the energy metering architecture (VMA) are powered by the digital power supply circuit. When the digital power supply output is 200 mV, lower than the power input on the pin VDD5, it will output a stable voltage, avoiding the digital power fluctuation caused by the variation of the power input. The digital power supply output is configurable via the bit "LDOV2SEL" (bit[2:0] of CtrlLDO, 0x2866).

The digital power supply circuit has a driving capability of 35 mA. When the load current through the circuits is less than 35 mA, the digital power supply will be stable; when the load current is higher than 35 mA, the higher the load current is, the lower the digital power supply will be.

This supply circuit will not stop working until the system is powered off.

It is recommended to decouple the pin DVCC externally with a  $\geq 4.7$ - $\mu F$  capacitor in parallel with a 0.1- $\mu F$  capacitor.

# 8.3. Power Supply Supervisor

In AL6111A, the DC main power is input into the pin "VDCIN" after a resistive divider. The input voltage on the pin "VDCIN" is monitored continuously by the power supply supervisor.

When the input voltage on the pin "VDCIN" is lower than 1.0 V, a power-down event will occur, the bit "PWRDN" (bit1 of Systate, SFR 0xA1) will be set to '1', and a power-down interrupt will be generated to MCU.

## Low-power Multifunctional Energy Metering SoC



Figure 8-4 Relationship between VDCIN Input Signal and States of Flag Bits PWRUP and PWRDN

# 8.4. Batteries Supply

AL6111A can be powered by the batteries. Users can read the value of the flag bit "PWRUP" (bit0 of Systate, SFR 0xA1) to get the state of the power supply. When this bit is read out as '0', it indicates the input voltage on the pin "VDCIN" is lower than 1.0 V, which means the system is powered by the batteries, or the power supply has been switched from the 5.0-V power to the batteries. The switchover between the main power and the batteries is determined by the diode drop in the circuit in Figure 8-1.

When the chip is powered by the batteries, please note that the batteries will get passive when it is reactive for a long time. So users should set the bit "BATDISC" (bit0 of CtrlBAT, 0x285C) to '1' at an interval to discharge the batteries to protect them from the passivation. During the batteries discharge, the load current is 3 mA, and the period for batteries discharge should not be too long. After the discharge, the bit "BATDISC" must be cleared.

# 9.Comparator



Figure 9-1 Comparator Architecture

AL6111A integrates one additional comparator, CB, to compare the analog signals:

- Positive signal input on pin "M1" and negative signal input on pin "M2"
- Positive signal input on pin "M1" and negative signal from internal low power reference circuit (REF\_LP)
- Positive signal input on pin "M2" and negative signal from internal low power reference circuit (REF\_LP)

When the RSTn pin reset, POR/BOR, or WDT overflow reset occurs, or the system is in the LPM1 state or LPM2 state, this comparator will stop running.

When IE6 = 1 (bit6 of 0x28A5), EIE.3 = 1 (bit3 of SFR 0xE8), and IE.7 = 1 (bit7 of SFR 0xA8), the comparator interrupt will be enabled. In this state, the interrupt flag "IR6" (bit6 of 0x28A2) will be set to '1' when the output of the comparator changes, and the comparator will generate an interrupt to MCU. After the interrupt service, users can read the bit "COMPB" (bit5 of 0x286B) to detect the comparison result of the input signals.

Table 9-1 Registers Related to Comparator, CB

| Register           | Bit      |               | Default | Description                                                                                                                                                                                                                   |
|--------------------|----------|---------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | bit4     | Reserved      | 0       |                                                                                                                                                                                                                               |
| 0x2861<br>CtrlCry2 | bit[3:2] | CMPSSELB[1:0] | 0       | To select the analog input to the comparator, CB  00: "M2" for positive input; "REF_LP" for negative input  01: "M1" for positive input; "REF_LP" for negative input  10/11: "M2" for positive input; "M1" for negative input |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Register           | Bit  |         | Default | Description                                                                                                                                                      |
|--------------------|------|---------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x2864<br>CtrlADC6 | bit5 | CMPPDNB | 0       | To enable the comparator, CB  0: Disable  1: Enable                                                                                                              |
| 0x286B<br>ANState  | bit5 | СОМРВ   | 0       | To indicate the output of the comparator, CB  1: The positive input is higher than the negative input.  0: The negative input is higher than the positive input. |

## Low-power Multifunctional Energy Metering SoC

# 10. Energy Metering

The energy-metering architecture in AL6111A has the following features:

- Four independent oversampling  $\Sigma/\Delta$  ADCs: One voltage channel, two current channels, and one multifunctional channel for various signal measurement.
- High metering accuracy:
  - Less than 0.1% error on active energy metering over dynamic range of 5000:1
  - Less than 0.1% error on reactive energy metering over dynamic range of 3000:1
  - Less than 0.5% error on current and voltage RMS calculation over dynamic range of 1000:1
- Providing measurements:
  - Raw waveform and DC component of current and voltage signals
  - Instantaneous/average, active/reactive power, and positive/negative, active/reactive energy
  - Average apparent power
  - Instantaneous/average current and voltage RMS
  - Line frequency
  - Temperature with measurement accuracy of ±1°C
  - Battery voltage, system voltage, and external voltage signals
- Two current inputs for active energy, or one current input for active and reactive energy
- Programmable energy metering modes:
  - Accumulating power, current RMS or a constant for energy metering
  - Accumulating energy at a configurable frequency
- Current detection, to lower power consumption
- CF pulse output and interrupt with configurable pulse width
- Zero-crossing interrupt
- Programmable threshold for no-load detection
- Calibrating meters via software:
  - Phase compensation supported, resolution 0.005°/lsb (Min.), over a range of ±1.4° (Min.)
  - Gain calibration of RMS and power, and offset calibration of power
  - Accelerating meter calibration when low current is applied



## Low-power Multifunctional Energy Metering SoC



Figure 10-1 Digital Signal Processing in Energy-metering Architecture

# 10.1. Accessing to Registers for Energy-metering Architecture

In AL6111A, MCU must write or read of the metering control, data and calibration registers through the buffer registers.

#### 1. Buffer registers for write and read operations

When the POR/BOR, RSTn pin reset, or WDT overflow reset event occurs, all buffer registers for the write and read operations on the registers for the energy-metering architecture are reset to their default states.

Table 10-1 Buffer Registers and Data to Be Written or Read

| Data            | ACK    | INVD   | DATA[31:24] | DATA[23:16] | DATA[15:8] | DATA[7:0] |
|-----------------|--------|--------|-------------|-------------|------------|-----------|
| Buffer Register | BUFF5  | BUFF4  | BUFF3       | BUFF2       | BUFF1      | BUFF0     |
| Address         | 0x2885 | 0x2884 | 0x2883      | 0x2882      | 0x2881     | 0x2880    |

#### 2. Read operation

MCU must read the registers for the energy-metering architecture. Please follow the steps as illustrated below:

- a. Write "0xCC", and then "0s" to the register "INVD"
- b. Read the address of the target register
- c. When the flag bit "ACK" is read out as '0', or in no more than 24 MTCLK clock periods, the content (DATA) of the target register will be loaded into the buffer registers in sequence as illustrated in Table 10-1
- d. Read the buffer registers to acquire the content (DATA)

#### 3. Write operation

MCU must write the registers for the energy-metering architecture. Please follow the steps as illustrated below:

- a. Write "0xCC", and then "0s" to the register "INVD"
- b. Write the data (DATA) to the buffer registers in sequence as illustrated in Table 10-1
- c. Write the address of the target register
- d. When the flag bit "ACK" is read out as '0', or in no more than 24 MTCLK clock periods, the content (DATA) in the buffer registers will be loaded into the target registers.

## Low-power Multifunctional Energy Metering SoC

# 10.2. Metering Clock

CLK2 provides the clock pulse for the energy-metering architecture, including ADCs. It is sourced by the OSC clock or PLL clock. When CLK2 is disabled, the metering architecture will stop running.

There is a specific bit (GT, bit7 of IDET, 0x2886) to disable the clock for the sampling circuits and RMS/power calculation circuits. When this bit is set to '1', the circuits will stop working, but the energy accumulation unit will keep on running.

In the working state, the PLL clock is enabled, and it is selected as the source for CLK2. In this condition, the metering clock frequency ( $f_{MTCLK}$ ) and sampling frequency of ADCs ( $f_{ADC}$ ) are configurable, and  $f_{MTCLK}$  must be 4 times of  $f_{ADC}$ .

Table 10-2 Configuration of CLK2

| Register | Bit            | Description                                                                      |
|----------|----------------|----------------------------------------------------------------------------------|
|          |                | To select the clock source for CLK2                                              |
|          |                | 0: OSC clock                                                                     |
|          | bit7           | 1: PLL clock                                                                     |
| SysCtrl  | MEAFRQ         | This bit is writable and readable. Configure this bit to switch the clock        |
| SFR 0x80 |                | source for CLK2, and read this bit to acquire the current clock source for CLK2. |
|          | bit4           | Set this bit to `1' to stop CLK2                                                 |
|          | PMG            | By default this clock is running.                                                |
|          |                | To configure the sampling frequency of the oversampling ADCs (ADCCLK)            |
|          | bit[5:4]       | Base: 204.8 kHz                                                                  |
|          | ADCLKSEL[1:0]  | 00: ×1                                                                           |
|          |                | 01: ×2                                                                           |
| CtrlCLK  |                | 10: ×4                                                                           |
| 0x2867   |                | To configure the clock frequency for the energy-metering architecture (MTCLK)    |
|          | bit[3:2]       | Base: 819.2 kHz                                                                  |
|          | MEACLKSEL[1:0] | 00: ×1                                                                           |
|          |                | 01: ×2                                                                           |
|          |                | 10: ×4                                                                           |

# 10.3. Reference Voltage

In AL6111A, the BandGap circuit outputs a reference voltage (About 1.185 V with a typical temperature drift of 10 ppm/°C) and bias current for ADCs and PLL circuit. Thus, users must enable the BandGap circuit before enabling ADCs or PLL circuit by setting the bit "BGPPDN" (bit6 of CtrlCLK, 0x2867) to '1'.

## 10.4. Analog Inputs

AL6111A has three pairs of analog inputs forming two current channels and one voltage channel. The current channels consist of two fully differential voltage inputs. And the voltage channel consists of a pseudo differential voltage input: UP is positive input for the voltage channel, and UN, grounded, is negative input for the voltage channel. Each input has a maximum voltage of  $\pm$  200 mV, and each pair has a maximum differential voltage of  $\pm$  400 mV.

In a current channel, a current transformer (CT) or a shunt resistor can be used for the current channels.



Figure 10-2 CT for Current channel



Figure 10-3 Shunt Resistor Network for Current Channel

In the voltage channel, a potential transformer (PT) or a resistor-divider network can be used for the voltage channel.

## Low-power Multifunctional Energy Metering SoC



Figure 10-4 Analog Input of Voltage

The full measurement scale of the ADCs is  $\pm$  1.1 V. To match the output signal of the sensors with the measurement scale of ADCs, groups of analog Programmable Gain Amplifiers (PGA) are set. The product of the analog input and the set analog PGA should not be over  $\pm$  1.1 V.

Table 10-3 Analog PGA Gain Configuration for Current and Voltage Analog Input

| Register           | Bit                    | Default | Description                                                                                                                                                                                                                                          |
|--------------------|------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | bit6<br>ADCGU          | 0       | To set analog PGA gain for voltage input to Voltage Channel (U) ADC. It is mandatory to set this bit to its default value for proper operation. $0: \times 1$ $1: \times 2$                                                                          |
| CtrlADC0<br>0x2858 | bit[5:3]<br>ADCGB[2:0] | 0       | To set analog PGA gain for current input to Current Channel B (IB) ADC  000: ×1  001: ×4  010: ×8  011: ×16  100/101/110/111: ×32  To match the output signal from the sensor to the measurement scale of ADC, the default value should not be used. |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Register | Bit        | Default | Description                                                                                                       |
|----------|------------|---------|-------------------------------------------------------------------------------------------------------------------|
|          |            |         | To set analog PGA gain for current input to Current Channel A (IA) ADC                                            |
|          |            |         | 000: ×1                                                                                                           |
|          | h:+[2,0]   |         | 001: ×4                                                                                                           |
|          | bit[2:0] 0 | 0       | 010: ×8                                                                                                           |
|          | ADCGA[2:0] | :0]     | 011: ×16                                                                                                          |
|          |            |         | 100/101/110/111: ×32                                                                                              |
|          |            |         | To match the output signal from the sensor to the measurement scale of ADC, the default value should not be used. |

# 10.5. Analog-to-Digital Conversion

Second-order  $\Sigma$ - $\Delta$ ADCs are designed in three channels of AL6111A for analog-to-digital conversion, and their full measurement scale is  $\pm$  1.1 V. By default,  $\Sigma$ - $\Delta$ ADCs are disabled. Users can enable them via configuring the "CtrlADC6" register (0x2864).

Note: It is mandatory to clear the bit "DCENN" (bit7 of CtrlLCDV, 0x285E) to add 10-mV direct voltage offset to the current input to current channel ADCs.

Table 10-4 Enable/Disable ADCs

| Register           | Bit  |         | Default | Description                                     |  |  |
|--------------------|------|---------|---------|-------------------------------------------------|--|--|
|                    | bit2 | ADCUPDN | 0       | To enable Channel U ADC  0: Disable  1: Enable  |  |  |
| CtrlADC6<br>0x2864 | bit1 | ADCBPDN | 0       | To enable Channel IB ADC  0: Disable  1: Enable |  |  |
|                    | bit0 | ADCAPDN | 0       | To enable Channel IA ADC  0: Disable  1: Enable |  |  |

After the analog-to-digital conversion, the analog signals are converted to be the 1-bit code streams of 22-bit length with both "bit21" and "bit20" being the sign bits.

## **Low-power Multifunctional Energy Metering SoC**

## 10.6. Switch of Current Channels

After the analog-to-digital conversion, current IA or IB is sent to Current I1 or Channel I2, via configuring the bit "SELI" (bit5 of PMCtrl1, 0x0100), for different signal processing.



Figure 10-5 Exchange of Current Channels

Table 10-5 Control Bit for Switching Current Signals

| it | Description                                                                                                                            |
|----|----------------------------------------------------------------------------------------------------------------------------------------|
|    | To exchange the current channels. By default this bit is cleared.                                                                      |
|    | 0: current IA is sent to Current I1 Channel for signal processing, and current IB is sent to Current I2 Channel for signal processing. |
|    | 1: current IA is sent to Current I2 Channel for signal processing, and current IB is sent to Current I1 Channel for signal processing. |
| E  | :LI<br>:5                                                                                                                              |

Then current (I1 and I2) and voltage signals must be input to a phase compensation circuit to correct the phase angle error between the current and voltage signals introduced by the transformers.

# 10.7. Phase Compensation



**Figure 10-6 Phase Compensation Schematics** 

A phase compensation circuit composed of a time delay chain of fixed length is applied to correct the phase angle error via delaying the selected signal. Either current or voltage signals can be delayed.

By default the phase compensation is disabled. Users can enable this function via configuring the bit "PHCEN" (bit6 of PMCtrl1, 0x2878). When the phase compensation is enabled, the phase angle error between I1 and U, and I2 and U, are corrected respectively. Bit [7:0] of register PHCCtrl1 (0x287B) together with bit[1:0] (IAPHC) of register CRPST (0x287F) or bit[7:0] of register PHCCtrl2 (0x287C) together with bit[3:2] (IBPHC) of register CRPST (0x287F) are used to calibrate the phase angle error between signal I1 or I2 and the voltage signal, see Table 10-7 for details.

In 50Hz power grid, when the sampling frequency of the phase compensation circuit ( $f_{smpl}$ ) is 3.2768MHz, the calibration resolution is 0.0055°/lsb, and the maximum phase angle error to be corrected is 1.4°. The value of  $f_{smpl}$  is determined by the configuration of bits MEACLKSEL<1:0> (bit[3:2] of CtrlCLK, 0x2867).

The value (N) to be set to the phase compensation control registers can be calculated via the following equation:

$$N = Round(\frac{1}{\pi} \times \frac{f_{smpl}}{100} \times \{\pm \arccos[\cos\theta \times (1+E)] - \theta\})$$
 Equation 10-1

where

N is the value, signed, to be set to the registers, listed in Table 10-7, to correct the phase angle error. A positive N indicates that the current signal must be delayed, so "0" must be set to the sign bit; a negative N indicates that the voltage signal must be delayed, so "1" must be set to the sign bit;

 $\theta$  is the phase angle between current and voltage signals, in radian format. A positive  $\theta$  indicates a phase lead in current signal; a negative  $\theta$  indicates a phase lag in current signal;

E is the energy metering error displayed on LCD screen of the calibration equipment;

## Low-power Multifunctional Energy Metering SoC

 $f_{smpl}$  is the sampling frequency of the phase compensation circuit, Hz.

Table 10-6  $f_{smpl}$  Determines Phase Compensation Resolution and Correction Range

| N            | MEACLKSEL[1:0] Configuration |    | f <sub>smpl</sub> (Hz) | Resolution (°/lsb) | Correction Range (°) |
|--------------|------------------------------|----|------------------------|--------------------|----------------------|
| [-255, +255] | bit[3:2], 0x2867             | 00 | 819200                 | 0.022              | 5.6                  |
|              |                              | 01 | 1638400                | 0.011              | 2.8                  |
|              |                              | 10 | 3276800                | 0.0055             | 1.4                  |

Table 10-7 Registers for Phase Compensation

|       | CRPST (0x287F)                          |       |       |       |       |       |       |       |
|-------|-----------------------------------------|-------|-------|-------|-------|-------|-------|-------|
| bit7  | bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 |       |       |       |       |       |       |       |
| PHCx7 | PHCx6                                   | PHCx5 | PHCx4 | PHCx3 | PHCx2 | PHCx1 | PHCx0 | IxPHC |

x=A or B. PHCx7 is the sign bit, PHCx6 is not used, and the other 8 bits are used to set the absolute value to correct the phase angle error.

# 10.8. Digital Programmable Gain Amplifier

In the AL6111A, decimation filters are designed to reduce the noise of the 1-bit code stream output from the oversampling  $\Sigma/\Delta$ ADC and to reduce the sampling frequency to 1/256 of  $f_{ADC}$ .



Figure 10-7 Digital Inputs

Bit[2:0] of the register PMCtrl1 (0x2878) enables or disables the code stream input into the decimation filter. When this function is enabled, the code stream is input to the filter; otherwise, 0s are input for digital signal processing.

## Low-power Multifunctional Energy Metering SoC

Table 10-8 Enable/Disable Digital Inputs

| Register          | Bit          | Description                                                                                          |
|-------------------|--------------|------------------------------------------------------------------------------------------------------|
|                   | Bit2<br>ONI2 | To enable digital signal input to the I2 channel  0: Disable; 0s are input to I2 channel.  1: Enable |
| 0x2878<br>PMCtrl1 | Bit1<br>ONI1 | To enable digital signal input to the I1 channel  0: Disable; 0s are input to I1 channel.  1: Enable |
|                   | Bit0<br>ONU  | To enable digital signal input to the U channel  0: Disable; 0s are input to U channel.  1: Enable   |

Digital programmable gain amplifiers (DPGA) with possible gain selection via PMCtrl2 (0x2879) and PMCtrl3 (0x287A) are applied to digital signals output from the high-pass filters to amplify their capability of depressing truncation noise when a low signal was input. Please note the product of the analog input and the total PGA gains, including APGA and DPGA, should not be over the measurement scales of the ADCs.

**Table 10-9 DPGA Gain Selection for Digital Signals** 

| Register | Bit                     | Description                                                                                     |
|----------|-------------------------|-------------------------------------------------------------------------------------------------|
| PMCtrl3  | PGANS<br>bit3           | To set sign of the digital PGA gain for I2 signal  0: Positive  1: Negative                     |
| 0x287A   | PGAN2~PGAN0<br>bit[2:0] | To set the digital PGA gain for I2 signal $Gain=2^{PGANx}$ PGANx is in the range of $0\sim5$ .  |
| PMCtrl2  | PGACS<br>bit7           | To set sign of the digital PGA gain for I1 signal.  0: Positive  1: Negative                    |
| 0x2879   | PGAC2~PGAC0<br>bit[6:4] | To set the digital PGA gain for I1 signal $Gain = 2^{PGACx}$ $PGACx is in the range of 0\sim5.$ |

## Low-power Multifunctional Energy Metering SoC

| Register | Bit           | Description                                                                                                                                                                                                                                    |
|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | PGAUS<br>bit3 | To set sign of the digital PGA for U signal  0: Positive  1: Negative                                                                                                                                                                          |
|          |               | To set the digital PGA gain for U signal  Gain=2 <sup>PGAUX</sup>                                                                                                                                                                              |
|          | PGAU2~PGAU0   | PGAUx is in the range of 0~5.                                                                                                                                                                                                                  |
|          | bit[2:0]      | When the bit "LPFEN" (bit5 of PMCtrl3, 0x287A) is set to '1', the digital PGA gain for U signal will be lowered to 1/4 of its configuration. When the bit "LPFEN" is cleared, the digital PGA gain for U signal will be what it is configured. |

Equation 10-2 describe the digital signals processed by the digital programmable gain amplifiers:

$$\label{eq:continuous} \begin{split} \text{Ua} &= \text{PGAdua} \times \text{PGAua} \times \frac{\text{Aua}}{1.185} \times \sin \omega t = \text{DUa} \times \sin \omega t \\ \text{Ia} &= \text{PGAdia} \times \text{PGAia} \times \frac{\text{Aia}}{1.185} \times \sin(\omega t + \psi) = \text{DIa} \times \sin(\omega t + \psi) \end{split}$$
 Equation 10-2

Where, "PGAdua" and "PGAdia" are the DPGA gains; "PGAua" and "PGAia" are the APGA gains; "Aua" and "Aia" are the amplitude of current and voltage inputs; and '1.185' is the reference voltage.

## 10.9. Current Detection

To lower the power consumption, a current detection circuit is designed in AL6111A to compare the AC component of the instantaneous I1 current signal with the preset threshold in the register "IDETTH" (0x1002). Set the bit "DETON" (bit4 of IDET, 0x2886) to '1' to enable the current detection, and configure bit[3:0] of "IDET" (0x2886) for the current detection window width ([IDLEN]+1). When ([IDLEN]+1) continuous current samples are detected to be higher than the preset threshold, it will be defined as that a current signal is caught, and the flag bit "CST" (bit6 of IDET, 0x2886) is set to '1'. Users must set the bit "CLR" (bit5 of IDET, 0x2886) to '1' or clear the bit "DETON" to clear the bit "CST".

The configuration of the bit "IDLEN" (bit[3:0] of IDET, 0x2886) and the current detection period have a relationship as shown in Equation 10-3:

$$t_{IDT} = \frac{256 \times ([IDLEN] + 1)}{f_{ADC}} \times 1000$$
 Equation 10-3

Where, '256' means that the decimation filter (CIC) has reduced the sampling frequency to 1/256 of  $f_{ADC}$ , the sampling frequency of the oversampling ADC; [IDLEN] is the configuration of bits "IDLEN";  $t_{IDT}$  is the current detection period, in unit of "ms". To perform the current detection, it is mandatory to enable the metering clock (MTCLK), and enable the power/RMS calculation.



## **Low-power Multifunctional Energy Metering SoC**

## 10.10. RMS Calculation and Calibration

AL6111A supports the RMS calculation. By default this function is disabled. When the RMS calculation is enabled, users can enable the band-pass filter in the RMS calculation circuit via the bit "BPFEN" (bit6 of PMCtrl3, 0x287A) and configure the filter coefficient via the register "PARABPF" (0x10EF) to improve the calculation accuracy.

Table 10-10 Configuring for RMS Calculation and Calibration

| Register          | Bit          | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IDET<br>0x2886    | GT<br>bit7   | Set this bit to '1' to disable the sampling circuits and power/RMS calculation circuits. In this case, the energy accumulation circuit keeps on working. Thus, in an application to accumulate a constant for the energy accumulation, it is recommended to set this bit to '1' to lower the power consumption further. But please note that the threshold for the energy-to-pulse conversion must be set before setting this bit to '1'. |
| PMCtrl1<br>0x2878 | PREN<br>bit4 | To enable power and RMS calculation, and digital signal processing in M Channel. 0: disable; 1: enable.  By default this function is disabled.                                                                                                                                                                                                                                                                                            |
|                   |              | To enable the band-pass filter in the voltage/current RMS calculation circuits.                                                                                                                                                                                                                                                                                                                                                           |
| PMCtrl3           | BPFEN        | 0: disable (default); 1: enable.                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x287A            | Bit6         | This filter can improve the RMS calculation accuracy, but will lead to harmonics loss. When a low signal is input, this filter will introduce greater truncation noise and prolong the period for the system to be settled.                                                                                                                                                                                                               |
|                   |              | To set the coefficient for the band-pass filter in the RMS calculation circuits.                                                                                                                                                                                                                                                                                                                                                          |
| PARABPF<br>0x10EF |              | If MTCLK frequency is reduced to 819.2kHz, users must disable energy accumulation, CF pulse output and no-load detection, and then configure this register to 0x911D3C9C. When MTCLK frequency is reinstated to 3.2768MHz, this register must be set to its default value.                                                                                                                                                                |

As illustrated in Figure 10-8, the current or voltage signal output from the high-pass filter is multiplied with itself in the multiplier to get the product with the second harmonic which can be removed by the low-pass filter, and then the signal processed output from the low-pass filter is sent to the circuit for rooting processing that produces a 32-bit datum, the raw RMS value of current or voltage. The raw RMS data will be gain calibrated and then stored in instantaneous RMS registers. Besides, the instantaneous RMS data will be averaged to acquire the average RMS data that are stored in average RMS registers.

If the raw RMS value is represented as RMS', the gain calibration value is represented as S, and the instantaneous RMS is represented as RMS, then the above three values have the relationship:

$$RMS=RMS'\times(1+S)$$

Equation 10-4

## Low-power Multifunctional Energy Metering SoC



Figure 10-8 RMS Calculation and Calibration

The content of all the instantaneous and average RMS data registers are in the form of 32-bit 2'-complement. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, these registers are reset to their default states.

## 10.11. Apparent Power Calculation

AL6111A supports apparent power calculation. This function is enabled or disabled together with RMS calculation.

In AL6111A, the average current and voltage RMS are multiplied to acquire the apparent power, as described in the following equation:

where, S represents apparent power; Irms and Urms are the average current and voltage RMS.

The content of the apparent power registers are in the form of 32-bit 2'-complement. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, these registers are reset to their default states.

## 10.12. Power Calculation and Calibration

The AL6111A supports active/reactive power calculation. This function is enabled or disabled together with the RMS calculation and apparent power calculation.

There are two paths for power calculation, energy accumulation and energy pulse generation: E1 path and E2 path. E1 path is used for active power calculation and energy accumulation only; but, E2 path can be configured for active or reactive power calculation and energy accumulation which is determined by bit DBLEN (bit4 of PMCtrl3, 0x287A). By default E2 path is used for reactive power calculation based on current I1.

## Low-power Multifunctional Energy Metering SoC

Table 10-11 Functions of E2 Path

| Register          | Bit           | Function Description                                                                                                                                                                                                                                                                                                                                       |
|-------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |               | To select the function of E2 path                                                                                                                                                                                                                                                                                                                          |
| 0x287A<br>PMCtrl3 | DBLEN<br>bit4 | 0: For reactive power calculation and energy metering based on current I1. If positive current I1 is input to the path, the reactive power is negative, and it is accumulated to the negative energy accumulators; if negative current I1 is input to the path, the reactive power is positive, and it is accumulated to the positive energy accumulators. |
|                   |               | 1: For active power calculation and energy metering based on current I2.                                                                                                                                                                                                                                                                                   |

#### 10.12.1. Active Power Calculation and Calibration



Figure 10-9 Signal Processing for Active Power Calculation and Calibration

In AL6111A, E1 path always calculates active power based on current I1. And when DBLEN is set to '1', E2 path will also be used to calculate the active power based on current I2.



Figure 10-9, after being filtered by the high-pass filter (HPF), the current and voltage multiply each other. Then, the product is input to the low-pass filter (LPF) to remove the harmonics and the ripples caused by the noise, and the output of the LPF is the raw active power. This raw power is gain calibrated and then offset calibrated to acquire the instantaneous active power that is stored in the registers DATAIP (0x10D1, for active power calculated in E1 path) and DATAIQ (0x10D2, for active power calculated in E2 path). The instantaneous active power will be averaged to get the average active power that is stored in the registers DATAP (0x10D6, for active power in E1 path) and DATAQ (0x10D7, for active power in E2 path). The content of all the registers are in the form of 32-bit 2'-complement, and they will be reset to their default states when POR/BOR, RSTn pin reset or WDT overflow reset occurs.

Users can configure the registers SCP (0x10E8) and SCQ (0x10E9) for gain calibration over the range of



## Low-power Multifunctional Energy Metering SoC

 $-\infty \sim +49.9\%$ , and the registers PARAPC (0x10ED) and PARAQC (0x10EE) for offset calibration over the range of  $-50\% \sim +50\%$ . The content of these registers are in the form of 32-bit 2'-complement. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, all the registers are reset to their default states.

#### 10.12.2. Reactive Power and Calibration

By default the AL6111A supports calculating active and reactive power based on current I1.



Figure 10-10 Signal Processing for Reactive Power Calculation and Calibration

As illustrated in the above figure, current I1, filtered by the high-pass filter (HPF), is input into a digital integrator to shift the phase by 90° (the integrator introduces an extra gain of 1.568 that can be eliminated via gain calibration). The filtered current signal is sent to the multiplier together with voltage to multiply each other. Then, the product is input to the low-pass filter (LPF) to remove the harmonics and the ripples caused by the noise, and the output of the LPF is the raw reactive power. This raw power is gain calibrated and offset calibrated to acquire the instantaneous reactive power, which is stored in the register DATAIQ (0x10D2, for reactive power calculated in E2 path). The instantaneous reactive power will be averaged to get the average reactive power, which is stored in the register DATAQ (0x10D7, for reactive power in E2 path). The content of the registers are in the form of 32-bit 2′-complement, and they will be reset to their default states when POR/BOR, RSTn pin reset or WDT overflow reset occurs.

Users can configure register SCQ (0x10E9) for gain calibration over the range of  $-\infty \sim +49.9\%$ , and register PARAQC (0x10EE) for offset calibration over the range of  $-50\% \sim +50\%$ . Both registers are in the form of 32-bit 2'-complement. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, both registers are reset to their default states.

## 10.13. Energy Accumulation and CF Pulse Output

The AL6111A supports energy accumulation and energy-to-pulse conversion. By default this function is disabled. Users can set bit EGYEN (bit3 of PMCtrl4, 0x287D) to 1 to enable energy accumulation and energy-to-pulse conversion.

## Low-power Multifunctional Energy Metering SoC



Figure 10-11 Energy Accumulation and CF Pulse Output

## 10.13.1. Energy Accumulation

In E1 path, positive and negative active powers are accumulated into the energy accumulators according to their signs; for example, positive active power is accumulated into PPCNT (0x10F0), and negative active power is accumulated into NPCNT (0x10F1). Besides, other data, such as I1 current RMS or a constant (preset in the register DATACP, 0x10FC), also can be selected to be accumulated into PPCNT via configuring bits PSEL1~PSEL0 (bit[1:0] of PMCtrl4, 0x287D) when the chip is used for low power applications.

In E2 path, positive and negative active/reactive powers are accumulated into the energy accumulators according to their signs; for example, positive power is accumulated into PQCNT (0x10F6), and negative power is accumulated into NQCNT (0x10F7).

When MTCLK frequency is 3.2768MHz, 1.6384MHz or 819.2kHz, the energy accumulation frequency is 12.8kHz. When MTCLK frequency is 32768Hz, the energy accumulation frequency is 2979Hz.

The energy accumulators are of actual 42-bit length. But only the higher 32 bits are readable; and only the higher 32 bits are valid for write operation and the 10 least significant bits are padded with 0s in write operation. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, all the energy accumulators are reset to default values, 0s.

Table 10-12 Register Configuration for Energy Accumulation

|                   | Table 10 11 Register comigaration for Emergy Accumulation |                                                                                                                                                   |  |  |  |  |  |  |
|-------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Register          | Bit                                                       | Description                                                                                                                                       |  |  |  |  |  |  |
|                   | Bit3                                                      | To enable energy accumulation and energy-to-pulse conversion.                                                                                     |  |  |  |  |  |  |
|                   | EGYEN                                                     | 0: disable; 1: enable.                                                                                                                            |  |  |  |  |  |  |
| PMCtrl4<br>0x287D | Bit[1:0] PSEL1~PSEL0                                      | To select the source for positive active energy accumulation in E1 path.  00/11: active power calculated based on current I1; 01: I1 current RMS; |  |  |  |  |  |  |
|                   | I SEET: *F SEEO                                           | 10: a constant preset in the register DATACP (0x10FC).                                                                                            |  |  |  |  |  |  |

## 10.13.2. Energy Pulse Generation and CF Pulse Output

When energy accumulation and energy-to-pulse conversion is enabled, the energy will be accumulated



## Low-power Multifunctional Energy Metering SoC

at a certain rate. Preset a threshold in the register GATEP (0x10F4, for active energy accumulation in E1 path) or GATEQ (0x10FA, for active/reactive energy accumulation in E2 path), and when the content of energy accumulators in E1 or E2 path is higher than the preset threshold, the energy accumulator overflows, an energy pulse is generated, the energy pulse counter increments by 1, and a value equal to the threshold is subtracted from the energy accumulator.

When a low signal is input, users can reduce the energy threshold to increase the pulse generation rate to speed up energy calibration via configuring bits CFQR1~CFQR0 and CFQ1~CFQ0 (bit[7:4] of CFCtrl, 0x287E).

When CF pulse output is enabled, one CF pulse will be output every 2 counts of the pulse counter. When MTCLK frequency is 3.2768MHz, the maximum CF pulse output frequency is 6.4kHz, and the pulse width is configurable via bits CFWD (bit[5:4] of CRPST, 0x287F) and by default the width is 80ms.

In the AL6111A, three pins, P9.5/CF2, P9.6/CF1 and P1.3/CFx, are used for CF pulse output:

- When bit5 and bit6 of the register P9FS (SFR 0xAD) are set to 1s, the ports P9.5 and P9.6 are used for CF pulse output of E1 and E2 paths respectively;
- When the register P13FS (0x28C7) is set to 0x01, the port P1.3 is used for CF pulse output of E2 path; when the register is set to 0x04, the port P1.3 is used for CF pulse output of E1 path.

When bit CFWKEN (bit2 of IOWK, SFR 0xC9) is set to 1, CF pulse output can wake up the system from LPM1 state. By default CF pulse output can wake up and reset the system to OSC state. But when bit IORSTN (bit0 of IOWK, SFR 0xC9) is set to 1, this event can wake the system only but not reset the system. In this condition, after wakeup, the MCU keeps on executing the codes, and all circuits goes back where they were before sleeping, except that bits of SysCtrl (SFR 0x80), SLEEP1, SLEEP0, FWC and FSC, are cleared. When bits RTC/CF (bit2 of Systate, SFR 0xA1) and CFWK (bit3 of IOWKDET, SFR 0xAF) are read out as 1s, it indicates the system was woken up by CF pulse output.

Table 10-13 Configurations for Energy Pulse Generation Rate and CF Pulse Output

| Register | Bit         | Description                                                                               |  |  |  |  |
|----------|-------------|-------------------------------------------------------------------------------------------|--|--|--|--|
|          | Bit5, CFENR | To enable CF pulse output of E2 path. 0: disable; 1: enable.                              |  |  |  |  |
| PMCtrl4  | Bit4, CFEN  | To enable CF pulse output of E1 path. 0: disable; 1: enable.                              |  |  |  |  |
| 0x287D   | Bit2        | To select the pins for CF pulse output.                                                   |  |  |  |  |
| OXEG7 B  | CFXCG       | 0: CF1 pin for E1 path; CF2 pin for E2 path; 1: CF2 pin for E1 path; CF1 pin for E2 path. |  |  |  |  |
|          | Bit[7:6],   | To adjust the energy pulse generation rate in E2 path.                                    |  |  |  |  |
| CFCtrl   | CFQR1~CFQR0 | 00: ×1; 01: ×4; 10: ×8; 11: ×16.                                                          |  |  |  |  |
| 0x287E   | Bit[5:4],   | To adjust the energy pulse generation rate in E1 path.                                    |  |  |  |  |
|          | CFQ1~CFQ0   | 00: ×1; 01: ×4; 10: ×8; 11: ×16.                                                          |  |  |  |  |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Register | Bit                         | Description                                                                                                                                                                                                                             |
|----------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | bit[3:2]<br>CFSELR1~CFSELR0 | To select the energy in E2 path to be converted into pulse.  01: positive active or reactive energy in E2 path;  10: negative active or reactive energy in E2 path;  00/11: the sum of the absolute values of the positive and negative |
|          |                             | active or reactive energy in E2 path.                                                                                                                                                                                                   |
|          |                             | To select the energy in E1 path to be converted into pulse.                                                                                                                                                                             |
|          | Bit[1:0]                    | 01: positive active energy in E1 path;                                                                                                                                                                                                  |
|          | CFSEL1~CFSEL0               | 10: negative active energy in E1 path;                                                                                                                                                                                                  |
|          |                             | 00/11: the sum of the absolute values of the positive and negative active energy in E1 path.                                                                                                                                            |
| CRPST    | bit[5:4]                    | To adjust the CF pulse width.                                                                                                                                                                                                           |
| 0x287F   | CFWD                        | 00: 80ms; 01: 40ms; 10: 20ms; 11: 10ms.                                                                                                                                                                                                 |

## 10.14. No-Load Detection

The AL6111A supports no-load detection on both E1 and E2 paths. By default this function is disabled, but users can enable it via configuring bits CRPENR and CRPEN (bit7 and bit6 of PMCtrl4, 0x287D).

There is an anti-creeping accumulator in the no-load detection circuit. When no-load detection is enabled, 1s are accumulated in this register constantly. When MTCLK frequency is 3.2768MHz, 1.6384MHz or 819.2kHz, the accumulation frequency is 12800Hz; and when MTCLK frequency is 32768Hz, the accumulation frequency is 2979Hz.

When no-load detection is enabled, constant 1s are accumulated into the embedded anti-creeping accumulator, and the energy accumulator in E1 or E2 path accumulates active or reactive power or a power constant. Preset a threshold for no-load detection in register GATECP (0x10F5) or GATECQ (0x10FB), and a threshold for energy-to-pulse conversion in register GATEP (0x10F4) or GATEQ (0x10FA). Compare the accumulation rate. If the energy accumulator overflows sooner, the anti-creeping accumulator is cleared, and E1 or E2 path starts to meter energy. Otherwise, E1 or E2 path enters creeping state. Users can read bit CRPST or CRPSTR (bit7 or bit6 of CRPST, 0x287F) to detect the state of the path.

When POR/BOR, RSTN pin reset or WDT overflow reset occurs, the mentioned threshold registers are reset to their default values, 0s.

The energy accumulators are of actual 42-bit length, but the threshold registers for energy-to-pulse conversion are of 32-bit length. So, the threshold registers will be padded with a string of 10 0s on the right to work as 42-bit registers.



## Low-power Multifunctional Energy Metering SoC

Table 10-14 Configure for No-Load Detection

| Register | Bit          | Description                                                              |
|----------|--------------|--------------------------------------------------------------------------|
| PMCtrl4  | CRPENR, Bit7 | To enable no-load detection of E2 path. 0: disable (default); 1: enable. |
| 0x287D   | CRPEN, Bit6  | To enable no-load detection of E1 path. 0: disable (default); 1: enable. |
| CRPST    | CRPST, Bit7  | To indicate the state of E1 path. 0: metering energy; 1: creeping.       |
| 0x287F   | CRPSTR, Bit6 | To indicate the state of E2 path. 0: metering energy; 1: creeping.       |

# 10.15. Line Frequency Measurement

The AL6111A supports line frequency measurement.



Figure 10-12 Signal Processing for Line Frequency Measurement

In the line frequency measurement circuit, the voltage signal, filtered by the high-pass filter, is input to a band-pass filter (BPF), which has a 50Hz center frequency with 25dB attenuation at 150Hz, for signal processing. The output signal from the BPF is detected for zero-crossing. The average number of the samples of the signal in 16 cycles is equal to the value of the register DATAFREQ (0x10FD). Then, the line frequency can be calculated via the following equation:

$$f = \frac{f_{ADC}}{FRO}$$
 Equation 10-6

where, f is the line frequency to be measured; FRQ is the content of register DATAFREQ (0x10FD) in the form of decimal.

The line frequency register is a 16-bit, unsigned register. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, this register is reset to its default state. The measurement resolution is 0.05Hz/lsb, and the measurement range is over 35~75Hz. When MTCLK frequency is 3.2768MHz, this register is updated in 320ms, and is settled in 500ms.

**Note**: When MTCLK frequency is lowered to 819.2kHz, the sampling frequency of the enabled band-pass filter in the RMS calculation circuit is changed to 800Hz and the center frequency is changed to 12.5Hz, which has a greater attenuation on 50Hz signals and will reduce the accuracy of the RMS calculation and line frequency measurement. So, if MTCLK frequency is reduced to 819.2kHz, users must disable energy accumulation, CF pulse output and no-load detection, and then configure this register to 0x911D3C9C.

## 10.16. Measuring Various Signals in M Channel

#### 10.16.1. Architecture of M Channel

The M Channel can be used to measure the ground, temperature, battery voltage and external voltage signals. As illustrated in the following figure, there is only one ADC in M Channel, so users must configure registers to use this channel to measure one signal at a time.



Figure 10-13 M Channel Architecture



Figure 10-14 Signal Processing in M Channel

There are three data registers of M Channel, DATAOM (0x10CE) for raw waveform of the various signal input, DATADM (0x10CF) for instantaneous DC component of the signal, and DATAADM (0x10D0) for average DC component of the signal. The content of these registers are in the form of 32-bit 2' complement. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, these registers are reset to their default states.

In 50Hz power grid, when MTCLK frequency is 3.2768MHz, DATAOM is updated in 0.3ms and settled in 10ms; DATADM is updated in 20ms and settled in 70ms; DATAADM is updated in 1.28s and settled in 3s. If MTCLK frequency is divided by a coefficient K, the update and settle time is K times of that for 3.2768MHz MTCLK frequency.

## Low-power Multifunctional Energy Metering SoC

# 11. Interrupt

When POR/BOR, RSTn pin reset, WDT overflow event, power supply restoration event, IO/RTC wakeup event or debugging event occurs, the interrupt control module is reset to its default state.

CLK1 provides clock pulses for the interrupt control module, so when the system enters LPM1 state or LPM2 state, the interrupt control module stops running to save power. Each extended interrupt can be gate controlled independently via configuring register PRCtrl1 (0x2D01).

# 11.1. Interrupt Sources

In the AL6111A 32 events can trigger interrupts:

- 4 IO interrupts on low or high-to-low transitions;
- 4 transmitter data output interrupt of UART;
- 4 receiver data input interrupt of UART;
- 7 timer overflow interrupts;
- 3 timer capture interrupts (TimerA);
- 2 CF pulse output interrupts;
- 1 pulse per second (PPS) output interrupt;
- 1 RTC illegal data interrupt;
- 1 zero-crossing interrupt;
- 1 power-down interrupt;
- 1 GPSI illegal data interrupt;
- 1 GPSI transmit interrupt;
- 1 comparator interrupt;
- 1 REF leakage interrupt.

In the AL6111A the interrupts triggered by peripheral events are called *Extended Interrupt*. They are named after the polling sequence; for example, Interrupt 8 is named because the polling sequence of the extended interrupt handler located at 43h is 8. Additionally, an extended interrupt may be triggered by more than one event (interrupt sources); for example, both transmitter data output interrupt and receiver data input interrupt of UART2 can trigger the program execution to service the interrupt handler located at 43h (Interrupt 8).

Take Interrupt 8 as an example to introduce how to trigger an interrupt, service and clear the interrupt flag, and detect the event that triggers an extended interrupt. Only when the global enable bit IE.7 and the enable bit for Interrupt 8 (EIE.0) is set to 1, will Interrupt 8 be triggered if any one enabled peripheral event occurs and the flag bits of Interrupt 8 and the interrupt event is set bit. The program has to detect the interrupt source depending on the flags and enable bits of the peripheral event when the program enters to the interrupt subroutine located at address 43h. The processor can respond to the interrupt event by polling or interrupt handling. When an extended interrupt is responded, the program must clear

## Low-power Multifunctional Energy Metering SoC

the flag of the peripheral event firstly, and then the flag of Interrupt 8.

In the AL6111A, there are two tiers of interrupts: Interrupt Priority 1 and Interrupt Priority 0. Registers IP (SFR 0xB8) and EIP (SFR 0xF8) can configure the priority of the interrupts. Interrupt Priority 1 takes precedence over Interrupt Priority 0. In addition to an assigned priority level (1 or 0), each interrupt has a polling sequence. An interrupt with a small polling sequence number means that it must be serviced firstly when two interrupts of the same tier occur simultaneously. If two interrupts of different priority occur, the one of Interrupt Priority 1 is serviced firstly. Only an interrupt of higher priority level can break the service routine of the interrupt currently being serviced; when the new interrupt is serviced, the program will go back where it was interrupted and serve the last interrupt.

# Low-power Multifunctional Energy Metering SoC

**Table 11-1 Interrupt Sources** 

| Polling<br>sequence | Vector<br>address | Interrupt<br>No. <sup>1</sup> | Description                                                              | Enable<br>bit of<br>interrupt | Enable bit of peripheral event | •       | Flag of peripheral event |
|---------------------|-------------------|-------------------------------|--------------------------------------------------------------------------|-------------------------------|--------------------------------|---------|--------------------------|
| 0 (highest)         | 33h               | 6                             | Reserved.                                                                |                               |                                |         |                          |
| 1                   | 03h               | 0                             | IO interrupt 0 (INT0), triggered on low level or high-to-low transition. | IE.0                          |                                | TCON.1  |                          |
| 2                   | 0Bh               | 1                             | Timer0 interrupt (TF0).                                                  | IE.1                          |                                | TCON.5  |                          |
| 3                   | 13h               | 2                             | IO interrupt 1 (INT1), triggered on low level or high-to-low transition. | IE.2                          |                                | TCON.3  |                          |
| 4                   | 1Bh               | 3                             | Timer1 interrupt (TF1).                                                  | IE.3                          |                                | TCON.7  |                          |
| 5                   | 23h               | 4                             | Reserved.                                                                |                               |                                |         |                          |
| 6                   | 2Bh               | 5                             | Timer2 interrupt (TF2, EXF2).                                            | IE.5                          |                                | T2CON.7 |                          |
|                     |                   | 3Bh 7                         | Receiver data input interrupt of UART1 (RI1).                            |                               |                                | SCON1.0 |                          |
| 7                   | 3Bh               |                               | Transmitter data output interrupt of UART1 (TI1).                        | IE.6                          |                                | SCON1.1 |                          |
|                     |                   | 8                             | Transmitter data output interrupt of UART2.                              |                               | ExInt2IE.0                     |         | ExInt2IFG.0              |
|                     |                   |                               | Receiver data input interrupt of UART2.                                  | EIE.0                         | ExInt2IE.1                     | EXIF.4  | ExInt2IFG.1              |
| 8                   | 43h               |                               | Transmitter data output interrupt of UART4.                              |                               | ExInt2IE.2                     |         | ExInt2IFG.2              |
|                     |                   |                               | Receiver data input interrupt of UART4.                                  |                               | ExInt2IE.3                     |         | ExInt2IFG.3              |

 $<sup>^{1}</sup>$  When Keil IDE is applied, users must use Interrupt No. to check the interrupts.



# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

|                     |                   |                               | <del>-</del>                                                |                               |                                |                   |                          |
|---------------------|-------------------|-------------------------------|-------------------------------------------------------------|-------------------------------|--------------------------------|-------------------|--------------------------|
| Polling<br>sequence | Vector<br>address | Interrupt<br>No. <sup>1</sup> | Description                                                 | Enable<br>bit of<br>interrupt | Enable bit of peripheral event | Flag of interrupt | Flag of peripheral event |
|                     |                   |                               | Timer overflow interrupt of UART2.                          |                               | ExInt2IE.4                     |                   | ExInt2IFG.4              |
|                     |                   |                               | Timer overflow interrupt of UART4.                          |                               | ExInt2IE.5                     |                   | ExInt2IFG.5              |
|                     |                   |                               | Reserved.                                                   |                               |                                |                   |                          |
|                     |                   |                               | CF pulse output interrupt of E1 path                        |                               | ExInt2IE.7                     |                   | ExInt2IFG.7              |
|                     |                   |                               | Reserved.                                                   |                               |                                |                   |                          |
|                     | 4Bh               | 9                             | Reserved.                                                   | EIE.1                         |                                | EXIF.5            |                          |
|                     |                   |                               | Transmitter data output interrupt of UART5.                 |                               | ExInt3IE.2                     |                   | ExInt3IFG.2              |
| 9                   |                   |                               | Receiver data input interrupt of UART5.                     |                               | ExInt3IE.3                     |                   | ExInt3IFG.3              |
| 9                   |                   |                               | Reserved.                                                   |                               |                                |                   |                          |
|                     |                   |                               | Timer overflow interrupt of UART5.                          |                               | ExInt3IE.5                     |                   | ExInt3IFG.5              |
|                     |                   |                               | Pulse per second (PPS) output interrupt of RTC.             |                               | ExInt3IE.6                     |                   | ExInt3IFG.6              |
|                     |                   |                               | CF pulse output interrupt of E2 path.                       |                               | ExInt3IE.7                     |                   | ExInt3IFG.7              |
|                     |                   | 10                            | Illegal data interrupt of RTC.                              |                               | ExInt4IE.0                     | EXIF.6            | ExInt4IFG.0              |
|                     |                   |                               | Reserved.                                                   |                               |                                |                   |                          |
| 10                  | 53h               |                               | IO interrupt 2 (INT2), triggered on high-to-low transition. | EIE.2                         | ExInt4IE.2                     |                   | ExInt4IFG.2              |
|                     |                   |                               | IO interrupt 3 (INT3), triggered on high-to-low transition. |                               | ExInt4IE.3                     |                   | ExInt4IFG.3              |

|                     |                   |                               | -                               |                               |                                  |         |                          |
|---------------------|-------------------|-------------------------------|---------------------------------|-------------------------------|----------------------------------|---------|--------------------------|
| Polling<br>sequence | Vector<br>address | Interrupt<br>No. <sup>1</sup> | Description                     | Enable<br>bit of<br>interrupt | Enable bit of peripheral event   | _       | Flag of peripheral event |
|                     |                   |                               | REF leakage interrupt.          |                               | ExInt4IE.4                       |         | ExInt4IFG.4              |
|                     |                   |                               | Zero-crossing interrupt.        |                               | X0EN (bit7 of 0x287A) ExInt4IE.5 |         | ExInt4IFG.5              |
|                     |                   |                               | Reserved.                       |                               |                                  |         |                          |
|                     |                   |                               | Reserved.                       |                               |                                  |         |                          |
|                     |                   | 11                            | TimerA overflow interrupt.      |                               | ExInt5IE.0                       | EXIF.7  | ExInt5IFG.0              |
|                     |                   |                               | TimerA capture interrupt 0.     |                               | ExInt5IE.1                       |         | ExInt5IFG.1              |
|                     |                   |                               | TimerA capture interrupt 1.     |                               | ExInt5IE.2                       |         | ExInt5IFG.2              |
| 4.4                 | ED!               |                               | TimerA capture interrupt 2.     | ETE 2                         | ExInt5IE.3                       |         | ExInt5IFG.3              |
| 11                  | 5Bh               |                               | Illegal data interrupt of GPSI. | EIE.3                         | ExInt5IE.4                       |         | ExInt5IFG.4              |
|                     |                   |                               | Transmit interrupt of GPSI.     |                               | ExInt5IE.5                       |         | ExInt5IFG.5              |
|                     |                   |                               | Comparator interrupt.           |                               | ExInt5IE.6                       |         | ExInt5IFG.6              |
|                     |                   |                               | Reserved.                       |                               |                                  |         |                          |
| 12 (lowest)         | 63h               | 12                            | Power-down interrupt.           | EIE.4                         |                                  | EICON.3 |                          |

# **Low-power Multifunctional Energy Metering SoC**



Figure 11-1 Interrupt Logic

# 11.2. Interrupt Control Registers

### Table 11-2 IE (SFR 0xA8)

|      |     | Description                                                                                                                                                                   |
|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit  |     | Description                                                                                                                                                                   |
| IE.7 | EA  | Global interrupt enable bit. EA overrides individual interrupt enable bit.  0: to disable all interrupts.                                                                     |
| 11.7 |     | · ·                                                                                                                                                                           |
|      |     | 1: indicating that each interrupt is enabled or disabled by its individual enable bit.                                                                                        |
| IE.6 | ES1 | UART1 interrupt enable bit.  1: to enable transmitter data output interrupt of UART1 triggered by the flag TI1 or receiver data interrupt of UART1 triggered by the flag RI1. |
|      |     | 0: to disable the UART1 interrupt.                                                                                                                                            |
| IE.5 | ET2 | Timer2 interrupt enable bit.  0: to disable Timer2 interrupt (TF2 or EXF2). 1: to enable the interrupt triggered by flag TF2 or EXF2.                                         |
| IE.4 | ES0 | Reserved                                                                                                                                                                      |
| IE.3 | ET1 | Timer1 interrupt enable bit.  0: to disable Timer1 interrupt (TF1). 1: to enable the interrupt generated by the flag TF1.                                                     |
| IE.2 | EX1 | IO Interrupt 1 enable bit.  0: to disable IO Interrupt 1. 1: to enable the interrupt triggered by high-to-low transition or low level on the port INT1.                       |
| IE.1 | ET0 | Timer0 interrupt enable bit.  0: to disable Timer0 interrupt (TF0). 1: to enable the interrupt triggered by the flag TF0.                                                     |
| IE.O | EX0 | IO Interrupt 0 enable bit.  0: to disable IO Interrupt 0. 1: to enable the interrupt triggered by high-to-low transition or low level on the port INTO.                       |

### Table 11-3 EIE (SFR 0xE8)

|         | ·                                                                           |
|---------|-----------------------------------------------------------------------------|
| Bit     | Description                                                                 |
| EIE.7-5 | Reserved. Read out as 1.                                                    |
| EIE.4   | Interrupt 12 (Power-down Interrupt, PFI) enable bit. 0: disable; 1: enable. |
| EIE.3   | Interrupt 11 enable bit. 0: disable; 1: enable.                             |
| EIE.2   | Interrupt 10 enable bit. 0: disable; 1: enable.                             |

# **Low-power Multifunctional Energy Metering SoC**

| Bit   | Description                                    |
|-------|------------------------------------------------|
| EIE.1 | Interrupt 9 enable bit. 0: disable; 1: enable. |
| EIE.0 | Interrupt 8 enable bit. 0: disable; 1: enable. |

### Table 11-4 EXIF (SFR 0x91)

| Bit        |          | Description                                                                                                                                                                                                   |  |  |  |
|------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| EXIF.7 IE5 |          | Interrupt 11 flag. When this bit is set to 1, it indicates that Interrupt 11 was riggered. IE5 must be cleared by software. When Interrupt 11 was enabled, setting IE5 by software can trigger an interrupt.  |  |  |  |
| EXIF.6     | IE4      | Interrupt 10 flag. When this bit is set to 1, it indicates that Interrupt 10 was triggered. IE4 must be cleared by software. When Interrupt 10 was enabled, setting IE4 by software can trigger an interrupt. |  |  |  |
| EXIF.5     | IE3      | Interrupt 9 flag. When this bit is set to 1, it indicates that Interrupt 9 was triggered. IE3 must be cleared by software. When Interrupt 9 was enabled, setting IE3 by software can trigger an interrupt.    |  |  |  |
| EXIF.4     | IE2      | Interrupt 8 flag. When this bit is set to 1, it indicates that Interrupt 8 was triggered. IE3 must be cleared by software. When Interrupt 8 was enabled, setting IE2 by software can trigger an interrupt.    |  |  |  |
| EXIF.3     | Reserved | Read out as 1.                                                                                                                                                                                                |  |  |  |
| EXIF.2-0   | Reserved | Read out as 0.                                                                                                                                                                                                |  |  |  |

### Table 11-5 EICON (SFR 0xD8)

| Bit       |           | Description                                                                                                                                                                                                                                                                                                                                                  |
|-----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EICON.7   | SMOD1     | UART1 baud rate double enable bit. Set this bit to 1 to double the baud rate for UART1 serial interface.                                                                                                                                                                                                                                                     |
| EICON.6   | Reserved  | Read out as 1.                                                                                                                                                                                                                                                                                                                                               |
| EICON.5   | Reserved. |                                                                                                                                                                                                                                                                                                                                                              |
| EICON.4   | Reserved. |                                                                                                                                                                                                                                                                                                                                                              |
| EICON.3   | PFI       | Power-down Interrupt (Interrupt 12) flag. When this bit is set to 1, it indicates that a power-down interrupt was triggered. This flag must be cleared by software before exiting the interrupt service routine. Otherwise, the interrupt will occur again. When Interrupt 12 was enabled, setting this flag by software can trigger a power-down interrupt. |
| EICON.2-0 | Reserved. | Read out as 0.                                                                                                                                                                                                                                                                                                                                               |

# Low-power Multifunctional Energy Metering SoC

# Table 11-6 IP (SFR 0xB8)

| Bit  |           | Description                                                                                                                                                      |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IP.7 | Reserved. | Read out as 1.                                                                                                                                                   |
| IP.6 | PS1       | Set this bit to 1 to configure UART1 transmit or receive interrupt (RI1 or TI1) to Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0. |
| IP.5 | PT2       | Set this bit to 1 to configure Timer2 interrupt (TF2 or EXF2) to Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                   |
| IP.4 | PS0       | Reserved                                                                                                                                                         |
| IP.3 | PT1       | Set this bit to 1 to configure Timer1 interrupt (TF1) to Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                           |
| IP.2 | PX1       | Set this bit to 1 to configure IO Interrupt 1 to Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                                   |
| IP.1 | PT0       | Set this bit to 1 to configure Timer0 interrupt (TF0) to Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                           |
| IP.0 | PX0       | Set this bit to 1 to configure IO Interrupt 0 to Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                                   |

### Table 11-7 EIP (SFR 0xF8)

|         | 17 Eli (Sik Gxi G)                                                                                                                               |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | Description                                                                                                                                      |
| EIP.7-5 | Reserved. Read out as 1.                                                                                                                         |
| EIP.4   | Set this bit to 1 to configure Interrupt 12 (Power-down interrupt) Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0. |
| EIP.3   | Set this bit to 1 to configure Interrupt 11 Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                        |
| EIP.2   | Set this bit to 1 to configure Interrupt 10 Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                        |
| EIP.1   | Set this bit to 1 to configure Interrupt 9 Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                         |
| EIP.0   | Set this bit to 1 to configure Interrupt 8 Interrupt Priority 1. Clear this bit to configure it to Interrupt Priority 0.                         |

# 11.3. Interrupt Processing



Figure 11-2 Interrupt Processing

The preceding figure illustrates the interrupt processing in the AL6111A. When an enabled interrupt occurs,

- The program jumps to the interrupt vector address to execute the interrupt service routine (ISR) of the interrupt. An ISR being executed can only be interrupted by one of the interrupt with higher priority. Each ISR ends with an RETI (return from interrupt) instruction, as shown as A in the preceding figure.
- After executing the RETI, the program returns to the place where it was interrupted, as if it did not leave off, to execute the next instruction that would have been executed if the interrupt had not occurred. The program always completes an instruction in progress before servicing an interrupt. If an instruction executed in progress is RETI, or a write operation to registers including IP SFR, IE SFR, EIP SFR, and EIE SFR, the program will complete one additional instruction before servicing the ISR.
- In the AL6111A, Interrupt Priority 1 has higher priority than Interrupt Priority 0. So, the ISR of Interrupt Priority 0 only can be interrupted by the ISR of Interrupt Priority 1, as shown as B and C in the preceding figure.
- An ISR of Interrupt Priority 0 can be intruded by one of Interrupt Priority 1. When the latter one is executed, the program will return to the place at the vector address of the former one where it was interrupted to execute the ISR, and then, execute the instruction *RETI* to finish the ISR, as shown as B in the preceding figure.
- When two interrupts of the same tier (Interrupt Priority 1 or Interrupt Priority 0) occur simultaneously, the polling sequence of them is observed, as shown as D in the preceding figure.
- Interrupt latency depends on the current state of the MCU.
  - The shortest interrupt latency is equal to five instruction cycles: one to detect the interrupt, and four to perform the *LCALL* to the ISR.
  - The longest latency (equal to thirteen instruction cycles) occurs when the MCU is currently executing an *RETI* instruction followed by a *MUL* or *DIV* instruction. The thirteen instruction cycles in this case are: one to detect the interrupt, three to complete the *RETI*, five to execute the *DIV* or *MUL*, and four to execute the *LCALL* to the ISR. For an interrupt with the maximum latency, the interrupt latency is 52 (13x4) clock cycles.
- To ensure that high-to-low-transition-triggered interrupts can be detected, such as IO Interrupt 0/1/2/3, the level on the corresponding ports should be held high for at least four clock cycles and then low for no less than four clock cycles. If a level-triggered interrupt occurs when the flag has not been set bit, or an interrupt with higher priority is in process which blocks the program jumping to the interrupt vector address to execute its ISR, the interrupt signal will hold until it is to be serviced.

# 11.4. Extended Interrupts

# 11.4.1. Interrupt 8

Interrupt 8 can be triggered by 7 interrupt events which are listed in the following table. Bit ExInt2 (bit0 of PRCtrl1, 0x2D01) gate controls Interrupt 8.

**Table 11-8 Interrupt Events to Trigger Interrupt 8** 

| Table 11 6 Interrupt Events to Higger Interrupt 6 |               |                 |                                            |            |             |  |  |  |  |  |
|---------------------------------------------------|---------------|-----------------|--------------------------------------------|------------|-------------|--|--|--|--|--|
| I                                                 | nterrupt 8    |                 | Tobayyant Frank                            | - II I I   | EL (5.040)  |  |  |  |  |  |
| Vector Address                                    | Enable Bit    | Flag (R/W)      | Interrupt Event                            | Enable bit | Flag (R/W)  |  |  |  |  |  |
|                                                   |               |                 | Transmitter data output interrupt of UART2 | ExInt2IE.0 | ExInt2IFG.0 |  |  |  |  |  |
|                                                   | IE.7<br>EIE.0 | EXIF.4<br>(IE2) | Receiver data input interrupt of UART2     | ExInt2IE.1 | ExInt2IFG.1 |  |  |  |  |  |
|                                                   |               |                 | Transmitter data output interrupt of UART4 | ExInt2IE.2 | ExInt2IFG.2 |  |  |  |  |  |
| 43h                                               |               |                 | Receiver data input interrupt of UART4     | ExInt2IE.3 | ExInt2IFG.3 |  |  |  |  |  |
|                                                   |               |                 | Timer overflow interrupt of UART2          | ExInt2IE.4 | ExInt2IFG.4 |  |  |  |  |  |
|                                                   |               |                 | Timer overflow interrupt of UART4          | ExInt2IE.5 | ExInt2IFG.5 |  |  |  |  |  |
|                                                   |               |                 | CF pulse interrupt of E1 path              | ExInt2IE.7 | ExInt2IFG.7 |  |  |  |  |  |

Table 11-9 Extended Interrupt Flag (Request) Register (ExInt2IFG, 0x2840)

| 0x2840, R/W, Extended Interrupt Flag (Request) Register, ExInt2IFG |      |      |      |      |      |      |      |      |  |
|--------------------------------------------------------------------|------|------|------|------|------|------|------|------|--|
|                                                                    | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |
|                                                                    | IR7  | -    | IR5  | IR4  | IR3  | IR2  | IR1  | IR0  |  |
| Default                                                            | 0    | Х    | 0    | 0    | 0    | 0    | 0    | 0    |  |

1: an interrupt request occurred; 0: no interrupt request occurred; X: do not care.

A flag bit can be set to 1 only when the corresponding interrupt was enabled. When an interrupt was enabled, writing 1 to the corresponding flag bit can trigger the interrupt. Otherwise, however, cannot.

Write 0 to a bit can clear the corresponding interrupt flag.

# Low-power Multifunctional Energy Metering SoC

### Table 11-10 Extended Interrupt Input Type Register (ExInt2IN, 0x2841)

| 0x2841, R/W, Extended Interrupt Input Type Register, ExInt2IN |       |   |       |       |       |       |       |       |  |
|---------------------------------------------------------------|-------|---|-------|-------|-------|-------|-------|-------|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                       |       |   |       |       |       |       |       |       |  |
|                                                               | EDG7I | - | EDG5I | EDG4I | EDG3I | EDG2I | EDG1I | EDG0I |  |
| Default                                                       | 1     | Х | 1     | 1     | 1     | 1     | 1     | 1     |  |
|                                                               |       |   |       |       |       |       |       |       |  |

These bits must be set to their default values for proper operation.

### Table 11-11 Extended Interrupt Output Type Register (ExInt2OUT, 0x2842)

| 0x2842, R/W, Extended Interrupt Output Type Register, ExInt2OUT      |   |   |   |   |   |   |   |      |  |
|----------------------------------------------------------------------|---|---|---|---|---|---|---|------|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                              |   |   |   |   |   |   |   |      |  |
|                                                                      | _ | - | - | - | - | - | - | EDGO |  |
| Default                                                              | - | - | - | - | - | - | - | 1    |  |
| These bits must be set to their default values for proper operation. |   |   |   |   |   |   |   |      |  |

### Table 11-12 Extended Interrupt Enable Register (ExInt2IE, 0x2843)

| 0x2843, R                               | 0x2843, R/W, Extended Interrupt Enable Register, ExInt2IE |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------------------|-----------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 |                                                           |  |  |  |  |  |  |  |  |  |  |  |
|                                         | IE7 - IE5 IE4 IE3 IE2 IE1 IE0                             |  |  |  |  |  |  |  |  |  |  |  |
| Default                                 | Default 0 X 0 0 0 0 0 0                                   |  |  |  |  |  |  |  |  |  |  |  |
| 1: enable; 0: disable; X: do not care.  |                                                           |  |  |  |  |  |  |  |  |  |  |  |

### Table 11-13 Extended Interrupt Pending Register (ExInt2OV, 0x2844)

| 0x2844, R/W, Extended Interrupt Pending Register, ExInt2OV |  |  |  |  |  |  |  |  |  |  |
|------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                    |  |  |  |  |  |  |  |  |  |  |
| IPND7 - IPND5 IPND4 IPND3 IPND2 IPND1 IPND0                |  |  |  |  |  |  |  |  |  |  |
| Default 0 X 0 0 0 0 0 0                                    |  |  |  |  |  |  |  |  |  |  |

If an interrupt is triggered again when the corresponding flag in the register ExInt2IFG has not been cleared yet, the corresponding pending bit of this register will be set to 1. The pending bit is just an indication flag, nothing to do with the interrupt. It must be cleared by the program.

# 11.4.2. Interrupt 9

Interrupt 9 can be triggered by 5 interrupt events which are listed in the following table. Bit ExInt3 (bit1 of PRCtrl1, 0x2D01) gate controls Interrupt 9.



# Low-power Multifunctional Energy Metering SoC

Table 11-14 Interrupt Event to Trigger Interrupt 9

| I              | nterrupt 9 |            |                                            |            |             |
|----------------|------------|------------|--------------------------------------------|------------|-------------|
| Vector Address | Enable Bit | Flag (R/W) | Interrupt Event                            | Enable Bit | Flag (R/W)  |
|                |            |            | Transmitter data output interrupt of UART5 | ExInt3IE.2 | ExInt3IFG.2 |
| 4Bh            | IE.7       | EXIF.5     | Receiver data input interrupt of UART5     | ExInt3IE.3 | ExInt3IFG.3 |
| 4011           | EIE.1      | (IE3)      | Timer overflow interrupt of UART5          | ExInt3IE.5 | ExInt3IFG.5 |
|                |            |            | Pulse per second interrupt of RTC          | ExInt3IE.6 | ExInt3IFG.6 |
|                |            |            | CF pulse interrupt of E2 path              | ExInt3IE.7 | ExInt3IFG.7 |

#### Table 11-15 Extended Interrupt Flag (Request) Register (ExInt3IFG, 0x2848)

| 0x2848, R/W, Extended Interrupt Flag (Request) Register, ExInt3IFG |     |     |     |   |     |     |   |   |  |
|--------------------------------------------------------------------|-----|-----|-----|---|-----|-----|---|---|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                            |     |     |     |   |     |     |   |   |  |
|                                                                    | IR7 | IR6 | IR5 | - | IR3 | IR2 | - | - |  |
| Default                                                            | 0   | 0   | 0   | Х | 0   | 0   | X | X |  |

1: an interrupt request occurred; 0: no interrupt request occurred; X: do not care.

A flag bit can be set to 1 only when the corresponding interrupt was enabled. When an interrupt was enabled, writing 1 to the corresponding flag bit can trigger the interrupt. Otherwise, however, cannot.

Write 0 to a bit can clear the corresponding interrupt flag.

#### Table 11-16 Extended Interrupt Input Type Register (ExInt3IN, 0x2849)

| 0x2849, R/W, Extended Interrupt Input Type Register, ExInt3IN        |       |       |       |   |       |       |   |   |  |  |
|----------------------------------------------------------------------|-------|-------|-------|---|-------|-------|---|---|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                              |       |       |       |   |       |       |   |   |  |  |
|                                                                      | EDG7I | EDG6I | EDG5I | - | EDG3I | EDG2I | - | - |  |  |
| Default 1 1 1 X 1 1 X X                                              |       |       |       |   |       |       |   |   |  |  |
| These hits must be set to their default values for proper operation. |       |       |       |   |       |       |   |   |  |  |

# Table 11-17 Extended Interrupt Output Type Register (ExInt3OUT, 0x284A)

| 0x284A, R/W, Extended Interrupt Output Type Register, ExInt3OUT |   |   |   |   |   |   |   |      |  |  |  |
|-----------------------------------------------------------------|---|---|---|---|---|---|---|------|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                         |   |   |   |   |   |   |   |      |  |  |  |
|                                                                 | - | - | - | - | - | - | - | EDGO |  |  |  |
| Default                                                         | - | - | - | - | - | - | - | 1    |  |  |  |



# Low-power Multifunctional Energy Metering SoC

| 0x284A, R/W, E | xtended In | terrupt Ou | tput Type F | Register, Ex | Int3OUT |      |      |      |
|----------------|------------|------------|-------------|--------------|---------|------|------|------|
|                | bit7       | bit6       | bit5        | bit4         | bit3    | bit2 | bit1 | bit0 |

These bits must be set to their default values for proper operation.

### Table 11-18 Extended Interrupt Enable Register (ExInt3IE, 0x284B)

| 0x284B, R/W, Extended Interrupt Enable Register, ExInt3IE |     |     |     |   |     |     |   |   |  |
|-----------------------------------------------------------|-----|-----|-----|---|-----|-----|---|---|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                   |     |     |     |   |     |     |   |   |  |
|                                                           | IE7 | IE6 | IE5 | - | IE3 | IE2 | - | - |  |
| Default                                                   | 0   | 0   | 0   | Х | 0   | 0   | Х | Х |  |
| 1: enable; 0: disable; X: do not care.                    |     |     |     |   |     |     |   |   |  |

### Table 11-19 Extended Interrupt Pending Register (ExInt3OV, 0x284C)

| 0x284C, R/W, Extended Interrupt Pending Register, ExInt3OV |       |       |       |   |       |       |   |   |  |  |
|------------------------------------------------------------|-------|-------|-------|---|-------|-------|---|---|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                    |       |       |       |   |       |       |   |   |  |  |
|                                                            | IPND7 | IPND6 | IPND5 | - | IPND3 | IPND2 | - | - |  |  |
| Default                                                    | 0     | 0     | 0     | Х | 0     | 0     | X | Χ |  |  |

If an interrupt occurs again when the corresponding flag in the register ExInt3IFG has not been cleared yet, the corresponding pending bit of this register will be set to 1. The pending bit is just an indication flag, nothing to do with the interrupt. It must be cleared by the program.

# 11.4.3. Interrupt 10

Interrupt 10 can be triggered by 5 interrupt events which are listed in the following table. Bit ExInt4 (bit2 of PRCtrl1, 0x2D01) gate controls Interrupt 10.

Table 11-20 Interrupt Events to Trigger Interrupt 10

| Ir                | nterrupt 10   |               |                                                            |            |             |
|-------------------|---------------|---------------|------------------------------------------------------------|------------|-------------|
| Vector<br>Address | Enable<br>Bit | Flag<br>(R/W) | Interrupt Event                                            | Enable Bit | Flag (R/W)  |
|                   |               |               | RTC illegal data interrupt                                 | ExInt4IE.0 | ExInt4IFG.0 |
|                   | IE.7          | EXIF.6        | IO Interrupt 2 (INT2), triggered on high-to-low transition | ExInt4IE.2 | ExInt4IFG.2 |
| 53h               |               |               | IO Interrupt 3 (INT3), triggered on high-to-low transition | ExInt4IE.3 | ExInt4IFG.3 |
|                   |               |               | REF leakage interrupt                                      | ExInt4IE.4 | ExInt4IFG.4 |



| Ir                | nterrupt 10   |               |                         |            |             |
|-------------------|---------------|---------------|-------------------------|------------|-------------|
| Vector<br>Address | Enable<br>Bit | Flag<br>(R/W) | Interrupt Event         | Enable Bit | Flag (R/W)  |
|                   |               |               | Zero-crossing interrupt | ExInt4IE.5 | ExInt4IFG.5 |

### Table 11-21 Extended Interrupt Flag (Request) Register (ExInt4IFG, 0x2850)

| 0x2850, R/W, Extended Interrupt Flag (Request) Register, ExInt4IFG |   |   |     |     |     |     |   |     |  |  |
|--------------------------------------------------------------------|---|---|-----|-----|-----|-----|---|-----|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                            |   |   |     |     |     |     |   |     |  |  |
|                                                                    | - | - | IR5 | IR4 | IR3 | IR2 | - | IR0 |  |  |
| Default                                                            | X | X | 0   | 0   | 0   | 0   | X | 0   |  |  |

1: an interrupt request occurred; 0: no interrupt request occurred; X: do not care.

A flag bit can be set to 1 only when the corresponding interrupt was enabled. When an interrupt was enabled, writing 1 to the corresponding flag bit can trigger the interrupt. Otherwise, however, cannot.

Write 0 to a bit can clear the corresponding interrupt flag.

### Table 11-22 Extended Interrupt Input Type Register (ExInt4IN, 0x2851)

| 0x2851, R/W, Extended Interrupt Input Type Register, ExInt4IN        |      |      |       |       |       |       |      |       |
|----------------------------------------------------------------------|------|------|-------|-------|-------|-------|------|-------|
|                                                                      | bit7 | bit6 | bit5  | bit4  | bit3  | bit2  | bit1 | bit0  |
|                                                                      | -    | -    | EDG5I | EDG4I | EDG3I | EDG2I | -    | EDG0I |
| Default                                                              | Х    | Х    | 1     | 1     | 1     | 1     | Х    | 1     |
| These bits must be set to their default values for proper operation. |      |      |       |       |       |       |      |       |

#### Table 11-23 Extended Interrupt Output Type Register (ExInt4OUT, 0x2852)

| 0x2852, R/W, Extended Interrupt Output Type Register, ExInt4OUT      |      |      |      |      |      |      |      |      |
|----------------------------------------------------------------------|------|------|------|------|------|------|------|------|
|                                                                      | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
|                                                                      | _    | -    | -    | -    | -    | -    | -    | EDGO |
| Default                                                              | _    | -    | -    | -    | -    | -    | -    | 1    |
| These bits must be set to their default values for proper operation. |      |      |      |      |      |      |      |      |

# Low-power Multifunctional Energy Metering SoC

Table 11-24 Extended Interrupt Enable Register (ExInt4IE, 0x2853)

| 0x2853, R/W, Extended Interrupt Enable Register, ExInt4IE |      |      |      |      |      |      |      |      |
|-----------------------------------------------------------|------|------|------|------|------|------|------|------|
|                                                           | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
|                                                           | -    | -    | IE5  | IE4  | IE3  | IE2  | -    | IE0  |
| Default                                                   | Х    | Х    | 0    | 0    | 0    | 0    | Х    | 0    |
| 1: enable: 0: disable: X: do not care.                    |      |      |      |      |      |      |      |      |

#### Table 11-25 Extended Interrupt Pending Register (ExInt4OV, 0x2854)

| 0x2854, R/W, Extended Interrupt Pending Register, ExInt4OV |      |      |       |       |       |       |      |       |  |
|------------------------------------------------------------|------|------|-------|-------|-------|-------|------|-------|--|
|                                                            | bit7 | bit6 | bit5  | bit4  | bit3  | bit2  | bit1 | bit0  |  |
|                                                            | -    | -    | IPND5 | IPND4 | IPND3 | IPND2 | -    | IPND0 |  |
| Default                                                    | 0    | x    | 0     | IPND4 | 0     | 0     | X    | 0     |  |

If an interrupt occurs again when the corresponding flag in the register ExInt4IFG has not been cleared yet, the corresponding pending bit of this register will be set to 1. The pending bit is just an indication flag, nothing to do with the interrupt. It must be cleared by the program.

### 11.4.4. Interrupt 11

Interrupt 11 can be triggered by 7 interrupt events which are listed in the following table. Bit ExInt5 (bit3 of PRCtrl1, 0x2D01) gate controls Interrupt 11.

Table 11-26 Interrupt Events to Trigger Interrupt 11

| In             | terrupt 11 |                 |                                 |            |             |
|----------------|------------|-----------------|---------------------------------|------------|-------------|
| Vector Address | Enable Bit | Flag (R/W)      | Interrupt Event                 | Enable Bit | Flag (R/W)  |
|                |            |                 | TimerA overflow interrupt       | ExInt5IE.0 | ExInt5IFG.0 |
|                |            |                 | TimerA capture interrupt 0      | ExInt5IE.1 | ExInt5IFG.1 |
|                | 5Bh        | EXIF.7<br>(IE5) | TimerA capture interrupt 1      | ExInt5IE.2 | ExInt5IFG.2 |
| 5Bh            |            |                 | TimerA capture interrupt 2      | ExInt5IE.3 | ExInt5IFG.3 |
|                |            |                 | Illegal data interrupt of GPSI* | ExInt5IE.4 | ExInt5IFG.4 |
|                |            |                 | Transmit interrupt of GPSI*     | ExInt5IE.5 | ExInt5IFG.5 |
|                |            |                 | Comparator interrupt            | ExInt5IE.6 | ExInt5IFG.6 |

<sup>\*</sup>When bit GPSI (bit6 of PRCtrl0, 0x2D00) is set to 1, GPSI (general-purpose serial interface) is enabled. Writing of illegal data or transmit completion will trigger interrupt to MCU.

# Low-power Multifunctional Energy Metering SoC

### Table 11-27 Extended Interrupt Flag (Request) Register (ExInt5IFG, 0x28A2)

| 0x28A2, R/W, Extended Interrupt Flag (Request) Register, ExInt4IFG |      |      |      |      |      |      |      |      |
|--------------------------------------------------------------------|------|------|------|------|------|------|------|------|
|                                                                    | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
|                                                                    | -    | IR6  | IR5  | IR4  | IR3  | IR2  | IR1  | IR0  |
| Default                                                            | X    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

1: an interrupt request occurred; 0: no interrupt request occurred; X: do not care.

A flag bit can be set to 1 only when the corresponding interrupt was enabled. When an interrupt was enabled, writing 1 to the corresponding flag bit can trigger the interrupt. Otherwise, however, cannot.

Write 0 to a bit can clear the corresponding interrupt flag.

#### Table 11-28 Extended Interrupt Input Type Register (ExInt5IN, 0x28A3)

| 0x28A3, R/W, Extended Interrupt Input Type Register, ExInt5IN        |      |       |       |       |       |       |       |       |
|----------------------------------------------------------------------|------|-------|-------|-------|-------|-------|-------|-------|
|                                                                      | bit7 | bit6  | bit5  | bit4  | bit3  | bit2  | bit1  | bit0  |
|                                                                      | -    | EDG6I | EDG5I | EDG4I | EDG3I | EDG2I | EDG1I | EDG0I |
| Default                                                              | Х    | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| These bits must be set to their default values for proper operation. |      |       |       |       |       |       |       |       |

#### Table 11-29 Extended Interrupt Output Type Register (ExInt5OUT, 0x28A4)

| 0x2852, R/W, Extended Interrupt Output Type Register, ExInt4OUT      |      |      |      |      |      |      |      |      |
|----------------------------------------------------------------------|------|------|------|------|------|------|------|------|
|                                                                      | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
|                                                                      | -    | -    | -    | -    | -    | -    | -    | EDGO |
| Default                                                              | -    | -    | -    | -    | -    | -    | -    | 1    |
| These bits must be set to their default values for proper operation. |      |      |      |      |      |      |      |      |

#### Table 11-30 Extended Interrupt Enable Register (ExInt5IE, 0x28A5)

| 0x28A5, R/W, Extended Interrupt Enable Register, ExInt4IE |      |      |      |      |      |      |      |      |
|-----------------------------------------------------------|------|------|------|------|------|------|------|------|
|                                                           | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
|                                                           | -    | IE6  | IE5  | IE4  | IE3  | IE2  | IE1  | IE0  |
| Default                                                   | Х    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| 1: enable; 0: disable; X: do not care.                    |      |      |      |      |      |      |      |      |

# Low-power Multifunctional Energy Metering SoC

### Table 11-31 Extended Interrupt Pending Register (ExInt5OV, 0x28A6)

| 0x28A6, R/W, Extended Interrupt Pending Register, ExInt5OV |      |       |       |       |       |       |       |       |
|------------------------------------------------------------|------|-------|-------|-------|-------|-------|-------|-------|
|                                                            | bit7 | bit6  | bit5  | bit4  | bit3  | bit2  | bit1  | bit0  |
|                                                            | -    | IPND6 | IPND5 | IPND4 | IPND3 | IPND2 | IPND1 | IPND0 |
| Default                                                    | X    | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

If an interrupt occurs again when the corresponding flag in the register ExInt5IFG has not been cleared yet, the corresponding pending bit of this register will be set to 1. The pending bit is just an indication flag, nothing to do with the interrupt. It must be cleared by the program.

# 12. UART/Timers

When power-on or brown out reset (POR/BOR), RSTn pin reset, WDT overflow, power supply restoration event, IO/RTC wakeup event or debugging reset occurs, all the timers and the UART serial interfaces are reset to their default states. In LPM1 state or LPM2 state, they stop working. Each extended UART serial interface and TimerA can be gate controlled independently via configuring register PRCtrl0 (0x2D00) and PRCtrl1 (0x2D01).

# 12.1. Timers/Counters

The AL6111A can provide users with timers listed as follows:

- TimerA, a 16-bit timer, with 3 compare/capture modules, gate controlled independently;
- Timer0, Timer1 and Timer2 of 8052 microcontroller. They work as general timers; furthermore, Timer1 can work as the baud rate generator of UART1;
- The general timer and specific baud rate generator of each extended UART serial interface (UART2/UART4/UART5). Each interface can be gate controlled independently. The general timer has the same function with Timer0, an overflow event of which will set a flag bit to 1, which will be cleared by executing interrupt service routine (ISR) or by polling interrupt sources, and generate an interrupt to the MCU. The specific baud rate generator has the same function with Timer1: it can be used as a general timer, an overflow event of which can set the flag bit to 1 but cannot generate an interrupt to the MCU.

In this section, only TimerA, Timer0, Timer1 and Timer2 are introduced. The general timers in extended UART serial interfaces are introduced in "UART".

### 12.1.1. TimerA

TimerA is a 16-bit timer/counter, and has 4 operation modes. It has 3 compare/capture modules, and 3 configurable output units with 8 output modes. Bit TimerA (bit0 of PRCtrl0, 0x2D00) gate controls TimerA.



**Figure 12-1 TimerA Architecture** 

Table 12-1 TimerA-Related Registers

| Address       | Description                                    |                                                |        |  |  |  |
|---------------|------------------------------------------------|------------------------------------------------|--------|--|--|--|
| 0x2900        | TACTL, Timer A Control                         | ACTL, Timer A Control Register                 |        |  |  |  |
| 0x2902        | Low byte                                       | TAD Time and Time of Country Designation       | R      |  |  |  |
| 0x2903        | High byte                                      | byte TAR, TimerA Timer/Counter Register        |        |  |  |  |
| 0x2904        | TACCTL0, low byte                              | Times A Company (Continue Control Degister O   | D () M |  |  |  |
| 0x2905        | TACCTH0, high byte                             | Timer A Compare/Capture Control Register 0     | R/W    |  |  |  |
| 0x2906        | TACCTL1, low byte                              | Time A. Common of Control Desirton 1           | D () M |  |  |  |
| 0x2907        | TACCTH1, high byte                             | Timer A Compare/Capture Control Register 1     | R/W    |  |  |  |
| 0x2908        | TACCTL2, low byte                              | Time A. Comment (Control Desirtor 2            | D () M |  |  |  |
| 0x2909        | TACCTH2, high byte                             | Timer A Compare/Capture Control Register 2     | R/W    |  |  |  |
| 0x290A~0x290B | TACCR0, Timer A Comp                           | TACCR0, Timer A Compare/Capture Register 0 R/V |        |  |  |  |
| 0x290C~0x290D | TACCR1, Timer A Compare/Capture Register 1 R/W |                                                |        |  |  |  |
| 0x290E~0x290F | TACCR2, Timer A Comp                           | pare/Capture Register 2                        | R/W    |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

### Table 12-2 Timer A Counter/Timer Register (TAR, 0x2902~0x2903)

| 0x2902~     | 0x2902~0x2903, R, Timer A Timer/Counter Register, TAR |         |                                                                                                                                                         |  |  |  |  |  |
|-------------|-------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit Default |                                                       | Default | Description                                                                                                                                             |  |  |  |  |  |
| 0x2903      | Bit[7:0]                                              |         | The registers give the value of TimerA (TAR), of which the low byte is in the register located at address 0x2902, and the high byte is in 0x2903. It is |  |  |  |  |  |
| 0x2902      | Bit[7:0]                                              | 0       | read-only, and can be reset by software. When TimerA overflows, an interrupt is generated to the MCU.                                                   |  |  |  |  |  |

### Table 12-3 Timer A Control Register (TACTL, 0x2900)

| 0x29   | 0x2900, R/W, TimerA Control Register, TACTL |         |                                                                                                                                                                                  |             |                                  |                                                                                      |  |  |  |  |  |
|--------|---------------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit    |                                             | Default | Descri                                                                                                                                                                           | Description |                                  |                                                                                      |  |  |  |  |  |
|        |                                             |         | These bits are used to select the divider for the input clock.                                                                                                                   |             |                                  |                                                                                      |  |  |  |  |  |
| Bit7   | ID1                                         |         | ID1                                                                                                                                                                              |             | ID0                              | Description                                                                          |  |  |  |  |  |
|        |                                             |         | 0                                                                                                                                                                                |             | 0                                | The input clock is divided by 2;                                                     |  |  |  |  |  |
| Direct | ***                                         | 0       | 0                                                                                                                                                                                |             | 1                                | The input clock is divided by 4;                                                     |  |  |  |  |  |
| Bit6   | ID0                                         |         | 1                                                                                                                                                                                |             | 0                                | The input clock is divided by 8;                                                     |  |  |  |  |  |
|        |                                             |         | 1                                                                                                                                                                                |             | 1                                | The input clock is divided by 16.                                                    |  |  |  |  |  |
|        |                                             |         | To sele                                                                                                                                                                          | ect ope     | ration mode, as i                | llustrated in Figure 12-2.                                                           |  |  |  |  |  |
| D:FE   | MC1                                         | 0       | MC1                                                                                                                                                                              | MC0         | Description                      |                                                                                      |  |  |  |  |  |
| Bit5   | MC1                                         |         | 0                                                                                                                                                                                | 0           | Stop Mode: the                   | timer is halted.                                                                     |  |  |  |  |  |
|        |                                             |         | 0                                                                                                                                                                                | 1           | Up Mode: the tir from 0000h.     | ner counts up to the value of TACCR0, and recount                                    |  |  |  |  |  |
| Bit4   | мс0                                         |         | 1                                                                                                                                                                                | 0           | Continuous Moofrom 0000h.        | le: the timer counts up to FFFFh, and recounts                                       |  |  |  |  |  |
|        |                                             |         | 1                                                                                                                                                                                | 1           | Up/Down Mode:<br>then, back down | the timer counts up to the value of TACCRO, and to 0000h.                            |  |  |  |  |  |
| Bit3   | TSEL                                        | -       | To sele                                                                                                                                                                          | ect the     | clock source for                 | the timer. 0: f <sub>MCU</sub> /128; 1: f <sub>MCU</sub> .                           |  |  |  |  |  |
| Bit2   | CLR                                         | 0       | Set the bit CLR to 1 to clear the register TAR, meanwhile, [ID1, ID0]=00; if the timer works in Up/Down mode, the timer rolls over to 0000h, and back up to the value of TACCR0. |             |                                  |                                                                                      |  |  |  |  |  |
| Bit1   | TAIE                                        | 0       |                                                                                                                                                                                  |             | , ,                              | et to 1, set this bit to 1 to enable TimerA overflow red, the interrupt is disabled. |  |  |  |  |  |

# Low-power Multifunctional Energy Metering SoC

| 0x29 | 0x2900, R/W, TimerA Control Register, TACTL |         |                                                                                                                                 |  |  |  |  |
|------|---------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit  |                                             | Default | Description                                                                                                                     |  |  |  |  |
|      |                                             |         | TimerA overflow interrupt flag.  In the Up Mode, when the timer rolls over to 0000h from the value of TACCRO, TAIFG is set bit. |  |  |  |  |
| Bit0 | TAIFG                                       | 0       | In the Continuous Mode, when the timer rolls over to 0000h from FFFFh, TAIFG is set bit.                                        |  |  |  |  |
|      |                                             |         | In the Up/Down Mode, when the timer counts down to 0000h from 0001h, TAIFG is set bit.                                          |  |  |  |  |



Figure 12-2 Operation Modes for TimerA

When either bit MC1 or MC0 is not cleared, or the clock source is active, the timer starts counting. In Up or Up/Down Mode, when the register TACCR0 is cleared, the timer stops running, and it may then be restarted counting in the up direction from zero when a non-zero value is written into the register TACCR0.

In Up Mode, when the value of the register TACCR0 is changed while the timer is running,

- if the new value is not less than the former value or current counts, the timer will count up to the new TACCRO value, and then rolls over to 0000h;
- if the new value is less than current counts, the timer will count to the former value firstly, rolls over to 0000h, and then counts to the new TACCRO value.

#### In Up/Down Mode,

when the value of the register TACCR0 is changed while the timer is counting in the down direction, the timer continues its direction until it counts down to 0000h, and then it counts up to the new



### Low-power Multifunctional Energy Metering SoC

value of TACCR0 from 0000h;

- when the value of the register TACCR0 is changed while the timer is counting in the up direction:
  - if the new value is not less than the former value or current counts, the timer counts up to the new TACCRO value before counting down;
  - if the new value is less than current counts, the timer will count to the former value firstly, counts back to 0000h, and then counts up to the new TACCRO value.

In Continuous Mode, the output frequency is configurable, as illustrated in the following figure. This operation mode can be used to generate independent output frequencies.



Figure 12-3 Configuring Output Frequency in Continuous Mode

As illustrated in the above figure, TACCR0a and TACCR1a are the values of the registers TACCR0 and TACCR1 at the moment of Ta0 and Ta1, and TACCR0b and TACCR1b are the values of the registers TACCR0 and TACCR1 at the moment of Tb0 (Tb0=Ta0+t0) and Tb1 (Tb1=Ta1+t1), and so forth. When the interrupt is enabled (CCIE=1, Bit4, TACCTLx), an interrupt will be generated at the moment of Ta0 and Ta1 independently and at an interval (t0 or t1). The interrupt flags CCIFG (Bit0 of TACCTLx, x=0 and 1) are set bit respectively. Up to 3 independent output frequencies can be generated using all capture/compare registers. In this application, when the timer rolls over to 0000h from FFFFh, the bit TAIFG is still set.

### **Low-power Multifunctional Energy Metering SoC**

### Table 12-4 Timer A Compare/Capture Control Registers (0x2904~0x2909)

0x2904~0x2905/0x2906~0x2907/0x2908~0x2909, R/W, TimerA Compare/Capture Control Register x<sup>†</sup>, TACCTLx~TACCTHx Description Byte Bit Default Bit15 CM1 To select the capture mode. CM1 CM0 Description O 0 To disable capture mode. Bit14 CM<sub>0</sub> 0 1 To capture signals on the rising edge. High byte 0 To capture signals on the falling edge. 1 TACCTHX 1 1 To capture signals on both edges. 0x2905 Read only. Bit[13:11] Reserved 0 0x2907 To latch the input signal (determined by bits CCISx) with the EQUx signal, and read it via the bit CCI. 0x2909 Bit10 SCCI 0 Note: when the value of TAR is equal to the value of TACCRx, TimerA output the EQUx signal, of which x can be 0, 1 or 2. Read-only. This bit is read out as 0 all the time. Bit9 Reserved Bit8 CAP To select capture or compare mode. 0: Compare Mode; 1: Capture Mode. Low byte To select the output mode, see Figure 12-4 for description of the pulse output. Bit7 OUTMOD2 Bit7 Bit6 Bit5 **TACCTL**x 0 Mode Description 0x2904 0 0 0 To output the value of the bit OUT on the pin TAx. Output

 $<sup>^{\</sup>dagger}$  x can be equal to 0/1/2 to represent the TimerA Capture/Compare Module 0/1/2 control register.



# **Low-power Multifunctional Energy Metering SoC**

0x2904~0x2905/0x2906~0x2907/0x2908~0x2909, R/W, TimerA Compare/Capture Control Register x<sup>+</sup>, TACCTLx~TACCTHx

| Byte             | Bit  |         | Default | Descript | ion |   |        |                                                                                                                                                                                |
|------------------|------|---------|---------|----------|-----|---|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x2906<br>0x2908 | Bit6 | OUTMOD1 |         | 0        | 0   | 1 | Set    | When TAR=TACCRx ( $x=0\sim2$ ), the output on the corresponding pin TAx is set bit. It remains the state until a reset of the timer, or until another output mode is selected. |
|                  |      |         |         | 0        | 1   | 0 | Toggle | When TAR= TACCRx ( $x=1\sim2$ ), the output on the corresponding pin                                                                                                           |

# **Low-power Multifunctional Energy Metering SoC**

0x2904~0x2905/0x2906~0x2907/0x2908~0x2909, R/W, TimerA Compare/Capture Control Register x<sup>+</sup>, TACCTLx~TACCTHx

| Byte | Bit  | Bit           |         | Descrip | tion      |           |               |                                                                                                                                                                                                 |
|------|------|---------------|---------|---------|-----------|-----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |               |         |         |           |           | Reset         | TAx is toggled. When TAR=TACCR0, the output on the corresponding pin TAx is reset.  And this mode is not for the output on the pin TA0.                                                         |
|      |      |               |         | 0       | 1         | 1         | Set<br>Reset  | When TAR= TACCRx (x=1~2), the output on the corresponding pin TAx is set. When TAR=TACCR0, the output on the corresponding pin TAx is reset.  This mode is not for the output on the pin TA0.   |
|      |      | OUTMOD0  CCIE |         | 1       | 0         | 0         | Toggle        | When TAR= TACCRx ( $x=0\sim2$ ), the output on the corresponding pin TAx is toggled.                                                                                                            |
|      | Bit5 |               | OUTMOD0 | 1       | 0         | 1         | Reset         | When TAR= TACCRx ( $x=0\sim2$ ), the output on the corresponding pin TAx is reset. It remains reset until another output mode is selected.                                                      |
|      |      |               |         | 1       | 1         | 0         | Toggle<br>Set | When TAR= TACCRx (x=1~2), the output on the corresponding pin TAx is toggled. When TAR=TACCR0, the output on the corresponding pin TAx is set.  This mode is not for the output on the pin TA0. |
|      |      |               |         | 1       | 1         | 1         | Reset<br>Set  | When TAR= TACCRx (x=1~2), the output on the corresponding pin TAx is reset. When TAR=TACCR0, the output on the corresponding pin TAx is set.  This mode is not for the output on the pin TA0.   |
|      | Bit4 |               | 0       | Interru | pt enabl  | e bit, to | enable Ti     | merA compare/capture interrupt. 0: disable; 1: enable.                                                                                                                                          |
|      | Bit3 | CCI           | 0       | To read | I the cap | tured in  | put signal    | (via configuring the bits CCIS1/CCIS0).                                                                                                                                                         |

# **Low-power Multifunctional Energy Metering SoC**

0x2904~0x2905/0x2906~0x2907/0x2908~0x2909, R/W, TimerA Compare/Capture Control Register x<sup>†</sup>, TACCTLx~TACCTHx

| Byte | Bit  |       | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Bit2 | OUT   | 0       | When the bits OUTMOD2, OUTMOD1 and OUTMOD0 are cleared, the value of this is output on the pins TAx $(x=0\sim2)$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      | Bit1 | COV   | 0       | Capture overflow flag.  In capture mode, when COV is read out as 0, the capture signal is reset, and the capture event cannot set this bit to 1.  In capture mode, when COV is read out as 1, if a capture event occurs when the value of the last capture has not been read out, COV is set bit.  This bit must be reset by program. Reading the captured signal cannot reset this bit.                                                                                                                                                                                                                                                                                                    |
|      | Bit0 | CCIFG | 0       | Compare / capture interrupt flag.  In capture mode: when the value of the register TAR is captured into the registers TACCR0/1/2, this flag bit will be set bit.  In compare mode: when the value of the register TAR is equal to that of the registers TACCR0/1/2 (EQUX signal), this flag bit will be set bit.  In Compare/Capture Module 0, when the interrupt request is responded, this flag bit will be reset automatically.  In Compare/Capture Module 1/2, when the interrupt request is responded, the CCIFG flag is reset; if the corresponding enable bit is cleared, this flag bit still will be set bit, which must be cleared by program, but no interrupt will be generated. |

# Low-power Multifunctional Energy Metering SoC



Figure 12-4 Output on Pin TA1 in Up Mode



Figure 12-5 Output on Pin TA1 in Continuous Mode

# Low-power Multifunctional Energy Metering SoC



Figure 12-6 Output on Pin TA1 in Up/Down Mode

As illustrated in the above figures, users can configure the bits OUTMOD2, OUTMOD1 and OUTMOD0 to select the output mode. When these bits are set to 0b010/011/100/110/111, the frequency and duty cycle of the output pulse changes, generating PWM signals (pulse width modulation).

# 12.1.2. Timer 0 / Timer 1 / Timer 2

### 12.1.2.1. Timer Rate Control

When the bits in CKCON (SFR 0x8E), CKCON.5, CKCON.4 and CKCON.3, are set bit, the associated timers increment by ones every clock cycle (clk). When they are cleared, the associated timers increment by ones every 12 clock cycles (clk/12). The timers are independent of each other. By default the above three bits are cleared.

Table 12-5 Bit Description of CKCON (SFR 0x8E)

| Bit     | Description                                                        |
|---------|--------------------------------------------------------------------|
| CKCON.5 | T2M – to select the clock source for Timer2.                       |
|         | When $T2M = 0$ , $clk/12$ is used; when $T2M = 1$ , $clk$ is used. |

| Bit     | Description                                                                                                      |
|---------|------------------------------------------------------------------------------------------------------------------|
| CKCON.4 | T1M - to select the clock source for Timer1.  When T1M = 0, clk/12 is used; when T1M = 1, clk is used.           |
| CKCON.3 | T0M – to select the clock source for Timer0.  When $T0M = 0$ , $clk/12$ is used; when $T0M = 1$ , $clk$ is used. |

# 12.1.2.2. Timer0/Timer1

Timer0 and Timer1 are two of three embedded timers of 8052 microcontroller. Both timers can act as a timer to count the MCU clock frequency, or act as a counter to count the input signals. Furthermore, Timer1 also can act as a baud rate generator of UART1 for serial communication.

There are 4 operation modes for Timer0 and Timer1. They are determined by TMOD (SFR 0x89) and TCON (SFR 0x88). The four modes are:

- 13-bit timer/counter (Mode 0).
- 16-bit timer/counter (Mode 1).
- 8-bit timer/counter in auto-reload mode (Mode 2).
- Split timer/counter mode (Mode 3, only for Timer0).

The SFRs associated with Timer0/Timer1 are:

- TL0 (SFR 0x8A) and TH0 (SFR 0x8C), the lower byte and higher byte of Timer0.
- TL1 (SFR 0x8B) and TH1 (SFR 0x8D), the lower byte and higher byte of Timer1.

#### Table 12-6 Timer0/1 Mode Control Special Function Register (TMOD, SFR 0x89)

| Bit            |      | Description                                                                                                                                                                                                                                                                   |
|----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit7<br>TMOD.7 | GATE | Timer1 gate control bit. If the bit TR1 (TCON.6) is set bit and the signal on the pin INT1 is high, Timer1 runs when this bit is set to 1. If this bit is cleared, Timer1 runs when TR1 is set to 1, regardless of the state of the pin INT1.                                 |
| Bit6<br>TMOD.6 | C/T  | When this bit is cleared, Timer1 acts as a timer to count the clock pulse (clk or clk/12, depending on the bit T1M, CKCON.4). When this bit is set bit, Timer1 acts as a counter driven by the input signal on the pin T1 and counts the 1-0 transitions of the input signal. |
| Bit5<br>TMOD.5 | M1   | To determine the operation mode for Timer1.  M1 M0 Mode                                                                                                                                                                                                                       |

| Bit            |      | Description                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|----------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                |      | 0 0 Mode 0: 13-bit timer/counter.                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Bit4           |      | 0 1 Mode 1: 16-bit timer/counter.                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| TMOD.4         | M0   | 1 0 Mode 2: 8-bit timer/counter in auto-reload mode.                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                |      | 1 1 Mode 3: Split timer/counter.                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| Bit3<br>TMOD.3 | GATE | Timer0 gate control bit. If the bit TR0 (TCON.4) is set bit and the signal on the pin INT0 is high, Timer0 runs when this bit is set bit. If this bit is cleared, Timer0 runs when TR0 is set bit, regardless of the state of the pin INT0.                                                                |  |  |  |  |  |  |
| Bit2<br>TMOD.2 | C/T  | Timer or counter select bit. When this bit is cleared, Timer0 acts as a timer to count the clock pulse (clk or clk/12, depending on the bit T0M, CKCON.3). When this bit is set bit, Timer0 acts as a counter driven by the input signal on the pin T0 and counts the 1-0 transitions of the input signal. |  |  |  |  |  |  |
| Bit1           |      | M1 M0 Mode                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| TMOD.1         | M1   | 0 0 Mode 0: 13-bit timer/counter.                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|                |      | 0 1 Mode 1: 16-bit timer/counter.                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Bit0           | M0   | 1 0 Mode 2: 8-bit timer/counter in auto-reload mode.                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| TMOD.0         |      | 1 1 Mode 3: Split timer/counter mode.                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |

### Table 12-7 Timer0/1 Control Special Function Register (TCON, SFR 0x88)

| Bit            |     | Description                                                                                                                                                                                          |  |  |  |  |
|----------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit7<br>TCON.7 | TF1 | Timer 1 overflow flag. It is set bit when Timer1 overflows. It is cleared when the processor vectors to execute interrupt service routine located at program address 0x001B ("Interrupt Resources"). |  |  |  |  |
| Bit6<br>TCON.6 | TR1 | Timer1 run control bit.  Set this bit to 1 to enable Timer1 to run.                                                                                                                                  |  |  |  |  |
| Bit5<br>TCON.5 | TF0 | Timer0 overflow flag. It is set bit when Timer0 overflows. It is cleared when the processor vectors to execute interrupt service routine located at program address 0x000B ("Interrupt Resources").  |  |  |  |  |
| Bit4<br>TCON.4 | TR0 | Timer0 run control bit.  Set this bit to 1 to enable Timer0 to run.                                                                                                                                  |  |  |  |  |

| Bit            |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit3<br>TCON.3 | IE1 | IO Interrupt 1 edge flag. If IO Interrupt 1 is configured to be edge-sensitive (IT1 is set bit), IE1 is set bit when a 1-to-0 transition is detected on the input signal on the pin INT1, but automatically cleared when the processor vectors to execute the corresponding interrupt service routine located at program address 0x0013 ("Interrupt Resources"). In edge-sensitive mode, IE1 also can be cleared by program.  If IO Interrupt 1 is configured to be level-sensitive (IT1 is cleared), IE1 is set bit when the level on the pin INT1 is low, but cleared when the level on the pin INT1 is high. In level-sensitive mode, the program cannot write of IE1.     |  |  |  |  |
| Bit2<br>TCON.2 | IT1 | IO Interrupt 1 signal type control bit. When IT1 is set bit, IO Interrupt 1 is triggered when a 1-to-0 transition of the input signal is detected on the pin INT1. When IT1 is cleared, IO Interrupt 1 is triggered when a low level input signal is detected on the pin INT1.                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| Bit1<br>TCON.1 | IE0 | IO Interrupt 0 edge flag. If IO Interrupt 0 is configured to be edge-sensitive (IT0 is set to 1), IE0 is set bit when a 1-to-0 transition is detected on the input signal on the pin INT0, but is automatically cleared when the processor vectors to execute the corresponding interrupt service routine located at program address 0x0003 ("Interrupt Resources"). In edge-sensitive mode, IE0 also can be cleared by program.  If IO Interrupt 0 is configured to be level-sensitive (IT0 is cleared), IE0 is set bit when the level on the pin INT0 is low, but cleared when the level on the pin INT0 is high. In level-sensitive mode, the program cannot write of IE0. |  |  |  |  |
| Bit0<br>TCON.0 | IT0 | IO Interrupt 0 signal type control bit. When IT0 is set bit, IO Interrupt 0 is triggered when a 1-to-0 transition of the input signal is detected on the pin INT0. When IT0 is cleared, IO Interrupt 0 is triggered when a low level input signal is detected on the pin INT0.                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |

# 12.1.2.2.1. Timer0/1, Mode 0

In Mode 0, Timer0 and Timer1 act as a 13-bit timer/counter. In this mode, the lower byte of Timer0/Timer1 (TLx, SFR 0x8A or SFR 0x8B) counts from 0 to 31. When it increments from 31, TLx SFR  $(x=0\sim1)$  is cleared, and the higher byte of the timer (THx, SFR 0x8C or SFR 0x8D) increments by 1. In this mode, only 13 bits of Timer0/Timer1, Bit0 $\sim$ Bit4 of TLx SFR and all 8 bits of THx SFR, are active. The upper three bits of TLx SFR are indeterminate in Mode 0 and must be masked when the software evaluates the register.

Users can configure the bit (TR0 or TR1, Bit4 or Bit6 of TCON SFR) to run Timer0 or Timer1. In the AL6111A, according to the value of the bit C/T (Bit6 or Bit2 of TMOD SFR), Timer0 or Timer1 can act as a timer or a counter.

When the bit GATE (Bit7 or Bit3 of TMOD SFR) is cleared or set bit, and the input signal on the pin INT0 or INT1 is active, Timer0 or Timer1 runs when TRx ( $x=0\sim1$ , TCON.4 or TCON.6) is set bit.

When the 13-bit timer increments from 0x1FFF, it rolls over to all zeros, and then the bit TFO (TCON.5)



### Low-power Multifunctional Energy Metering SoC

or TF1 (TCON.7) is set bit, and an interrupt is generated to MCU.

### 12.1.2.2.2. Timer0/1, Mode 1

In Mode 1, Timer0 and Timer1 act as 16-bit timers/counters. In this mode, all eight bits of the lower byte of the timers, TL0 (SFR 0x8A) or TL1 (SFR 0x8B), are active, so, TLx SFR increments from 0 to 255. When the TLx SFR increments from 255, it is cleared, and the higher byte of the timer, THx SFR (TH0 SFR or TH1 SFR), increments by 1. The timer will roll over to all zeros when the timer/counter increments from 0xFFFF.



Figure 12-7 Timer 0/1, Mode 0/1

# 12.1.2.2.3. Timer0/1, Mode 2

In Mode 2, only the lower byte of Timer0/Timer1 (TLx SFR,  $x=0\sim1$ ) acts as an 8-bit timer/counter, while the higher byte of it (THx SFR,  $x=0\sim1$ ) holds a value that will be loaded into TLx SFR every time TLx SFR overflows. When the value is loaded into the TLx SFR, the timer will increment from the loaded value.

For example, TH1 SFR is set to 200, and when TL1 SFR increments from 255, it rolls to 200, and recounts from 200 to 255, and then to 200, and repeats.

# Low-power Multifunctional Energy Metering SoC



Figure 12-8 Timer 0/1, Mode 2

### 12.1.2.2.4. Timer0/1, Mode 3

In Mode 3, Timer0 becomes two completely separate 8-bit timers/counters. When Timer0 is set to work in this mode, TR0 (TCON.4) and TF0 (TCON.5) are used by TL0 SFR, but TR1 (TCON.6) and TF1 (TCON.7) are used by TH0 SFR, so Timer1 stops running as a general timer but still can be used as a baud rate generator.

When Timer0 works in Mode3, Timer1 still can be enabled via configuring its operation mode to Mode 0/1/2, but no interrupt will be generated by it, because the flag TF1 is used by Timer0. When Timer1 is configured to work in Mode 3, it stops running, but holds its counts.

# Low-power Multifunctional Energy Metering SoC



Figure 12-9 Timer 0, Mode 3

### 12.1.2.3. Timer2

Besides Timer0 and Timer1, there is a third timer, Timer2, in 8052 microcontroller, a 16-bit timer, has a number of new functions. The modes for Timer2 are:

- 16-bit timer/counter.
- 16-bit timer/counter in capture mode.
- 16-bit timer/counter in auto-reload mode.

The SFRs associated with Timer 2 are:

- T2CON (SFR 0xC8).
- TL2 (SFR 0xCC) Lower byte of Timer2.
- TH2 (SFR 0xCD) Higher byte of Timer2.
- RCAP2L (SFR 0xCA) To capture the value of TL2 SFR when Timer 2 is configured in capture mode,
   or, to hold the lower byte of the loaded value when Timer 2 is configured in auto-reload mode.
- RCAP2H (SFR 0xCB) -To capture the value of TH2 SFR when Timer 2 is configured in capture mode, or, to hold the higher byte of the loaded value when Timer 2 is configured in auto-reload mode.

# **Low-power Multifunctional Energy Metering SoC**

Table 12-8 Timer2 Control Special Function Register (T2CON, SFR 0xC8)

| Bit             |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit7<br>T2CON.7 | TF2    | Timer2 overflow flag.  The bit TF2 is set bit when Timer2 overflows from FFFFh. TF2 must be cleared by the program. Only when both RCLK and TCLK are cleared, TF2 will be set bit. Writing 1 to TF2 can force the Timer2 interrupt if it is enabled.                                                                                                                                                                                                                                       |
| Bit6<br>T2CON.6 | EXF2   | Timer2 external interrupt flag.  When EXEN2 is set bit, EXF2 will be set bit when a 1-to-0 transition of the input signal on the pin T2EX is detected, which can trigger an auto-reload or capture event. EXF2 must be cleared by the program. Writing 1 to EXF2 can force the Timer 2 external interrupt if it is enabled.                                                                                                                                                                |
| Bit5<br>T2CON.5 | RCLK   | Reserved.  By default it is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit4<br>T2CON.4 | TCLK   | Reserved.  By default it is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit3<br>T2CON.3 | EXEN2  | Timer2 external interrupt enable bit.  When EXEN2 is set bit, an auto-reload or capture event will be triggered when a 1-to-0 transition of the input signal on the pin T2EX is detected. When EXEN2 is cleared, no interrupt will be generated whatever the input signal on the pin T2EX is.                                                                                                                                                                                              |
| Bit2<br>T2CON.2 | TR2    | Timer2 run control flag.  1: Timer2 runs. 0: Timer2 stops.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit1<br>T2CON.1 | C/T2   | Timer or counter select bit. When C/T2 is cleared, Timer2 acts as a timer to count the clock pulses (clk or clk/12, depending on the bit T2M, CKCON.5). When C/T2 is set bit, Timer2 acts as a counter driven by the input signal on the pin T2 and counts the 1-to-0 transitions of the input signals.                                                                                                                                                                                    |
| Bit0<br>T2CON.0 | CP/RL2 | Capture/reload flag.  When CP/RL2 and EXEN2 are set bit, the current counts will be captured into the registers RCAP2L SFR and RCAP2H SFR when a 1-to-0 transition of the input signal on the pin T2EX is detected. When CP/RL2 is cleared, but EXEN2 is set bit, an auto-reload event will occur when a 1-to-0 transition of the input signal on the pin T2EX is detected. If either RCLK or TCLK is set bit, CP/RL2 cannot work, and Timer2 can operate in auto-reload mode on overflow. |

# Low-power Multifunctional Energy Metering SoC

Table 12-9 Timer 2 Mode

| RCLK | TCLK | CP/RL2 | TR2 | Mode                                      |
|------|------|--------|-----|-------------------------------------------|
| 0    | 0    | 1      | 1   | 16-bit timer/counter in capture mode.     |
| 0    | 0    | 0      | 1   | 16-bit timer/counter in auto-reload mode. |
| 1    | х    | x      | 1   | Reserved.                                 |
| Х    | 1    | x      | 1   | Reserved.                                 |
| Х    | Х    | Х      | 0   | Stop working                              |

### 12.1.2.3.1. Timer2, 16-Bit Timer/Counter Mode

In this mode, users can configure the register T2CON SFR to enable Timer2 to act as a 16-bit timer or a 16-bit counter (C/T2, T2CON.1), and to enable Timer2 to run (TR2, T2CON.2). In this mode, Timer2 increments from 0000h to FFFFh, and then rolls over to all zeros, setting the flag TF2 (T2CON.7) to 1, which generate an interrupt to MCU.

### 12.1.2.3.2. Timer2, 16-Bit Timer/Counter in Capture Mode

When CP/RL2 (T2CON.0) and EXEN2 (T2CON.3) are set bit, the values of TH2 SFR and TL2 SFR are captured and loaded into the registers RCAP2L SFR and RCAP2H SFR when a 1-to-0 transition of the input signal on the pin T2EX is detected. At the same time, the flag EXF2 (T2CON.6) is set bit, which will generate an interrupt to the processor if it is enabled.



Figure 12-10 Timer2, 16-bit Timer/ Counter in Capture Mode

### Low-power Multifunctional Energy Metering SoC

### 12.1.2.3.3. Timer2, 16-Bit Timer/Counter in Auto-Reload Mode

When CP/RL2 (T2CON.0) is cleared, Timer2 acts as a 16-bit counter/timer in auto-reload mode.

In this mode, the MCU must write the reload value to the registers RCAP2L (SFR 0xCA) and RCAP2H (SFR 0xCB). When the timer increments from FFFFh, the value stored in RCAP2L will be reloaded into the register TL2 (SFR 0xCC), and the value stored in RCAP2H will be reloaded into the register TH2 (SFR 0xCD), at the same time, TF2 is set bit, which will generate an interrupt to the processor if it is enabled.

When CP/RL2 is cleared, but EXEN2 (T2CON.3) is set bit, an auto-reload event occurs when a 1-to-0 transition of the input signal on the pin T2EX is detected, at the same time, the flag EXF2 (T2CON.6) is set bit, which will generate an external interrupt to the processor if it is enabled.



Figure 12-11 Timer2, 16-Bit Timer/Counter in Auto-Reload Mode

# 12.2. UART

In AL6111A, there are 4 active UART serial interfaces on the chip, including UART1 of 8052 microcontroller and the extended UART2, UART4 and UART5 serial interfaces. Bits UART2, UART4 and UART5 (bit4, bit6 and bit7 of PRCtrl1, 0x2D01) gate controls the corresponding UART serial interfaces.

The UART serial interfaces can work in 4 modes. In Mode 0, the serial interface can only receive data on the RXD port and output shifting clock on the TXD port. In other modes, the extended UART serial interfaces can work like UART1 serial interfaces of 8052 microcontroller.

It is recommended to use extended UART interfaces for serial communication.

### 12.2.1. UART1

UART1 uses Timer1 to generate baud rate, and the bit SMOD1 (EICON.7) controls doubling the baud rate of UART1.

# Low-power Multifunctional Energy Metering SoC

The SFRs associated with UART1 are:

- SCON1 (SFR 0xC0) UART1 Control Register.
- SBUF1 (SFR 0xC1) UART1 Buffer Register.

### Table 12-10 UART1 Control Special Function Register (SCON1, SFR 0xC0)

| Bit             |       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|-----------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit7<br>SCON1.7 | SM0_1 | To determine the mode for UART1.                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|                 |       | SM0_1 SM1_1 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|                 |       | 0 0: 8-bit shift register; baud rate=clk or clk/12.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| Bit6<br>SCON1.6 | SM1_1 | 0 1 1: 8-bit UART; baud rate, determined by Timer1.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                 |       | 1 0 2: 9-bit UART; baud rate = clk/32 or clk/64.                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|                 |       | 1 1 3: 9-bit UART; baud rate, determined by Timer1.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| Bit5<br>SCON1.5 | SM2_1 | Multiprocessor communication enable bit. In Mode2 and Mode3, SM2_1 enables the multiprocessor communication. In Mode2 and Mode3, when SM2_1 is set bit, RI_1 cannot be set bit in case that the received 9 <sup>th</sup> bit is 0. In Mode1, when SM2_1 is set bit, RI_1 will be set bit only if a valid stop bit is received. In Mode0, SM2_1 establishes the baud rate: when SM2_1 is cleared, the baud rate is clk/12; when SM2_1 is set to 1, the baud rate is clk. |  |  |  |
| Bit4            |       | Receive enable bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| SCON1.4         | REN_1 | When REN_1 is set bit, data reception is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Bit3            |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| SCON1.3         | TB8_1 | To define the 9 <sup>th</sup> bit to be transmitted in Mode2 or Mode3.                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| Bit2            |       | In Mode2 and Mode3, RB8_1 is to store the received 9 <sup>th</sup> bit. In Mode1, the stop bit is                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| SCON1.2         | RB8_1 | stored as the RB8_1. In Mode0, RB8_1 is not used.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Bit1<br>SCON1.1 | TI_1  | Transmit interrupt flag. If this bit is set bit, it indicates that the transmit data has been shifted out. In ModeO, TI_1 is set bit at the end of the 8 <sup>th</sup> bit. In other modes, TI_1 is set bit when the stop bit is placed on the pin TXD1. TI_1 must be cleared by the program.                                                                                                                                                                           |  |  |  |
| Bit0<br>SCON1.0 | RI_1  | Receive interrupt flag. If this bit is set bit, it indicates that a serial data has been received. In Mode 0, RI_1 is set bit at the end of the 8 <sup>th</sup> data bit. In Mode1, according to the state of SM2_1, RI_1 is set bit after the last sample of the incoming stop bit. In Mode2 and Mode3, RI_1 is set bit at the end of the last sample of the 9 <sup>th</sup> bit. RI_1 must be cleared by the program.                                                 |  |  |  |

### Low-power Multifunctional Energy Metering SoC

### 12.2.2. Extended UART Serial Interfaces

All the extended UART serial interfaces have the same architecture, but only UART2 has an optional 38 kHz carrier wave modulator.

In each extended UART serial interface, there are a general timer (compatible with Timer0) and a baud rate generator (compatible with Timer1). The overflow of general timer can set a flag bit which will be cleared by executing interrupt service routine (ISR) or by polling interrupt sources, and generate an interrupt to the MCU. When the baud rate generator is used as a general timer, it can set the related overflow flag to 1, but cannot generate an overflow interrupt. As an extended peripheral, there is a specific control/status register for each UART interface, which can control the baud rate, select the clock sources for the timers, disable or enable the timers, and show the overflow state of the timers.

### **12.2.2.1.** Registers

Table 12-11 Extended UART Serial Interfaces Registers

| 0x2820, R/W | TCON2, UART2 Control / Status Register            |
|-------------|---------------------------------------------------|
| 0x2821, R/W | TMOD2, UART2 Timers Mode Control Register         |
| 0x2822, R/W | TH20, Higher Byte of General Timer of UART2       |
| 0x2823, R/W | TH21, Higher Byte of Baud Rate Generator of UART2 |
| 0x2824, R/W | TL20, Lower Byte of General Timer of UART2        |
| 0x2825, R/W | TL21, Lower Byte of Baud Rate Generator of UART2  |
| 0x2826, R/W | SCON2, UART2 Control Register                     |
| 0x2827, R/W | SBUF2, UART2 Buffer Register                      |
| 0x2830, R/W | TCON4, UART4 Control / Status Register            |
| 0x2831, R/W | TMOD4, UART4 Timers Mode Control Register         |
| 0x2832, R/W | TH40, Higher Byte of General Timer of UART4       |
| 0x2833, R/W | TH41, Higher Byte of Baud Rate Generator of UART4 |
| 0x2834, R/W | TL40, Lower Byte of General Timer of UART4        |
| 0x2835, R/W | TL41, Lower Byte of Baud Rate Generator of UART4  |
| 0x2836, R/W | SCON4, UART4 Control Register                     |

# December Multifunctional Energy Metering SoC Ox2837, R/W SBUF4, UART4 Buffer Register TCON5, UART5 Control / Status Register TMOD5, UART5 Timers Mode Control Register TH50, Higher Byte of General Timer of UART5

TH51, Higher Byte of Baud Rate Generator of UART5

TL51, Lower Byte of Baud Rate Generator of UART5

TL50, Lower Byte of General Timer of UART5

**AL6111A Datasheet** 

# Table 12-12 UARTx Control/Status Register (TCON2/TCON4/TCON5)

SBUF5, UART5 Buffer Register

SCON5, UART5 Control Register

| Bit  |          | Default | Description                                                                                                                                                                                  |
|------|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit7 | SMOD     | 0       | When this bit is set to 1, the baud rate of UARTx is doubled.                                                                                                                                |
| Bit6 | Reserved |         |                                                                                                                                                                                              |
| Bit5 | T1M      | 0       | To select the clock source for the baud rate generator. 0: clk/12; 1: clk.                                                                                                                   |
| Bit4 | ТОМ      | 0       | To select the clock source for the general timer. 0: clk/12; 1: clk.                                                                                                                         |
| Bit3 | TF1      | 0       | Overflow flag of the baud rate generator.  When an overflow occurs to the baud rate generator, this bit will be set bit, but no overflow interrupt will be generated.                        |
| Bit2 | TF0      | 0       | Overflow flag of the general timer.  When an overflow occurs to the general timer, this bit will be set bit, and an overflow interrupt will be generated to MCU if the interrupt is enabled. |
| Bit1 | TR1      | 0       | Baud rate generator run control bit. 1: to run; 0: to stop.                                                                                                                                  |
| Bit0 | TR0      | 0       | General timer run control bit. 1: to run; 0: to stop.                                                                                                                                        |

#### Table 12-13 UARTx Timers Mode Control Register (TMOD2/TMOD4/TMOD5)

| Bit             |       | Description                                                                                                                    |
|-----------------|-------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit7<br>TMOD2.7 | GATE1 | This bit must be cleared for proper operation. In this case, the baud rate generator runs when TR1 (Bit1 of TCONx) is set bit. |



0x283B, R/W

0x283C, R/W

0x283D, R/W

0x283E, R/W

0x283F, R/W

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Bit             |       | Description                                                                                                                                             |  |  |  |  |
|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit6<br>TMOD2.6 | C/T1  | This bit must be cleared for proper operation. In this case, the clock source for the baud rate generator is determined by the bit T1M (bit5 of TCONx). |  |  |  |  |
| Bit5<br>TMOD2.5 | T1M1  | To select the mode for the baud rate generator.  T1M1 T1M0 Mode                                                                                         |  |  |  |  |
|                 |       | 0 0 Mode0: 13-bit timer.                                                                                                                                |  |  |  |  |
| Bit4            | T1M0  | 0 1 Mode1: 16-bit timer.                                                                                                                                |  |  |  |  |
| TMOD2.4         | 11110 | 1 0 Mode2: 8-bit timer in auto-reload mode.                                                                                                             |  |  |  |  |
|                 |       | 1 1 Mode3: Split timer mode.                                                                                                                            |  |  |  |  |
| Bit3<br>TMOD2.3 | GATE0 | This bit must be cleared for proper operation. In this case, the general timer runs when TRO (BitO of TCONx) is set bit.                                |  |  |  |  |
| Bit2<br>TMOD2.2 | C/T0  | This bit must be cleared for proper operation. In this case, the clock source for the baud rate generator is determined by the bit TOM (bit4 of TCONx). |  |  |  |  |
| Bit1            |       | To select the mode for the general timer.                                                                                                               |  |  |  |  |
| TMOD2.1         | T0M1  | T0M1 T0M0 Mode                                                                                                                                          |  |  |  |  |
| TMOD2.1         |       | 0 0 Mode0: 13-bit timer.                                                                                                                                |  |  |  |  |
| D:FO            |       | 0 1 Mode1: 16-bit timer.                                                                                                                                |  |  |  |  |
| Bit0            | ТОМО  | 1 0 Mode2: 8-bit timer in auto-reload mode.                                                                                                             |  |  |  |  |
| TMOD2.0         |       | 1 1 Mode3: Split timer mode.                                                                                                                            |  |  |  |  |

#### Table 12-14 UARTx Control Register (SCON2/SCON4/SCON5)

| Bit     |      | Descr  | Description                   |                                                                      |  |  |  |  |
|---------|------|--------|-------------------------------|----------------------------------------------------------------------|--|--|--|--|
| Bit7    | 2112 | To sel | To select the mode for UARTx. |                                                                      |  |  |  |  |
| SCON2.7 | SM0  | SM0    | SM1                           | Mode                                                                 |  |  |  |  |
|         |      | 0      | 0                             | Mode0: 8-bit shift register; baud rate =clk or clk/12.               |  |  |  |  |
| Bit6    |      | 0      | 1                             | Mode1: 8-bit UART; baud rate, determined by the baud rate generator. |  |  |  |  |
| SCON2.6 | SM1  | 1      | 0                             | Mode2: 9-bit UART; baud rate =clk/32 or clk/64.                      |  |  |  |  |
|         |      | 1      | 1                             | Mode3: 9-bit UART; baud rate, determined by the baud rate generator. |  |  |  |  |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Bit             |       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|-----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit5<br>SCON2.5 | SM2   | Multiprocessor communication enable bit. In Mode2 and Mode3, SM2 enables the multiprocessor communication. In Mode2 or Mode3, when SM2 is set bit, RI cannot be set bit in case that the received 9 <sup>th</sup> bit is 0. In Mode1, when SM2 is set bit, RI will be set bit only if a valid stop bit is received. In Mode0, SM2 determines the baud rate: when SM2 is cleared, the baud rate is clk/12; when SM2 is set bit, the baud rate is clk. |  |  |  |  |
| Bit4            | REN   | Receive enable bit.                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| SCON2.4         | IXLIN | When REN is set bit, data reception is enabled.                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| Bit3<br>SCON2.3 | TB8   | To define the 9 <sup>th</sup> bit transmitted in Mode2 and Mode3.                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| Bit2<br>SCON2.2 | RB8   | In Mode2 and Mode3, RB8 stores the received 9 <sup>th</sup> bit. In Mode 1, RB8 stores the received stop bit. In Mode0, RB8 is not used.                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| Bit1<br>SCON2.1 | TI    | Transmit interrupt flag. If this flag is set bit, it indicates that the transmit data has been shifted out. In Mode0, TI is set bit at the end of the 8 <sup>th</sup> bit. In other modes, TI is set bit when the stop bit is placed on the pin TXD2. TI must be cleared by the program.                                                                                                                                                             |  |  |  |  |
| Bit0<br>SCON2.0 | RI    | Receive interrupt flag. If this flag is set bit, it indicates that a serial data has been received. In Mode0, RI is set bit at the end of the 8 <sup>th</sup> bit. In Mode1, according to the state of SM2, RI is set bit after the last sample of the incoming stop bit. In Mode2 and Mode3, RI is set bit at the end of the last sample of the 9 <sup>th</sup> bit. RI must be cleared by the program.                                             |  |  |  |  |

#### Table 12-15 UARTx Buffer Register (SBUF2/SBUF4/SBUF5)

|          | Table 11 15 Chiki A Barrel Register (SBC) 1/SBC 1/SBC 5/ |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|----------|----------------------------------------------------------|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Register | R/W                                                      | Bit      | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| SBUFx    | R/W                                                      | Bit[7:0] | 0       | SBUFx is physically two registers. One is written only and is used to hold data to be transmitted out of the MCU via the pin TXD2. The other is read only and is used to hold received data from external sources via the pin RXD2. Both mutually exclusive registers use one address. When UARTx works in the asynchronous and full-duplex communication mode, it can be used for "read" and "write" simultaneously. |  |  |  |

# 12.2.2.2. Carrier Wave Modulation on UART2

UART2 has a 38 kHz carrier wave modulator controlled by TXD2 Type Register (Txd2FS). When bit TXD2CARRY (bit0 of Txd2FS, 0x28CF) is cleared, pin TXD2 will output modulated signals. Users can write of the carrier wave generation registers to configure the carrier wave frequency and its duty cycle:



Equation 12-1

# Low-power Multifunctional Energy Metering SoC

$$f_{CARR} = \frac{f_{MCU}}{CARRH + CARRL}$$

$$Duty_{CARR} = \frac{CARRH}{CARRL}$$
 Equation 12-2

where,  $f_{CARR}$  is the carrier wave frequency;  $f_{MCU}$  is MCU clock frequency;  $Duty_{CARR}$  is the duty cycle of the carrier wave; CARRH is the value of registers CARRHH and CARRHL; CARRL is the value of registers CARRHH and CARRLL.

When the level on the pin TXD2 is low, the modulated signal is output.

#### Table 12-16 TXD2 Type Register (Txd2FS, 0x28CF)

| 0x28CF, R/W, TXD2 Type Register, Txd2FS |           |         |                                                              |  |
|-----------------------------------------|-----------|---------|--------------------------------------------------------------|--|
| Bit                                     |           | Default | Description                                                  |  |
| Bit[7:1]                                | Reserved  | X       |                                                              |  |
| Bit0                                    | TXD2CARRY | 0       | 0: with 38 kHz carrier wave; 1: without 38 kHz carrier wave. |  |

#### **Table 12-17 Carrier Wave Generation Registers**

| Register |        | Description                                                                                | R/W | Bit      | Default |
|----------|--------|--------------------------------------------------------------------------------------------|-----|----------|---------|
| 0x2898   | CARRHH | Higher byte of Carrier Wave Generation Register 1: Duty Cycle Control, High Pulse Duration | R/W | Bit[7:0] | 0       |
| 0x2899   | CARRHL | Lower byte of Carrier Wave Generation Register 1: Duty Cycle Control, High Pulse Duration  | R/W | Bit[7:0] | 0       |
| 0x289A   | CARRLH | Higher Byte of Carrier Wave Generation Register 2: Duty Cycle Control, Low Pulse Duration  | R/W | Bit[7:0] | 0       |
| 0x289B   | CARRLL | Lower Byte of Carrier Wave Generation Register 2: Duty Cycle Control, Low Pulse Duration   | R/W | Bit[7:0] | 0       |

#### 12.2.2.3. UART Modes

The UART serial interfaces can work in 4 modes via configuring the mode select bits, for example, SM1 and SM2 of the register SCON2 (0x2826).

#### Table 12-18 UART Modes

| Мо | Mode Sync. Async     |       | Baud rate     | Data  | Start or Stop Bit | The 9 <sup>th</sup> Bit |
|----|----------------------|-------|---------------|-------|-------------------|-------------------------|
| 0  | 8-bit shift register | Sync. | clk or clk/12 | 8-bit | None              | None                    |

|   |            |        |                                   |        | ALUIIIA D       | acasiicce  |
|---|------------|--------|-----------------------------------|--------|-----------------|------------|
|   |            | Low    | -power Multifunc                  | tional | Energy Met      | ering SoC  |
| 1 | 8-bit UART | Async. | Determined by baud rate generator | 8-bit  | 1 start, 1 stop | None       |
| 2 | 9-bit UART | Async. | clk/32 or clk/64                  | 9-bit  | 1 start, 1 stop | Parity bit |
| 3 | 9-bit UART | Async. | Determined by baud rate generator | 9-bit  | 1 start, 1 stop | Parity bit |

All the UART serial interfaces have the same architecture and functions except that:

- Only UART2 has 38kHz carrier wave with its TXD.
- UART1 uses Timer1 as its baud rate generator.

So take UART2 for an example to introduce the work modes for UART serial interfaces.

#### 12.2.2.3.1. Mode0

In Mode0, UART2 receives data on the pin RXD2, and outputs shift clock on the pin TXD2. Data can be received as soon as the bit REN (bit4 of SCON2, 0x2826) is set bit and the bit RI (bit0 of SCON2, 0x2826) is cleared. The shift clock is activated and the UART shifts data in on each rising edge of the shift clock until eight bits have been received. The 8<sup>th</sup> bit was shifted in, and one machine cycle later, the bit RI is set bit and the reception stops until the bit RI is cleared by the program.

#### 12.2.2.3.2. Mode1

Mode1 provides standard asynchronous and full-duplex communication. In this mode, a data frame contains ten bits: one start bit, eight bits of data, and one stop bit. When a data frame is received, the stop bit is stored in the bit RB8 (bit2 of SCON2, 0x2826). On receive and transmit operation, start with the LSB.

In Mode1, the baud rate is determined by the baud rate generator overflow frequency. UART2 uses a dedicated baud rate generator, which is compatible with Timer 1. When the baud rate generator overflows, it generates a clock which is then divided by 16 to generate the baud rate.

BaudRate= 
$$\frac{2^{SMODx}}{32} \times Overflow$$
 Equation 12-3

Where,

Overflow is the baud rate generator overflow frequency. As for UART1, Timer1 is the baud rate generator; as for the extended UART serial interfaces, the specific baud rate generator is used. SMODx, the value of the bit SMOD0/1, determines to double the baud rate or not.

Generally, the baud rate generator works in the mode of 8-bit timer with auto-reload. The reload value is stored in the register TH21 (0x2823), which makes the above equation for baud rate (clk/12 is used as the clock source):



# Low-power Multifunctional Energy Metering SoC

BaudRate = 
$$\frac{2^{\text{SMODx}}}{32} \times \frac{\text{clk}}{12 \times (256 - \text{TH21})}$$
 Equation 12-4

where, clk is the MCU clock, and TH21 is the reload value of the register TH21 (0x2823).

The bit T1M (TCON2.5) determines the clock source for the baud rate generator of UART2. When T1M is set bit, clk is used as the clock source:

BaudRate = 
$$\frac{2^{\text{SMODx}}}{32} \times \frac{\text{clk}}{(256 - \text{TH}21)}$$
 Equation 12-5

Users can obtain the value of TH21 via the equation:

TH21 = 256 - 
$$\frac{2^{\text{SMODx}} \times \text{clk}}{32 \times \text{BaudRate}}$$
 Equation 12-6

When T1M is cleared, and the baud rate is known, users can obtain the value of TH21 via the following equation:

$$TH21 = 256 - \frac{2^{SMODx} \times clk}{384 \times BaudRate}$$
 Equation 12-7

In Mode1, UART2 begins to transmit data after the program writing data into the register SBUF2 (0x2827). UART2 transmits data on the pin TXD2 in the following order: start bit, eight data bits (LSB first), stop bit. The bit TI (bit1 of SCON2, 0x2826) will be set bit two clock cycles after the stop bit is transmitted.

In Mode1, UART2 starts to receive data at the falling edge of a start bit received on the pin RXD2, when REN (bit4 of SCON2, 0x2826) is set bit. To achieve this, every bit on the pin RXD2 should be sampled sixteen times at any baud rate. When a falling edge of a start bit is detected, the timer used to generate the receive clock is reset to synchronize with the received bits. To reject noise, the serial port detects the values of the three consecutive samples in the middle of each bit. Only more than two same values can decide the received data bit to be valid. This is especially true for the start bit. If the falling edge on the pin RXD2 is not verified by a majority decision of three consecutive samples, then the serial port stops receiving data and waits for another falling edge on RXD2.

When RI (bit0 of SCON2, 0x2826) is cleared, SM2 (bit5 of SCON2, 0x2826) is set bit, and the stop bit is 1 (if SM2 is cleared, the state of stop bit does not matter), the serial port will write the received byte to the register SBUF2 (0x2827), load the stop bit into RB8 (bit2 of SCON2, 0x2826), and set the bit RI to 1. Otherwise, the received data lose; they cannot load data into the register SBUF2 and the bit RB8; and the bit RI cannot be set bit.

#### 12.2.2.3.3. Mode2

Mode2 provides asynchronous and full-duplex communication. In this mode, the data frame contains eleven bits: one start bit, eight data bits, one programmable 9<sup>th</sup> bit, and one stop bit.

When data bits are received or transmitted, start with LSB. As to the transmitting operation, the 9<sup>th</sup> bit is determined by the value of the bit TB8 (bit3 of SCON2, 0x2826). If the 9<sup>th</sup> bit is used as a parity bit, the value of the P bit (Bit 0 of PSW SFR) should be moved to TB8.

# Low-power Multifunctional Energy Metering SoC

In Mode2, the baud rate is either clk/32 or clk/64, determined by the bit SMOD (Bit7 of TCON2, 0x2820). It can be calculated as follows:

BaudRate= 
$$\frac{2^{SMODx} \times clk}{64}$$
 Equation 12-8

In Mode2, UART2 starts transmitting data after the software writing data into the register SBUF2 (0x2827). UART2 transmits data on the pin TXD2 in the following order: the start bit, eight data bits (LSB first), the 9<sup>th</sup> bit, then the stop bit. The bit TI (bit1 of SCON2, 0x2826) is set bit when the stop bit has been transmitted.

In Mode2, receiving data begins at the falling edge of a start bit received on the pin RXD2, when the bit REN=1 (bit4 of SCON2, 0x2826). To achieve it, every bit on the pin RXD2 should be sampled sixteen times at any baud rate. When a falling edge of a start bit is detected, the timer used to generate the receive clock is reset to synchronize with the received bits. To reject noise, the serial port detects the values of the three consecutive samples in the middle of every bit. Only more than two same values can decide the received data bit to be valid. This is especially true for the start bit. If the falling edge on the pin RXD2 is not verified by a majority decision of three consecutive samples, then the serial port stops receiving data and waits for another falling edge on RXD2.

When RI (bit0 of SCON2) is cleared, SM2 (bit5 of SCON2) is set bit, and the stop bit is 1 (if SM2 is cleared, the state of stop bit does not matter), the serial port will write the received byte to the register SBUF2 (0x2827), load the stop bit into RB8 (bit2 of SCON2), and set the bit RI. Otherwise, the received data lose; they cannot load data into the register SBUF2 and the bit RB8; and the bit RI cannot be set bit.

#### 12.2.2.3.4. Mode3

Mode3 provides asynchronous and full-duplex communication. In this mode, the data frame contains eleven bits: one start bit, eight data bits, one programmable 9<sup>th</sup> bit, and one stop bit. When data bits are received and transmitted, start with LSB.

In Mode3, the data is transmitted or received in the same way that in Mode2. In Mode3, the baud rate generation is identical to that in Mode1. That is, Mode3 is a combination of the communication protocol in Mode2 and the baud rate generation in Mode1.

# 12.2.2.3.5. Multiprocessor Communication

The multiprocessor communication is enabled in Mode2 and Mode3 when the bit SM2 (bit5 of SCON2, 0x2826) is set bit. In the multiprocessor communication mode, the received 9<sup>th</sup> bit is stored in the bit RB8 (bit2 of SCON2, 0x2826), and, after the stop bit has been received, UART2 receive interrupt is activated if RB8 is set bit.

The multiprocessor communication is used to send a block of data from a master to one slave. The master first transmits an address byte that identifies the target slave. When transmitting an address byte, the master sets the 9<sup>th</sup> bit to 1; when transmitting data bytes, the master clears the 9<sup>th</sup> bit.

When SM2 is set bit, no slave can generate an interrupt when a data byte has been received. However,



# Low-power Multifunctional Energy Metering SoC

all slaves can generate interrupts when an address byte is received. Every slave can examine the received address byte to determine whether it is the slave being addressed. Address decoding must be done by the program during the interrupt service routine. The slave being addressed clears the bit SM2 and prepares to receive the data bytes. The slaves that are not being addressed leave the bit SM2 set and ignore the incoming data bytes.

# 13. General-Purpose Serial Interface (GPSI)

The AL6111A integrates a general-purpose serial interface (GPSI) that is compliant with I<sup>2</sup>C protocol. When bit GPSI (bit6 of PRCtrl0, 0x2D00) is set to 1, pins P9.1 and P9.2 work as the two wires of the general-purpose serial interface: P9.1 for serial data (SDA), and P9.2 for serial clock (SCL). When pins P9.1 and P9.2 is used for GPSI wires, P9.1 must be configured to "input enabled", but no mandatory requirement on output enable register of P9.1; and P9.2 is "output enabled" automatically.

# 13.1. Frame Structure



Figure 13-1 Frame Structure on SDA

As illustrated in Figure 13-1, a frame through the wire SDA is composed of some of the following parts.

- 1-bit START: a falling edge on SDA when SCL holds HIGH sets up a START condition. This bit must be sent by Master.
- 8-bit DATA byte: 1 bit DATA transferred on 1 SCL clock. A DATA bit is prepared on falling edge of each SCL clock, and sampled on rising edge of each SCL clock. The endian of byte transfer is defined by bit Endian (bit4 of SICFG, 0x2F01). 8-bit DATA byte must be followed by 1-bit ACK.
- 1-bit ACK: the ACK bit is prepared on falling edge of an SCL clock, and sampled on rising edge of an SCL clock. Only the ACK bit transferred by the receiver is valid. HIGH indicates not acknowledged;
   LOW indicates acknowledged. 1-bit ACK must be preceded by 8-bit DATA.
- 1-bit STOP or RESTART: to set up a STOP or RESTART condition, it is mandatory to generate a falling edge of the SCL clock, and then ensure a low level on SDA when SCL holds HIGH to set up a STOP condition, or a high level on SDA when SCL holds HIGH to set up a RESTART condition. Either bit must be sent by Master device.

Bit[3:0] of register SICFG (0x2F01) defines the structure of the frame to be transmitted or received.

# **Low-power Multifunctional Energy Metering SoC**

**Table 13-1 Description of Different Frame Structures** 

| # | START | DATA+ACK | STOP/RESTART | Description                                                                             |
|---|-------|----------|--------------|-----------------------------------------------------------------------------------------|
| 0 | 0     | 0        | 0            | Not valid.                                                                              |
| 1 | 0     | 0        | X            | To receive or transmit the starting frame.                                              |
| 2 | 0     | X        | 0            | Not valid.                                                                              |
| 3 | 0     | X        | X            | To receive or transmit START bit only.                                                  |
| 4 | X     | 0        | 0            | To receive or transmit the last frame composed of 8-bit DATA, 1-bit ACK and 1-bit STOP. |
| 5 | Х     | 0        | Х            | To receive or transmit 8-bit DATA and 1-bit ACK only.                                   |
| 6 | Х     | X        | 0            | To receive or transmit 1-bit STOP only.                                                 |
| 7 | Х     | X        | Х            | Not valid.                                                                              |

O: to receive or transmit; X: not to receive or transmit.

# 13.2. Serial Clock Generation

When a START condition is set up, the 16-bit timer embedded in the GPSI unit starts to count the MCU clock pulses to generate the serial clock ( $f_{SCL}$ ). The  $f_{SCL}$  is defined by the following equation:

$$f_{SCL} = \frac{f_{MCU}}{4 \times (TH + 1)}$$
 Equation 13-1

where  $f_{MCU}$  is the clock frequency for MCU operation; TH is the threshold preset in registers SITHH (0x2F03) and SITHL (0x2F02);  $f_{SCL}$  is the serial clock (SCL) frequency.

# 13.3. Receive and Transmit Data



Figure 13-2 Receive and Transmit Data

When the AL6111A communicate with other devices via GPSI, it transmits and receives data simultaneously.

The data on the wire SDA is in the format of Wire-AND, which means the data is the data from receiver and transmitter in "AND" logic, but not the state of either. The MCU can read the register SIDAT (0x2F04) and bit ACK (bit0 of SIFLG, 0x2F05) to acquire the data of the SDA. When GPSI is idle (BUSY, bit1 of SIFLG, 0x2F05, is cleared), writing of register SIDAT (0x2F04) triggers data receive and transmit.

When bit BUSY (bit1 of SIFLG, 0x2F05) is cleared, writing 0xFF or a specific data byte to be transmitted to register SIDAT (0x2F04) triggers data receive and transmit. Then bit BUSY is set to 1. After data transmit and receive, bit BUSY is cleared again, and read register SIDAT and bit ACK (bit0 of SIFLG, 0x2F05) to acquire the data from SDA.

# 13.4. GPSI Interrupt

When IE4=1 (bit4 of ExInt5IE, 0x28A5), EIE.3=1 (SFR 0xE8) and IE.7=1 (SFR 0xA8), a transmit interrupt will be triggered every time a frame (structure defined by register SICFG) is transmitted, and MCU will service the interrupt, read bit ACK, and prepares for the next frame transmission.

When IE5=1 (bit5 of ExInt5IE, 0x28A5), EIE.3=1 (SFR 0xE8) and IE.7=1 (SFR 0xA8), writing of registers located at addresses 0x2F01~0x2F04 when bit BUSY (bit1 of SIACK, 0x2F05) is set to 1, an illegal data interrupt will be triggered and the write operation is invalid.

SCL holds LOW on interrupt service.

# 13.5. For I<sup>2</sup>C Application

The GPSI is I<sup>2</sup>C compliant. When it is used for I<sup>2</sup>C application, the AL6111A works as Master device to communicate with other devices connected to the I<sup>2</sup>C bus. In this case, the starting frame is to select the

# Low-power Multifunctional Energy Metering SoC

target slave, of which bit[7:1] of 8-bit DATA is slave address byte, and bit0 is read/write control bit ("1" read; "0" write).



## Figure 13-3 Read Operation



Figure 13-4 Write Operation

Figure 13-3 and Figure 13-4 depict read and write operation on  $I^2C$  application when interrupt is enabled. For example, when the AL6111A writes or reads a slave device connected on  $I^2C$  bus via GPSI, it could be done following the procedure:

- 1. Write of registers SITHH/SITHL (0x2F03/0x2F02) to configure f<sub>SCL</sub>;
- 2. Write of register SICFG (0x2F01) to enable transmitting START, and clear bit Endian to 0;
- 3. Write anything to register SIDAT (0x2F04) to trigger to transmit START. During transmission, bit BUSY is set to 1;
- 4. When BUSY is cleared, write of register SICFG (0x2F01) to enable transmitting DATA and ACK; write 0x01 to register SIACK (0x2F05); and then write target slave address to bit[7:1] of register SIDAT (0x2F04) and write 1 (to read) or 0 (to write) to bit0 to trigger transmitting the slave address frame. During transmission, bit BUSY is set to 1;
- 5. When BUSY is cleared, read of register SIACK (0x2F05). If it is read out as 0, the target slave device is selected;
- Write of register SICFG (0x2F01) to enable transmitting DATA and ACK; write of 0x01 to register SIACK (0x2F05); and then write the content to be transmitted to register SIDAT (0x2F04) to trigger



# Low-power Multifunctional Energy Metering SoC

transmitting data frame. During transmission, bit BUSY is set to 1;

- 7. Repeat step 5 and 6 until all data have been transmitted;
- 8. Write of register SICFG (0x2F01) to enable transmitting STOP or RESTART;
- 9. Write anything to register SIDAT (0x2F04) to trigger transmitting bit STOP or RESTART.

The bit STOP ends a serial communication.

# 13.6. Registers

#### Table 13-2 Register to Disable or Enable GPSI

| 0x2D00, R/W, Peripheral Control Register 0, PRCtrl0 |      |                         |   |                                                                     |  |
|-----------------------------------------------------|------|-------------------------|---|---------------------------------------------------------------------|--|
| Bit                                                 |      | R/W Default Description |   | Description                                                         |  |
| Bit6                                                | GPSI | R/W                     | 0 | To enable or disable GPSI.  1: enable; 0: disable.                  |  |
| Bit4                                                | P9   | R/W                     | 0 | To enable or disable the fast IOs Group P9.  1: disable; 0: enable. |  |

#### Table 13-3 GPSI Control Register (SICFG, 0x2F01)

| 0x2F01,  | 0x2F01, R/W, GPSI Control Register, SICFG |     |         |                                                                                           |  |  |  |  |  |
|----------|-------------------------------------------|-----|---------|-------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit      |                                           | R/W | Default | Description                                                                               |  |  |  |  |  |
| Bit[7:5] | Reserved                                  | R/W | 0       |                                                                                           |  |  |  |  |  |
| Bit4     | Endian                                    | R/W | 0       | To configure the DATA endian for transmission and reception.  1: LSB first; 0: MSB first. |  |  |  |  |  |
| Bit3     | TXS                                       | R/W | 0       | Set this bit to 1 to enable receiving or transmitting START bit.                          |  |  |  |  |  |
| Bit2     | TXD                                       | R/W | 0       | Set this bit to 1 to enable receiving or transmitting 8-bit DATA byte and 1-bit ACK.      |  |  |  |  |  |
| Bit1     | TXP                                       | R/W | 0       | Set this bit to 1 to enable receiving or transmitting STOP bit.                           |  |  |  |  |  |
| Bit0     | TXRS                                      | R/W | 0       | Set this bit to 1 to enable receiving or transmitting RESTART bit.                        |  |  |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

Table 13-4 GPSI Timer Divider Registers (SITHH/SITHL, 0x2F03/0x2F02)

| Register | Register Bit |          | Bit      |     | Default | Description                                       |
|----------|--------------|----------|----------|-----|---------|---------------------------------------------------|
| 0x2F03   | SITHH        | Bit[7:0] | TH[15:8] | R/W | 0       | Set a threshold for serial clock (SCL)            |
|          |              |          |          |     |         | generation.                                       |
| 0x2F02   | SITHL        | Bit[7:0] | TH[7:0]  | R/W | 0       | $f_{SCL} = \frac{f_{MCU}}{4 \times (TH[15:0]+1)}$ |

#### Table 13-5 GPSI Data Register (SIDAT, 0x2F04)

| 0x2F04, R/W, GPSI Data Register, SIDAT |      |      |      |      |      |      |      |      |  |
|----------------------------------------|------|------|------|------|------|------|------|------|--|
|                                        | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |
| Endian=0                               | D0   | D1   | D2   | D3   | D4   | D5   | D6   | D7   |  |
| Endian=1                               | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   |  |

The content of this register is the 8-bit DATA byte received or to be transmitted. Writing of this register triggers receiving or transmitting data.

# Table 13-6 GPSI Communication Flag Register (SIFLG, 0x2F05)

| 0x2F05,  | R/W, GPSI ( | Commu | ınication f | Flag Register (SIFLG)                                                                                                                                                                                                                                                                                                                        |
|----------|-------------|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit      |             | R/W   | Default     | Description                                                                                                                                                                                                                                                                                                                                  |
| Bit[7:2] | Reserved    | R/W   | 0           |                                                                                                                                                                                                                                                                                                                                              |
| Bit1     | BUSY        | R     | 0           | When the interface is receiving or transmitting data, this bit is set to 1. In this case, writing of registers located at addresses $0x2F01\sim0x2F04$ will trigger illegal data interrupt when this interrupt is enabled.                                                                                                                   |
| Bit0     | ACK         | R/W   | 0           | When Master works as the receiver, writing of this bit and transmit it to acknowledge the transmitter or not.  When Master works as the transmitter, writing 1 to this bit to transmit it, and read this bit after the transmission to check whether the receiver acknowledge the transmitter or not.  1: not acknowledged. 0: acknowledged. |

# 14. LCD Driver

The AL6111A has an LCD driver which can drive an LCD panel of  $4\times24$  or  $6\times22$  segments (1/3 bias) or  $8\times20$  segments (1/3 bias or 1/4 bias). CLK3, sourced by the 32.768kHz OSC clock, provides the LCD driver with the clock pulse. The driver is powered by the regulated voltage output from the 3.3V LDO; the LCD bias generator composed of an internal resistor ladder generates the LCD waveform voltage; and the LCD waveform voltage level can be adjusted over the range of  $2.7\sim3.3V$  with a resolution of 0.1V/lsb.

When POR/BOR, RSTn pin reset, or WDT overflow reset occurs, the LCD driver is reset to its default state.



Figure 14-1 LCD Driver Block Diagram

# 14.1. Pins for LCD Driver

In the AL6111A, some pins are multiplexed by SEG/COM signal output, general-purpose input/output (GPIO) and analog input of M Channel or comparator CB.

When some bits of Table 14-11 are set to 1s, the corresponding pins are used for SEG output. In this condition, it is mandatory to configure the GPIO ports as "input disabled" and "output disabled" in corresponding input and output enable registers.

When the pins work as GPIO or analog input of M Channel or comparator CB, the corresponding bits of Table 14-11 must be cleared to disable SEG output.

# Low-power Multifunctional Energy Metering SoC

# 14.2. LCD Timing

In the AL6111A, the CLK3, sourced by the 32.768-kHz OSC clock, provides the LCD driver with clock pulse for timing generation. Generally, the crystal oscillator keeps on running until it is powered off, so the LCD driver keeps on working even in LPM1 state or LPM2 state unless CLK3 is disabled. When the crystal stops running anomaly when power is still on, the internal RC clock will become the replacement of the OSC clock to source the LCD driver until the crystal is stimulated to run again.

The CLK3 frequency is divided to generate frame frequency for the waveform. The MCU can configure bit[1:0] of LCDCtrl (0x2C1E) to select the appropriate frame frequency. By default it is 64Hz.

# 14.3. LCD Waveform Voltage

In the AL6111A, the LCD driver is powered by LDO33, and an internal resistor ladder is designed to generate LCD waveform voltage (VLCD). Users can adjust the waveform voltage via bits VLCD (bit2 of CtrlLCDV, 0x285E) and LDO3SEL<2:0> configurations.

$$VLCD = [VLCD] \times \frac{[LD03SEL < 2:0>]}{3.3}$$
 Equation 14-1

Where,

VLCD is the LCD waveform voltage;

[LDO3SEL<2:0>] is the output voltage of LDO33. [LDO3SEL<2:0>] is equal to configuration of bits LDO3SEL<2:0> (bit[5:3] of CtrlLDO, 0x2866);

[VLCD] is the configuration of bit VLCD (bit2 of CtrlLCDV, 0x285E).

Table 14-1 VLCD to Configuration of [LDO3SEL<2:0>] and [VLCD]

| [LDO3SEL<2:0>] | 3.5V | 3.4V | 3.3V | 3.2V | 3.1V | 3.0V |      |
|----------------|------|------|------|------|------|------|------|
|                | 3.3V | 3.5V | 3.4V | 3.3V | 3.2V | 3.1V | 3.0V |
| [VLCD]         | 3.0V | 3.2V | 3.1V | 3.0V | 2.9V | 2.8V | 2.7V |

Users can adjust the resistance value of each resistor in the resistor ladder of the bias voltage generation circuits via bits DRV1/DRV0 (bit[3:2] of LCDCtrl, 0x2C1E) to adjust the current through the circuits to change the lightness of the display panel. By default the resistance value is 300 k $\Omega$ .

# 14.4. Display RAM

In the AL6111A, the display RAM located at addresses of 0x2C00~0x2C1D and 0x2C28~0x2C31 stores the LCD data. When the SEG/COM driver is enabled (setting bit7 of LCDCtrl to 1), the LCD panel displays the data immediately they are updated in the RAM. When the SEG/COM driver is disabled (clearing bit7 of LCDCtrl), the LCD panel displays nothing. When POR/BOR, RSTn pin reset or WDT overflow event occurs,

# Low-power Multifunctional Energy Metering SoC

the SEG/COM driver will be reset and the RAM will be cleared.

The LCD driver supports LCD panel of 1/4 duty, 1/6 duty or 1/8 duty. When bits LCDTYPE (bit[5:4] of LCDCtrl, 0x2C1E) are cleared, an LCD panel of 1/4 Duty should be used. In this application, each byte of display RAM stores content of 2 LCD segments: lower 4 bits for Seg (n), and higher 4 bits for Seg (n+1).

Table 14-2 RAM Byte Allocation for Segments of LCD Panel of 1/4 Duty

|          |        |         | D7    | D6   | D5   | D4   | D3    | D2   | D1   | D0   |  |
|----------|--------|---------|-------|------|------|------|-------|------|------|------|--|
| Register |        | Segment | сомз  | COM2 | COM1 | СОМО | сомз  | COM2 | COM1 | СОМ0 |  |
| 0x2C00   | LCDM0  | S01 S00 |       | SE   | G01  |      |       | SEC  | G00  |      |  |
| 0x2C04   | LCDM4  | S09 S08 |       | SE   | G09  |      |       | SEC  | G08  |      |  |
| 0x2C05   | LCDM5  | S11 S10 |       | SE   | G11  |      |       | SEC  | G10  |      |  |
| 0x2C06   | LCDM6  | S13 S12 |       | SE   | G13  |      |       | SEC  | G12  |      |  |
| 0x2C07   | LCDM7  | S15 S14 |       | SE   | G15  |      | SEG14 |      |      |      |  |
| 0x2C09   | LCDM9  | S19 S18 |       | SE   | G19  |      | SEG18 |      |      |      |  |
| 0x2C0A   | LCDM10 | S21 S20 |       | SE   | G21  |      | SEG20 |      |      |      |  |
| 0x2C0B   | LCDM11 | S23 S22 |       | SE   | G23  |      | SEG22 |      |      |      |  |
| 0x2C0F   | LCDM15 | S31 S30 |       | SE   | G31  |      | SEG30 |      |      |      |  |
| 0x2C10   | LCDM16 | S33 S32 | SEG33 |      |      |      | SEG32 |      |      |      |  |
| 0x2C11   | LCDM17 | S35 S34 | SEG35 |      |      |      | SEG34 |      |      |      |  |
| 0x2C13   | LCDM19 | S39 S38 |       | SE   | G39  |      |       | SEC  | G38  |      |  |

When bits LCDTYPE (bit[5:4] of LCDCtrl, 0x2C1E) are set to 1, an LCD panel of 1/6 Duty should be used. In this application, by default every 3 bytes of display RAM store content of 4 LCD segments. But when bit 6COMTYPE (bit6 of LCDCtrl, 0x2C1E) is set to 1, each byte of display RAM stores content of one LCD segment.

Table 14-3 RAM Byte Allocation for Segments of LCD Panel of 1/6Duty When 6COMTYPE=0

| Register |        | SEG     | D7    | D6 | D5    | D4 | D3    | D2 | D1    | D0 |
|----------|--------|---------|-------|----|-------|----|-------|----|-------|----|
| 0x2C06   | LCDM6  | S09 S08 | SEG09 | Ð  | SEG08 | 3  |       |    |       |    |
| 0x2C07   | LCDM7  | S10 S09 | SEG10 | )  |       |    | SEG09 | )  |       |    |
| 0x2C08   | LCDM8  | S11 S10 | SEG1: | 1  |       |    |       |    | SEG10 | )  |
| 0x2C09   | LCDM9  | S13 S12 | SEG13 | 3  | SEG12 | 2  |       |    |       |    |
| 0x2C0A   | LCDM10 | S14 S13 | SEG14 | 1  |       |    | SEG13 | 3  |       |    |
| 0x2C0B   | LCDM11 | S15 S14 | SEG15 | 5  |       |    |       |    | SEG14 | ļ. |

|          |        |     |         |       |       |       | AL    | 6111 | LA Da | itash | eet |
|----------|--------|-----|---------|-------|-------|-------|-------|------|-------|-------|-----|
|          | L      | ow- | power l | Multi | funct | tiona | l Ene | ergy | Mete  | ring  | SoC |
| Register |        | SEG |         | D7    | D6    | D5    | D4    | D3   | D2    | D1    | D0  |
| 0x2C0D   | LCDM13 | S18 |         | SEG18 | 3     |       |       |      |       |       |     |
| 0x2C0E   | LCDM14 | S19 | S18     | SEG19 | )     |       |       |      |       | SEG18 | 3   |
| 0x2C0F   | LCDM15 | S21 | S20     | SEG21 | L     | SEG20 | )     |      |       |       |     |
| 0x2C10   | LCDM16 | S22 | S21     | SEG22 | 2     |       |       | SEG2 | 1     |       |     |
| 0x2C11   | LCDM17 | S23 | S22     | SEG23 | 3     |       |       |      |       | SEG22 | 2   |
| 0x2C16   | LCDM22 | S30 |         | SEG30 | )     |       |       |      |       |       |     |
| 0x2C17   | LCDM23 | S31 | S30     | SEG31 | L     |       |       |      |       | SEG30 | )   |
| 0x2C18   | LCDM24 | S33 | S32     | SEG33 | 3     | SEG32 | 2     |      |       |       |     |
| 0x2C19   | LCDM25 | S34 | S33     | SEG34 | 1     |       |       | SEG3 | 3     |       |     |
| 0x2C1A   | LCDM26 | S35 | S34     | SEG35 | 5     |       |       |      |       | SEG34 | 4   |
| 0x2C1C   | LCDM28 | S38 |         | SEG38 | 3     |       |       |      |       |       |     |
| 0x2C1D   | LCDM29 | S39 | S38     | SEG39 | )     |       |       |      |       | SEG38 | 3   |

Table 14-4 RAM Byte Allocation for Segments of LCD Panel of 1/6 Duty When 6COMTYPE=1

| Register | T byte Anocation | D7 | D6 | D5 | D4 | D3  | D2  | D1 | D0 |
|----------|------------------|----|----|----|----|-----|-----|----|----|
| 0x2C08   | LCDM8            | -  | -  |    |    | SE  | G08 |    |    |
| 0x2C09   | LCDM9            | -  | -  |    |    | SE  | G09 |    |    |
| 0x2C0A   | LCDM10           | -  | -  |    |    | SE  | G10 |    |    |
| 0x2C0B   | LCDM11           | -  | -  |    |    | SE  | G11 |    |    |
| 0x2C0C   | LCDM12           | -  | -  |    |    | SE  | G12 |    |    |
| 0x2C0D   | LCDM13           | -  | -  |    |    | SE  | G13 |    |    |
| 0x2C0E   | LCDM14           | -  | -  |    |    | SE  | G14 |    |    |
| 0x2C0F   | LCDM15           | -  | -  |    |    | SE  | G15 |    |    |
| 0x2C12   | LCDM18           | -  | -  |    |    | SE  | G18 |    |    |
| 0x2C13   | LCDM19           | -  | -  |    |    | SEC | G19 |    |    |
| 0x2C14   | LCDM20           | -  | -  |    |    | SE  | G20 |    |    |

#### **AL6111A Datasheet** Low-power Multifunctional Energy Metering SoC Register D7 D6 D5 D4 D3 D2 D1 D0 0x2C15 LCDM21 SEG21 0x2C16 LCDM22 SEG22 0x2C17 LCDM23 SEG23 0x2C28 LCDM30 SEG30 0x2C29 LCDM31 SEG31 0x2C2A LCDM32 SEG32 0x2C2B LCDM33 SEG33 0x2C2C LCDM34 SEG34 0x2C2D LCDM35 SEG35 0x2C30 LCDM38 SEG38 0x2C31 LCDM39 SEG39

When bits LCDTYPE (bit[5:4] of LCDCtrl, 0x2C1E) are set to 2 or 3, an LCD panel of 1/8 Duty should be used. In this application, each byte of display RAM stores content of one LCD segment.

Table 14-5 RAM Byte Allocation for Segments of LCD Panel of 1/8 Duty

| Register | Register |       |  | D5 | D4  | D3  | D2 | D1 | D0 |
|----------|----------|-------|--|----|-----|-----|----|----|----|
| 0x2C0A   | LCDM10   | SEG10 |  |    |     |     |    |    |    |
| 0x2C0B   | LCDM11   | SEG11 |  |    |     |     |    |    |    |
| 0x2C0C   | LCDM12   |       |  |    | SEC | G12 |    |    |    |
| 0x2C0D   | LCDM13   |       |  |    | SEC | G13 |    |    |    |
| 0x2C0E   | LCDM14   |       |  |    | SEC | G14 |    |    |    |
| 0x2C0F   | LCDM15   |       |  |    | SEC | G15 |    |    |    |
| 0x2C12   | LCDM18   | SEG18 |  |    |     |     |    |    |    |
| 0x2C13   | LCDM19   | SEG19 |  |    |     |     |    |    |    |

|          |        |       |       |         |        | AL6  | 111A  | Datas   | heet |
|----------|--------|-------|-------|---------|--------|------|-------|---------|------|
|          | Lov    | v-pow | er Mu | ltifund | ctiona | Ener | gy Me | etering | SoC  |
| Register |        | D7    | D6    | D5      | D4     | D3   | D2    | D1      | D0   |
| 0x2C14   | LCDM20 |       |       |         | SE     | G20  |       |         |      |
| 0x2C15   | LCDM21 |       |       |         | SE     | G21  |       |         |      |
| 0x2C16   | LCDM22 |       |       |         | SE     | G22  |       |         |      |
| 0x2C17   | LCDM23 |       |       |         | SE     | G23  |       |         |      |
| 0x2C28   | LCDM30 |       |       |         | SE     | G30  |       |         |      |
| 0x2C29   | LCDM31 |       |       |         | SE     | G31  |       |         |      |
| 0x2C2A   | LCDM32 |       |       |         | SE     | G32  |       |         |      |
| 0x2C2B   | LCDM33 |       |       |         | SE     | G33  |       |         |      |
| 0x2C2C   | LCDM34 |       |       |         | SE     | G34  |       |         |      |
| 0x2C2D   | LCDM35 |       |       |         | SE     | G35  |       |         |      |
| 0x2C30   | LCDM38 |       |       |         | SE     | G38  |       |         |      |
| 0x2C31   | LCDM39 |       |       |         | SE     | G39  |       |         |      |

# 14.5. LCD Drive Waveform

There are 4 resistors in series in the bias voltage generation circuit, which can be configured to work in 1/3 bias mode or 1/4 bias mode.

When an LCD panel of 1/4 or 1/6 duty is applied, only 1/3 bias mode can be used.

When an LCD panel of 1/8 duty is applied, users can configure bit LCDBMOD (bit3 of CtrlBAT, 0x285C) to disable or enable one resistor in the bias voltage generation circuit to enable the LCD driver to work in 1/3 bias mode or 1/4 bias mode.

When an LCD panel of 1/4 duty is applied, the LCD drive waveform is depicted in the following figure.

# **Low-power Multifunctional Energy Metering SoC**



Figure 14-2 LCD Drive Waveform When LCD Panel of 1/4 Duty and 1/3 Bias Applied

When an LCD panel of 1/6 duty is applied, the LCD drive waveform is depicted in the following figure.

# Low-power Multifunctional Energy Metering SoC



Figure 14-3 LCD Drive Waveform When LCD Panel of 1/6 Duty and 1/3 Bias Applied

When an LCD panel of 1/8 duty is applied, the LCD drive waveform is depicted in the following figures.

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC



Figure 14-4 LCD Drive Waveform When LCD Panel of 1/8 Duty and 1/3 Bias Applied

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC



Figure 14-5 LCD Drive Waveform When LCD Panel of 1/8 Duty and 1/4 Bias Applied

# 14.6. Registers

#### Table 14-6 LCD Control Register (LCDCtrl, 0x2C1E)

| 0x2C1E,  | R/W, LCD Co | ntrol Regi | ster, LCDCtrl                                                                                                                                                                                                 |
|----------|-------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit      |             | Default    | Description                                                                                                                                                                                                   |
| Bit7     | ON/OFF      | 0          | To enable or disable the COM/SEG driver of the LCD driver.  Set this bit to 1 to enable the COM/SEG driver to output COM and SEG signals to the LCD panel. Otherwise, this circuit outputs high impedance.    |
| Bit6     | 6СОМТҮРЕ    | 0          | When 1/6 Duty is applied, set this bit to 1 to enable each byte of display RAM to store content of one LCD segment. By default, every 6 bits of display RAM store content of 1 LCD segments in 1/6 Duty mode. |
| Bit[5:4] | LCDTYPE     | 0          | To define LCD duty.  00: 1/4 Duty; 01: 1/6 Duty; 10/11: 1/8 Duty.                                                                                                                                             |
| Bit3     | DRV1        | 0          | To set the resistance value of each resistor in the internal resistor ladder for bias voltage generation.                                                                                                     |
| Bit2     | DRV0        | 0          | 00: 300kΩ; 01: 600kΩ; 10: 150kΩ; 11: 200kΩ.                                                                                                                                                                   |
| Bit1     | FRQ1        | 0          | To configure the frame frequency.                                                                                                                                                                             |
| Bit0     | FRQ0        | 0          | 11: 512Hz; 10: 256Hz; 01: 128Hz; 00: 64Hz.                                                                                                                                                                    |

## Table 14-7 Enable/Disable CLK3

| SFR 0>       | SFR 0x80, R/W, Clock Switchover Control Register, SysCtrl |                                                                                                                                                                    |  |  |  |  |  |  |
|--------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bit          | Default                                                   | Description                                                                                                                                                        |  |  |  |  |  |  |
| bit3<br>LCDG | 0                                                         | Set this bit to 1 to stop CLK3. By default this clock is running.  Only when the PLL clock is selected as the clock source for CLK1 and CLK2 can CLK3 be disabled. |  |  |  |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

#### Table 14-8 Register to Select Bias Mode

| 0x285C,        | 0x285C, R/W, Battery Discharge Control Register, CtrlBAT |         |                                                                                                               |  |  |  |  |
|----------------|----------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit            |                                                          | Default | Description                                                                                                   |  |  |  |  |
| bit[7:4]       | Reserved                                                 | 0       | These bits must hold their default values for proper operation.                                               |  |  |  |  |
|                |                                                          |         | When the LCD driver works in 1/8 duty mode, set this bit to select the bias ratio.                            |  |  |  |  |
| bit3 LCDBMOD 0 |                                                          | 0       | 0: 1/3 Bias; 1: 1/4 Bias.                                                                                     |  |  |  |  |
|                |                                                          |         | When the LCD driver works in 1/4 or 1/6 duty mode, 1/3 Bias ratio is used whatever this bit is set.           |  |  |  |  |
| bit[2:1]       | IITU<1:0>                                                | 0       | To adjust the bias current of the amplifier of the voltage channel ADC.  00: 0%; 01: -33%; 11:+33%; 10: 100%. |  |  |  |  |
| bit0           | BATDISC                                                  | 0       | To enable discharging the battery. 1: enable; 0: disable.                                                     |  |  |  |  |

# Table 14-9 LCD Waveform Voltage Configuration 1

| 0x285E,     | 0x285E, R/W, LCD Driver Voltage Control Register, CtrlLCDV |         |                                                                                                                                                                                          |  |  |  |  |  |
|-------------|------------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit Default |                                                            | Default | Description                                                                                                                                                                              |  |  |  |  |  |
| Bit7        | DCENN                                                      | 0       | By default additional 10mV direct voltage offset is applied to the current input. Set this bit to 1 to disable this function. This bit must hold its default value for proper operation. |  |  |  |  |  |
| Bit[6:3]    | Reserved                                                   | 0       | These bits must hold their default values for proper operation.                                                                                                                          |  |  |  |  |  |
| bit2        | VLCD                                                       | 0       | To adjust the LCD waveform voltage. 0: 3.3V; 1: 3.0V.                                                                                                                                    |  |  |  |  |  |
| bit[1:0]    | Reserved                                                   | 0       | These bits must hold their default values for proper operation.                                                                                                                          |  |  |  |  |  |

#### Table 14-10 LCD Waveform Voltage Configuration 2

| 0x2866, | 0x2866, R/W, LDO Control Register, CtrlLDO |         |                                                                                                                                                                                          |  |  |  |  |  |
|---------|--------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit     |                                            | Default | Description                                                                                                                                                                              |  |  |  |  |  |
|         |                                            |         | Set this bit to 1 to disable the internal power detection circuit. By default this circuit is enabled.                                                                                   |  |  |  |  |  |
| Bit7    | Bit7 PDDET 0                               |         | When the chip is 3.3V powered, users must set this bit to 1 to disable the power detection circuit, to prevent current leakage of the battery when a battery is connected to the device. |  |  |  |  |  |
|         |                                            |         | When the chip is 5V powered, this bit must hold its default value.                                                                                                                       |  |  |  |  |  |
| Bit6    | LD03IT                                     | 0       | Set this bit to 1 to increase bias current of LDO33 by 100%.                                                                                                                             |  |  |  |  |  |

# Low-power Multifunctional Energy Metering SoC

| 0x2866, R/\ | N, LDO | Control | Register, | CtrlLDO |
|-------------|--------|---------|-----------|---------|
|-------------|--------|---------|-----------|---------|

| Bit      |               | Default | Description                                                                                                                                       |
|----------|---------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[5:3] | LD03SEL       | 0       | To adjust output voltage of LDO33.  000: 3.3V; 001: 3.2V; 010/100/101: 3.5V; 011: 3.4V; 110: 3.1V; 111: 3.0V.                                     |
| Bit[2:0] | LDOV2SEL<2:0> | 0       | To adjust output voltage of digital power circuit.  000: +0V; 001: -0.1V; 010: +0.2V; 011: +0.1V; 100: -0.4V; 101: -0.5V; 110: -0.2V; 111: -0.3V. |

#### Table 14-11 SEG Control Registers (R/W)

| Register |          | bit7    | bit6    | bit5    | Bit4    | bit3    | bit2    | bit1    | bit0    |
|----------|----------|---------|---------|---------|---------|---------|---------|---------|---------|
| 0x2C1F   | SegCtrl0 | -       | -       | -       | -       | -       | -       | SEGON1  | SEGON0  |
| 0x2C20   | SegCtrl1 | SEGON15 | SEGON14 | SEGON13 | SEGON12 | SEGON11 | SEGON10 | SEGON9  | SEGON8  |
| 0x2C21   | SegCtrl2 | SEGON23 | SEGON22 | SEGON21 | SEGON20 | SEGON19 | SEGON18 | -       | -       |
| 0x2C22   | SegCtrl3 | SEGON31 | SEGON30 | -       | -       | -       | -       | -       | -       |
| 0x2C23   | SegCtrl4 | SEGON39 | SEGON38 | -       | -       | SEGON35 | SEGON34 | SEGON33 | SEGON32 |
| Default  |          | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

0: to disable SEG signal output. 1: to enable SEG signal Output.

In the AL6111A, the pins for SEG output are multiplexed by GPIO and analog input of M Channel. When these pins are configured for SEG output, they must be set to "input and output are disabled" for GPIO purpose. When the pins work as GPIO ports or for analog input of M Channel, they must be set to "disable SEG signal output" in these registers.

When bits LCDTYPE (bit[5:4] of LCDCtrl, 0x2C1E) are cleared, bit[1:0] of SegCtrl0 and SegCtrl1 are valid.

When bits LCDTYPE is set to 1, bit[1:0] of SegCtrl1 is valid, but bit[1:0] of SegCtrl0 is invalid.

When bits LCDTYPE is set to 2 or 3, bit[1:0] of SegCtrl1 and SegCtrl0 are invalid.

# Low-power Multifunctional Energy Metering SoC

# 15. **GPIO**

In the AL6111A there are 10 groups, P0~P9, 43 general-purpose input/output ports (GPIO) in total, of which:

- Ports of Group P0 are multiplexed by general input/output and JTAG interfaces. When the chip
  operates in metering mode, besides for general input/output, both P0.2 and P0.3 can be used to wake
  up the system from sleeping state. When the chip operates in debugging mode, these ports work as
  JTAG interfaces;
- Ports of Group P1 and P2 are multiplexed by general input/output and special functions. Both P1.3 and P1.4 can be used to wake up the system from sleeping state;
- Ports of Group P3 are multiplexed by general input/output and backplanes of the LCD driver;
- Ports of Group P4 and P5 are multiplexed by general input/output and COM or SEG output of the LCD driver;
- Ports of Group P6~P8 are multiplexed by general input/output and SEG output of the LCD driver;
- Ports of Group 9 are General-Purpose Input/Output (GPIO) ports, which are named *Fast IO* in this datasheet. These ports are multiplexed by general input/output and special functions.

All the I/O ports have features:

- Ports of Group P0~P8 can be gate controlled simultaneously; Ports of Group P9 can be gate controlled independently;
- When POR/BOR, RSTn pin reset or WDT overflow event occurs, all ports will be reset to their default states: both input and output are disabled;
- In LPM1 state or LPM2 state, all ports hold their states;
- No pull-up or pull-down resistors are connected internally in all I/O ports.

# 15.1. PO

In Group P0 there are 4 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and JTAG interfaces.

When the level on the pin MODE1 is driven low, all ports of this group will work as JTAG interfaces. In this state, Port P0.0 is used for test data output (TDO); Port P0.1 is used for test data input (TDI); Port P0.2 is used for test mode select (TMS); Port P0.3 is used for test clock input (TCK).

When the level on the pin MODE1 is pulled high, all ports of this group will work as General-Purpose Input/Output (GPIO) ports, and the input and output enable registers determine the state of each port. Set bit P0P8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used. Besides, bit IOP0 (bit1 of IOWK, SFR 0xC9) determines both P0.2 and P0.3 to be used for IO wakeup inputs. See "IO wakeup inputs" for details.

# **Low-power Multifunctional Energy Metering SoC**





Figure 15-1 Architecture of P0.0

Figure 15-2 Architecture of P0.1/P0.2/P0.3

#### Table 15-1 P0 Output Enable Register (P00E, 0x28A8)

| 0x28A8, R/W, P0 Output Enable Register, P0OE |                                        |   |   |   |        |        |        |        |  |  |  |
|----------------------------------------------|----------------------------------------|---|---|---|--------|--------|--------|--------|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0      |                                        |   |   |   |        |        |        |        |  |  |  |
|                                              | -                                      | - | - | - | P030EN | P020EN | P010EN | P000EN |  |  |  |
| Default                                      | Default X X X X X 1 1 1 1              |   |   |   |        |        |        |        |  |  |  |
| 1: disable; (                                | 1: disable; 0: enable; X: do not care. |   |   |   |        |        |        |        |  |  |  |

#### Table 15-2 P0 Input Enable Register (P0IE, 0x28A9)

| 0x28A9, R/W, P0 Input Enable Register, P0IE |                                 |          |          |            |  |  |  |  |  |  |
|---------------------------------------------|---------------------------------|----------|----------|------------|--|--|--|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0     |                                 |          |          |            |  |  |  |  |  |  |
|                                             | PO3INEN PO2INEN PO1INEN PO0INEN |          |          |            |  |  |  |  |  |  |
| Default                                     | Default X X X X 0 0 0 0         |          |          |            |  |  |  |  |  |  |
| 1: enable; (                                | D: disabl                       | e; X: do | not care | <b>)</b> . |  |  |  |  |  |  |

#### Table 15-3 PO Output Data Register (POOD, 0x28AA)

| 0x28AA, R/W, P0 Output Data Register, P0OD |      |      |      |      |      |      |      |      |  |
|--------------------------------------------|------|------|------|------|------|------|------|------|--|
|                                            | bit7 | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |
| Default                                    | x    | x    | x    | x    | 1    | 1    | 1    | 1    |  |
| X: do not care.                            |      |      |      |      |      |      |      |      |  |

# Low-power Multifunctional Energy Metering SoC

Table 15-4 P0 Input Data Register (P0ID, 0x28AB)

| 0x28AB, R/W, P0 Input Data Register, P0ID |      |      |      |      |      |      |      |      |  |  |
|-------------------------------------------|------|------|------|------|------|------|------|------|--|--|
|                                           | bit7 | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |
| Default                                   | X    | X    | X    | X    | 0    | 0    | 0    | 0    |  |  |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

# 15.2. P1

In Group P1 there are 4 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and special functions.

The function of each port can be configured via the dedicated special function register. When a port works as a General-Purpose Input/Output (GPIO) port, the input and output enable registers determine its state. Set bit P0P8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used. However, setting this bit to 1 after configuring these ports to work for special functions has no effect on its functions.



Figure 15-3 Architecture of Each Port of Group P1

If port P1.3 and/or P1.4 is set to "input enabled" before the system enters LPM1 state or LPM2 state, the system will be woken up when a transition occurs to either port (either high-to-low or low-to-high, holding high and low level for at least 4 OSC clock cycles). The wakeup signal holds 8 OSC clock cycles. The wakeup inputs on these ports are independent. See "IO wakeup input" for details.

# Low-power Multifunctional Energy Metering SoC

#### Table 15-5 P1 Output Enable Register (P10E, 0x28AC)

| 0x28AC, R/W, P1 Output Enable Register, P1OE |        |         |          |        |        |        |        |   |  |  |
|----------------------------------------------|--------|---------|----------|--------|--------|--------|--------|---|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0      |        |         |          |        |        |        |        |   |  |  |
|                                              | -      | -       | -        | P140EN | P130EN | P120EN | P110EN | - |  |  |
| Default                                      | Х      | Х       | Х        | 1      | 1      | 1      | 1      | Х |  |  |
| 1: disable; 0: e                             | nable; | X: do n | ot care. |        |        |        |        |   |  |  |

#### Table 15-6 P1 Input Enable Register (P1IE, 0x28AD)

| 0x28AD, R/W, P1 Input Enable Register, P1IE |      |      |      |         |         |         |         |      |
|---------------------------------------------|------|------|------|---------|---------|---------|---------|------|
|                                             | bit7 | bit6 | bit5 | bit4    | bit3    | bit2    | bit1    | bit0 |
|                                             | -    | -    | -    | P14INEN | P13INEN | P12INEN | P11INEN | -    |
| Default                                     | Х    | Х    | Х    | 0       | 0       | 0       | 0       | Х    |
| 1: enable; 0: disable; X: do not care.      |      |      |      |         |         |         |         |      |

#### Table 15-7 P1 Output Data Register (P10D, 0x28AE)

| 0x28AE, R/W, P1 Output Data Register, P1OD |      |      |      |      |      |      |      |      |
|--------------------------------------------|------|------|------|------|------|------|------|------|
|                                            | bit7 | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
| Default                                    | X    | Х    | х    | 1    | 1    | 1    | 1    | X    |
| X: do not care.                            |      |      |      |      |      |      |      |      |

#### Table 15-8 P1 Input Data Register (P1ID, 0x28AF)

| 0x28AF, R/W, P1 Input Data Register, P1ID |      |      |      |      |      |      |      |      |
|-------------------------------------------|------|------|------|------|------|------|------|------|
|                                           | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
| Default                                   | X    | X    | X    | 0    | 0    | 0    | 0    | X    |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

# **Low-power Multifunctional Energy Metering SoC**

# Table 15-9 P1.1 Special Function Register (P11FS, 0x28C5, R/W)

| Bit      |                         | Default | Description                                                                                                            |  |  |  |  |  |
|----------|-------------------------|---------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit[7:3] | Reserved.               | 0       |                                                                                                                        |  |  |  |  |  |
| Bit[2:0] | P11FNC2 P11FNC1 P11FNC0 | 0       | 000: GPIO, general-purpose input/output port; 010: RXD1, receiver data input of UART1; 011: T1, Timer1 external input; |  |  |  |  |  |
|          | LITINCO                 |         | 100: IO interrupt input 2, active on high-to-low transition.                                                           |  |  |  |  |  |

#### Table 15-10 P1.2 Special Function Register (P12FS, 0x28C6, R/W)

| Bit      |           | Default | Description                                                  |
|----------|-----------|---------|--------------------------------------------------------------|
| Bit[7:3] | Reserved. | 0       |                                                              |
|          |           |         | 000: GPIO, general-purpose input/output port;                |
|          | P12FNC2   |         | 001: reserved;                                               |
| Bit[2:0] | P12FNC1   | 0       | 010: TXD1, transmitter data output of UART1;                 |
|          | P12FNC0   |         | 011: T2EX, Timer2 capture or reload trigger input;           |
|          |           |         | 100: IO interrupt input 3, active on high-to-low transition. |

#### Table 15-11 P1.3 Special Function Register (P13FS, 0x28C7, R/W)

| Bit      |                               | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|-------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[7:3] | Reserved.                     | 0       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit[2:0] | P13FNC2<br>P13FNC1<br>P13FNC0 | 0       | 000: GPIO, general-purpose input/output port; 001: CF2, CF pulse output of E2 path; 010: RXD5, receiver data input of UART5; 011: IO interrupt input 0, active on high-to-low transition; 100: CF1, CF pulse output of E1 path; 101: SP, pulse per second (PPS) output from the RTC. On calibrating the RTC, every 30 seconds, from the 1st to 29th second, an un-calibrated pulse is output every second, and in the 30th second, a calibrated pulse is output that averages the period of each pulse in the 30 seconds to be 1s. 110: PLLDIV, pulse output proportional to the divided PLL clock frequency, can be configured to output pulses of 1s width from the PLL counter. |

# Low-power Multifunctional Energy Metering SoC

Table 15-12 P1.4 Special Function Register (P14FS, 0x28C8)

| Bit[7:2] Reserved. 0 | Bit      |           | Default | Description                                  |
|----------------------|----------|-----------|---------|----------------------------------------------|
|                      | Bit[7:2] | Reserved. | 0       |                                              |
|                      | Bit[1:0] |           | 0       | 010: TXD5, transmitter data output of UART5; |

# 15.3. P2

In Group P2 there are 4 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and special functions.

The function of each port can be configured via the dedicated special function register. When a port works as a General-Purpose Input/Output (GPIO) port, the input and output enable registers determine its state. Set bit P0P8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used. However, setting this bit to 1 after configuring these ports to work for special functions has no effect on its functions.



Figure 15-4 Architecture of Each Port of Group P2

Table 15-13 P2 Output Enable Register (P2OE, 0x28B0)

| 0x28B0, R/W, P2 Output Enable Register, P2OE |      |      |        |        |      |      |        |        |
|----------------------------------------------|------|------|--------|--------|------|------|--------|--------|
|                                              | bit7 | bit6 | bit5   | bit4   | bit3 | bit2 | bit1   | bit0   |
|                                              | -    | -    | P250EN | P240EN | -    | -    | P210EN | P200EN |
| Default X X 1 1 X X 1 1                      |      |      |        |        |      |      |        | 1      |
| 1: disable; 0: enable; X: do not care.       |      |      |        |        |      |      |        |        |

# Low-power Multifunctional Energy Metering SoC

# Table 15-14 P2 Input Enable Register (P2IE, 0x28B1)

| 0x28B1, R/W, P2 Input Enable Register, P2IE |                                        |   |         |         |   |   |         |         |  |
|---------------------------------------------|----------------------------------------|---|---------|---------|---|---|---------|---------|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0     |                                        |   |         |         |   |   |         | bit0    |  |
|                                             | -                                      | - | P25INEN | P24INEN | - | - | P21INEN | P20INEN |  |
| Default X X 0 0 X X 0 0                     |                                        |   |         |         |   |   |         |         |  |
| 1: enable: 0: disal                         | 1: enable: 0: disable: X: do not care. |   |         |         |   |   |         |         |  |

#### Table 15-15 P2 Output Data Register (P2OD, 0x28B2)

| 0x28B2, R/W, P2 Output Data Register, P2OD |      |      |      |      |      |      |      |      |
|--------------------------------------------|------|------|------|------|------|------|------|------|
|                                            | bit7 | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
| Default                                    | х    | х    | 1    | 1    | х    | х    | 1    | 1    |
| X: do not care.                            |      |      |      |      |      |      |      |      |

#### Table 15-16 P2 Input Data Register (P2ID, 0x28B3)

| 0x28B3, R/W, P2 Input Data Register, P2ID |      |      |      |      |      |      |      |      |
|-------------------------------------------|------|------|------|------|------|------|------|------|
|                                           | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
| Default                                   | Х    | X    | 0    | 0    | Х    | X    | 0    | 0    |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

#### Table 15-17 P2.0 Special Function Register (P20FS, 0x28C9, R/W)

| Bit      |           | Default | Description                                  |
|----------|-----------|---------|----------------------------------------------|
| Bit[7:2] | Reserved. | 0       |                                              |
|          |           |         | 00: GPIO, general-purpose input/output port; |
| Bit[1:0] | P20FNC1   |         | 01: OSC, OSC clock waveform output;          |
|          | P20FNC0   | 0       | 10: RXD4, receiver data input of UART4;      |
|          |           |         | 11: T2, Timer2 external input.               |

# Low-power Multifunctional Energy Metering SoC

#### Table 15-18 P2.1 Special Function Register (P21FS, 0x28CA, R/W)

| Bit      |           | Default | Description                                 |
|----------|-----------|---------|---------------------------------------------|
| Bit[7:2] | Reserved. | 0       |                                             |
|          |           | 0       | 00: GPIO, general-purpose input/output port |
| Bit[1:0] | P21FNC1   |         | 01: reserved                                |
|          | P21FNC0   |         | 10: TXD4, transmitter data output of UART4  |
|          |           |         | 11: T0, Timer0 external input               |

#### Table 15-19 P2.4 Special Function Register (P24FS, 0x28CD, R/W)

| Bit      |          | Default | Description                                 |
|----------|----------|---------|---------------------------------------------|
| Bit[7:2] | Reserved | 0       |                                             |
| Bit[1:0] | P24FNC1  | 0       | 00: GPIO, general-purpose input/output port |
| Dit[1.0] | P24FNC0  | U       | 10: RXD2, receiver data input of UART2      |

#### Table 15-20 P2.5 Special Function Register (P25FS, 0x28CE, R/W)

| Bit      |                    | Default | Description                                                                                                                                          |
|----------|--------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[7:2] | Reserved           | 0       |                                                                                                                                                      |
| Bit[1:0] | P25FNC1<br>P25FNC0 | 0       | 00: GPIO, general-purpose input/output port; 10: TXD2, transmitter data output of UART2. This port can be configured to transmit 38kHz carrier wave. |

# 15.4. P3

In Group P3 there are 4 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and backplanes of the LCD driver.

When a port works as backplanes of the LCD driver, in input and output enable registers, P3OE (0x28B4) and P3IE (0x28B5), the corresponding bit must be configured "input disabled, output disabled".

When a port works as a General-Purpose Input/Output (GPIO) port, the SEG/COM driver in the LCD driver must be disabled (bit7 of LCDCtrl, 0x2C1E), and input and output enable registers determine its state. Set bit P0P8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used.

# Low-power Multifunctional Energy Metering SoC



Figure 15-5 Architecture of Each Port of Group P3

#### Table 15-21 P3 Output Enable Register (P3OE, 0x28B4)

| 0x28B4, R/W, P3 Output Enable Register, P3OE |   |   |   |   |        |        |        |        |  |  |
|----------------------------------------------|---|---|---|---|--------|--------|--------|--------|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0      |   |   |   |   |        |        |        |        |  |  |
|                                              | - | - | - | - | P330EN | P320EN | P310EN | P300EN |  |  |
| Default X X X X X 1 1 1 1                    |   |   |   |   |        |        |        |        |  |  |
| 1: disable; 0: enable; X: do not care.       |   |   |   |   |        |        |        |        |  |  |

## Table 15-22 P3 Input Enable Register (P3IE, 0x28B5)

| 0x28B5, R/W, P3 Input Enable Register, P3IE |   |   |   |   |         |         |         |         |  |  |
|---------------------------------------------|---|---|---|---|---------|---------|---------|---------|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0     |   |   |   |   |         |         |         |         |  |  |
|                                             | - | - | - | - | P33INEN | P32INEN | P31INEN | P30INEN |  |  |
| Default X X X X 0 0 0 0                     |   |   |   |   |         |         |         |         |  |  |
| 1: enable; 0: disable; X: do not care.      |   |   |   |   |         |         |         |         |  |  |

#### Table 15-23 P3 Output Data Register (P3OD, 0x28B6)

| 0x28B6, R/W, P3 Output Data Register, P3OD |   |   |   |   |   |   |   |   |  |  |
|--------------------------------------------|---|---|---|---|---|---|---|---|--|--|
| bit7 Bit6 bit5 bit4 bit3 bit2 bit1 bit0    |   |   |   |   |   |   |   |   |  |  |
| Default                                    | х | Х | Х | х | 1 | 1 | 1 | 1 |  |  |
| X: do not care.                            |   |   |   |   |   |   |   |   |  |  |

#### Table 15-24 P3 Input Data Register (P3ID, 0x28B7)

| 0x28B7, R/W, P3 Input Data Register, P3ID |   |   |   |   |   |   |   |   |  |  |
|-------------------------------------------|---|---|---|---|---|---|---|---|--|--|
| bit7 Bit6 bit5 bit4 bit3 bit2 bit1 bit0   |   |   |   |   |   |   |   |   |  |  |
| Default                                   | Х | Х | X | х | 0 | 0 | 0 | 0 |  |  |
| X: do not care.                           |   |   |   |   |   |   |   |   |  |  |



### Low-power Multifunctional Energy Metering SoC

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

### 15.5. P4

In Group P4 there are 2 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and signal output of the LCD driver.

Ports P4.0 and P4.1 can be configured to be multiplexed by SEG output when a display panel of 1/4 duty is applied, or two extra backplanes when a display panel of 1/6 or 1/8 duty is applied, and General-Purpose Input/Output (GPIO).

When a port works as backplanes or SEG output of the LCD driver, in input and output enable registers, P4OE (0x28B8) and P4IE (0x28B9), the corresponding bit must be configured "input disabled, output disabled".

When a port works as a General-Purpose Input/Output (GPIO) port, the SEG output on the corresponding port must be disabled and input and output enable registers determine its state. Set bit P0P8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used.



Figure 15-6 Architecture of Each Port of Group P4

Table 15-25 P4 Output Enable Register (P40E, 0x28B8)

| 0x28B8, R/W, P4 Output Enable Register, P4OE |                           |  |  |  |  |  |        |        |  |  |  |
|----------------------------------------------|---------------------------|--|--|--|--|--|--------|--------|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0      |                           |  |  |  |  |  |        |        |  |  |  |
|                                              |                           |  |  |  |  |  | P410EN | P400EN |  |  |  |
| Default                                      | Default X X X X X X X 1 1 |  |  |  |  |  |        |        |  |  |  |
| 1: disable; 0: enable; X: do not care.       |                           |  |  |  |  |  |        |        |  |  |  |

# Low-power Multifunctional Energy Metering SoC

### Table 15-26 P4 Input Enable Register (P4IE, 0x28B9)

| 0x28B9, R/W, P4 Input Enable Register, P4IE |      |      |      |      |      |      |         |         |  |  |
|---------------------------------------------|------|------|------|------|------|------|---------|---------|--|--|
|                                             | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1    | bit0    |  |  |
|                                             |      |      |      |      |      |      | P41INEN | P40INEN |  |  |
| Default                                     | Х    | Х    | Х    | Х    | Х    | X    | 0       | 0       |  |  |
| 1: enable: 0: disable: X: do not care.      |      |      |      |      |      |      |         |         |  |  |

#### Table 15-27 P4 Output Data Register (P4OD, 0x28BA)

| 0x28BA, R/W, P4 Output Data Register, P4OD |   |   |   |   |   |   |   |   |  |  |
|--------------------------------------------|---|---|---|---|---|---|---|---|--|--|
| bit7 Bit6 bit5 bit4 bit3 bit2 bit1 bit0    |   |   |   |   |   |   |   |   |  |  |
| Default                                    | Х | Х | Х | Х | Х | Х | 1 | 1 |  |  |
| X: do not care.                            |   |   |   |   |   |   |   |   |  |  |

#### Table 15-28 P4 Input Data Register (P4ID, 0x28BB)

| 0x28BB, R/W, P4 Input D | 0x28BB, R/W, P4 Input Data Register, P4ID |      |      |      |      |      |      |      |  |  |  |
|-------------------------|-------------------------------------------|------|------|------|------|------|------|------|--|--|--|
|                         | bit7                                      | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |  |
| Default                 | X                                         | X    | X    | Х    | Х    | X    | 0    | 0    |  |  |  |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

# 15.6. P5

In Group P5 there are 8 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and signal output of the LCD driver.

Ports P5.0 and P5.1 can be configured to be multiplexed by SEG output when a display panel of 1/4 or 1/6 duty is applied, or two extra backplanes when a display panel of 1/8 duty is applied, and General-Purpose Input/Output (GPIO); and ports P5.2-P5.7 are multiplexed by SEG output and General-Purpose Input/Output (GPIO).

When a port works as backplanes or SEG output of the LCD driver, in input and output enable registers, P5OE (0x28BC) and P5IE (0x28BD), the corresponding bit must be configured "input disabled, output disabled".

When a port works as a General-Purpose Input/Output (GPIO) port, SEG output on the corresponding port must be disabled, and input and output enable registers determine its state. Set bit POP8 (bit3 of



# Low-power Multifunctional Energy Metering SoC

PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used.



Figure 15-7 Architecture of Each Port of Group P5

### Table 15-29 P5 Output Enable Register (P5OE, 0x28BC)

| 0x28BC, R/W, P5 Output Enable Register, P5OE |                         |        |        |        |        |        |        |        |  |  |
|----------------------------------------------|-------------------------|--------|--------|--------|--------|--------|--------|--------|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0      |                         |        |        |        |        |        |        |        |  |  |
|                                              | P570EN                  | P560EN | P550EN | P540EN | P530EN | P520EN | P510EN | P500EN |  |  |
| Default                                      | Default 1 1 1 1 1 1 1 1 |        |        |        |        |        |        |        |  |  |
| 1: disable; 0: enable; X: do not care.       |                         |        |        |        |        |        |        |        |  |  |

#### Table 15-30 P5 Input Enable Register (P5IE, 0x28BD)

| 0x28BD, R/W, P5 Input Enable Register, P5IE |                                         |         |         |         |         |         |         |         |  |  |
|---------------------------------------------|-----------------------------------------|---------|---------|---------|---------|---------|---------|---------|--|--|
|                                             | bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 |         |         |         |         |         |         |         |  |  |
|                                             | P57INEN                                 | P56INEN | P55INEN | P54INEN | P53INEN | P52INEN | P51INEN | P50INEN |  |  |
| Default                                     | 0                                       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |  |  |
| 1: enable; 0: disable; X: do not care.      |                                         |         |         |         |         |         |         |         |  |  |

#### Table 15-31 P5 Output Data Register (P5OD, 0x28BE)

| 0x28BE, R/W, P | 0x28BE, R/W, P5 Output Data Register, P5OD |      |      |      |      |      |      |      |  |  |  |
|----------------|--------------------------------------------|------|------|------|------|------|------|------|--|--|--|
|                | bit7                                       | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |  |
| Default        | 1                                          | 1    | 1    | 1    | 1    | 1    | 1    | 1    |  |  |  |

# Low-power Multifunctional Energy Metering SoC

Table 15-32 P5 Input Data Register (P5ID, 0x28BF)

| 0x28BF, R/W, | 0x28BF, R/W, P5 Input Data Register, P5ID |      |      |      |      |      |      |      |  |  |  |
|--------------|-------------------------------------------|------|------|------|------|------|------|------|--|--|--|
|              | bit7                                      | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |  |
| Default      | 0                                         | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |  |  |

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

### 15.7. P6

In Group P6 there are 6 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and SEG output of the LCD driver.

When a port works as SEG output of the LCD driver, in input and output enable registers, P6OE (0x28C0) and P6IE (0x28C1), the corresponding bit must be configured "input disabled, output disabled".

When a port works as a General-Purpose Input/Output (GPIO) port, SEG output on the corresponding port must be disabled, and input and output enable registers determine its state. Set bit POP8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used.



Figure 15-8 Architecture of Each Port of Group P6

Table 15-33 P6 Output Enable Register (P60E, 0x28C0)

| 0x28C0                                             | 0x28C0, R/W, P6 Output Enable Register, P6OE |        |        |        |        |        |   |   |  |  |  |
|----------------------------------------------------|----------------------------------------------|--------|--------|--------|--------|--------|---|---|--|--|--|
| onzoco, il, ii, i o output Eliable Register, i ooz |                                              |        |        |        |        |        |   |   |  |  |  |
|                                                    | bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0      |        |        |        |        |        |   |   |  |  |  |
|                                                    | P670EN                                       | P660EN | P650EN | P640EN | P630EN | P62OEN | - | - |  |  |  |
| Default                                            | Default 1 1 1 1 1 1 X X                      |        |        |        |        |        |   |   |  |  |  |
| 1: disable; 0: enable; X: do not care.             |                                              |        |        |        |        |        |   |   |  |  |  |

# Low-power Multifunctional Energy Metering SoC

### Table 15-34 P6 Input Enable Register (P6IE, 0x28C1)

| 0x28C1,                                | 0x28C1, R/W, P6 Input Enable Register, P6IE |         |         |         |         |         |   |   |  |  |  |
|----------------------------------------|---------------------------------------------|---------|---------|---------|---------|---------|---|---|--|--|--|
|                                        | bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0     |         |         |         |         |         |   |   |  |  |  |
|                                        | P67INEN                                     | P66INEN | P65INEN | P64INEN | P63INEN | P62INEN | - | - |  |  |  |
| Default                                | Default 0 0 0 0 0 0 X X                     |         |         |         |         |         |   |   |  |  |  |
| 1: enable; 0: disable; X: do not care. |                                             |         |         |         |         |         |   |   |  |  |  |

#### Table 15-35 P6 Output Data Register (P6OD, 0x28C2)

| 0x28C2, R/W, P6 Output Data Register, P6OD |   |   |   |   |   |   |   |   |  |  |
|--------------------------------------------|---|---|---|---|---|---|---|---|--|--|
| bit7 Bit6 bit5 bit4 bit3 bit2 bit1 bit0    |   |   |   |   |   |   |   |   |  |  |
| Default                                    | 1 | 1 | 1 | 1 | 1 | 1 | х | х |  |  |
| X: do not care.                            |   |   |   |   |   |   |   |   |  |  |

#### Table 15-36 P6 Input Data Register (P6ID, 0x28C3)

| 0x28C3, R/W, P6 | 0x28C3, R/W, P6 Input Data Register, P6ID |      |      |      |      |      |      |      |  |  |  |
|-----------------|-------------------------------------------|------|------|------|------|------|------|------|--|--|--|
|                 | bit7                                      | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |  |
| Default         | 0                                         | 0    | 0    | 0    | 0    | 0    | X    | X    |  |  |  |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

# 15.8. P7

In Group P7 there are 2 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and SEG output of the LCD driver.

When a port works as SEG output of the LCD driver, in input and output enable registers, P7OE (0x28D5) and P7IE (0x28D6), the corresponding bit must be configured "input disabled, output disabled".

When a port works as a General-Purpose Input/Output (GPIO) port, the SEG output on the corresponding ports must be disabled and input and output enable registers determine its state. Set bit P0P8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used.

# **Low-power Multifunctional Energy Metering SoC**



Figure 15-9 Architecture of Each Port of Group P7

#### Table 15-37 P7 Output Enable Register (P70E, 0x28D5)

|                                              | <u> </u> |        | <u> </u> | -    |      |      |      |      |  |  |
|----------------------------------------------|----------|--------|----------|------|------|------|------|------|--|--|
| 0x28D5, R/W, P7 Output Enable Register, P7OE |          |        |          |      |      |      |      |      |  |  |
|                                              | bit7     | bit6   | bit5     | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |
|                                              | P770EN   | P760EN | -        | -    | -    | -    | -    | -    |  |  |
| Default                                      | 1        | 1      | х        | Х    | х    | X    | Х    | Х    |  |  |
| 1: disable; 0: enable; X: do not care.       |          |        |          |      |      |      |      |      |  |  |

### Table 15-38 P7 Input Enable Register (P7IE, 0x28D6)

| 0x28D6, R/W, P7 Input Enable Register, P7IE |         |         |      |      |      |      |      |      |  |  |
|---------------------------------------------|---------|---------|------|------|------|------|------|------|--|--|
|                                             | bit7    | bit6    | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |
|                                             | P77INEN | P76INEN | -    | -    | -    | -    | -    | -    |  |  |
| Default                                     | 0       | 0       | Х    | Х    | Х    | х    | х    | Х    |  |  |
| 1: enable; 0: disable; X: do not care.      |         |         |      |      |      |      |      |      |  |  |

#### Table 15-39 P7 Output Data Register (P7OD, 0x28D7)

| 0x28D7, R/W, P7 Output Data Register, P7OD |   |   |   |   |   |   |   |   |  |
|--------------------------------------------|---|---|---|---|---|---|---|---|--|
| bit7 Bit6 bit5 bit4 bit3 bit2 bit1 bit0    |   |   |   |   |   |   |   |   |  |
| Default                                    | 1 | 1 | Х | Х | Х | Х | Х | Х |  |
| X: do not care.                            |   |   |   |   |   |   |   |   |  |

### Low-power Multifunctional Energy Metering SoC

Table 15-40 P7 Input Data Register (P7ID, 0x28D8)

| 0x28D8, R/W, P7 Input Data Register, P7ID |   |   |   |   |   |   |   |   |  |
|-------------------------------------------|---|---|---|---|---|---|---|---|--|
| bit7 Bit6 bit5 bit4 bit3 bit2 bit1 bit0   |   |   |   |   |   |   |   |   |  |
| Default                                   | 0 | 0 | X | Х | X | X | X | X |  |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

### 15.9. P8

In Group P8 there are 3 ports, which are multiplexed by General-Purpose Input/Output (GPIO) and SEG output of the LCD driver.

When a port works as SEG output of the LCD driver, in input and output enable registers, P8OE (0x28D9) and P8IE (0x28DA), the corresponding bit must be configured "input disabled, output disabled".

When a port works as a General-Purpose Input/Output (GPIO) port, the SEG output on the corresponding port must be disabled, and input/output enable registers determine its state. Set bit POP8 (bit3 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P0~P8 to lower power consumption when these ports are not used.



Figure 15-10 Architecture of Each Port of Group P8

# Low-power Multifunctional Energy Metering SoC

#### Table 15-41 P8 Output Enable Register (P80E, 0x28D9)

| 0x28D9, R/                              | 0x28D9, R/W, P8 Output Enable Register, P8OE |   |   |   |   |        |        |        |  |  |  |
|-----------------------------------------|----------------------------------------------|---|---|---|---|--------|--------|--------|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 |                                              |   |   |   |   |        |        |        |  |  |  |
|                                         | -                                            | - | - | - | - | P820EN | P810EN | P800EN |  |  |  |
| Default                                 |                                              |   |   |   |   |        |        |        |  |  |  |
| 1: disable; 0: enable; X: do not care.  |                                              |   |   |   |   |        |        |        |  |  |  |

#### Table 15-42 P8 Input Enable Register (P8IE, 0x28DA)

| 0x28DA, R                               | 0x28DA, R/W, P8 Input Enable Register, P8IE |   |   |   |   |         |         |         |  |  |  |
|-----------------------------------------|---------------------------------------------|---|---|---|---|---------|---------|---------|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 |                                             |   |   |   |   |         |         |         |  |  |  |
|                                         | -                                           | - | - | - | - | P82INEN | P81INEN | P80INEN |  |  |  |
| Default                                 | Х                                           | Х | Х | Х | Х | 0       | 0       | 0       |  |  |  |
| 1: enable; 0: disable; X: do not care.  |                                             |   |   |   |   |         |         |         |  |  |  |

#### Table 15-43 P8 Output Data Register (P8OD, 0x28DB)

| 0x28DB, R/W, P8 Output Data Register, P8OD |   |   |   |   |   |   |   |   |  |
|--------------------------------------------|---|---|---|---|---|---|---|---|--|
| bit7 Bit6 bit5 bit4 bit3 bit2 bit1 bit0    |   |   |   |   |   |   |   |   |  |
| Default                                    | X | X | X | х | х | 1 | 1 | 1 |  |
| X: do not care.                            |   |   |   |   |   |   |   |   |  |

#### Table 15-44 P8 Input Data Register (P8ID, 0x28DC)

| 0x28DC, R/W, P8 Input Data Register, P8ID |      |      |      |      |      |      |      |      |  |
|-------------------------------------------|------|------|------|------|------|------|------|------|--|
|                                           | bit7 | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |
| Default                                   | X    | X    | X    | X    | X    | 0    | 0    | 0    |  |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

# Low-power Multifunctional Energy Metering SoC

### 15.10. P9

In Group P9 there are 6 ports, which are multiplexed by General-Purpose Input/Output (GPIO), special functions and SEG output of the LCD driver.

When the ports work as General-Purpose Input/Output (GPIO) ports, the ports of Group P9 are different from those of the above groups. They are accessed in a fast mode. But when a reference pulse of exact one second width is input to the port P9.1, the input of this port is enabled automatically.

The function of each port can be configured via the register P9FS (SFR 0xAD).

When bit GPSI (bit6 of PRCtrl0, 0x2D00) is set to 1, port P9.1 and P9.2 are used for serial data and clock delivery for general-purpose serial interface (GPSI). In this condition, P9.1 must be set to "input enabled"; and P9.2 is set to "output enabled" automatically.

The port P9.0 can be used for SEG output of the LCD driver. When the port works as SEG output of the LCD driver, in input and output enable registers, P9OE (SFR 0xA4) and P9IE (SFR 0xA5), the corresponding bit must be configured "input disabled, output disabled".

Set bit P9 (bit4 of PRCtrl0, 0x2D00) to 1 to gate control ports of Group P9 to lower power consumption when these ports are not used. However, setting this bit to 1 after configuring these ports to work for special functions has no effect on its functions.

#### Table 15-45 P9 Output Enable Register (P90E, SFR 0xA4)

| SFR 0xA4                                | SFR 0xA4, R/W, P9 Output Enable Register, P9OE |  |  |  |  |  |  |  |  |  |
|-----------------------------------------|------------------------------------------------|--|--|--|--|--|--|--|--|--|
| bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 |                                                |  |  |  |  |  |  |  |  |  |
|                                         | - P960EN P950EN - P930EN P920EN P910EN P900EN  |  |  |  |  |  |  |  |  |  |
| Default                                 | Default X 1 1 X 1 1 1 1                        |  |  |  |  |  |  |  |  |  |
| 1: disable                              | 1: disable; 0: enable; X: do not care.         |  |  |  |  |  |  |  |  |  |

#### Table 15-46 P9 Input Enable Register (P9IE, SFR 0xA5)

| SFR 0xA5                               | SFR 0xA5, R/W, P9 Input Enable Register, P9IE |         |         |      |         |         |         |         |  |  |  |
|----------------------------------------|-----------------------------------------------|---------|---------|------|---------|---------|---------|---------|--|--|--|
|                                        | bit7                                          | bit6    | bit5    | bit4 | bit3    | bit2    | bit1    | bit0    |  |  |  |
|                                        | -                                             | P96INEN | P95INEN | -    | P93INEN | P92INEN | P91INEN | P90INEN |  |  |  |
| Default                                | Х                                             | 0       | 0       | Х    | 0       | 0       | 0       | 0       |  |  |  |
| 1: enable; 0: disable; X: do not care. |                                               |         |         |      |         |         |         |         |  |  |  |

#### Table 15-47 P9 Output Data Register (P9OD, SFR 0xA6)

| SFR 0xA6, R/W, P9 Output Data Register, P9OD |      |      |      |      |      |      |      |      |  |
|----------------------------------------------|------|------|------|------|------|------|------|------|--|
|                                              | bit7 | Bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |



|                | AL6111A Datasheet |        |        |           |         |        |         |        |  |
|----------------|-------------------|--------|--------|-----------|---------|--------|---------|--------|--|
|                |                   | Low-pe | ower M | lultifund | ctional | Energy | Meterir | ng SoC |  |
| Default        | х                 | 1      | 1      | Х         | 1       | 1      | 1       | 1      |  |
| X: do not care | ).                |        |        |           |         |        |         |        |  |

#### Table 15-48 P9 Input Data Register (P9ID, SFR 0xA7)

| SFR 0xA7, R/W, P9 Input Data Register, P9ID |      |      |      |      |      |      |      |      |
|---------------------------------------------|------|------|------|------|------|------|------|------|
|                                             | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
| Default                                     | Х    | 0    | 0    | X    | 0    | 0    | 0    | 0    |

X: do not care.

When input is enabled, users can read the state of each I/O port via this register all the time, which is not affected by the special function of the port. But the state change of an I/O port will lead to value variation of this register, which consumes more power. So to lower power consumption, it is recommended to disable data input if no need to read the input data.

#### Table 15-49 P9 Special Function Register (P9FS, SFR 0xAD)

| SFR 0x | SFR 0xAD, R/W, P9 Special Function Register, P9FS |                                                                                                                                               |  |  |  |
|--------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit    |                                                   | Description                                                                                                                                   |  |  |  |
| Bit7   | Reserved                                          |                                                                                                                                               |  |  |  |
|        |                                                   | To configure the function of the port P9.6.                                                                                                   |  |  |  |
| Bit6   | P96FNC                                            | 1: CF1, CF pulse output of E1 path;                                                                                                           |  |  |  |
|        |                                                   | 0: General-Purpose Input/Output (GPIO) port in fast mode.                                                                                     |  |  |  |
|        |                                                   | To configure the function of the port P9.5.                                                                                                   |  |  |  |
| Bit5   | P95FNC                                            | 1: CF2, CF pulse output of E2 path;                                                                                                           |  |  |  |
|        |                                                   | 0: General-Purpose Input/Output (GPIO) port in fast mode.                                                                                     |  |  |  |
| Bit4   | Reserved                                          |                                                                                                                                               |  |  |  |
|        |                                                   | To configure the function of the port P9.3.                                                                                                   |  |  |  |
| Bit3   | P93FNC                                            | 1: PLLDIV, pulse output proportional to the divided PLL clock frequency, can be configured to output pulses of 1s width from the PLL counter; |  |  |  |
|        |                                                   | 0: General-Purpose Input/Output (GPIO) port in fast mode.                                                                                     |  |  |  |
|        |                                                   | To configure the function of the port P9.2.                                                                                                   |  |  |  |
| Bit2   | P92FNC                                            | 1: TA2, to input/output the signals for Timer A Compare/Capture Module 2;                                                                     |  |  |  |
|        |                                                   | 0: General-Purpose Input/Output (GPIO) port in fast mode.                                                                                     |  |  |  |

# Low-power Multifunctional Energy Metering SoC

| SFR 0xAD, R/W, P9 Special Function Register, P9FS |        |                                                                                                                                                                                   |  |  |  |
|---------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit Description                                   |        |                                                                                                                                                                                   |  |  |  |
| Bit1                                              | P91FNC | To configure the function of the port P9.1.  1: TA1, to input/output the signals for Timer A Compare/Capture Module 1;  0: General-Purpose Input/Output (GPIO) port in fast mode. |  |  |  |
| Bit0                                              | P90FNC | To configure the function of the port P9.0.  1: TA0, to input/output the signals for Timer A Compare/Capture Module 0;  0: General-Purpose Input/Output (GPIO) port in fast mode. |  |  |  |

# 16. Watchdog Timer (WDT)

In the AL6111A the embedded 16-bit watchdog timer (WDT) counting pulses of the 32kHz RC clock. When the program gets stuck somewhere, the timer overflows and reset the system to cause the program restart from the beginning.

# 16.1. Clock for WDT

In the AL6111A, CLK4, sourced by the 32kHz RC clock, provides clock pulse for the WDT. RC clock cannot be disabled until the chip is powered off, but CLK4 is enabled or disabled together with CLK1. When CLK4 (together with CLK1) is disabled, which means the system enters LPM1 state or LPM2 state, the WDT stops running. When the system is woken up by IO/RTC wakeup event or power supply restoration, the WDT restarts counting from zero.

Table 16-1 Enable/Disable CLK4

| SFR 0x8        | SFR 0x80, R/W, Clock Switchover Control Register, SysCtrl SFR |                                                                                                                                                            |  |  |  |  |  |
|----------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit            | Default                                                       | escription                                                                                                                                                 |  |  |  |  |  |
| Bit2<br>SLEEP1 |                                                               | When the bit PWRUP is read out as 0, write 0 to the bit MCUFRQ, and then:  - set SLEEP1 and SLEEP0 to 0b11 or 0b01 to stop CLK1 (together with CLK4) and   |  |  |  |  |  |
| Bit1<br>SLEEP0 | 0                                                             | force the system entering the LPM1 state.  - set SLEEP1 and SLEEP0 to 0b10 to stop CLK1 (together with CLK4) and force the system entering the LPM2 state. |  |  |  |  |  |

# 16.2. Clearing WDT

When IO/RTC wakeup event, power supply restoration event, POR/BOR or RSTn pin reset occurs, the WDT is reset, and its counts are cleared. When the reset signal is released, the WDT starts counting from zero again.

Users can write a program to clear the WDT counts to prevent the WDT from resetting the system when its counts overflow: write 0xA5 to the register WDTEN (SFR 0xCE) and then 0x5A to the register WDTCLR (SFR 0xCF) continuously to clear the WDT counts. Immediately the WDT is cleared, it will restart counting pulses from zero.

| SFR 0xCE, W, WDTEN SFR  | 0xA5 |
|-------------------------|------|
| SFR 0xCF, W, WDTCLR SFR | 0x5A |

### 16.3. WDT Overflow Reset

Initially, the WDT starts counting pulses from 0. If the counts are not cleared when the WDT counts to  $(3\times2^{14})$ , that is about 1.5s, the WDT overflows, a reset pulse of 8 RC clock periods  $(8/f_{RC})$  width is output, and the system is reset to default state. After the reset, the WDT starts counting from  $(-2^{14})$ , and then, if the WDT is still not cleared, the WDT will overflow again when it counts to  $(3\times2^{14})$ , that is about 2s.

When the WDT overflow reset occurs, the flag bit POR (bit5 of Systate, SFR 0xA1) is set to 1. When other reset events, not POR/BOR or RSTn pin reset, occurs, this bit will be cleared. In debugging mode, this reset event is masked.

A WDT overflow event can reset all circuits except the RTC calibration registers, RTC timing registers, IRAM and XRAM.



Figure 16-1 WDT Overflow Reset

# 17. Real-Time Clock (RTC)

In the AL6111A, the RTC has features as follows:

- counting the pulses of the 32.768kHz OSC clock;
- calibrating crystal frequency over temperature variation;
- calibrated pulse output every exact one second;
- timing error less than 5ppm over operating temperature range;
- providing real-time clock and calendar, and adjusting the date for leap year automatically.

In the RTC, the registers for calibration and timing cannot be reset by any reset event; and the other registers will be reset to their default states when POR/BOR, RSTn pin reset or WDT overflow event occurs.

In LPM1 state, the RTC keeps running and can be configured to wake up the system at an programmable interval of 1 day, 1 hour, 1 minute,  $1\sim64$  seconds, 500ms, 250ms, 125ms or 62.5ms. The wakeup signal will hold 8 OSC clock periods.



Figure 17-1 Architecture of RTC

# 17.1. Reading and Writing of RTC Registers

### 17.1.1. Writing of RTC

In the AL6111A, the registers INTRTC (SFR 0x96), RTC calibration registers and RTC timing registers are protected from writing.

The MCU must write of these registers following exact steps as:

- 1. writing 0x96 to the register RTCPEN to enable writing of the register RTCPWD;
- 2. writing 0x57 to the register RTCPWD to enable writing of INTRTC (SFR 0x96), RTC calibration registers and RTC timing registers;
- 3. configuring the registers INTRTC (SFR 0x96), RTC calibration registers and RTC timing registers;
- 4. writing 0x96 to the register RTCPEN to enable writing of the register RTCPWD;
- 5. writing 0x56 to the register RTCPWD to disable writing of the registers INTRTC (SFR 0x96), RTC calibration registers and RTC timing registers. 5 OSC clock cycles later, the contents of the registers are activated. A second write operation can be done to these registers only when the last configuration is completed.

# 17.1.2. Reading of RTC

To read the timing registers, the MCU must read the register RDRTC (SFR 0xDA) firstly, waits no less than 5 OSC clock cycles till the contents of the RTC timing registers are latched, and then read the timing registers for the time information.

MCU can read the calibration registers directly.

# **17.2.** Timing

When the chip is powered on, the RTC starts to run, and it keeps on running until the system is powered off.

If the timing registers are not configured, the RTC runs from a random time; otherwise, the RTC runs from the preset time.

# 17.3. RTC Interrupts

In the AL6111A, the RTC can trigger two interrupt events if they are enabled: illegal data interrupt and pulse output interrupt per second.

### Low-power Multifunctional Energy Metering SoC

# 17.3.1. RTC Illegal Data Interrupt

When the RTC illegal data interrupt is enabled (EA=1, EIE.2=1 and ExInt4IE.0=1), an illegal data interrupt will be triggered when:

- The MCU writes of the registers INTRTC (SFR 0x96), RTC calibration registers and RTC timing registers when they are still being protected from writing;
- The MCU writes the contents in an illegal format into the registers INTRTC (SFR 0x96), RTC calibration registers and RTC timing registers when the writing operation is enabled;

The contents of the timing registers are in binary-coded decimal (BCD) format, so 0xF is not considered as an illegal data.

In both circumstances, the RTC timing registers will hold the contents.

Data error caused by the system error occurs during the operation. In this circumstance, the MCU
must configure all RTC timing registers consecutively immediately the writing operation is enabled,
and then disable the writing operation to activate the correction.

# 17.3.2. Pulse Output Interrupt per Second

When EA=1, EIE.1=1 and ExInt3IE.6=1, the pulse output interrupt per second is enabled, and the RTC will output pulses of 1 second width to the MCU to trigger interrupts.

### 17.4. PLL Counter

There is a 24-bit PLL counter in the AL6111A. It can work as a PLL clock divider or a counter, which is determined by the register PLLCNT (SFR 0xDE).

When the register PLLCNT (SFR 0xDE) is set to 0x00, the PLL counter works as a divider. In this mode, the PLL counter counts from 0 and increments by 1 every OSC clock cycle. When it counts to the pre-set value of the PLL clock divider registers, this counter will be cleared, output pulses at a frequency proportional to the divided PLL clock frequency from Pin22/Pin21/Pin27, and then the counter will start recounting. The frequency of the pulse can be calculated as follows:

$$f_{DIV} = \frac{f_{MCU}}{2 \times (TH + 1)}$$
 Equation 17-1

Where,

- $f_{DIV}$ , the frequency of the pulse, Hz;
- $f_{MCU}$ , the MCU clock frequency (Hz), which has a relationship with the OSC clock frequency ( $f_{OSC}$ )as follows:

$$f_{MCU} = K \times f_{OSC}$$
 Equation 17-2

Where, K is a coefficient, equal to 100/200/400; when the theoretical  $f_{MCU}$  is 13.1072MHz, K is 400.

• TH, the preset value of the PLL divider registers (DIVTHH/DIVTHM/DIVTHL). In the default state, the value of *TH* is 0, so the MCU clock frequency is divided by 2. The MCU clock frequency can be divided

# Low-power Multifunctional Energy Metering SoC

by up to  $2^{25}$ .

When the register PLLCNT (SFR 0xDE) is configured to 0x01, the PLL counter works as a counter. When the first low-to-high transition of a reference pulse of exact 1 second width input on Pin57 (SDSP) is detected, which will configure the register to 0x02 automatically, the counter starts counting from zero. And then, when the second low-to-high transition of the reference pulse input is detected, the register PLLCNT (SFR 0xDE) is configured to 0x03 automatically, the PLL counter stops running, and the current counts is transferred to the PLL clock divider registers to calculate the actual frequency of the pulse.

# 17.5. Registers

In the RTC, the registers for calibration and timing cannot be reset by any reset event; and the other registers will be reset when POR/BOR, RSTn pin reset or WDT overflow event occurs.

Table 17-1 RTC Password Enable Register (RTCPEN, SFR 0x90)

| SFR 0x90, RTC Password Enable Register, RTCPEN |         |     |                                                                                                                                                                                                                        |  |  |  |
|------------------------------------------------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit                                            | Default | R/W | Description                                                                                                                                                                                                            |  |  |  |
| bit[7:0]                                       | 0       | W   | Only 0x96 is the valid value.  Only when this register is configured to 0x96 can the register RTCPWD (SFR 0x97) be configured validly. The write operation of both registers must be consecutive without interruption. |  |  |  |

### Table 17-2 RTC Password Register (RTCPWD, SFR 0x97)

| Table 17-2 KTC Password Register (KTCPWD, 51 K 0x97) |                                         |         |     |                                                                                                                                                                                                            |  |  |
|------------------------------------------------------|-----------------------------------------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| SFR 0x97                                             | SFR 0x97, RTC Password Register, RTCPWD |         |     |                                                                                                                                                                                                            |  |  |
| Bit                                                  |                                         | Default | R/W | Description                                                                                                                                                                                                |  |  |
| bit[7:1]                                             |                                         | 0       | W   | Bit[7:1] are writable only, but bit0 is writable and readable.  Only 0x57 and 0x56 are valid for this register.                                                                                            |  |  |
| bit0                                                 | WE                                      | 0       | R/W | Write 0x57 to this register to enable write operation on the registers INTRTC (SFR 0x96), RTC calibration registers and RTC timing registers.  Write 0x56 to this register to disable the write operation. |  |  |

#### Table 17-3 RTC Wakeup Interval Register (INTRTC, SFR 0x96)

| SFR 0x96, RTC Wakeup Interval Register, INTRTC |          |         |     |                                                                                                         |  |
|------------------------------------------------|----------|---------|-----|---------------------------------------------------------------------------------------------------------|--|
| Bit                                            |          | Default | R/W | Description                                                                                             |  |
| bit[7:3]                                       |          | 0       | R/W |                                                                                                         |  |
| bit[2:0]                                       | RTC<2:0> | 0       | R/W | 000: 1 second; 001: 1 minute; 010: 1 hour; 011: 1 day; 100: 500ms; 101: 250ms; 110: 125ms; 111: 62.5ms. |  |

# **Low-power Multifunctional Energy Metering SoC**

| SFR | 0x96.  | RTC | Wakeup        | Interval   | Register, | <b>INTRTC</b> |
|-----|--------|-----|---------------|------------|-----------|---------------|
| O   | 0,100, |     | · · · · · · · | 111CC1 VG1 |           |               |

| Bit | Default | R/W | Description |
|-----|---------|-----|-------------|

Configure this register for the interval at which the RTC will wake up the system from LPM1 state. The wakeup signal holds 8 OSC clock periods.

#### Table 17-4 RTC Seconds Wake-up Interval Configuration Register (SECINT, SFR 0xDF)

| SFR 0xDI | SFR 0xDF, R/W, RTC Seconds Wake-up Interval Configuration Register, SECINT |         |                                                                                                                                                                                                                                                                        |  |  |  |  |
|----------|----------------------------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit      | R/W                                                                        | Default | Description                                                                                                                                                                                                                                                            |  |  |  |  |
| Bit7     | R/W                                                                        | 0       | Reserved                                                                                                                                                                                                                                                               |  |  |  |  |
| Bit6     | R/W                                                                        | 0       | It is mandatory to set register INTRTC (SFR $0x96$ ) to $0x07$ , and then set this bit to 1 to enable writing of bit[5:0] of this register.                                                                                                                            |  |  |  |  |
| Bit[5:0] | R/W                                                                        | 0       | To set interval in unit of second for RTC to wake up the system from LPM1 state. The actual wakeup interval is equal to (bit[5:0]+1) seconds, of which bit[5:0] can be set to $1\sim63$ (decimal). Setting these bits to 0 (decimal) forces the interval to be 62.5ms. |  |  |  |  |

#### Table 17-5 Flag Bit of RTC Wakeup Event

| SFR 0xA | SFR 0xA1, R, System State Register, Systate |                                                                                                                                                                |  |  |  |  |  |  |
|---------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bit     | Default                                     | Description                                                                                                                                                    |  |  |  |  |  |  |
| Bit2    | 0                                           | When this bit is read out as 1, but bit CFWK (bit3 of IOWKDET, SFR 0xAF) is cleared, it indicates the system was woken up from LPM1 state by RTC wakeup event. |  |  |  |  |  |  |
| RTC/CF  | U                                           | If both this bit and bit CFWK are set to 1s, it indicates the system was woken up from LPM1 state by CF pulse wakeup event.                                    |  |  |  |  |  |  |

### Table 17-6 RTC Calibration Registers (RTCCH/RTCCL, SFR 0x94/0x95)

| The register is in the                    |
|-------------------------------------------|
|                                           |
| provided by the OSC                       |
| en the counts is up to                    |
| econds to be 1s. The stment range is over |
| e pulse even the cou<br>econds to         |

### Low-power Multifunctional Energy Metering SoC

#### Table 17-7 RTC Data Reading Enable Register (RDRTC, SFR 0xDA)

| SFR 0xD/ | SFR 0xDA, RTC Data Reading Enable Register, RDRTC |   |                                                                                                                                    |  |  |  |  |  |  |
|----------|---------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bit      | Default R/W Description                           |   |                                                                                                                                    |  |  |  |  |  |  |
| bit[7:0] | 0                                                 | R | The MCU must read this register to enable read operation on the RTC timing registers. This register is read out as $0 \times 00$ . |  |  |  |  |  |  |

#### Table 17-8 PLL Clock Divider Registers (DIVTHH/DIVTHM/DIVTHL, SFR 0xDB/0xDC/0xDD)

| Register         | Bit      |            | Default | R/W | Description                           |
|------------------|----------|------------|---------|-----|---------------------------------------|
| SFR 0xDB, DIVTHH | bit[7:0] | DIV<23:16> | 0       | R/W | High byte of the PLL clock divider.   |
| SFR 0xDC, DIVTHM | bit[7:0] | DIV<15:8>  | 0       | R/W | Middle byte of the PLL clock divider. |
| SFR 0xDD, DIVTHL | bit[7:0] | DIV<7:0>   | 0       | R/W | Low byte of the PLL clock divider.    |

#### Table 17-9 PLL Counter State Register (PLLCNT, SFR 0xDE)

| SFR 0xDE, PLL Counter State Register, PLLCNT, R/W |         |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|---------------------------------------------------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit                                               | Default | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| bit[7:2]                                          | 0       | R/W | When this register is cleared to 0x00, the PLL counter works as a divider.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| bit[1:0]<br>STT<1:0>                              | 0       | R/W | When the PLL counter increments from 0 to the value of the PLL clock divider registers, this counter is cleared, outputs a pulse at a frequency proportional to the divided PLL clock frequency, and then starts recounting.  When this register is set to 0x01, the PLL counter works as a counter. When the first low-to-high transition of the reference pulse of exact 1 second width input on Pin57(SDSP) is detected, which will set this register to 0x02 automatically, the counter starts counting from zero. And then, when the second low-to-high transition of the reference pulse input is detected, the register is configured to 0x03 automatically, the PLL counter stops running, and the current counts is transferred to the PLL clock divider registers to calculate the actual frequency of the pulse per second. |  |  |  |  |

The time and calendar information is obtained by reading the appropriate register bytes. The contents of the timing registers, except the register for day of week configuration, are in binary-coded decimal (BCD) format, of which bit7~bit4 represents the tens digit of the time and calendar, and bit3~bit0 represents the units digit of the time and calendar; for example, 0b1000011 in the register RTCSC represents 43 seconds. The RTC can provide second, hour, day, week, month and year information. As such, both RTCSC (seconds) and RTCMiC (minutes) range 0~59, RTCHC (hour) ranges 0~24, RTCDC (day) ranges 1~31, RTCMoC (month) ranges 1~12 and RTCYC (year) ranges 0~99.

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

#### **Table 17-10 RTC Timing Registers**

| Register    |                                              | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------------|----------------------------------------------|------|------|------|------|------|------|------|------|
| SFR<br>0x9A | RTCSC, to set the second information, 0~59.  | -    | S40  | S20  | S10  | S8   | S4   | S2   | S1   |
| SFR<br>0x9B | RTCMiC, to set the minute information, 0~59. | -    | M40  | M20  | M10  | M8   | M4   | M2   | M1   |
| SFR<br>0x9C | RTCHC, to set the hour information, 0~23.    | -    | -    | H20  | H10  | Н8   | H4   | H2   | H1   |
| SFR<br>0x9D | RTCDC, to set the day information, 1~31.     | -    | -    | D20  | D10  | D8   | D4   | D2   | D1   |
| SFR<br>0x9E | RTCWC, to set the day of week information.   | -    | -    | -    | -    | W8   | W4   | W2   | W1   |
| SFR<br>0x9F | RTCMoC, to set the month information, 1~12.  | -    | -    | -    | Mo10 | Mo8  | Mo4  | Mo2  | Mo1  |
| SFR<br>0x93 | RTCYC, to set the year information, 00~99.   | Y80  | Y40  | Y20  | Y10  | Y8   | Y4   | Y2   | Y1   |
| Default     |                                              | Х    | X    | Х    | Х    | Х    | Х    | Х    | Х    |

Users must set the day of week information for one date; for example, set the date 1st Jan. 2010 to be Friday, and the RTC will determine the date 2nd, Jan., 2010 to be Saturday automatically. 0b0000: Sunday; 0b0001: Monday; 0b0010: Tuesday; 0b0011: Wednesday; 0b0100: Thursday; 0b0101: Friday; 0b0110: Saturday.

For the year information, only the tens and units digits of the year need to be configured in the register RTCYC; for example, 0b00010000 represents the year 2010.

# 18. Registers

# 18.1. Analog Control Registers

In the AL6111A, analog control registers are located at addresses 0x2858~0x2868. The registers are readable and writable. When POR/BOR, RSTn pin reset or WDT overflow reset occurs, the analog control registers will be reset to their default states. In this section, the default values are in decimal form unless otherwise noted.

The register located at address 0x285F must be configured to its default values for proper operation.

Users can read of bytes located at addresses 0x300C~0x3059 to obtain the recommended configuration of the analog registers, and write them to the analog registers.

Table 18-1 ADC Control Register 0 (CtrlADC0, 0x2858)

| 0x2858,  | 0x2858, R/W, ADC Control Register 0, CtrlADC0 |         |                                                                                                                                                                                                                                                            |  |  |  |  |
|----------|-----------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit      |                                               | Default | Description                                                                                                                                                                                                                                                |  |  |  |  |
| Bit7     | Reserved                                      | 0       | This bit must hold its default value for proper operation.                                                                                                                                                                                                 |  |  |  |  |
| Bit6     | ADCGU                                         | 0       | To set analog PGA gain for voltage input to Voltage Channel (U) ADC.  This bit must hold its default value for proper operation.  0: ×1; 1: ×2.                                                                                                            |  |  |  |  |
| Bit[5:3] | ADCGB<2:0>                                    | 0       | To set analog PGA gain for current input to Current Channel B (IB) ADC.  000: ×1; 001: ×4; 010: ×8; 011: ×16; 100/101/110/111: ×32.  To match the output signal from the sensor to the measurement scale of the ADC, the default value should not be used. |  |  |  |  |
| Bit[2:0] | ADCGA<2:0>                                    | 0       | To set analog PGA gain for current input to Current Channel A (IA) ADC.  000: ×1; 001: ×4; 010: ×8; 011: ×16; 100/101/110/111: ×32.  To match the output signal from the sensor to the measurement scale of the ADC, the default value should not be used. |  |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

### Table 18-2 ADC Control Register 2 (CtrlADC2, 0x285A)

| 0x285A,  | 0x285A, R/W, ADC Control Register 2, CtrlADC2 |         |                                                                                                                                                                        |  |  |  |  |
|----------|-----------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit      |                                               | Default | Description                                                                                                                                                            |  |  |  |  |
| bit[7:5] | Reserved                                      | 0       | These bits must hold their default values for proper operation.                                                                                                        |  |  |  |  |
| bit4     | Reserved                                      | 0       |                                                                                                                                                                        |  |  |  |  |
| bit3     | ADRSTM                                        | 0       | To reset the integrator in the modulator in the ADC of Channel M.  When some errors occur to the data output from the ADC, set this bit to 1 to reset the integrator.  |  |  |  |  |
| bit2     | ADRSTU                                        | 0       | To reset the integrator in the modulator in the ADC of Channel U.  When some errors occur to the data output from the ADC, set this bit to 1 to reset the integrator.  |  |  |  |  |
| bit1     | ADRSTB                                        | 0       | To reset the integrator in the modulator in the ADC of Channel IB.  When some errors occur to the data output from the ADC, set this bit to 1 to reset the integrator. |  |  |  |  |
| bit0     | ADRSTA                                        | 0       | To reset the integrator in the modulator in the ADC of Channel IA.  When some errors occur to the data output from the ADC, set this bit to 1 to reset the integrator. |  |  |  |  |

#### Table 18-3 Battery Discharge Control Register (CtrlBAT, 0x285C)

|          | Table 10 0 1 access, 1 access go common megicial (emiliarily existent) |         |                                                                                                               |  |  |  |  |
|----------|------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0x285C,  | 0x285C, R/W, Battery Discharge Control Register, CtrlBAT               |         |                                                                                                               |  |  |  |  |
| Bit I    |                                                                        | Default | Description                                                                                                   |  |  |  |  |
| bit[7:4] | Reserved                                                               | 0       | These bits must hold their default values for proper operation.                                               |  |  |  |  |
| bit3     | LCDBMOD                                                                | 0       | When the LCD driver works in 1/8 duty mode, set this bit to select the bias ratio.  0: 1/3 Bias; 1: 1/4 Bias. |  |  |  |  |
|          |                                                                        |         | When the LCD driver works in $1/4$ or $1/6$ duty mode, $1/3$ Bias ratio is used whatever this bit is set.     |  |  |  |  |
| bit[2:1] | Reserved                                                               | 0       |                                                                                                               |  |  |  |  |
| bit0     | BATDISC                                                                | 0       | To enable discharging the battery. 1: enable; 0: disable.                                                     |  |  |  |  |

# Low-power Multifunctional Energy Metering SoC

### Table 18-4 LCD Driver Voltage Control Register (CtrlLCDV, 0x285E)

| 0x285E, R/W, LCD Driver Voltage Control Register, CtrlLCDV |          |         |                                                                                                                                                                                                                  |  |  |  |
|------------------------------------------------------------|----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit Default                                                |          | Default | Description                                                                                                                                                                                                      |  |  |  |
| Bit7                                                       | DCENN    | 0       | By default additional 10mV direct voltage offset is applied to the current input to current channel ADCs. Set this bit to 1 to disable this function. This bit must hold its default value for proper operation. |  |  |  |
| Bit[6:3]                                                   | Reserved | 0       | These bits must hold their default values for proper operation.                                                                                                                                                  |  |  |  |
| bit2                                                       | VLCD     | 0       | To adjust the LCD waveform voltage. 0: 3.3V; 1: 3.0V.                                                                                                                                                            |  |  |  |
| bit[1:0]                                                   | Reserved | 0       | These bits must hold their default values for proper operation.                                                                                                                                                  |  |  |  |

### Table 18-5 Crystal Control Register 1 (CtrlCry1, 0x2860)

| 0x2860,     | 0x2860, R/W, Crystal Control Register 1, CtrlCry1 |               |                                                                                                                             |  |  |  |                                                                                                                                                                                                                                                                                    |
|-------------|---------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit Default |                                                   | Default       | Description                                                                                                                 |  |  |  |                                                                                                                                                                                                                                                                                    |
| Bit[7:5]    | Reserved                                          | 0             | These bits must hold their default values for proper operation.                                                             |  |  |  |                                                                                                                                                                                                                                                                                    |
| Bit4        | CSEL                                              | 0             | The fixed capacitance in the crystal oscillator circuit is 12.5pF. Set this bit to 1 to decrease the capacitance by 2.35pF. |  |  |  |                                                                                                                                                                                                                                                                                    |
| Bit3        | Reserved                                          | 0             | These bits must hold their default values for proper operation.                                                             |  |  |  |                                                                                                                                                                                                                                                                                    |
|             | Bit[2:0] XTRSEL[2:0]                              |               |                                                                                                                             |  |  |  | To adjust the resistance of the resistors in the internal crystal oscillator circuit. When the RTC is used, these bits must be set to 0b011, and the oscillation monitoring circuit must be enabled. Set bit XTRSEL[2] to 1 to increment the resistance to P end by $400k\Omega$ . |
| Bit[2:0]    |                                                   | CTRSEL[2:0] 0 | XTRSEL[2:0] to adjust the resistance to N end:                                                                              |  |  |  |                                                                                                                                                                                                                                                                                    |
|             |                                                   |               | 00/01: hold the resistance to N end.   10: increment by $128k\Omega$ .                                                      |  |  |  |                                                                                                                                                                                                                                                                                    |
|             |                                                   |               | 11: increment by $64k\Omega$ .                                                                                              |  |  |  |                                                                                                                                                                                                                                                                                    |

# **Low-power Multifunctional Energy Metering SoC**

### Table 18-6 Crystal Control Register 2 (CtrlCry2, 0x2861)

| 0x2861, R/W, Crystal Control Register 2, CtrlCry2 |               |         |                                                                                                                                                                                                                      |  |  |  |
|---------------------------------------------------|---------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit                                               |               | Default | Description                                                                                                                                                                                                          |  |  |  |
| Bit7                                              | Reserved      | 0       |                                                                                                                                                                                                                      |  |  |  |
| Bit6                                              | Reserved      | 0       | This bit must hold its default value for proper operation. By default this function is disabled.                                                                                                                     |  |  |  |
| bit5                                              | XRESETEN      | 0       | Set this bit to 1 to enable the oscillation monitor.                                                                                                                                                                 |  |  |  |
| Bit4                                              | Reserved      | 0       |                                                                                                                                                                                                                      |  |  |  |
| bit[3:2]                                          | CMPSSELB<1:0> | 0       | To select the analog input to the comparator CB.  00: M2 for positive input; REF_LP for negative input;  01: M1 for positive input; REF_LP for negative input;  10/11: M2 for positive input; M1 for negative input. |  |  |  |
| Bit[1:0]                                          | Reserved      | 0       | These bits must hold their default values for proper operation.                                                                                                                                                      |  |  |  |

### Table 18-7 ADC Control Register 5 (CtrlADC5, 0x2863)

| 0x2863,     | 0x2863, R/W, ADC Control Register 5, CtrlADC5 |         |                                                                                                                                                                                                                                                              |  |  |  |
|-------------|-----------------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit Default |                                               | Default | Description                                                                                                                                                                                                                                                  |  |  |  |
| Bit[7:6]    | Reserved                                      | 0       | These bits must hold their default values for proper operation.                                                                                                                                                                                              |  |  |  |
| Bit5        | GDE4                                          | 0       | To set analog PGA gain for signal input to various Measurement Channel (M) ADC. $0: \times 1; 1: \times 1/4.$                                                                                                                                                |  |  |  |
| bit4        | RESDIV                                        | 0       | To set the division coefficient of the resistor divider network in M Channel. 0: $\times 1$ ; 1: $\times 1/4$ .                                                                                                                                              |  |  |  |
| Bit3        | Reserved                                      | 0       | This bit must hold its default value for proper operation.                                                                                                                                                                                                   |  |  |  |
| Bit[2:0]    | MEAS<2:0>                                     | 0       | To select the analog input to be measured in Channel M.  000: ground;  001: temperature;  010: battery voltage or other external DC voltage via pin BAT.  011/100/101: reserved;  110: external DC voltage via pin M1;  111: external DC voltage via pin M2. |  |  |  |

# Low-power Multifunctional Energy Metering SoC

0x2863, R/W, ADC Control Register 5, CtrlADC5

Bit Default Description

Note: When the pins M1 and M2 are used for analog input for Channel M, bit7 and bit 6 of the register SegCtrl4 (0x2C23) must be cleared to disable the SEG output on the pins.

#### Table 18-8 ADC Control Register 6 (CtrlADC6, 0x2864)

| 0x2864, R/W, ADC Control Register 6, CtrlADC6 |          |   |                                                                 |  |  |
|-----------------------------------------------|----------|---|-----------------------------------------------------------------|--|--|
| Bit                                           | Bit      |   | Description                                                     |  |  |
| bit[7:6]                                      | Reserved | 0 | These bits must hold their default values for proper operation. |  |  |
| bit5                                          | CMPPDNB  | 0 | To enable the comparator CB. 0: disable; 1: enable.             |  |  |
| bit4                                          | Reserved | 0 | This bit must hold its default value for proper operation.      |  |  |
| bit3                                          | ADCMPDN  | 0 | To enable Channel M ADC. 0: disable; 1: enable.                 |  |  |
| bit2                                          | ADCUPDN  | 0 | To enable Channel U ADC. 0: disable. 1: enable.                 |  |  |
| bit1                                          | ADCBPDN  | 0 | To enable Channel IB ADC. 0: disable; 1: enable.                |  |  |
| bit0                                          | ADCAPDN  | 0 | To enable Channel IA ADC. 0: disable; 1: enable.                |  |  |

#### Table 18-9 Channel M Control Register (CtrlM, 0x2865)

| 0x2865,  | 0x2865, R/W, Channel M Control Register, CtrlM |         |                                                                                                                                                                                                                                       |  |  |  |
|----------|------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit      |                                                | Default | Description                                                                                                                                                                                                                           |  |  |  |
| bit[7:1] | Reserved                                       | 0       | These bits must hold their default values for proper operation.                                                                                                                                                                       |  |  |  |
| bit0     | MADCHOPN                                       | 0       | By default the ADC offset of the input signal into the M Channel will be removed. When M Channel is used to measure temperature, it is recommended to set this bit to 1 to disable this function to improve the measurement accuracy. |  |  |  |

#### Table 18-10 LDO Control Register (CtrlLDO, 0x2866)

| 0x2866, R/W, LDO Control Register, CtrlLDO |       |   |                                                                                                                                                                                                                                                              |  |  |
|--------------------------------------------|-------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                                        | Bit   |   | Description                                                                                                                                                                                                                                                  |  |  |
|                                            |       |   | Set this bit to 1 to disable the internal power detection circuit. By default this circuit is enabled.                                                                                                                                                       |  |  |
| Bit7                                       | PDDET | 0 | When the chip is 3.3V powered, users must set this bit to 1 to disable the power detection circuit, to prevent current leakage of the battery when a battery is connected to the device.  When the chip is 5V powered, this bit must hold its default value. |  |  |



# Low-power Multifunctional Energy Metering SoC

| 0x2866,  | 0x2866, R/W, LDO Control Register, CtrlLDO |   |                                                                                                                                                   |  |  |
|----------|--------------------------------------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit      | Bit                                        |   | Description                                                                                                                                       |  |  |
| Bit6     | Bit6 Reserved                              |   |                                                                                                                                                   |  |  |
| Bit[5:3] | LDO3SEL<2:0>                               | 0 | To adjust output voltage of LDO33.  000: 3.3V; 001: 3.2V; 010/100/101: 3.5V; 011: 3.4V; 110: 3.1V; 111: 3.0V.                                     |  |  |
| Bit[2:0] | LDOV2SEL<2:0>                              | 0 | To adjust output voltage of digital power circuit.  000: +0V; 001: -0.1V; 010: +0.2V; 011: +0.1V; 100: -0.4V; 101: -0.5V; 110: -0.2V; 111: -0.3V. |  |  |

### Table 18-11 Clock Control Register (CtrlCLK, 0x2867)

| 0x2867,  | 0x2867, R/W, Clock Control Register, CtrlCLK |                     |                                                                                                                         |  |  |
|----------|----------------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit      |                                              | Default Description |                                                                                                                         |  |  |
| bit7     | PLLPDN 0                                     |                     | To enable the PLL circuit. 0: disable; 1: enable.  Enable the BandGap circuit, and then enable the PLL circuit.         |  |  |
| bit6     | BGPPDN                                       | 0                   | To enable the BandGap circuit. 0: disable; 1: enable.  Enable the BandGap circuit, and then enable the PLL circuit.     |  |  |
| bit[5:4] | ADCLKSEL<1:0>                                | 0                   | To configure the sampling frequency of the oversampling ADCs (ADCCLK). Base: 204.8kHz.  00: ×1; 01: ×2; 10: ×4.         |  |  |
| bit[3:2] | MEACLKSEL<1:0>                               | 0                   | To configure the clock frequency for the energy metering architecture (MTCLK). Base: 819.2kHz.  00: ×1; 01: ×2; 10: ×4. |  |  |
| bit[1:0] | MCUCLKSEL<1:0>                               | 0                   | To adjust the clock frequency for the MCU (MCUCLK). Base: 819.2kHz.  00: ×1; 01: ×2; 10: ×4; 11: ×8.                    |  |  |

### Table 18-12 PLL Control Register (CtrlPLL, 0x2868)

| 0x2868, R/W, PLL Control Register, CtrlPLL |        |         |                                                                                        |  |  |
|--------------------------------------------|--------|---------|----------------------------------------------------------------------------------------|--|--|
| Bit Default                                |        | Default | Description                                                                            |  |  |
| bit7                                       | MCU26M | 0       | When the bit MCU13M is set to 1, set this bit to 1 to double MCUCLK frequency further. |  |  |
| bit6                                       | MCU13M | 0       | Set this bit to 1 to double MCUCLK frequency.                                          |  |  |



# **Low-power Multifunctional Energy Metering SoC**

| 0x2868, R/W, PLL Control Register, CtrlPLL |          |         |                                                                 |  |  |
|--------------------------------------------|----------|---------|-----------------------------------------------------------------|--|--|
| Bit Defau                                  |          | Default | Description                                                     |  |  |
| bit5                                       | PLLSEL   | 0       | To apply the chip to 50Hz or 60Hz power grid. 0: 50Hz; 1: 60Hz. |  |  |
| bit[4:0]                                   | Reserved | 0       | These bits must hold their default values for proper operation. |  |  |

### Table 18-13 Analog Circuits State Register (ANState, 0x286B)

| 0x286B,  | 0x286B, R, Analog Circuits State Register, ANState |         |                                                                                                                                                                                                                         |  |  |  |
|----------|----------------------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit      |                                                    | Default | Description                                                                                                                                                                                                             |  |  |  |
| bit7     | OSC                                                | 0       | To indicate the state of the OSC clock.  0: the crystal is working.  1: the crystal stops running, and all the circuits, including PLL circuit, sourced by the OSC clock now is being sourced by the internal RC clock. |  |  |  |
| Bit6     | Reserved                                           | -       |                                                                                                                                                                                                                         |  |  |  |
| bit5     | СОМРВ                                              | 0       | To indicate the output of the comparator CB.  1: the positive input is higher than the negative input;  0: the negative input is higher than the positive input.                                                        |  |  |  |
| bit[4:2] | Reserved                                           | 5       | It is read out as 0x5.                                                                                                                                                                                                  |  |  |  |
| bit[1:0] | Reserved                                           | -       |                                                                                                                                                                                                                         |  |  |  |

# 18.2. Metering Control Registers

When POR/BOR, RSTn pin reset or WDT overflow reset occurs, all metering control registers are reset to their default states.

All the default values in this section are in decimal form if not specifically noted.

#### Table 18-14 PM Control Register 1 (PMCtrl1, 0x2878)

| 0x2878, R/W, PM Control Register 1, PMCtrl1 |          |         |                                                                                                                                                                                                                                                                                                                   |  |  |
|---------------------------------------------|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                                         |          | Default | Description                                                                                                                                                                                                                                                                                                       |  |  |
| bit7                                        | Reserved | 0       |                                                                                                                                                                                                                                                                                                                   |  |  |
| bit6                                        | PHCEN    | 0       | To enable phase compensation. 0: disable; 1: enable.  When phase compensation is enabled, the phase angle errors between U and IA, and U and IB, are corrected respectively.                                                                                                                                      |  |  |
| bit5                                        | SELI     | 0       | To exchange the current channels.  0: current IA is sent to Current I1 Channel for signal processing, and current IB is sent to Current I2 Channel for signal processing;  1: current IA is sent to Current I2 Channel for signal processing, and current IB is sent to Current I1 Channel for signal processing. |  |  |
| bit4                                        | PREN     | 0       | To enable power and RMS calculation, and digital signal processing in M Channel. 0: disable; 1: enable.                                                                                                                                                                                                           |  |  |
| bit3                                        | ONM      | 0       | To enable digital signal input to M channel.  0: disable; 0 is input to M channel. 1: enable.                                                                                                                                                                                                                     |  |  |
| Bit2                                        | ONI2     | 0       | To enable digital signal input to the I2 channel. 0: disable; 0s are input to I2 channel. 1: enable.                                                                                                                                                                                                              |  |  |
| Bit1                                        | ONI1     | 0       | To enable digital signal input to the I1 channel. 0: disable; 0s are input to I1 channel. 1: enable.                                                                                                                                                                                                              |  |  |
| Bit0                                        | ONU      | 0       | To enable digital signal input to the U channel. 0: disable; 0s are input to U channel. 1: enable.                                                                                                                                                                                                                |  |  |

# **Low-power Multifunctional Energy Metering SoC**

### Table 18-15 PM Control Register 2 (PMCtrl2, 0x2879)

| 0x2879,  | 0x2879, R/W, PM Control Register 2, PMCtrl2 |         |                                                                                                                                                                             |  |  |
|----------|---------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit      |                                             | Default | Description                                                                                                                                                                 |  |  |
| bit7     | PGACS                                       | 0       | To set sign of the digital PGA gain for I1 signal. 0: positive; 1: negative.                                                                                                |  |  |
| bit[6:4] | PGAC2~PGAC0                                 | 0       | To set the digital PGA gain for I1 signal. Gain= $2^{PGACx}$ . PGACx is in the range of $0\sim5$ .                                                                          |  |  |
| bit3     | PGAUS                                       | 0       | To set sign of the digital PGA for U signal. 0: positive; 1: negative.                                                                                                      |  |  |
| bit[2:0] | PGAU2~PGAU0                                 | 0       | To set the digital PGA gain for U signal. Gain= $2^{PGAUx}$ . PGAUx is in the range of $0\sim5$ .  When bit LPFEN (bit5 of PMCtrl3, $0x287A$ ) is set to 1, the digital PGA |  |  |
| 5.0[210] | . 5.152 1 6.160                             | Ü       | gain for U signal is lowered to 1/4 of its configuration. When bit LPFEN is cleared, the digital PGA gain for U signal is what it is configured.                            |  |  |

### Table 18-16 PM Control Register 3 (PMCtrl3, 0x287A)

| 0x287A, R/W, PM Control Register 3, PMCtrl3 |       |         |                                                                                                                                                                                                                                                                                                                                        |  |
|---------------------------------------------|-------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit                                         |       | Default | Description                                                                                                                                                                                                                                                                                                                            |  |
| bit7                                        | X0EN  | 0       | Set this bit to 1 to enable zero-crossing interrupt to MCU. By default this interrupt is masked.                                                                                                                                                                                                                                       |  |
| bit6                                        | BPFEN | 0       | To enable the band-pass filter in the voltage/current RMS calculation circuits. 0: disable; 1: enable.  This filter can improve the RMS calculation accuracy, but it will lead to harmonics loss. When a low signal is input, this filter will introduce greater truncation noise and prolong the period for the system to be settled. |  |
| bit5                                        | LPFEN | 0       | When this bit is set to 1, the digital PGA gain for U signal is lowered to 1/4 of its configuration. When this bit is cleared, the digital PGA gain for U signal is what it is configured.                                                                                                                                             |  |

# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| 0x287A, R/W, PM Control Register 3, PMCtrl3 |             |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|---------------------------------------------|-------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                                         |             | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| bit4                                        | DBLEN       | 0       | To select the function of E2 path.  0: for reactive power calculation and energy metering based on current I1. If positive current I1 is input to the path, the reactive power is negative, and it is accumulated to the negative energy accumulators; if negative current I1 is input to the path, the reactive power is positive, and it is accumulated to the positive energy accumulators.  1: for active power calculation and energy metering based on current I2. |  |  |
| bit3                                        | PGANS       | 0       | To set sign of the digital PGA gain for I2 signal. 0: positive; 1: negative.                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| bit[2:0]                                    | PGAN2~PGAN0 | 0       | To set the digital PGA gain for I2 signal. Gain= $2^{PGANx}$ . PGANx is in the range of $0\sim5$ .                                                                                                                                                                                                                                                                                                                                                                       |  |  |

### Table 18-17 Phase Compensation Control Register 1 (PHCCtrl1, 0x287B)

| 0x287B, R/W, Phase Compensation Control Register 1, PHCCtrl1 |           |         |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|--------------------------------------------------------------|-----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit                                                          |           | Default | Description                                                                                                                                                                                                                                                                                                                            |  |  |  |
| bit7                                                         | PHCA7     | 0       | To select the signal to be delayed. 1: to delay voltage; 0: to delay current I1.                                                                                                                                                                                                                                                       |  |  |  |
| bit6                                                         | PHCA6     | 0       | Not used.                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Bit[5:0]                                                     | PHCA<5:0> | 0       | Together with bit IAPHC (bit[1:0] of CRPST, 0x287F) as the right 2 bits, these 8 bits are to set the time to be delayed. When the sampling frequency of phase compensation circuit ( $f_{smpl}$ ) is 3.2768MHz, the resolution of the phase compensation is 0.0055°/lsb, and 1.4° in total of the phase angle error can be calibrated. |  |  |  |

### Table 18-18 Phase Compensation Control Register 2 (PHCCtrl2, 0x287C)

| 0x287C,     | 0x287C, R/W, Phase Compensation Control Register 2, PHCCtrl2 |   |                                                                                  |  |  |  |  |
|-------------|--------------------------------------------------------------|---|----------------------------------------------------------------------------------|--|--|--|--|
| Bit Default |                                                              |   | Description                                                                      |  |  |  |  |
| bit7        | PHCB7                                                        | 0 | To select the signal to be delayed. 1: to delay voltage; 0: to delay current I2. |  |  |  |  |
| bit6        | PHCB6                                                        | 0 | Not used.                                                                        |  |  |  |  |

# Low-power Multifunctional Energy Metering SoC

| 0x287C, R/W, Phase Compensation Control Register 2, PHCCtrl2 |           |         |                                                                                                                                                                                                                                                                                                                                        |  |  |
|--------------------------------------------------------------|-----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit Default                                                  |           | Default | Description                                                                                                                                                                                                                                                                                                                            |  |  |
| Bit[5:0]                                                     | PHCB<5:0> | 0       | Together with bit IBPHC (bit[3:2] of CRPST, 0x287F) as the right 2 bits, these 8 bits are to set the time to be delayed. When the sampling frequency of phase compensation circuit ( $f_{smpl}$ ) is 3.2768MHz, the resolution of the phase compensation is 0.0055°/lsb, and 1.4° in total of the phase angle error can be calibrated. |  |  |

### Table 18-19 PM Control Register 4 (PMCtrl4, 0x287D)

| 0x287D,  | 0x287D, R/W, PM Control Register 4, PMCtrl4 |         |                                                                                                                                                                                                           |  |  |
|----------|---------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit      |                                             | Default | Description                                                                                                                                                                                               |  |  |
| bit7     | CRPENR                                      | 0       | To enable no-load detection of E2 path. 0: disable; 1: enable.                                                                                                                                            |  |  |
| bit6     | CRPEN                                       | 0       | To enable no-load detection of E1 path. 0: disable; 1: enable.                                                                                                                                            |  |  |
| bit5     | CFENR                                       | 0       | To enable CF pulse output of E2 path. 0: disable; 1: enable.                                                                                                                                              |  |  |
| bit4     | CFEN                                        | 0       | To enable CF pulse output of E1 path. 0: disable; 1: enable.                                                                                                                                              |  |  |
| bit3     | EGYEN                                       | 0       | To enable energy accumulation and energy-to-pulse conversion. 0: disable; 1: enable.                                                                                                                      |  |  |
| bit2     | CFXCG                                       | 0       | To select the pins for CF pulse output.  0: CF1 pin for E1 path, CF2 pin for E2 path;  1: CF2 pin for E1 path, CF1 pin for E2 path.                                                                       |  |  |
| bit[1:0] | PSEL1/PSEL0                                 | 0       | To select the source for positive active energy accumulation in E1 path.  00/11: active power calculated based on current I1; 01: I1 current RMS;  10: a constant preset in the register DATACP (0x10FC). |  |  |

# **Low-power Multifunctional Energy Metering SoC**

### Table 18-20 CF Pulse Output Control Register (CFCtrl, 0x287E)

| 0x287E,  | 0x287E, R/W, CF Pulse Output Control Register, CFCtrl |         |                                                                                                                                                                                                                                                                              |  |  |  |  |
|----------|-------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit      |                                                       | Default | efault Description                                                                                                                                                                                                                                                           |  |  |  |  |
| bit[7:6] | CFQR1/CFQR0                                           | 0       | To adjust the energy pulse generation rate in E2 path. 00: $\times$ 1; 01: $\times$ 4; 10: $\times$ 8; 11: $\times$ 16. When low current signal is applied, configure these bits to accelerate meter calibration.                                                            |  |  |  |  |
| bit[5:4] | CFQ1/CFQ0                                             | 0       | To adjust the energy pulse generation rate in E1 path. 00: $\times$ 1; 01: $\times$ 4; 10: $\times$ 8; 11: $\times$ 16. When low current signal is applied, configure these bits to accelerate meter calibration.                                                            |  |  |  |  |
| bit[3:2] | CFSELR1/CFSELR0                                       | 0       | To select the energy in E2 path to be converted into pulse.  01: positive active or reactive energy in E2 path; 10: negative active or reactive energy in E2 path;  00/11: the sum of the absolute values of the positive and negative active or reactive energy in E2 path. |  |  |  |  |
| bit[1:0] | CFSEL1/CFSEL0                                         | 0       | To select the energy in E1 path to be converted into pulse.  01: positive active energy in E1 path; 10: negative active energy in E1 path;  00/11: the sum of the absolute values of the positive and negative active energy in E1 path.                                     |  |  |  |  |

# **Low-power Multifunctional Energy Metering SoC**

Table 18-21 No-Load Detection Indication Register (CRPST, 0x287F)

| 0x287F, No-Load Detection Indication Register, CRPST |        |     |         |                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|------------------------------------------------------|--------|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit                                                  |        | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Bit7                                                 | CRPST  | R   | 0       | To indicate the state of E1 path. 0: metering energy; 1: creeping.                                                                                                                                                                                                                                                                            |  |  |  |
| Bit6                                                 | CRPSTR | R   | 0       | To indicate the state of E2 path. 0: metering energy; 1: creeping.                                                                                                                                                                                                                                                                            |  |  |  |
| Bit[5:4]                                             | CFWD   |     | 0       | To adjust the CF pulse width.  00: 80ms; 01: 40ms; 10: 20ms; 11: 10ms.                                                                                                                                                                                                                                                                        |  |  |  |
| Bit[3:2]                                             | IBPHC  | R/W | 0       | Together with bits PHCB<5:0> (bit[5:0] of PHCCtrl2, 0x287C) as the left 6 bits, these 8 bits are to set the time to be delayed. When the sampling frequency of phase compensation circuit ( $f_{smpl}$ ) is 3.2768MHz, the resolution of the phase compensation is 0.0055°/lsb, and 1.4° in total of the phase angle error can be calibrated. |  |  |  |
| Bit[1:0]                                             | IAPHC  | R/W | 0       | Together with bits PHCA<5:0> (bit[5:0] of PHCCtrl1, 0x287B) as the left 6 bits, these 8 bits are to set the time to be delayed. When the sampling frequency of phase compensation circuit ( $f_{smpl}$ ) is 3.2768MHz, the resolution of the phase compensation is 0.0055°/lsb, and 1.4° in total of the phase angle error can be calibrated. |  |  |  |

#### Table 18-22 Current Detection Control Register (IDET, 0x2886)

| 0x2886, | 0x2886, R/W, Current Detection Control Register, IDET |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|---------|-------------------------------------------------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit     |                                                       | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Bit7    | GT                                                    | R/W | 0       | Set this bit to 1 to disable the sampling circuits and power/RMS calculation circuits. In this case, the energy accumulation circuit keeps on working. So, in an application to accumulate a constant for energy accumulation, it is recommended to set this bit to 1 to lower power consumption further. But please note the threshold for energy-to-pulse conversion must be set before setting this bit to 1. |  |  |  |
| Bit6    | CST                                                   | R   | 0       | When current signal is detected, this bit is set to 1 and holds until bit CLR is set to 1 or DETON is cleared.                                                                                                                                                                                                                                                                                                   |  |  |  |
| Bit5    | CLR                                                   | R/W | 0       | After a cycle of current detection, set this bit to 1 and then clear it to clear bit CST.                                                                                                                                                                                                                                                                                                                        |  |  |  |
| Bit4    | DETON                                                 | R/W | 0       | 1: enable current detection; 0: disable current detection.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |

# Low-power Multifunctional Energy Metering SoC

| 0x2886, R/W, | <b>Current Detection</b> | Control Register, | IDET |
|--------------|--------------------------|-------------------|------|
|--------------|--------------------------|-------------------|------|

| Bit      |       | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|-------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[3:0] | IDLEN | R/W | 0       | To set the number of current samples for current detection. If continuous ([IDLEN]+1) samples of the AC component of instantaneous I1 current are higher than the threshold for current detection (IDETTH, $0x1002$ ), it indicates a current signal is caught. [IDLEN] is over the range of $0{\sim}15$ . See "錯誤! 找不到參照來源。" for the relationship between IDLEN configuration and the period for current detection. |

# 18.3. Metering Data Registers

When POR/BOR, RSTn pin reset or WDT overflow reset occurs, all metering data registers are reset to their default states.

All metering data registers are readable and writable (R/W). But users must not write of these registers to avoid unexpected results.

All the default values in this section are in decimal form if not specifically noted. All the time for updating and settling listed in the tables is appropriate for 50Hz power grid and  $f_{MTCLK}$ =3.2768MHz. When the frequency for metering architecture ( $f_{MTCLK}$ ) is divided by K, the time for updating and settling must be K times of that for 3.2768MHz. In 60Hz power grid, the time for updating and settling is 1.2 times of that for 50Hz power grid.

Table 18-23 Signal Waveform Registers (R/W)

| Address | Register |                                           |     | Default | Format               | Update<br>in | Settle<br>in |
|---------|----------|-------------------------------------------|-----|---------|----------------------|--------------|--------------|
| 0x1005  | DATAOIU  | Raw waveform of voltage.                  | R/W | 0       | 32-bit 2' complement | 0.3ms        | 10ms         |
| 0x100A  | DATAOII1 | Raw waveform of Current I1.               | R/W | 0       | 32-bit 2' complement | 0.3ms        | 10ms         |
| 0x100F  | DATAOII2 | Raw waveform of Current I2.               | R/W | 0       | 32-bit 2' complement | 0.3ms        | 10ms         |
| 0x103A  | DATAIDU  | DC component of instantaneous voltage.    | R/W | 0       | 32-bit 2' complement | 20ms         | 70ms         |
| 0x1041  | DATAIDI1 | DC component of instantaneous Current I1. | R/W | 0       | 32-bit 2' complement | 20ms         | 70ms         |
| 0x1048  | DATAIDI2 | DC component of instantaneous Current I2. | R/W | 0       | 32-bit 2' complement | 20ms         | 70ms         |



# AL6111A Datasheet Low-power Multifunctional Energy Metering SoC

| Address | Register |                                           |     | Default | Format               | Update<br>in | Settle<br>in |
|---------|----------|-------------------------------------------|-----|---------|----------------------|--------------|--------------|
| 0x1051  | DATAIAU  | AC component of instantaneous voltage.    | R/W | 0       | 32-bit 2' complement | 0.3ms        | 70ms         |
| 0x1052  | DATAIAI1 | AC component of instantaneous Current I1. | R/W | 0       | 32-bit 2' complement | 0.3ms        | 70ms         |
| 0x1053  | DATAIAI2 | AC component of instantaneous Current I2. | R/W | 0       | 32-bit 2' complement | 0.3ms        | 70ms         |

### Table 18-24 Power and RMS Registers (R/W)

|         |          | i aliu KMS Registers (R/W                                                      | ,   |         | ı                    |           |           |
|---------|----------|--------------------------------------------------------------------------------|-----|---------|----------------------|-----------|-----------|
| Address | Register |                                                                                | R/W | Default | Format               | Update in | Settle in |
| 0x10D1  | DATAIP   | Instantaneous active power in E1 path.                                         | R/W | 0       | 32-bit 2' complement | 80ms      | 250ms     |
| 0x10D2  | DATAIQ   | Instantaneous active/reactive power in E2 path.                                | R/W | 0       | 32-bit 2' complement | 80ms      | 250ms     |
| 0x10D3  | RMSIU    | Instantaneous voltage RMS.                                                     | R/W | 0       | 32-bit 2' complement | 10ms      | 100ms     |
| 0x10D4  | RMSII1   | Instantaneous current I1 RMS.                                                  | R/W | 0       | 32-bit 2' complement | 10ms      | 100ms     |
| 0x10D5  | RMSII2   | Instantaneous current I2 RMS.                                                  | R/W | 0       | 32-bit 2' complement | 10ms      | 100ms     |
| 0x10D6  | DATAP    | Average active power in E1 path.                                               | R/W | 0       | 32-bit 2' complement | 1.28s     | 3s        |
| 0x10D7  | DATAQ    | Average active/reactive power in E2 path.                                      | R/W | 0       | 32-bit 2' complement | 1.28s     | 3s        |
| 0x10D8  | RMSU     | Average voltage RMS.                                                           | R/W | 0       | 32-bit 2' complement | 1.28s     | 3s        |
| 0x10D9  | RMSI1    | Average current I1 RMS.                                                        | R/W | 0       | 32-bit 2' complement | 1.28s     | 3s        |
| 0x10DA  | RMSI2    | Average current I2 RMS.                                                        | R/W | 0       | 32-bit 2' complement | 1.28s     | 3s        |
| 0x10DB  | DATAAP1  | Average apparent power calculated based on average current I1 and voltage RMS. | R/W | 0       | 32-bit 2' complement | 1.28s     | 3s        |

# Low-power Multifunctional Energy Metering SoC

| Address | Register |                                                                                | R/W | Default | Format               | Update in | Settle in |
|---------|----------|--------------------------------------------------------------------------------|-----|---------|----------------------|-----------|-----------|
| 0x10DC  | DATAAP2  | Average apparent power calculated based on average current I2 and voltage RMS. | R/W | 0       | 32-bit 2' complement | 1.28s     | 3s        |

#### Table 18-25 Energy Accumulators and Energy Pulse Counters (R/W)

| Address | Register |                                                           | R/W | Default | Format              |
|---------|----------|-----------------------------------------------------------|-----|---------|---------------------|
| 0x10F0  | PPCNT    | Positive active energy accumulator in E1 path.            | R/W | 0       | 32-bit,<br>unsigned |
| 0x10F1  | NPCNT    | Negative active energy accumulator in E1 path.            | R/W | 0       | 32-bit,<br>unsigned |
| 0x10F2  | PPCFCNT  | Positive active energy pulse counter in E1 path.          | R/W | 0       | 32-bit,<br>unsigned |
| 0x10F3  | NPCFCNT  | Negative active energy pulse counter in E1 path.          | R/W | 0       | 32-bit,<br>unsigned |
| 0x10F6  | PQCNT    | Positive active/reactive energy accumulator in E2 path.   | R/W | 0       | 32-bit,<br>unsigned |
| 0x10F7  | NQCNT    | Negative active/reactive energy accumulator in E2 path.   | R/W | 0       | 32-bit,<br>unsigned |
| 0x10F8  | PQCFCNT  | Positive active/reactive energy pulse counter in E2 path. | R/W | 0       | 32-bit,<br>unsigned |
| 0x10F9  | NQCFCNT  | Negative active/reactive energy pulse counter in E2 path. | R/W | 0       | 32-bit,<br>unsigned |

The energy accumulators are of actual 42-bit length. But only the higher 32 bits are readable; and only the higher 32 bits are valid for write operation and the 10 least significant bits are padded with 0s in write operation.

When MTCLK frequency is 3.2768MHz, 1.6384MHz or 819.2kHz, the energy accumulation frequency is 12800Hz; when MTCLK frequency is 32768Hz, the energy accumulation frequency is 2979Hz.

When CF pulse output is enabled, the overflow frequency of the energy accumulators is twice of CF pulse output frequency. The reading of the energy pulse counter is twice of the number of the output CF pulses.

# **Low-power Multifunctional Energy Metering SoC**

### Table 18-26 Line Frequency Register (DATAFREQ, 0x10FD)

| 0x10FD, R, Line Frequency Register, DATAFREQ |        |       |       |   |   |      |      |  |  |
|----------------------------------------------|--------|-------|-------|---|---|------|------|--|--|
|                                              | Value  | bit15 | bit14 |   |   | bit1 | bit0 |  |  |
| Default                                      | 0x0000 | 0     | 0     | 0 | 0 | 0    | 0    |  |  |

This register is in the form of 16-bit unsigned.

When MTCLK frequency is 3.2768MHz, the content is updated in 320ms and settled in 500ms. The frequency measurement resolution is up to 0.05Hz/lsb, and the measurement scale is over the range of 35~75Hz.

#### Table 18-27 Data Registers for Channel M

| Address | s Register |                                                       |     | Default | Format               | Update<br>in | Settle<br>in |
|---------|------------|-------------------------------------------------------|-----|---------|----------------------|--------------|--------------|
| 0x10CE  | DATAOM     | Raw waveform of Channel M.                            | R/W | 0       | 32-bit 2' complement | 0.3ms        | 10ms         |
| 0x10CF  | DATADM     | DC component of the measurement of Channel M.         | R/W | 0       | 32-bit 2' complement | 20ms         | 70ms         |
| 0x10D0  | DATAADM    | Average DC component of the measurement of Channel M. | R/W | 0       | 32-bit 2' complement | 1.28s        | 3s           |

# **Low-power Multifunctional Energy Metering SoC**

# 18.4. Calibration Registers

When POR/BOR, RSTn pin reset or WDT overflow reset occurs, all calibration registers are reset to their default states.

All the default values in this section are in decimal form if not specifically noted.

#### Table 18-28 Registers for Gain Calibration (R/W)

| Address | Regist | er                                                                 | R/W | Format                  | Default | Description                                                 |
|---------|--------|--------------------------------------------------------------------|-----|-------------------------|---------|-------------------------------------------------------------|
| 0x10E8  | SCP    | To set a value to gain calibrate active power in E1 path.          | R/W | 32-bit 2'<br>complement | 0       |                                                             |
| 0x10EB  | SCI1   | To set a value to gain calibrate current I1 RMS.                   | R/W | 32-bit 2' complement    | 0       |                                                             |
| 0x10E9  | SCQ    | To set a value to gain calibrate active/reactive power in E2 path. | R/W | 32-bit 2' complement    | 0       | The gain calibration range is from $-\infty$ to $+49.9\%$ . |
| 0x10EC  | SCI2   | To set a value to gain calibrate current I2 RMS.                   | R/W | 32-bit 2' complement    | 0       | T 4 9 . 9 70 .                                              |
| 0x10EA  | SCU    | To set a value to gain calibrate voltage RMS.                      | R/W | 32-bit 2' complement    | 0       |                                                             |

#### Table 18-29 Registers for Power Offset Calibration (R/W)

| Address | Register |                                                                      | R/W | Format               | Default | Description                                      |
|---------|----------|----------------------------------------------------------------------|-----|----------------------|---------|--------------------------------------------------|
| 0x10ED  | PARAPC   | To set a value to offset calibrate active power in E1 path.          | R/W | 32-bit 2' complement | 0       |                                                  |
| 0x10EE  | PARAQC   | To set a value to offset calibrate active/reactive power in E2 path. | R/W | 32-bit 2' complement | 0       | The gain calibration range is from -50% to +50%. |

# Low-power Multifunctional Energy Metering SoC

#### Table 18-30 Band-pass Filter Coefficient Register (0x10EF, R/W)

| Address | Register |                                                                                  | R/W | Format              | Default    |
|---------|----------|----------------------------------------------------------------------------------|-----|---------------------|------------|
| 0x10EF  | PARABPF  | To set the coefficient for the band-pass filter in the RMS calculation circuits. | R/W | 32-bit 2 complement | 0x889374BC |

When MTCLK frequency is lowered to 819.2kHz, the sampling frequency of the enabled band-pass filter in the RMS calculation circuit is changed to 800Hz and the center frequency is changed to 12.5Hz, which has a greater attenuation on 50Hz signals and will reduce the accuracy of the RMS calculation and line frequency measurement. So, if MTCLK frequency is reduced to 819.2kHz, users must disable energy accumulation, CF pulse output and no-load detection, and then configure this register to 0x911D3C9C. When MTCLK frequency is reinstated to 3.2768MHz, this register must be set to its default value.

Table 18-31 Energy Threshold Registers and Constant Power Register (R/W)

| Address | Register |                                                                                  | R/W | Format               | Default |
|---------|----------|----------------------------------------------------------------------------------|-----|----------------------|---------|
| 0x10F4  | GATEP    | To set a threshold for active energy-to-pulse conversion in E1 path.             | R/W | 32-bit,<br>unsigned  | 0       |
| 0x10F5  | GATECP   | To set a threshold for no-load detection in E1 path.                             | R/W | 32-bit,<br>unsigned  | 0       |
| 0x10FA  | GATEQ    | To set a threshold for active or reactive energy-to-pulse conversion in E2 path. | R/W | 32-bit,<br>unsigned  | 0       |
| 0x10FB  | GATECQ   | To set a threshold for no-load detection in E2 path.                             | R/W | 32-bit,<br>unsigned  | 0       |
| 0x10FC  | DATACP   | To set a constant for active energy accumulation in E1 path.                     | R/W | 32-bit 2' complement | 0       |

The energy accumulators are of actual 42-bit length, but the threshold registers for energy-to-pulse conversion are of 32-bit length. So, the threshold registers will be padded with a string of 10 0s on the right to work as 42-bit registers for computation.

There is an anti-creeping accumulator in the no-load detection circuit. When no-load detection is enabled, 1s are accumulated in this register constantly. When MTCLK frequency is 3.2768MHz, 1.6384MHz or 819.2kHz, the accumulation frequency is 12800Hz; and when MTCLK frequency is 32768Hz, the accumulation frequency is 2979Hz.

When no-load detection is enabled, the circuit compares the rate at which the anti-creeping accumulator increments by 1s to that at which the energy accumulators accumulate E1/E2 power or the preset constant. If the energy accumulator overflows sooner, the anti-creeping accumulator is cleared, and E1 or E2 path starts to metering energy. Otherwise, the energy accumulator in E1 or E2 path is cleared, and the path enters creeping state. Users can read bit7 or bit6 of register CRPST (0x287F) to detect the state of the path.

# Low-power Multifunctional Energy Metering SoC

# Table 18-32 Threshold Register for Current Detection (R/W)

| Address | Register |                                           |     | Format                                                    | Default |
|---------|----------|-------------------------------------------|-----|-----------------------------------------------------------|---------|
| 0x1002  | IDETTH   | To set a threshold for current detection. | R/W | 32-bit 2' complement, both bit31 and bit30 are sign bits. | 0       |

# 19. Outline Dimensions



**Figure 19-1 Outline Dimensions**