

# TM56F8225 Battery Car and Electrical Tools Charger ASSP IC DATA SHEET Rev 0.95

**tenx** reserves the right to change or discontinue the manual and online documentation to this product herein to improve reliability, function or design without further notice. **tenx** does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. **tenx** products are not designed, intended, or authorized for use in life support appliances, devices, or systems. If Buyer purchases or uses **tenx** products for any such unintended or unauthorized application, Buyer shall indemnify and hold **tenx** and its officers, employees, subsidiaries, affiliates and distributors harmless against all claims, cost, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use even if such claim alleges that **tenx** was negligent regarding the design or manufacture of the part.



# **AMENDMENT HISTORY**

\_\_\_\_\_

| Version | Date       | Description                                                                                  |
|---------|------------|----------------------------------------------------------------------------------------------|
| 0.90    | June, 2020 | New Release                                                                                  |
| 0.91    | Aug, 2020  | Revised Describe and Update Parameter                                                        |
|         |            | 1. Fig. BCM Block Diagram (P.67)                                                             |
|         |            | 2. Memory map HWAUTO describe (P. 75)                                                        |
|         |            | 3. VR parameter (P.93)                                                                       |
|         |            | 4. BCM Electrical Characteristics (P. 94)                                                    |
| 0.92    | Sep, 2020  | 1. Update Electrical Characteristics (P.92-P.94)                                             |
|         |            | 2. Revised Describe                                                                          |
|         |            | - SFR description (P.58)                                                                     |
| 0.93    | Dec, 2020  | 1. Revised ADVREFS default value (P.74)                                                      |
|         |            | 2. Add VR v.s. Temp. curve (P.96)                                                            |
|         |            | 3. Suggest EEPTE setting                                                                     |
| 0.94    | Sep, 2021  | 1. Fixed typo in the description of indirect addressing(P.17)                                |
|         |            | 2. Fixed typo in example code (P.19)                                                         |
|         |            | 3. Revised description and fixed typos in example code (P.21)                                |
|         |            | 4. Revised description for INT1IF(P.34)                                                      |
|         |            | 5. Add SFR OPTION table for the description of interrupt(P.35)                               |
|         |            | 6. Revised description of output mode example(P.37)                                          |
|         |            | 7. Revised description to clear watchdog timer(P.41)                                         |
|         |            | 8. Fixed typos in the table of SFR OPTION(P.42)                                              |
|         |            | 9. Revised figure of timer0 worked in counter mode(P.46)                                     |
|         |            | 10. Fixed typo in the description of PWM1AOE1(P.75)                                          |
|         |            | 11. Fixed typos in the description of CALL instruction(P.83)                                 |
|         |            | 12. Fixed typos in the description of GOTO instruction(P.84)                                 |
|         |            | 13. Fixed typos in the description of MOVX and MOVXW                                         |
|         |            | instructions(P.86)                                                                           |
|         |            | 14. Fixed description of SUBLW instruction(P.89)                                             |
| 0.07    | E-1 2022   | 15. Fixed typos in the explanation of example code(P.55)                                     |
| 0.95    | Feb, 2022  | 1. Add the description of "PWM0 clock is enabled and PWM0 is<br>not hold after reset" (P 52) |
|         |            | not hold after reset".(P.53)                                                                 |
|         |            | 2. Add the description of "PWM1 clock is enabled and PWM1 is<br>not hold after reset" (P 59) |
|         |            | not hold after reset". (P.59)                                                                |



# CONTENTS

| AM  | ENDN       | MENT HISTORY                                 | 2   |
|-----|------------|----------------------------------------------|-----|
| COI | NTEN       | TS                                           | 3   |
| FEA | TUR        | ES                                           | 5   |
| SYS | TEM        | BLOCK DIAGRAM                                | 8   |
|     |            | GNMENT DIAGRAM                               |     |
|     |            |                                              |     |
|     |            | CRIPTIONS                                    |     |
| PIN | SUM        | MARY                                         | .11 |
| FUN | ICTI(      | ON DESCRIPTION                               | .12 |
| 1   | CPU        | Core                                         | .12 |
|     | 1.1        | Program ROM (PROM)                           | .12 |
|     |            | 1.1.1 Reset Vector (000H)                    | .12 |
|     |            | 1.1.2 Interrupt Vector (004H)                | .12 |
|     | 1.2        | System Configuration Register (SYSCFG)       |     |
|     | 1.3        | Data ROM (EEPROM)                            |     |
|     | 1.4        | RAM Addressing Mode                          |     |
|     | 1.5        | Programming Counter (PC) and Stack           |     |
|     |            | 1.5.1 ALU and Working (W) Register           |     |
| -   | _          | 1.5.2 STATUS Register (03H/83H/103H/183H)    |     |
| 2   |            | et                                           |     |
|     | 2.1        | Power on Reset                               |     |
|     | 2.2        | Low Voltage Reset                            |     |
|     | 2.3        | External Pin Reset                           |     |
| •   | 2.4        | Watchdog Timer Reset                         |     |
| 3   |            | ck Circuitry and Operation Mode              |     |
|     | 3.1        | System Clock                                 |     |
|     | 3.2        | Dual System Clock Modes Transition           |     |
| 4   | 3.3        | System Clock Oscillator                      |     |
| 4   | meer       | 1                                            |     |
| 5   |            | Port                                         |     |
| C   | 5.1        | PA0-PA7                                      |     |
| 6   | -          | pheral Functional Block                      |     |
|     | 6.1<br>6.2 | Watchdog (WDT) /Wakeup (WKT) Timer<br>Timer0 |     |
|     | 6.3        | Timer0                                       |     |
|     | 0.3<br>6.4 | T2:15-bit Timer                              |     |
|     | 6.5        | PWM0: (8+2) bits PWM                         |     |
|     | 0.5<br>6.6 | PWM1A / PWM1B / PWM1C: 16 bits PWMs          |     |
|     | 6.7        | Analog-to-Digital Converter                  |     |
|     | 6.8        | Battery Charge Module (BCM)                  |     |
|     | 6.9        | Cyclic Redundancy Check (CRC)                |     |
|     | ···        |                                              |     |



| <ol> <li>LVR Circuit Characteristics (TA = 25°C)</li> <li>ADC Electrical Characteristics</li></ol> | 71                                                |    |
|----------------------------------------------------------------------------------------------------|---------------------------------------------------|----|
| INS                                                                                                | TRUCTION SET                                      | 79 |
| ELI                                                                                                | ECTRICAL CHARACTERISTICS                          | 92 |
| 1.                                                                                                 | Absolute Maximum Ratings                          |    |
| 2.                                                                                                 |                                                   |    |
| 3.                                                                                                 |                                                   |    |
| 4.                                                                                                 | Reset Timing Characteristics                      |    |
| 5.                                                                                                 | LVR Circuit Characteristics (TA = $25^{\circ}$ C) | 93 |
| 6.                                                                                                 | ADC Electrical Characteristics                    |    |
| 7.                                                                                                 | BCM Electrical Characteristics                    | 94 |
| 8.                                                                                                 | EEPROM Block Characteristics                      | 94 |
| 9.                                                                                                 | Electrical Characteristics Graphs                 | 95 |
| PAC                                                                                                | CKAGING INFORMATION                               | 97 |
|                                                                                                    | -SOP Package Dimension                            |    |
| 16-                                                                                                | DIP Package Dimension                             |    |



## **FEATURES**

#### 1. ROM: 2K x 16 bits Flash Program Memory

- 10K erase times at least
- 10 years data retention at least

#### 2. EEPROM: 128 x 8 bits

- 50K erase times at least
- 10 years data retention at least
- 3. RAM: 176 x 8 bits
- 4. STACK: 8 Levels
- 5. System Oscillation Sources (Fsys) :
  - Fast-clock
    - FIRC (Fast Internal RC) : 8 MHz
  - Slow-clock
    - SIRC (Slow Internal RC) : 70 KHz @VCC=5V

#### 6. System Clock Prescaler:

• System Oscillation Sources can be divided by 1 / 2 / 4 / 8 as System Clock (Fsys)

#### 7. Dual System Clock:

• FIRC + SIRC

#### 8. Power Saving Operation Mode

- FAST Mode: Slow-clock can be disabled or enabled, Fast-clock keeps CPU running
- SLOW Mode: Fast-clock can be disabled or enabled, Slow-clock keeps CPU running
- IDLE Mode: Fast-clock and CPU stop. Slow-clock, T2, or Wake-up Timer keep running
- STOP Mode: All clocks stop, T2 and Wake-up Timer stop

#### 9. 3 Independent Timers

- Timer0
  - 8-bit timer divided by 1~32768 pre-scale option / auto-reload / counter / interrupt / stop function
- Timer1
  - 8-bit timer divided by 1~256 pre-scale option / auto-reload / interrupt / stop function
- T2
  - 15-bit timer with 4 interrupt interval time options
  - IDLE mode wake-up timer or used as one simple 15-bit time base
  - Clock source: Slow-clock (SIRC) or Fsys/128



#### **10. Interrupt**

- Three External Interrupt pins
  - 1 pin is falling edge wake-up triggered & interrupts
  - 2 pins are rising or falling edge wake-up triggered & interrupt
- Timer0 / Timer1 / T2 / Wake-up Timer Interrupt
- ADC Interrupt
- PWM1 period and PWM1A / PWM1B / PWM1C duty Interrupt

#### 11. Wake-up Timer (WKT)

- Clocked by built-in RC oscillator with 4 adjustable interrupt times
  - 16 ms / 33 ms / 65 ms / 130 ms @VCC=3V
  - 15 ms / 29 ms / 59 ms / 118 ms @VCC=5V

#### 12. Watchdog Timer (WDT)

- Clocked by built-in RC oscillator with 4 adjustable reset times
  - 130 ms / 260 ms / 1040 ms / 2080 ms @VCC=3V
  - 118 ms / 236 ms / 944 ms / 1888 ms @VCC=5V
- Watchdog timer can be disabled / enabled in STOP mode

#### 13. PWM x 4

- PWM0
  - 8+2 bits, duty-adjustable, period-adjustable controlled PWM
  - PWM0 clock source: Fast-clock or FIRC 8 MHz / 16MHz, with 1~8 pre-scalers
  - Complementary PWM output (PWM0P, PWM0N)
  - Non-overlap time durations adjustable: (0~8)\*(PWMCLK)
- PWM1A / PWM1B / PWM1C
  - 16-bit PWM1 with three groups independent duty-adjustable function and shared periodadjustable controlled
  - PWM1 shared clock source: System clock (Fsys) or FIRC 8 MHz / 16 MHz
  - With duty and period interrupt function

#### 14. 12-bit ADC with 8 input channels and 1 internal reference voltage

- Internal reference voltage VR (3V ±1.2% @25°C, VCC=3V~5V)
- ADC reference voltage = VCC or VR

#### **15. Battery Charging Module**

- OPA x 2
- 10-bit DAC x 2
  - DAC reference voltage = VR  $(3V \pm 1.2\% @25^{\circ}C, VCC=3V\sim5V)$



#### 16. Reset Sources

- Power On Reset
- Watchdog Reset
- Low Voltage Reset
- External Pin Reset

#### 17. Low Voltage Reset (LVR) / Low Voltage Detection Flag (LVD)

- 4-Level Low Voltage Reset: 2.2V / 2.8V / 3.6V / 4.2V
- 3-Level Low Voltage Detection Flag: 2.8V / 3.6V / 4.2V (when LVR = 2.2V)

#### **18.Operating Voltage**

- Fsys= 4 MHz, 1.6V~5.5V @LVR disable. Suggest LVR 2.2V or above at -40°C to +85°C
- Fsys=8 MHz, 2.1V~5.5V @LVR disable. Suggest LVR 2.8V or above at -40°C to +85°C Note: Power-up VCC must exceed LVR 2.2V and selected LVR level, refer to the "Electrical Characteristics Graphs" to avoid entering ROM deadzone.
- **19.** Operating Temperature Range : -40 °C to + 85 °C
- 20. Table Read Instruction: 16-bit ROM data lookup table
- 21. Integrated 16-bit Cyclic Redundancy Check function
- 22. Instruction set: 39 Instructions
- 23. I/O ports:
  - Maximum 8 programmable I/O pins
    - Open-Drain Output
    - CMOS Push-Pull Output
    - Schmitt Trigger Input with pull-up resistor option
    - All I/O with High-Sink and High-Drive
  - 5 OPA analog I/O pins
  - 1 reference voltage output pin (VR =  $3V \pm 1.2\%$  @25°C, VCC= $3V \sim 5V$ )
- 24. Programming connectivity support 4-wire (ICP) or 7-wire program
- 25. Package Types:
  - 16-pin SOP (150 mil)
  - 16-pin DIP (300 mil)
- 26. Supported EV board on ICE

EV board: EV8235



## SYSTEM BLOCK DIAGRAM







## PIN ASSIGNMENT DIAGRAM





# **PIN DESCRIPTIONS**

| Name      | In/Out | Pin Description                                                                                                                                |
|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|
| PA0–PA7   | I/O    | Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output or open-drain output. Pull-up resistors are assignable by software. |
| nRESET    | Ι      | External active low reset                                                                                                                      |
| VCC, VSS  | Р      | Power Voltage input pin and ground                                                                                                             |
| VR        | 0      | Internal reference voltage 3V output (at least 1uF to ground)                                                                                  |
| INT0-INT2 | Ι      | External interrupt input                                                                                                                       |
| TM0CKI    | Ι      | Timer0's input in counter mode                                                                                                                 |
| PWM0P     | 0      | (8+2) bit PWM0 positive output                                                                                                                 |
| PWM0N     | 0      | (8+2) bit PWM0 negative output                                                                                                                 |
| PWM1A     | 0      | 16 bit PWM1 output                                                                                                                             |
| PWM1B     | 0      | 16 bit PWM1 output                                                                                                                             |
| PWM1C     | 0      | 16 bit PWM1 output                                                                                                                             |
| ADC0-ADC7 | Ι      | ADC channels input                                                                                                                             |
| OP0P      | Ι      | OPA0 positive input                                                                                                                            |
| OP0N      | Ι      | OPA0 negative input                                                                                                                            |
| OP1P      | Ι      | OPA1 positive input                                                                                                                            |
| OP1N      | Ι      | OPA1 negative input                                                                                                                            |
| OPO       | 0      | OPA0, OPA1 output                                                                                                                              |

Programming pins:

Normal mode: VCC / VSS / PA0 / PA1 / PA2 / PA3 / PA4

ICP mode: VCC / VSS / PA0 / PA1 - When using ICP (In-circuit Program) mode, the PCB needs to remove all components of PA0, PA1.



# **PIN SUMMARY**

| Pin<br>Number |                            |     | G              | PIO |      |                     | A   | Altern | ate F | unction |
|---------------|----------------------------|-----|----------------|-----|------|---------------------|-----|--------|-------|---------|
|               |                            |     | Input          | Out | tput | eset                |     |        |       |         |
| 16-SOP/DIP    | Pin Name                   |     | Ext. Interrupt | 0.D | P.P  | Function AfterReset | MMd | ADC    | OPA   | MISC    |
| 1             | OPO                        | 0   |                |     |      |                     |     |        | 0     |         |
| 2             | OP1N                       | Ι   |                |     |      |                     |     |        | 0     |         |
| 3             | VSS                        | Р   |                |     |      |                     |     |        |       |         |
| 4             | VCC                        | Р   |                |     |      |                     |     |        |       |         |
| 5             | VR                         | 0   |                |     |      |                     |     |        |       |         |
| 6             | PA0/ADC0/PWM1A             | I/O |                | 0   | 0    | PA0                 | 0   | 0      |       |         |
| 7             | PA1/ADC1/PWM0N/INT1        |     | 0              | 0   | 0    | PA1                 | 0   | 0      |       |         |
| 8             | PA2/ADC2/PWM1B/INT0        |     | 0              | 0   | 0    | PA2                 | 0   | 0      |       |         |
| 9             | OP0N                       | Ι   |                |     |      |                     |     |        | 0     |         |
| 10            | OP0P                       | Ι   |                |     |      |                     |     |        | 0     |         |
| 11            | OP1P                       | Ι   |                |     |      |                     |     |        | 0     |         |
| 12            | PA4/ADC4/PWM1C             | I/O |                | 0   | 0    | PA4                 | 0   | 0      |       |         |
| 13            | PA5/ADC5/PWM0P             | I/O |                | 0   | 0    | PA5                 | 0   | 0      |       |         |
| 14            | PA6/ADC6/PWM1A/INT0/TM0CKI | I/O | 0              | 0   | 0    | PA6                 | 0   | 0      |       | TM0CKI  |
| 15            | PA7/ADC7/PWM1B/INT2/nRESET | I/O | 0              | 0   | 0    | PA7                 | 0   | 0      |       | nRESET  |
| 16            | PA3/ADC3/PWM1C             | I/O |                | 0   | 0    | PA3                 | 0   | 0      |       |         |

Symbol : P.P. = COM Push-Pull Output O.D. = Open Drain Output



## **FUNCTION DESCRIPTION**

#### 1 CPU Core

#### 1.1 Program ROM (PROM)

The Flash Program ROM of this device is 2K words, with an extra 64-Word INFO area to store the SYSCFG and an extra 128-Byte EEPROM. The ROM can be written multi-times and can be read as long as the PROTECT bit of SYSCFG is not set. The SYSCFG can be read no matter PROTECT bit is set or cleared, but PROTECT bit can be cleared only when User ROM Code area is erased. That is, unprotect the PROTECT bit needs to erase the corresponding ROM area. If PROTECT bit is set, the user ROM code area will not be read by writer, and the user ROM code can't be updated until the PROTECT bit is cleared.



#### 1.1.1 Reset Vector (000H)

After reset, system will restart the program counter (PC) at the address 000h, all registers will revert to the default value.

#### **1.1.2 Interrupt Vector (004H)**

When an interrupt occurs, the program counter (PC) will be pushed onto the stack and jumps to address 004H.



#### **1.2** System Configuration Register (SYSCFG)

The System Configuration Register (SYSCFG) is located at Flash INFO area; it contains a 13 bits register (CFGWH). The SYSCFG determines the option for initial condition of CPU. It is written by PROM Writer only. User can select LVR operation Mode and chip operation mode by SYSCFG register. The 13<sup>th</sup> bit of CFGWH is code protect selection bit. If this bit is 1, the data in PROM will be protected, when user reads PROM.

| Bit             |       |                             | 13~0                                                  |  |  |
|-----------------|-------|-----------------------------|-------------------------------------------------------|--|--|
| Default Value   |       | 00_0000_0000                |                                                       |  |  |
| Bit Description |       |                             | Description                                           |  |  |
|                 |       | PROTECT                     | : Code protection selection                           |  |  |
|                 | 13    | 1                           | Enable                                                |  |  |
|                 |       | 0                           | Disable                                               |  |  |
|                 |       | XRSTE: I                    | External Pin (PA7) Reset Enable                       |  |  |
|                 | 12    | 1                           | Enable                                                |  |  |
|                 |       | 0                           | Disable (PA7 as input I/O pin)                        |  |  |
|                 | 11-10 | LVR: Low Voltage Reset Mode |                                                       |  |  |
|                 |       | 11                          | 4.2V                                                  |  |  |
| CFGWH           |       | 10                          | 3.6V                                                  |  |  |
| CFGWH           |       | 01                          | 2.8V                                                  |  |  |
|                 |       | 00                          | 2.2V + LVD function (LVDS 00: 3.6V 01: 2.8V 1X: 4.2V) |  |  |
|                 |       | WDTE: WI                    | DT Reset Enable                                       |  |  |
|                 | 9-8   | 11                          | Always Enable                                         |  |  |
|                 | 9-8   | 10                          | Enable in FAST/SLOW mode, Disable in IDLE/STOP mode   |  |  |
|                 |       | 0X                          | Disable                                               |  |  |
|                 | 7-0   | tenx Reserv                 | ed                                                    |  |  |



#### **1.3 Data ROM (EEPROM)**

The TM56F8225 contains 128 bytes of data EEPROM memory. It is organized as a separate data space, in which single bytes can be read and written. According the physical characteristic the EEPROM need more long access time than Program ROM. The EEPROM has an endurance of at least 50K write/erase cycle.

**The EEPROM Read** usage is same as use Table Read instruction except EEPROM enable bit must be set to high. By writing 0xE2 to register EEPEN (18Eh) can set the EEPROM enable bit, writing other value to EEPEN (18Eh) will clear the EEPROM enable bit.

♦ Example: read EEPROM data @address 23h

| MOVLW | E2H   | ;                                 |
|-------|-------|-----------------------------------|
| MOVWX | EEPEN | ; set EEPROM enable bit           |
| CLRX  | DPH   | ; set DPH=0 for EEPROM write/read |
| MOVLW | 00H   |                                   |
| MOVWX | DPH   |                                   |
| MOVLW | 23H   | ; set DPTR=0023h                  |
| MOVWX | DPL   |                                   |
|       |       |                                   |

; Read EEPROM @Address 23h data into W by using opcode TABRL TABRL

1 AD

; Another way to read EEPROM @Address 23h data into W by using TABR

| MOVLW | 01H  |                               |
|-------|------|-------------------------------|
| MOVWX | TABR | ; $TABR = 01h = opcode TABRL$ |
|       |      |                               |

**The EEPROM Write** usage is similar to read EEPROM expect the LVRPD must be set to 0x37 to disable LVR. When F/W writes data to the register EEPDT (18Fh), the data will also be written to EEPROM.

 $\diamond$  Example: write EEPROM data A5h to address 23h

| MOVLW | E2H       |                                                   |
|-------|-----------|---------------------------------------------------|
| MOVWX | EEPEN     | ; set EEPROM enable bit                           |
| CLRX  | DPH       | ; set DPH=0 for EEPROM write/read                 |
| MOVLW | 23H       |                                                   |
| MOVWX | DPL       | ; set DPTR=0023h                                  |
| MOVLW | 00000011B |                                                   |
| MOVWX | EEPCTL    | ; set EEPROM write with 12.8mS time out           |
| MOVLW | 37H       | ; set W=LVRPD=37h, force LVR disable              |
| MOVWX | LVRPD     | ; LVR must be disabled before EEP Write operation |
| MOVLW | A5H       |                                                   |
| MOVWX | EEPDT     | ; write data A5h EEPDT (18Fh)                     |
|       |           | ; the data also save to EEPROM @Address 23h       |
| BTXSC | EEPTO     | ; check EEPROM write time-out flag                |
| GOTO  | TIMEOUT   |                                                   |
| CLRX  | EEPEN     | ; protect EEPROM from abnormal write              |



| 0Fh    | Bit 7 | Bit 6 | Bit 5 | Bit 4   | Bit 3   | Bit 2  | Bit 1 | Bit 0 |
|--------|-------|-------|-------|---------|---------|--------|-------|-------|
| CLKCTL | _     |       |       | SLOWSTP | FASTSTP | CPUCKS | CPU   | PSC   |
| R/W    | _     | _     | _     | R/W     | R/W     | R/W    | R/W   | R/W   |
| Reset  | _     | _     | _     | 0       | 1       | 0      | 1     | 1     |

| 0Fh.4   | <b>SLOWSTP:</b> Stop Slow-clock in Stop mode |
|---------|----------------------------------------------|
|         | 0: no stop                                   |
|         | 1: stop Slow-clock                           |
| 0Fh.3   | FASTSTP: Stop Fast-clock                     |
|         | 0: Fast-clock Running                        |
|         | 1: Fast-clock Stop                           |
| 0Fh.2   | <b>CPUCKS:</b> System clock selection        |
|         | 0: Slow Clock as system clock                |
|         | 1: Fast Clock as system clock                |
| 0Fh.1~0 | <b>CPUPSC:</b> System clock prescaler        |
|         | 0: div 8 1: div 4 2: div 2 3: div 1          |

| 109h  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| LVRPD |       | LVRPD |       |       |       |       |       |       |
| R/W   | W     | W     | W     | W     | W     | W     | W     | W     |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

109h.7~0 **LVRPD:** LVR power down register

Write 37h to force LVR disable. (LVR must be disabled before EEPROM Write operation)

| 18Ch  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| TABR  |       | TABR  |       |       |       |       |       |       |
| R/W   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

18Ch.7~0 1. TABR write 01h = opcode TABRL

2. TABR write 02h = opcode TABRH

3. After step.1 or step.2, read TABR to get main ROM table read value After step.1, read TABR to get EEPROM value (when EEPEN = E2h) *Table Read for ASM: TABRL/ TABRH or TABR Table Read for C: TABR* 

| 18Dh   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| EEPCTL | _     | —     | —     | —     | —     | EEPTO | EEH   | PTE   |
| R/W    | -     | _     | —     | _     | _     | R     | R/W   | R/W   |
| Reset  | -     |       | —     | —     | —     | 0     | 0     | 0     |

18Dh.2 **EEPTO:** EEPROM write time-Out flag Set by H/W when EEPROM write time-out occurs Cleared by H/W when EEPTE=0

18Dh.1~0EEPTE: EEPROM write watchdog timer enable (suggest set 11)00: disable01: 1.6ms10: 6.4ms11: 12.8ms

| 18Eh  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| EEPEN |       | EEPEN |       |       |       |       |       |       |
| R/W   | W     | W     | W     | W     | W     | W     | W     | W     |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

18Eh.7~0 **EEPEN**: EEPROM Access Enable

write 0xE2 to this register will enable EEPROM access

write others value to this register will disable EEPROM access



| 18Fh  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| EEPDT |       | EEPDT |       |       |       |       |       |       |
| R/W   | W     | W     | W     | W     | W     | W     | W     | W     |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

18Fh.7~0 **EEPDT:** EEPROM Data to write

write data to this register will let H/W write the data to EEPROM when EEPROM access is enable



#### 1.4 RAM Addressing Mode

There is one Data Memory Plane in CPU. The Plane is partitioned into four banks. Each bank extends up to 7Fh (128 bytes). The lower locations of each bank are reserved for Special Function Register (SFR). Above the SFR are General Purpose Registers, implemented as static RAM. All implemented banks contain Special Function Registers. Some frequently used Special Function Registers from one bank may be mirrored in another bank for code reduction and quicker access.

Bit RP1 and RP0 (STATUS[6:5]) are the bank select bit

| [RP1, RP0] | BANK |
|------------|------|
| 00         | 0    |
| 01         | 1    |
| 10         | 2    |
| 11         | 3    |

The plane can be addressed directly or indirectly. The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing. Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses the register pointed to by the File Select Register, FSR. Reading the INDF register itself, indirectly (FSR = '0') will read 00h. Writing to the INDF register indirectly results in a no operation (although status bit may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS[7]). Refer to the figure below.



#### **Direct / Indirect Addressing**

Keeping RP0=RP1=0 in the beginning of the F/W code and using the new instruction set. The advantage of using new instruction is user can ignore the bank location of registers and the code size can be saved. The new instruction is almost same as the old instruction. By replacing the "F" to "X" in the instruction set can easily use the new instruction without switching the bank.



For example:

00h

01h

02h

03h

04h

05h

06h

07h

08h 09h

0Ah

0Bh

0Ch

0Dh

0Eh

0Fh

10h

11h

12h

13h 14h

15h

16h

17h

18h

19h

1Ah

1Bh

1Ch

1Dh

1Eh

1Fh

20h

6Fh

70h

7Fh

| BCF                 | TM0IE    | <b>→</b> | BCX                 | TM0IE    |
|---------------------|----------|----------|---------------------|----------|
| DECF                | CNT, 1   | →        | DECX                | CNT, 1   |
| INCFSZ              | RAM25, 0 | →        | INCXSZ              | RAM25, 0 |
| MOVWF               | PAMODL   | →        | MOVWX               | PAMODL   |
| RLF                 | RAMA0, 0 | →        | RLX                 | RAMA0, 0 |
| SWAP <mark>F</mark> | ADCTL, 0 | →        | SWAP <mark>X</mark> | ADCTL, 0 |

| 【BANK0】 |  |
|---------|--|
| 00~7Fh  |  |

INDF

TM0

PCL

STATUS

FSR

PAD

PCLATH

INTIE

INTIF

INTIE1

INTIF1

CLKCTL

**TMORLD** 

TM0CTL

TM1 TM1RLD

TM1CTL

T2CTL

MF016

ADCH

ADCTL

MF019 **OPA0CTL** 

**OPA1CTL** 

DAC0DH

DAC0DL

DAC1DH

DAC1DL

RAM Bank0 area

(80 Bytes)

common area

16 Bytes

|     | <b>BANK1</b>         |
|-----|----------------------|
|     | 80h~FFh              |
| 80h |                      |
| 81h | OPTION               |
| 82h | PCL                  |
| 83h | STATUS               |
| 84h | FSR                  |
| 85h |                      |
| 86h |                      |
| 87h |                      |
| 88h |                      |
| 89h |                      |
| 8Ah | PCLATH               |
| 8Bh | INTIE                |
| 8Ch | PAMODH               |
| 8Dh | PAMODL               |
| 8Eh |                      |
| 8Fh |                      |
| 90h |                      |
| 91h | PWMOE                |
| 92h | PWM0PRD              |
| 93h | PWM0DH               |
| 94h | PWM0DL               |
| 95h | PWM0CTL              |
| 96h | PWM0CTL1             |
| 97h | PWM1CTL              |
| 98h | PWM1PRDH             |
| 99h | PWM1PRDL             |
| 9Ah | PWM1ADH              |
| 9Bh | PWM1ADL              |
| 9Ch | PWM1BDH              |
| 9Dh | PWM1BDL              |
| 9Eh | PWM1CDH              |
| 9Fh | PWM1CDL              |
| A0h |                      |
|     |                      |
|     | RAM Bank1 area       |
| ~   | $(90 \mathbf{P} ())$ |
|     | (80 Bytes)           |
| EFh |                      |
| F0h | accesses             |
|     |                      |

70h~7Fh

FFh

| 100h~17Fh         180h~1FFh           100h         INDF         180h         INDF           101h         TM0         181h         OPTION           102h         PCL         182h         PCL           103h         STATUS         183h         STATUS           104h         FSR         184h         FSR           105h         185h         DPL           106h         186h         DPH           107h         187h         CRCDL           108h         INTIE         188h         CRCIN           108h         INTIE         188h         INTIE           108h         INTIE         188h         INTIE           108h         INTIE         188h         INTIE           108h         INTIE         188h         INTIE           108h         INTIE         188h         EEPCTL           100h         180h         EEPCTL         100h           100h         180h         EEPDT         110h           110h         190h         110h         190h           111h         191h         192h         14h           113h         193h         14h         19h                                                           |       | [BANK2]   |        | 【BANK3】   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------|--------|-----------|
| 101h         TM0         181h         OPTION           102h         PCL         182h         PCL           103h         STATUS         183h         STATUS           104h         FSR         184h         FSR           106h         186h         DPL           106h         186h         DPH           107h         187h         CRCDL           108h         188h         CRCDH           109h         LVRPD         189h         CRCIN           10Ah         PCLATH         18Ah         PCLATH           10Bh         INTIE         18Bh         INTIE           10Ch         18Ch         TABR         18Dh           10Ch         18Ch         TABR           10Dh         18Dh         EEPCTL           10Eh         BGTRIM         18Eh         EEPDT           10Fh         IRCF         18Fh         EEPDT           110h         190h         111h         191h           112h         192h         13th         193h           114h         194h         194h         194h           117h         197h         197h         118h                                                                                | -     | 100h~17Fh |        | 180h~1FFh |
| 102h         PCL         182h         PCL           103h         STATUS         183h         STATUS           104h         FSR         183h         DPL           105h         185h         DPL           106h         186h         DPH           107h         187h         CRCDL           108h         188h         CRCDH           109h         LVRPD         189h         CRCIN           10Ah         PCLATH         18Ah         PCLATH           10Bh         INTIE         188h         INTIE           10Ch         18Ch         TABR           10Dh         18Dh         EEPCTL           10Eh         BGTRIM         18Eh         EEPDT           10Fh         IRCF         18Fh         EEPDT           110h         190h         111h         191h           112h         192h         113h         193h           114h         194h         194h         194h           117h         197h         117h         197h           118h         198h         198h         114h           192h         192h         114h         192h           1                                                                     | 100h  | INDF      | 180h   | INDF      |
| 103h       STATUS       183h       STATUS         104h       FSR       183h       FSR         105h       185h       DPL         106h       185h       DPL         107h       187h       CRCDL         108h       188h       CRCDH         109h       LVRPD       189h       CRCIN         10Ah       PCLATH       188h       PCLATH         10Bh       INTIE       188h       INTIE         10Ch       18Ch       TABR         10Dh       18Ch       TABR         10Dh       18Dh       EEPCTL         10Eh       BGTRIM       18Eh       EEPDT         110h       190h       111h       191h         112h       192h       113h       193h         114h       194h       194h       115h         115h       195h       116h       196h         117h       197h       118h       198h         118h       198h       194h       115h         116h       196h       117h       197h         118h       198h       199h       11Ah       190h         11Ch       19Ch       1                                                                                                                                                    |       | TM0       | 181h   | OPTION    |
| 104h       FSR       184h       FSR         105h       185h       DPL         106h       185h       DPL         107h       187h       CRCDL         108h       188h       CRCDH         109h       LVRPD       189h       CRCIN         10Ah       PCLATH       188h       PCLATH         10Bh       INTIE       188h       INTIE         10Ch       180h       EEPCTL         10Ch       18Ch       TABR         10Dh       18Ch       TABR         10Dh       18Ch       EEPCTL         10Eh       BGTRIM       18Eh       EEPCTL         10Fh       IRCF       18Fh       EEPDT         110h       190h       111h       191h         112h       192h       113h       193h         114h       194h       194h       115h         115h       195h       116h       196h         117h       197h       118h       198h         118h       198h       199h       11Ah         11Ah       19Ah       19Bh       116h         11Ch       19Ch       1A0h       14h                                                                                                                                                             | 102h  | PCL       | 182h   | PCL       |
| 105h       185h       DPL         106h       186h       DPH         107h       187h       CRCDL         108h       188h       CRCDH         109h       LVRPD       189h       CRCIN         10Ah       PCLATH       188h       PCLATH         10Bh       INTIE       188h       INTIE         10Ch       18Ch       TABR         10Ch       18Ch       TABR         10Dh       18Dh       EEPCTL         10Eh       BGTRIM       18Eh       EEPEN         10Fh       IRCF       18Fh       EEPDT         110h       190h       111h       191h         112h       192h       13h       193h         114h       194h       194h       114h         115h       195h       16h       196h         117h       197h       197h       11Ah       19Ah         118h       198h       199h       11Ah       19Ah         11Ah       19Ah       19Bh       11Ch       19Ch         11Dh       19Dh       19Dh       14H       19Ch         11Ch       19Ch       1AOh                                                                                                                                                                  | 103h  | STATUS    | 183h   | STATUS    |
| 106h       186h       DPH         107h       187h       CRCDL         108h       188h       CRCDH         109h       LVRPD       189h       CRCIN         10Ah       PCLATH       188h       PCLATH         10Bh       INTIE       188h       INTIE         10Ch       18Ch       TABR         10Ch       18Ch       TABR         10Dh       18Dh       EEPCTL         10Eh       BGTRIM       18Eh       EEPDT         10Fh       IRCF       18Fh       EEPDT         10Fh       IRCF       18Fh       EEPDT         110h       190h       190h       111h         112h       192h       13h       193h         114h       194h       194h       114h         117h       197h       118h       198h         118h       198h       199h       11Ah       190h         118h       199h       14H       194h       114h         118h       196h       116H       19Ch       116H         11Ah       192h       11Ah       190h       11Ah         11Ch       19Ch       1A0h       1                                                                                                                                            | 104h  | FSR       | 184h   | FSR       |
| 107h $187h$ CRCDL $108h$ $188h$ CRCDH $109h$ $LVRPD$ $189h$ CRCIN $10Ah$ <b>PCLATH</b> $188h$ <b>PCLATH</b> $10Bh$ <b>INTIE</b> $188h$ <b>INTIE</b> $10Bh$ <b>INTIE</b> $18Bh$ <b>INTIE</b> $10Ch$ $18Ch$ TABR $10Oh$ $18Dh$ EEPCTL $10Eh$ BGTRIM $18Eh$ EEPEN $10Fh$ IRCF $18Fh$ EEPDT $110h$ $190h$ $190h$ $111h$ $111h$ $192h$ $192h$ $113h$ $113h$ $192h$ $192h$ $114h$ $114h$ $194h$ $199h$ $114h$ $115h$ $195h$ $16h$ $190h$ $114h$ $118h$ $198h$ $199h$ $114h$ $194h$ $117h$ $197h$ $198h$ $116h$ $190h$ $11Ah$ $190h$ $190h$ $116h$ $190h$ $116h$ $11Ch$ $19Ch$ $1A0h$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 105h  |           | 185h   | DPL       |
| 108h       188h       CRCDH         109h       LVRPD       189h       CRCIN         10Ah       PCLATH       189h       PCLATH         10Bh       INTIE       18Bh       INTIE         10Ch       18Ch       TABR         10Ch       18Ch       TABR         10Dh       18Dh       EEPCTL         10Eh       BGTRIM       18Eh       EEPEN         10Fh       IRCF       18Fh       EEPDT         110h       190h       190h       111h         112h       192h       191h       111h         113h       193h       14H       194h         115h       195h       116h       196h         117h       197h       118H       198h         118h       198h       199h       11Ah         118h       198h       199h       11Ah         117h       197h       197h       118H       198h         118h       198h       199h       11Ah       190h         11Ah       19Ah       190h       11Ah       192h         11Ch       19Ch       11Ah       19Ch       11Ah         120h       A                                                                                                                                            | 106h  |           | 186h   | DPH       |
| 109h       LVRPD       189h       CRCIN         10Ah       PCLATH       18Ah       PCLATH         10Bh       INTIE       18Bh       INTIE         10Ch       18Ch       TABR         10Dh       18Dh       EEPCTL         10Eh       BGTRIM       18Eh       EEPEN         10Fh       IRCF       18Fh       EEPDT         110h       190h       190h       111h         112h       192h       113h       193h         113h       193h       193h       114h         115h       195h       16h       196h         117h       197h       198h       119h         118h       198h       199h       11Ah         118h       198h       199h       11Ah         118h       198h       199h       11Ah         11Bh       192h       11Ah       192h         11Ch       19Ch       11Dh       19Dh         11Bh       19Bh       14Ah       19Fh         120h       IAOh       IAOh       IAOh         ~       ~       ~       ~         16Fh       1EFh       1FOh       accesses                                                                                                                                                  | 107h  |           | 187h   | CRCDL     |
| 10Ah       PCLATH       18Ah       PCLATH         10Bh       INTIE       18Bh       INTIE         10Ch       18Ch       TABR         10Dh       18Dh       EEPCTL         10Eh       BGTRIM       18Eh       EEPEN         10Fh       IRCF       18Fh       EEPDT         110h       190h       190h       111h         112h       192h       113h       193h         113h       193h       194h       114h         115h       195h       116h       196h         117h       197h       197h       118h         118h       198h       199h       114h         117h       197h       197h       118h         118h       198h       199h       114h         118h       198h       199h       114h         117h       197h       197h       116h         118h       198h       199h       114h         118h       198h       116H       190h         11Ch       19Ch       110h       19Dh         11Ch       19Fh       19Fh       116H         120h                                                                                                                                                                            | 108h  |           | 188h   | CRCDH     |
| 10Bh       INTIE       18Bh       INTIE         10Ch       18Ch       TABR         10Dh       18Dh       EEPCTL         10Eh       BGTRIM       18Eh       EEPEN         10Fh       IRCF       18Fh       EEPDT         110h       190h       190h       111h         111h       191h       192h       111h         112h       192h       193h       114h         113h       193h       193h       114h         115h       195h       16h       196h         117h       197h       198h       199h         118h       198h       199h       114h         118h       198h       199h       114h         117h       197h       197h       118h       192h         118h       198h       199h       114h       192h         118h       199h       199h       114h       192h         118h       199h       190h       116h       190h         11Bh       190h       110h       190h       110h         118h       199h       140h       140h       140h         10h       10h       10h                                                                                                                                          | 109h  | LVRPD     | 189h   | CRCIN     |
| 10Ch         18Ch         TABR           10Dh         18Dh         EEPCTL           10Eh         BGTRIM         18Eh         EEPEN           10Fh         IRCF         18Fh         EEPDT           110h         190h         190h         111h           112h         192h         192h         111h           112h         192h         193h         114h           113h         193h         193h         114h           115h         195h         16H         196h           117h         197h         198h         199h           118h         198h         199h         114h           117h         197h         197h         118h           118h         198h         199h         114h           118h         198h         199h         114h           117h         197h         197h         118h           118h         198h         199h         114h           118h         192h         116H         192h           116H         19Fh         116H         19Fh           120h         IA0h         IEFh         IEFh           16Fh         1EFh <td>10Ah</td> <td>PCLATH</td> <td>18Ah</td> <td>PCLATH</td>    | 10Ah  | PCLATH    | 18Ah   | PCLATH    |
| $10Dh$ $18Dh$ $EEPCTL$ $10Fh$ $IRCF$ $18Fh$ $EEPDT$ $110h$ $190h$ $190h$ $110h$ $110h$ $190h$ $190h$ $110h$ $111h$ $191h$ $190h$ $111h$ $112h$ $192h$ $192h$ $111h$ $112h$ $192h$ $192h$ $111h$ $112h$ $192h$ $192h$ $111h$ $112h$ $192h$ $192h$ $111h$ $115h$ $195h$ $116h$ $196h$ $117h$ $197h$ $118h$ $198h$ $117h$ $197h$ $199h$ $114h$ $118h$ $198h$ $199h$ $114h$ $118h$ $199h$ $190h$ $116h$ $110h$ $190h$ $190h$ $110h$ $190h$ $1120h$ $1A0h$ $100h$ $100h$ $100h$ $16Fh$ $1EFh$ $100h$ $100h^27Fh$ $10h^27Fh$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10Bh  | INTIE     | 18Bh   | INTIE     |
| 10Eh         BGTRIM         18Eh         EEPEN           10Fh         IRCF         18Fh         EEPDT           110h         190h         190h         111h           112h         192h         193h         114h           113h         193h         193h         114h           115h         195h         116h         196h           117h         197h         197h         118h           118h         198h         199h         114h           117h         197h         197h         118h           117h         197h         197h         118h           118h         198h         199h         114h           118h         198h         199h         114h           118h         198h         199h         114h           118h         192h         199h         114h           118h         192h         199h         114h           119h         192h         199h         114h           110h         192h         190h         116h           118h         198h         198h         199h           116h         192h         140h         190h <tr< td=""><td>10Ch</td><td></td><td>18Ch</td><td>TABR</td></tr<> | 10Ch  |           | 18Ch   | TABR      |
| 10Fh         IRCF         18Fh         EEPDT           110h         190h         190h         190h           111h         191h         191h         191h           112h         192h         193h         114h           113h         193h         193h         114h           113h         193h         193h         114h           115h         195h         196h         197h           116h         196h         197h         197h           118h         198h         199h         11Ah           119h         199h         199h         11Ah           110h         192h         198h         119h           110h         192h         199h         11Ah           110h         192h         199h         11Ah           110h         192h         199h         11Ah           110h         192h         199h         11Ah           110h         192h         140h         190h           1120h                                                                                                                                                                                                                        | 10Dh  |           | 18Dh   | EEPCTL    |
| 110h       190h         111h       191h         112h       192h         113h       193h         113h       193h         114h       194h         115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Eh       19Fh         120h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 10Eh  | BGTRIM    | 18Eh   | EEPEN     |
| 1111h       191h         112h       192h         113h       192h         113h       193h         114h       194h         115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         114h       194h         115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Eh       19Fh         120h       IAOh         ~       ~         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10Fh  | IRCF      | 18Fh   | EEPDT     |
| 112h       192h         113h       193h         114h       193h         114h       194h         115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Ah         11Bh       19Ph         11Ch       19Ch         11Dh       19Dh         11Eh       19Eh         11Fh       19Fh         120h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 110h  |           | 190h   |           |
| 113h       193h         114h       194h         115h       194h         115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Eh       19Eh         11Fh       19Fh         120h       IAOh         ~       ~         16Fh       1EFh         170h       accesses         70h~7Fh       ~       70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 111h  |           | 191h   |           |
| 113h       193h         114h       194h         115h       194h         115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Eh       19Eh         11Fh       19Fh         120h       IAOh         ~       ~         16Fh       1EFh         170h       accesses         70h~7Fh       ~       70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 112h  |           | 192h   |           |
| 114h       194h         115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       199h         11Ah       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Eh       19Fh         11Fh       19Fh         120h       IAOh              16Fh       1EFh         170h       accesses         1170h       TOh~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |           |        |           |
| 115h       195h         116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Ch       19Ph         11Ph       19Ph         11Ph       19Ph         11Ph       19Ph         120h       IAOh         ~       ~         16Fh       1EFh         170h       accesses         1F0h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |        |           |
| 116h       196h         117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Eh       19Fh         11Fh       19Fh         120h       IAOh         ^       Accesses         16Fh       1FOh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |           |        |           |
| 117h       197h         118h       198h         119h       199h         11Ah       19Ah         11Bh       19Ah         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Eh       19Eh         11Fh       19Fh         120h       IAOh         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |           |        |           |
| 118h       198h         119h       199h         11Ah       199h         11Ah       19Ah         11Bh       19Bh         11Ch       19Ch         11Ch       19Dh         11Dh       19Dh         11Eh       19Fh         11Fh       19Fh         120h       1AOh         ^       -         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |           |        |           |
| 119h       199h         11Ah       199h         11Bh       19Bh         11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Dh       19Dh         11Eh       19Eh         11Fh       19Fh         120h       1A0h         ~       ~         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |           |        |           |
| 11Ah       19Ah         11Bh       19Bh         11Ch       19Bh         11Ch       19Ch         11Dh       19Dh         11Bh       19Dh         11Bh       19Dh         11Bh       19Bh         11Dh       19Dh         11Fh       19Fh         120h       1A0h         ~       -         16Fh       1EFh         170h       accesses         11F0h       2000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |           |        |           |
| 11Bh       19Bh         11Ch       19Ch         11Dh       19Dh         11Bh       19Dh         11Eh       19Fh         11Fh       19Fh         120h       1A0h         ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |           |        |           |
| 11Ch       19Ch         11Dh       19Dh         11Eh       19Dh         11Fh       19Fh         120h       1A0h         ~       -         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |           |        |           |
| 11Dh       19Dh         11Eh       19Eh         11Fh       19Fh         120h       1A0h         ~       ~         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |           |        |           |
| 11Eh       19Eh         11Fh       19Fh         120h       1A0h         ~       ~         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |           |        |           |
| 11Fh       19Fh         120h       1A0h         ~       ~         16Fh       1EFh         170h       accesses         70h~7Fh       ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |           |        |           |
| 120h         1A0h           ~         ~           16Fh         1EFh           170h         accesses           70h~7Fh         ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |           |        |           |
| 16Fh         1EFh           170h         accesses           70h~7Fh         ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |           | -      |           |
| 170h accesses 1F0h accesses<br>~ 70h~7Fh ~ 70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 12011 |           | 111011 |           |
| 170h accesses 1F0h accesses<br>~ 70h~7Fh ~ 70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |           |        |           |
| 170h accesses 1F0h accesses<br>~ 70h~7Fh ~ 70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ~     |           | ~      |           |
| 170h accesses 1F0h accesses<br>~ 70h~7Fh ~ 70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |           |        |           |
| 170h accesses 1F0h accesses<br>~ 70h~7Fh ~ 70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 16Fh  |           | 1EFh   |           |
| ~ 70h~7Fh ~ 70h~7Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       | accesses  | -      | 200000    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ~     |           | ~      |           |
| 1/111 111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 17Fh  |           | 1FFh   |           |



 $\bigcirc$ Example: read / write register by using direct addressing (force RP0 = RP1 = 0)

| e       | •              | •    |                                         |
|---------|----------------|------|-----------------------------------------|
| TM1     | equ            | 12H  | ;SFR in Bank0                           |
| PWM0PRD | equ            | 92H  | ;SFR in Bank1                           |
| IRCF    | equ            | 10FH | ;SFR in Bank2                           |
| DPL     | equ            | 185H | ;SFR in Bank3                           |
| RAM20   | equ            | 20H  | ;RAM in Bank0                           |
| RAMA0   | equ            | A0H  | ;RAM in Bank1                           |
| MOUNN   | TTN <b>(</b> 1 |      | , mod TM1 (Darka) to W                  |
| MOVXW   | TM1            |      | ; read TM1 (Bank0) to W                 |
| MOVXW   | PWM0PR         | D    | ; read PWM0PRD (Bank1) to W             |
| MOVXW   | IRCF           |      | ; read IRCF (Bank2) to W                |
| MOVXW   | DPL            |      | ; read DPL (Bank3) to W                 |
| MOVLW   | 16H            |      |                                         |
| MOVLW   | RAM20          |      | ; $W = 16h$ write to RAM[0x20]          |
| MOVWX   | RAMA0          |      | ; $W = 16h$ write to RAM[0x20]          |
| MOVWA   | KAMAU          |      | ; $w = 1011$ while to $RAM[0xA0]$       |
| MOVLW   | 37H            |      |                                         |
| MOVWX   | LVRPD          |      | ; $LVRPD = W = 37h$ , force LVR disable |
|         |                |      |                                         |
| MOVXW   | CLKCTL         |      | ; read SFR CLKCTL (0Fh) to W            |
| MOVXW   | IRCF           |      | ; read SFR IRCF (10Fh) to W             |
|         |                |      |                                         |
| MOVLW   | 0BH            |      |                                         |
| MOVWX   | CLKCTL         |      | ; CLKCTL $(0Fh) = W = 0Bh$              |
| MOVWX   | IRCF           |      | ; IRCF $(10Fh) = W = 0Bh$               |
|         |                |      |                                         |

 $\diamond$ Example: read / write register by using indirect addressing (force RP0 = RP1 = 0)

| BSX                                     | IRP                              | ; IRP = 1 => Bank2/3                                                                                   |
|-----------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------|
| MOVLW                                   | 0FH                              | ; $W = 0Fh$                                                                                            |
| MOVWX                                   | FSR                              | ; $FSR = W = 0Fh$                                                                                      |
| MOVXW                                   | INDF                             | ; read SFR IRCF (10Fh) to W                                                                            |
|                                         |                                  |                                                                                                        |
| BSX                                     | IRP                              | ; IRP = $1 => Bank2/3$                                                                                 |
| MOVLW                                   | 0FH                              | ; $W = 0Fh$                                                                                            |
| MOVWX                                   | FSR                              | ; $FSR = W = 0Fh$                                                                                      |
| MOVLW                                   | 0BH                              | ; $W = 0Bh$                                                                                            |
| MOVWX                                   | INDF                             | ; IRCF $(10Fh) = W = 0Bh$                                                                              |
|                                         |                                  |                                                                                                        |
| BCX                                     | IRP                              | ; IRP=0 =>Bank0/1                                                                                      |
|                                         |                                  |                                                                                                        |
| MOVLW                                   | 0FH                              | ; $W = 0Fh$                                                                                            |
| MOVLW<br>MOVWX                          |                                  | ; $W = 0Fh$<br>; FSR = W = 0Fh                                                                         |
|                                         | FSR                              |                                                                                                        |
| MOVWX                                   | FSR                              | ; $FSR = W = 0Fh$                                                                                      |
| MOVWX                                   | FSR                              | ; $FSR = W = 0Fh$                                                                                      |
| MOVWX<br>MOVXW                          | FSR<br>INDF<br>IRP               | ; FSR = W = 0Fh<br>; read SFR CLKCTL (0Fh) to W                                                        |
| MOVWX<br>MOVXW<br>BCX                   | FSR<br>INDF<br>IRP<br>0FH        | ; FSR = W = 0Fh<br>; read SFR CLKCTL (0Fh) to W<br>; IRP = 0 => Bank0/1                                |
| MOVWX<br>MOVXW<br>BCX<br>MOVLW          | FSR<br>INDF<br>IRP<br>0FH<br>FSR | ; FSR = W = 0Fh<br>; read SFR CLKCTL (0Fh) to W<br>; IRP = 0 => Bank0/1<br>; W = 0Fh                   |
| MOVWX<br>MOVXW<br>BCX<br>MOVLW<br>MOVWX | FSR<br>INDF<br>OFH<br>FSR<br>OBH | ; FSR = W = 0Fh<br>; read SFR CLKCTL (0Fh) to W<br>; IRP = 0 => Bank0/1<br>; W = 0Fh<br>; FSR = W =0Fh |





#### **1.5** Programming Counter (PC) and Stack

The Programming Counter is 11-bit wide capable of addressing a 2K x 16 Flash ROM. The low byte comes from PCL register, which is readable and writable register. The upper bits (PC[10:8]) are not readable, but are indirectly writable through the PCLATH register. On any RESET, the upper bits of the PC will be cleared. As a program instruction is executed, the PC will contain the address of the next program instruction to be executed. The PC value is normally increased by one except the followings. The Reset Vector (000h) and the Interrupt Vector (004h) are provided for PC initialization and Interrupt. For CALL/GOGO instruction, PC loads 11 bit address from instruction word. For RET/RETI/RETLW instruction, PC retrieves its content from the top level STACK. Executing any instruction with the PCL register as the destination simultaneously causes the Program Counter PC[10:8] bits (PCH) to be replaced by the contents of the PCLATH register. This allows the entire contents of the program counter to be changed by writing the desired upper 3 bits to the PCLATH register. When the lower 8 bits are written to the PCL register, all 11 bits of program counter will change to the values contained in the PCLATH register.



The STACK is 11-bit wide and 8-level in depth. The CALL instruction and hardware interrupt will push STACK level in order. While the RET/RETI/RETLW instruction pops STACK level in order. For table lookup, the device offer the powerful table read instructions TABRL, TABRH to return the 16-bit ROM data into W register by setting DPTR={DPH, DPL} registers. It also offers another way to read the16-bit ROM data into W register by setting TABR (18Ch) for C language.

 $\diamond$  Example: To look up the PROM data located "TABLE1" and "TABLE2".

| ORG    | 000h<br>GOTO | START              | ; Reset Vector                                 |
|--------|--------------|--------------------|------------------------------------------------|
| START: |              |                    |                                                |
|        | MOVLW        | 00H                |                                                |
|        | MOVWX        | INDEX              | ; Set lookup table's address                   |
| LOOP:  |              |                    |                                                |
|        | MOVLW        | (TABLE1>>8) & 0xff |                                                |
|        | MOVWX        | PCLATH             | ; Instruction with PCL as Destination          |
|        | MOVXW        | INDEX              | ; Move index value to W register               |
|        | CALL         | TABLE1             | ; To lookup data, W=55h                        |
|        |              |                    | -                                              |
|        | INCX         | INDEX, 1           | ; Increment the index address for next address |
|        |              |                    |                                                |
|        | GOTO         | LOOP               | ; Go to LOOP label                             |
|        |              |                    |                                                |



|                | MOVLW<br>MOVWX<br>MOVLW<br>MOVWX          | (TABLE2 >>8) & 0xff<br>DPH<br>(TABLE2) & 0xff<br>DPL | ; DPH register (F186.2~0)<br>; DPL register (F185.7~0)                                                                                          |
|----------------|-------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| ; Table Rea    | d by opcode T<br>TABRL<br>TABRH<br>       | ABRL / TABRH                                         | ; read PROM low byte data to W (W=86h)<br>; read PROM high byte data to W (W=19h)                                                               |
| ; Another w    | ay of Table R                             | ead by sfr TABR                                      |                                                                                                                                                 |
| ,              | MOVLW<br>MOVWX<br>MOVLW<br>MOVWX          | 01H<br>TABR<br>02H<br>TABR                           | ; TABR = 01H = opcode TABRL<br>; read PROM low byte data to W (W=86h)<br>; TABR = 02H = opcode TABRH<br>; read PROM high byte data to W (W=19h) |
| TABLE1:        |                                           |                                                      |                                                                                                                                                 |
| TABLET.        | ADDWX<br>RETLW<br>RETLW<br>RETLW<br>RETLW | PCL, 1<br>55H<br>56H<br>57H<br>58H                   | ; Add the W with PCL, the result back in PCL.<br>; W=55h when return<br>; W=56h when return<br>; W=57h when return<br>; W=58h when return       |
| ORG<br>TABLE2: | 368h                                      |                                                      |                                                                                                                                                 |
| TIDEL2.        | .DT<br>.DT<br>.DT<br>                     | 0x1986<br>0x3719<br>0x2983                           | ; 16-bit ROM data                                                                                                                               |

| 18Ch  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| TABR  |       | TABR  |       |       |       |       |       |       |
| R/W   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

18Ch.7~0 1. TABR write 01h = opcode TABRL

2. TABR write 02h = opcode TABRH

3. After step.1 or step.2, read TABR to get main ROM table read value After step.1, read TABR to get EEPROM value (when EEPEN = E2h) *Table Read for ASM: TABRL/ TABRH or TABR Table Read for C: TABR*



#### 1.5.1 ALU and Working (W) Register

The ALU is 8-bit wide and capable of addition, subtraction, shift and logical operations. In two-operand instructions, typically one operand is the W register, which is an 8-bit non-addressable register used for ALU operations. The other operand is either a file register or an immediate constant. In single operand instructions, the operand is either W register or a file register. Depending on the instruction executed, the ALU may affect the values of Carry (C), Digit Carry (DC), and Zero (Z) Flags in the STATUS register. The C and DC flags operate as a /Borrow and /Digit Borrow, respectively, in subtraction.

Note: /Borrow represents inverted of Borrow register.

/Digit Borrow represents inverted of Digit Borrow register.

#### 1.5.2 STATUS Register (03H/83H/103H/183H)

This register contains the arithmetic status of ALU and the Reset status. The STATUS register can be the destination for any instruction, as with any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. It is recommended, therefore, that only BCX, BSX and MOVWX instructions are used to alter the STATUS Register because these instructions do not affect those bits.

| STATUS             | Bit 7                                               | Bit 6                                                                                                                                                                                                             | Bit 5     | Bit 4        | Bit 3                  | Bit 2       | Bit 1                     | Bit 0     |
|--------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------|------------------------|-------------|---------------------------|-----------|
| <b>Reset Value</b> | 0                                                   | 0                                                                                                                                                                                                                 | 0         | 0            | 0                      | 0           | 0                         | 0         |
| R/W                | R/W                                                 | R/W                                                                                                                                                                                                               | R/W       | R            | R                      | R/W         | R/W                       | R/W       |
| Bit                |                                                     |                                                                                                                                                                                                                   |           | Descr        | iption                 |             |                           |           |
| 7                  | 0 = Ban                                             | ister Bank S<br>1k 0,1 (00h<br>1k 2,3 (100ł                                                                                                                                                                       | - FFh)    | sed for indi | rect addres            | sing)       |                           |           |
| 6:5                | 00 = Bat $01 = Bat$ $10 = Bat$ $11 = Bat$ Each bank | <b>RP1:RP0</b> : Register Bank Select bits (used for direct addressing)<br>00 = Bank 0 (00h - 7Fh)<br>01 = Bank 1 (80h - FFh)<br>10 = Bank 2 (100h - 17Fh)<br>11 = Bank 3 (180h - 1FFh)<br>Each bank is 128 bytes |           |              |                        |             |                           |           |
| 4                  | 0: after P                                          | <b>TO</b> : Time Out Flag<br>0: after Power On Reset, LVR Reset or CLRWDT/SLEEP instruction<br>1: WDT time out occurs                                                                                             |           |              |                        |             |                           |           |
| 3                  | 0: after P                                          | PD: Power Down Flag<br>0: after Power On Reset, LVR Reset or CLRWDT instruction<br>1: after SLEEP instruction                                                                                                     |           |              |                        |             |                           |           |
| 2                  | 0: the res<br>1: the res                            | <ul> <li>Z: Zero Flag</li> <li>0: the result of a logic operation is not zero</li> <li>1: the result of a logic operation is zero</li> </ul>                                                                      |           |              |                        |             |                           |           |
|                    | DC: Decin                                           |                                                                                                                                                                                                                   |           | imal / Borro | ow Flag                |             |                           |           |
| 1                  | 0: no carr<br>1: a carry<br>result o                | from the l                                                                                                                                                                                                        |           | oits of the  |                        | sult occurs | struction<br>e low nibble | e bits of |
|                    | C: Carry I                                          | Flag or /Bo                                                                                                                                                                                                       | rrow Flag |              |                        |             |                           |           |
| 0                  |                                                     | ADD in                                                                                                                                                                                                            | struction |              |                        | SUB ins     | struction                 |           |
| U                  | 0: no carr<br>1: a carry                            | ry<br>v occurs fro                                                                                                                                                                                                | m the MSB |              | 0: a borr<br>1: no bor |             | from the MS               | SB        |



♦ Example: Write immediate data into STATUS register.

| MOVLW | 00H    |                         |
|-------|--------|-------------------------|
| MOVWX | STATUS | ; Clear STATUS register |

♦ Example: Bit addressing set and clear STATUS register.

| BSX | STATUS, 0 | ; Set C=1   |
|-----|-----------|-------------|
| BCX | STATUS, 0 | ; Clear C=0 |

♦ Example: Determine the C flag by BTXSS instruction.

| BTXSS | STATUS, 0 | ; Check the carry flag |
|-------|-----------|------------------------|
| GOTO  | LABEL_1   | ; If C=0, goto label_1 |
| GOTO  | LABEL_2   | ; If C=1, goto label_2 |



#### 2 Reset

This device can be RESET in four ways.

- Power-On-Reset (POR)
- Low Voltage Reset (LVR)
- External Pin Reset (PA7)
- Watchdog Reset (WDT)

Resets can be caused by Power on Reset (POR), External Pin Reset (XRST), Watchdog Timer Reset (WDT), or Low Voltage Reset (LVR). The CFGWH controls the Reset functionality. After Reset, the SFRs are returned to their default value, the program counter (PC) is cleared, and the system starts running from the reset vector 000H place. The TO and PD flags at status register (STATUS) are indicate system reset status.

#### 2.1 Power on Reset

After Power-On-Reset, all system and peripheral control registers are then set to their default hardware Reset values. The clock source, LVR level and chip operation mode are selected by the CFGWH register value.

#### 2.2 Low Voltage Reset

The Low Voltage Reset features static reset when supply voltage is below a threshold level. There are four threshold levels can be selected. The LVR's operation mode is defined by the CFGWH register. See the following LVR Selection Table; user must also consider the lowest operating voltage of operating frequency.

LVR Selection Table:

| LVR level | Operating voltage                      |
|-----------|----------------------------------------|
| LVR2.2    | 5.5V > VCC > 2.2V                      |
| LVR2.8    | 5.5V > VCC > 2.8V                      |
| LVR3.6    | 5.5V > VCC > 3.6V                      |
| LVR4.2    | $5.5V > VCC > 4.2V$ or $V_{CC} = 5.0V$ |

Different Fsys have different system minimum operating voltage, reference to Operating Voltage of DC characteristics, if current system voltage is low than minimum operating voltage and lower LVR is selected, then the system maybe enters dead-band and error occurs.



#### 2.3 External Pin Reset

The External Pin Reset can be disabled or enabled by the CFGWH register. It needs to keep at least 2 SIRC clock cycle long to be seen by the chip. XRST also set all the control registers to their default reset value. The TO/PD flags are not affected by these resets.

External reset pin is low level active. The system is running when reset pin is high level voltage input. The reset pin receives the low voltage and the system is reset. The external reset can reset the system during power on duration, and good external reset circuit can protect the system to avoid working at unusual power condition.



#### 2.4 Watchdog Timer Reset

WDT overflow Reset can be disabled or enabled by the CFGWH register. It runs in Fast/Slow mode and runs or stops in IDLE/STOP mode. WDT overflow speed can be defined by WDTPSC SFR. WDT is cleared by device Reset or CLRWDT SFR bit WDT overflow Reset also set all the control registers to their default reset value. The TO/PD flags are not affected by these resets.

♦ Example: Defining Reset Vector

|        | ORG<br>GOTO | 000H<br>START | ; Reset Vector<br>; Jump to user program address. |
|--------|-------------|---------------|---------------------------------------------------|
| START: | ORG         | 010H          | ; 010H, The head of user program                  |
|        |             |               |                                                   |
|        | GOTO        | START         |                                                   |



#### **3** Clock Circuitry and Operation Mode

#### 3.1 System Clock

The device is designed with dual-clock system. There are two kinds of clock source, i.e. SIRC (Slow Internal RC), and FIRC (Fast Internal RC). Each clock source can be applied to CPU kernel as system clock. When in IDLE mode, only Slow-clock can be configured to keep oscillating to provide clock source to T2 block. Refer to the figure below.

After Reset, the device is running at Slow mode with 70 KHz SIRC. S/W should select the proper clock rate for chip operation safety. The higher  $V_{CC}$  allows the chip to run at a higher System clock frequency. In a typical condition, a 8MHz System clock rate requires  $V_{CC} > 2.1V$ .

The CLKCTL (0Fh) SFR controls the System clock operating. H/W automatically blocks the S/W abnormally setting for this register. Never to write both FASTSTP=1 & CPUCKS=1. It is recommended to write this SFR bit by bit.



#### **Clock Scheme Block Diagram**

The frequency of FIRC (Fast Internal RC) can be adjusted by IRCF (10Fh). When IRCF=00h, frequency is the lowest. When IRCF=7Fh, frequency is the highest. With this function, we can adjust the frequency of FIRC after power on. Each IC may have different default value of IRCF, to make sure the frequency of FIRC=8 MHz after Power on Reset.



#### FAST Mode:

In this mode, the program is executed using Fast-clock as CPU clock (Fsys). The Timer0, Timer1 blocks are also driven by Fast-clock, The PWM0/PWM1 block can driven by FIRC 8M, FIRC 16M or Fsys. T2 can be driven by Slow-clock or Fsys/128 by setting T2CKS (15h.2).

#### SLOW Mode:

After power-on or reset, device enters SLOW mode, the default Slow-clock is SIRC. In this mode, the Fast-clock can stopped (by FASTSTP=1, for power saving) or running (by FASTSTP=0), and Slow-clock is enabled. All peripheral blocks (Timer0, Timer1etc...) clock sources are Slow-clock in the SLOW mode.

#### **IDLE Mode:**

If Slow-clock is enabled (SLOWSTP=0) and T2CKS=0 before executing the SLEEP instruction, the CPU enters the IDLE mode. In this mode, the Slow-clock source keeps T2 block running. CPU stop fetching code and all blocks are stop except T2 related circuits. Idle mode is terminated by Reset or enabled Interrupts wake up.

Another way to keep Slow-clock oscillation in IDLE mode is setting WKTIE=1 (0Bh.3) to keeping WKT running before executing the SLEEP instruction or WDTE=11 (CFGWH.9~8) to keeping WDT running. In such condition, the Slow-clock keeps working and wakes up CPU periodically no matter SLOWSTP is set or cleared.

T2 and WKT/WDT are independent and have their own control registers. It is possible to keep both T2 and WKT working and wake-up in the IDLE mode.

#### **STOP Mode:**

When SLOWSTP (0Fh.4) is set, WKTIE (0Bh.3) is cleared and WDTE=10 or 0X, all blocks will be turned off and the Chip will enter the "STOP Mode" after executing the SLEEP instruction. STOP mode is similar to IDLE mode. The difference is all clock oscillators either Fast-clock or Slow-clock are stopped and no clocks are generated.



#### 3.2 Dual System Clock Modes Transition

The device is operated in one of four modes: FAST mode, SLOW mode, IDLE mode, and STOP mode.



#### **CPU Operation Block Diagram**

CPU Mode & Clock Functions Table:

| Mode | Oscillator | Fsys       | Fast-clock        | Slow-clock        | TM0/TM1 | T2   | Wakeup event |
|------|------------|------------|-------------------|-------------------|---------|------|--------------|
| FAST | FIRC       | Fast-clock | Run               | Set by<br>SLOWSTP | Run     | Run  | Х            |
| SLOW | SIRC       | Slow-clock | Set by<br>FASTSTP | Run               | Run     | Run  | Х            |
| IDLE | SIRC       | Stop       | Stop              | Run               | Stop    | Run  | WKT/IO/T2    |
| STOP | Stop       | Stop       | Stop              | Stop              | Stop    | Stop | IO           |



#### • FAST mode switches to SLOW mode

The following steps are suggested to be executed by order when FAST mode switches to SLOW mode:

- (1) Enable Slow-clock (SLOWSTP=0)
- (2) Switch to Slow-clock (CPUCKS=0)
- (3) Stop Fast-clock (FASTSTP=1)

◇ Example: Switch FAST mode to SLOW mode.

| BCX | SLOWSTP | ; Enable Slow-clock  |
|-----|---------|----------------------|
| NOP |         |                      |
| BCX | CPUCKS  | ; Fsys=Slow-clock    |
| BSX | FASTSTP | ; Disable Fast-clock |

#### • SLOW mode switches to FAST mode

SLOW mode can be enabled by CPUCKS=0 in CLKCTL register. The following steps are suggested to be executed by order when SLOW mode switches to FAST mode:

- (1) Enable Fast-clock (FASTSTP=0)
- (2) Switch to Fast-clock (CPUCKS=1)

♦ Example: Switch SLOW mode to FAST mode (The Fast-clock stop).

| BCX | FASTSTP | ; Enable Fast-clock |
|-----|---------|---------------------|
| NOP |         |                     |
| BSX | CPUCKS  | ; Fsys=Fast-clock   |

#### • IDLE mode Setting

The IDLE mode can be configured by following setting in order:

- (1) Enable Slow-clock (SLOWSTP=0) or WKT(WKTIE=1)
- (2) Switch T2 clock source to Slow-clock (T2CKS=0)
- (3) Execute SLEEP instruction

IDLE mode can be wake up by External interrupt, WKT interrupt and T2 interrupt.

♦ Example: Switch FAST/SLOW mode to IDLE mode.

| BCX   | SLOWSTP            | ; Enable Slow-clock |
|-------|--------------------|---------------------|
| MOVLW | 00000 <u>000</u> B |                     |
| MOVWX | T2CTL              |                     |
| SLEEP |                    | ; Enter IDLE mode   |



#### • STOP Mode Setting

The STOP mode can be configured by following setting in order:

- (1) Stop Slow-clock (SLOWSTP=1)
- (2) Stop WKT/WDT (WKTIE=0, WDTE=10 or 0X)
- (3) Execute SLEEP instruction

STOP mode can be woken up only by External pin interrupt.

♦ Example: Switch FAST/SLOW mode to STOP mode.

| BSX   | SLOWSTP            | ; Disable Slow-clock.  |
|-------|--------------------|------------------------|
| MOVLW | 0000 <u>0</u> 000B | ; Disable WKT counting |
| MOVWX | INTIE              |                        |
| SLEEP |                    | ; Enter STOP mode.     |

| 0Fh    | Bit 7 | Bit 6 | Bit 5 | Bit 4   | Bit 3   | Bit 2  | Bit 1  | Bit 0 |
|--------|-------|-------|-------|---------|---------|--------|--------|-------|
| CLKCTL | _     | _     | _     | SLOWSTP | FASTSTP | CPUCKS | CPUPSC |       |
| R/W    | -     | _     | _     | R/W     | R/W     | R/W    | R/W    |       |
| Reset  |       |       |       | 0       | 0       | 0      | 1      | 1     |

0Fh.4 SLOWSTP: Slow-clock stop

| 0: Slow-clock | is | running |
|---------------|----|---------|
|---------------|----|---------|

- 1: Slow-clock stops running in Power-down mode
- 0Fh.3 FASTSTP: Fast-clock stop
  - 0: Fast-clock is running
  - 1: Fast-clock stops running
- 0Fh.2 CPUCKS: System clock source select
  - 0: Slow-clock
  - 1: Fast-clock
- 0Fh.1~0 CPUPSC: System clock source prescaler. System clock source
  - 00: divided by 8
  - 01: divided by 4
  - 10: divided by 2
  - 11: divided by 1



#### 3.3 System Clock Oscillator

In the Fast Internal RC (FIRC) mode, the on-chip oscillator generates 8 MHz system clock. Since power noise degrades the performance of Internal Clock Oscillator, placing power supply bypass capacitors 1 uF and 0.1 uF very close to VCC/VSS pins improves the stability of clock and the overall system.



Internal RC Mode



### 4 Interrupt

TM56F8225 has 1 level, 1 vector and 12 interrupt sources. Each interrupt source has its own enable control bit. An interrupt event will set its individual pending flag, no matter its enable control bit is 0 or 1.

If the corresponding interrupt enable bit (INTIE[7:0], INTIE1[3:0]) has been set, it would trigger CPU to service the interrupt. CPU accepts interrupt in the end of current executed instruction cycle. In the mean while, a "CALL 004" instruction is inserted to CPU, and i-flag is set to prevent recursive interrupt nesting.

The i-flag is cleared in the instruction after the "RETI" instruction. That is, at least one instruction in main program is executed before service the pending interrupt. The interrupt event is level triggered. F/W must clear the interrupt event register while serving the interrupt routine.





◊ Example: Setup INT1 (PA1) interrupt request with rising edge trigger

| ORG 000H ; Reset Vector                | r                                |
|----------------------------------------|----------------------------------|
| GOTO START ; Goto user pr              | rogram address                   |
|                                        |                                  |
| ORG 004H ; All interrupt               |                                  |
| GOTO INT ; If INT1 (PA                 | 1) input occurred rising edge    |
| ORG 005H                               |                                  |
| START:                                 |                                  |
| MOVLW xxxx <b>00</b> xxB               |                                  |
|                                        | Pin Mode as Mode0                |
|                                        | output low or input with Pull-up |
| MOVLW xxxxxx <b>1</b> xB               |                                  |
| =                                      | 1, it becomes Schmitt-trigger    |
| ,                                      | nput pull-up resistor            |
| MOVLW $001xxxxB$                       |                                  |
| —————————————————————————————————————— | terrupt trigger as rising edge   |
| MOVLW 11111101B                        |                                  |
| =                                      | interrupt request flag           |
| MOVLW 000000 <u>1</u> 0B               | interrupt request mag            |
| MOVWX INTIE ; Enable INT               | 1 interrupt                      |
| MAIN:                                  |                                  |
|                                        |                                  |
| GOTO MAIN                              |                                  |
|                                        |                                  |
| INT:                                   |                                  |
| MOVWX 20H ; Store W data               | a to FRAM 20H                    |
| MOVXW STATUS ; Get STATU               | S data                           |
| MOVWX 21H ; Store STAT                 | US data to FRAM 21H              |
|                                        |                                  |
| BTXSS INT1IF ; Check INT1              |                                  |
|                                        | exit interrupt subroutine        |
|                                        | upt service routine              |
| MOVLW 111111 <u>0</u> 1B               |                                  |
|                                        | interrupt request flag           |
| EXIT_INT:                              |                                  |
| MOVXW 21H ; Get FRAM 2                 |                                  |
| MOVWX STATUS ; Restore STA             | ATUS data                        |
| SWAPX 20H,f                            |                                  |
| SWAPX 20H,w ; Restore W d              |                                  |
| RETI ; Return from                     | interrunt                        |



| 0Bh/8Bh/10Bh/18Bh | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------------------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIE             | ADCIE | T2IE  | TM1IE | TM0IE | WKTIE | INT2IE | INT1IE | INT0IE |
| R/W               | R/W   | R/W   | R/W   | R/W   | R/W   | R/W    | R/W    | R/W    |
| Reset             | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

| INTIE.7 | ADCIE: ADC interrupt enable                       |
|---------|---------------------------------------------------|
|         | 0: disable                                        |
|         | 1: enable                                         |
| INTIE.6 | <b>T2IE:</b> T2 interrupt enable                  |
|         | 0: disable                                        |
|         | 1: enable                                         |
| INTIE.5 | TM1IE: Timer1 interrupt enable                    |
|         | 0: disable                                        |
|         | 1: enable                                         |
| INTIE.4 | TM0IE: Timer0 interrupt enable                    |
|         | 0: disable                                        |
|         | 1: enable                                         |
| INTIE.3 | WKTIE: Wakeup Timer interrupt enable              |
|         | 0: disable                                        |
|         | 1: enable                                         |
| INTIE.2 | <b>INT2IE:</b> INT2 (PA7) interrupt enable        |
|         | 0: disable                                        |
|         | 1: enable                                         |
| INTIE.1 | <b>INT1IE:</b> INT1 (PA1) interrupt enable        |
|         | 0: disable                                        |
|         | 1: enable                                         |
| INTIE.0 | <b>INTOIE:</b> INTO (PA2 or PA6) interrupt enable |
|         | 0: disable                                        |
|         |                                                   |

1: enable

| 0Ch   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIF | ADCIF | T2IF  | TM1IF | TM0IF | WKTIF | INT2IF | INT1IF | INT0IF |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

| 0Ch.7 | ADCIF: ADC interrupt event pending flag                                                            |
|-------|----------------------------------------------------------------------------------------------------|
|       | This bit is set by H/W after end of ADC conversion, write 0 to this bit will clear this flag       |
| 0Ch.6 | <b>T2IF:</b> T2 interrupt event pending flag                                                       |
|       | This bit is set by H/W while T2 overflows, write 0 to this bit will clear this flag                |
| 0Ch.5 | TM1IF: Timer1 interrupt event pending flag                                                         |
|       | This bit is set by H/W while Timer1 overflows, write 0 to this bit will clear this flag            |
| 0Ch.4 | TM0IF: Timer0 interrupt event pending flag                                                         |
|       | This bit is set by H/W while Timer0 overflows, write 0 to this bit will clear this flag            |
| 0Ch.3 | WKTIF: Wakeup Timer interrupt event pending flag                                                   |
|       | This bit is set by H/W while Wakeup Timer is timeout, write 0 to this bit will clear this flag     |
| 0Ch.2 | <b>INT2IF:</b> INT2 (PA7) pin falling interrupt pending flag                                       |
|       | This bit is set by H/W at INT2 pin's falling edge, write 0 to this bit will clear this flag        |
| 0Ch.1 | <b>INT1IF:</b> INT1 (PA1) pin falling/rising interrupt pending flag                                |
|       | This bit is set by H/W at INT1 pin's falling/rising edge, write 0 to this bit will clear this flag |
| 0Ch.0 | INTOIF: INTO (PA2 or PA6) pin falling/rising interrupt pending flag                                |
|       | This bit is set by H/W at INTO pin's falling/rising edge, write 0 to this bit will clear this flag |
|       |                                                                                                    |



| 0Dh    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|--------|-------|-------|-------|-------|---------|---------|---------|---------|
| INTIE1 | _     | _     | —     | —     | PWM1PIE | PWM1CIE | PWM1BIE | PWM1AIE |
| R/W    | _     | _     | —     | _     | R/W     | R/W     | R/W     | R/W     |
| Reset  | —     | —     | _     | _     | 0       | 0       | 0       | 0       |

| 0Dh.3 | <b>PWM1PIE:</b> PWM1 period interrupt enable |
|-------|----------------------------------------------|
|       | 0: disable                                   |
|       | 1: enable                                    |
| 0Dh.2 | <b>PWM1CIE:</b> PWM1C duty interrupt enable  |
|       | 0: disable                                   |
|       | 1: enable                                    |
| 0Dh.1 | <b>PWM1BIE:</b> PWM1B duty interrupt enable  |
|       |                                              |

0: disable

1: enable

#### 0Dh.0 **PWM1AIE:** PWM1A duty interrupt enable 0: disable 1: enable

| 0Eh    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|--------|-------|-------|-------|-------|---------|---------|---------|---------|
| INTIF1 | —     | —     | —     | —     | PWM1PIF | PWM1CIF | PWM1BIF | PWM1AIF |
| R/W    | —     | —     | —     | —     | R/W     | R/W     | R/W     | R/W     |
| Reset  | _     |       | _     | _     | 0       | 0       | 0       | 0       |

# 0Eh.3 PWM1PIF: PWM1 period interrupt event pending flag This bit is set by H/W after PWM1 counter count to the set period, write 0 to this bit will clear this flag 0Eh.2 PWM1CIF: PWM1C duty interrupt event pending flag This bit is set by H/W after PWM1 counter count to the set PWM1C duty, write 0 to this bit will

This bit is set by H/W after PWM1 counter count to the set PWM1C duty, write 0 to this bit will clear this flag

#### 0Eh.1 **PWM1BIF:** PWM1B duty interrupt event pending flag This bit is set by H/W after PWM1 counter count to the set PWM1B duty, write 0 to this bit will clear this flag

#### 0Eh.0 **PWM1AIF:** PWM1A duty interrupt event pending flag This bit is set by H/W after PWM1 counter count to the set PWM1A duty, write 0 to this bit will clear this flag

| 81h/181h | Bit 7  | Bit 6   | Bit 5   | Bit 4          | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|----------|--------|---------|---------|----------------|--------|-------|--------|-------|
| OPTION   | HWAUTO | INT0EDG | INT1EDG | <b>INT0SEL</b> | WDTPSC |       | WKTPSC |       |
| R/W      | R/W    | R/W     | R/W     | R/W            | R/W    | R/W   | R/W    | R/W   |
| Reset    | 0      | 0       | 0       | 0              | 1      | 1     | 1      | 1     |

| 81h.6 | <b>INT0EDG:</b> INT0 pin interrupt trigger edge |
|-------|-------------------------------------------------|
|       | 0: falling edge to trigger                      |
|       | 1: rising edge to trigger                       |
| 81h.5 | <b>INT1EDG:</b> INT1 pin interrupt trigger edge |
|       | 0: falling edge to trigger                      |
|       | 1: rising edge to trigger                       |
| 81h.4 | <b>INTOSEL:</b> INTO pin select                 |
|       | 0: PA6 1: PA2                                   |
|       |                                                 |



#### 5 I/O Port

#### 5.1 PA0-PA7

These pins can be used as Schmitt-trigger input, CMOS push-pull output. The pull-up resistor is assignable to each pin by S/W setting. To use the pin in Schmitt-trigger input mode, S/W needs to set the I/O pin to Mode0 or Mode1 and PxD=1. Reading the pin data (PxD) has different meaning. In "Read-Modify-Write" instruction, CPU actually reads the output data register. In the others instructions, CPU reads the pin state. The so-called "Read-Modify-Write" instruction includes BSX, BCX and all instructions.

These pins can operate in four different modes as below.

| Mode   | PA0~PA7<br>pin function | PxD<br>SFR data | Pin State  | Resistor<br>Pull-up | Digital Input |
|--------|-------------------------|-----------------|------------|---------------------|---------------|
| Mode 0 | Open Drain              | 0               | Drive Low  | Ν                   | Ν             |
|        | Input                   | 1               | Pull-up    | Y                   | Y             |
| Mode 1 | Open Drain              | 0               | Drive Low  | Ν                   | Ν             |
|        |                         | 1               | Hi-Z       | Ν                   | Y             |
| Mode 2 | CMOS Output             | 0               | Drive Low  | Ν                   | Ν             |
|        |                         | 1               | Drive High | Ν                   | Ν             |
| Mode 3 | Analog input for ADC    | Х               | _          | N                   | N             |

#### I/O Pin Function Table

Beside I/O port function, each pin has one or more alternative functions, such as PWM and ADC.

| Pin Name | Wake-up | ADC  | others       | Mode3 |
|----------|---------|------|--------------|-------|
| PA0      |         | ADC0 | PWM1A        | ADC0  |
| PA1      | INT1    | ADC1 | PWM0N        | ADC1  |
| PA2      | INT0    | ADC2 | PWM1B        | ADC2  |
| PA3      |         | ADC3 | PWM1C        | ADC3  |
| PA4      |         | ADC4 | PWM1C        | ADC4  |
| PA5      |         | ADC5 | PWM0P        | ADC5  |
| PA6      | INT0    | ADC6 | TM0CKI/PWM1A | ADC6  |
| PA7      | INT2    | ADC7 | PWM1B        | ADC7  |

#### **PortA multi-function Table**

The necessary SFR setting for pin's alternative function is list below.

| Alternative Function | Mode                 | PxD<br>SFR data | Pin State                | Other<br>necessary<br>SFR setting |  |
|----------------------|----------------------|-----------------|--------------------------|-----------------------------------|--|
| INT0, INT1, INT2     | 0                    | 1               | Input with Pull-up       | INTxIE                            |  |
| TM0CKI               | 1                    | 1               | Input                    | TM0CTL                            |  |
| ADC0~ADC7            | ADC0~ADC7 <b>3</b> X |                 | ADC Channel              | ADCHS                             |  |
| PWM0N, PWM0P,        | MON, PWMOP, 1        | Х               | PWM Output (Open Drain)  | PWMOE                             |  |
| PWM1A, PWM1B, PWM1C  | 2                    | Х               | PWM Output (COMS Output) | F W WICE                          |  |

Mode Setting for Port Alternative Function





#### **General Pin Structure**

♦ Example: Set PA0 as Schmitt-trigger input with pull-up (Mode0)

MOVLW xxxxxx<u>1</u>B MOVWX PAD MOVLW xxxxxx<u>00</u>B MOVWX PAMODL

; Set PA0 as Schmitt-trigger input with pull-up

◊ Example: Set PA0 as Schmitt-trigger input without pull-up (Mode1)

| MOVLW | xxxxxxx <b>1</b> B |                                                    |
|-------|--------------------|----------------------------------------------------|
| MOVWX | PAD                |                                                    |
| MOVLW | xxxxxx <b>01</b> B |                                                    |
| MOVWX | PAMODL             | ; Set PA0 as Schmitt-trigger input without pull-up |

◊ Example: Set PA0 as CMOS push-pull output mode (Mode2)

| MOVLW | xxxxxx <u>10</u> B |
|-------|--------------------|
| MOVWX | PAMODL             |

Example: Set PA0 as ADC0 analog input mode (Mode3)

| MOVLW | xxxxxx <u>11</u> B |                    |
|-------|--------------------|--------------------|
| MOVWX | PAMODL             | ; Set PA0 as mode3 |



| 8Ch    | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|--------|-------|-------|--------|-------|--------|-------|--------|-------|
| PAMODH | PA71  | MOD   | PA6MOD |       | PA5MOD |       | PA4MOD |       |
| R/W    | R/    | W     | R/W    |       | R/W    |       | R/W    |       |
| Reset  | 0     | 0     | 0      | 1     | 0      | 1     | 0      | 1     |

- 8Ch.7~6 PA7MOD: PA7 Pin Mode Control 00: Mode0 01: Mode1 10: Mode2 11: Mode3, PA7 as ADC7 channel input
  8Ch.5~4 PA6MOD: PA6 Pin Mode Control 00: Mode0 01: Mode1 10: Mode2 11: Mode3, PA6 as ADC6 channel input
  8Ch.3~2 PA5MOD: PA5 Pin Mode Control 00: Mode0
  - 01: Mode1
    - 10: Mode2
  - 11: Mode3, PA5 as ADC5 channel input
- 8Ch.1~0 **PA4MOD**: PA4 Pin Mode Control
  - 00: Mode0
    - 01: Mode1
    - 10: Mode2
    - 11: Mode3, PA4 as ADC4 channel input

| 8Dh    | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|--------|-------|-------|--------|-------|--------|-------|--------|-------|
| PAMODL | PA31  | MOD   | PA2MOD |       | PA1MOD |       | PA0MOD |       |
| R/W    | R/    | W     | R/W    |       | R/W    |       | R/W    |       |
| Reset  | 0     | 1     | 0      | 1     | 0      | 1     | 0      | 1     |

- 8Dh.7~6 PA3MOD: PA3 Pin Mode Control 00: Mode0 01: Mode1 10: Mode2 11: Mode3, PA3 as ADC3 channel input 8Dh.5~4 PA2MOD: PA2 Pin Mode Control 00: Mode0 01: Mode1 10: Mode2 11: Mode3, PA2 as ADC2 channel input 8Dh.3~2 PA1MOD: PA1 Pin Mode Control 00: Mode0 01: Mode1 10: Mode2 11: Mode3, PA1 as ADC1 channel input 8Dh.1~0 PA0MOD: PA0 Pin Mode Control 00: Mode0 01: Mode1 10: Mode2
  - 11: Mode3, PA0 as ADC0 channel input



| 05h   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PAD   |       | PAD   |       |       |       |       |       |       |
| R/W   |       | R/W   |       |       |       |       |       |       |
| Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

05h.7~0 **PAD**: PA7~PA0 data



# 6 Peripheral Functional Block

#### 6.1 Watchdog (WDT) /Wakeup (WKT) Timer

The WDT and WKT share the same built-in internal RC Oscillator and have individual own counters. The overflow period of WDT, WKT can be selected by individual prescaler (WDTPSC [1:0], WKTPSC [1:0]). The WDT timer is cleared by the CLRWDT instruction. If the Watchdog is enabled (CFGWH.9=WDTE=1), the WDT generates the chip reset signal. Set CFGWH.8 to '0' can let WDT timer stop counting after executing SLEEP instruction, i.e. CFGWH.8=1 WDT timer is always keep counting even if the SLEEP instruction is executed.

The WKT timer is an interval timer, WKT time out will generate WKT Interrupt Flag (WKTIF). The WKT timer is cleared/stopped by WKTIE=0. Set WKTIE=1, the WKT timer will always count regardless at any CPU operating mode.



WDT/WKT Block Diagram



| -           |         |         |      |
|-------------|---------|---------|------|
| Mode        | WDTE[1] | WDTE[0] | WDT  |
|             | 0       | 0       | Stop |
| Normal Mode | 0       | 1       | Stop |
| Normai Mode | 1       | 0       | Run  |
|             | 1       | 1       | Run  |
| Power-down  | 0       | 0       | Stop |
| Mode        | 0       | 1       | Stop |
| (SLEEP)     | 1       | 0       | Stop |
| (SLEEF)     | 1       | 1       | Run  |

The WDT's behavior in different Mode is shown as below table.

CLRWDT instruction could clear watchdog timer.

♦ Example: Clear watchdog timer by CLRWDT instruction.

| MAIN: | <br>CLRWDT |      | ; Execute program.<br>; Execute CLRWDT instruction. |
|-------|------------|------|-----------------------------------------------------|
|       | <br>GOTO   | MAIN |                                                     |

◇ Example: Setup WDT time and disable after executing SLEEP instruction.

| MOVLW<br>MOVWX | 0000 <u>01</u> 11B<br>OPTION | Select WDT Time out=256 ms @5V |
|----------------|------------------------------|--------------------------------|
| <br>SLEEP      |                              |                                |

♦ Example: Set WKT period and interrupt function.

| MOVLW | 000001 <u>10</u> B |                                                    |
|-------|--------------------|----------------------------------------------------|
| MOVWX | OPTION             | ; Select WKT period=64 ms @5V.                     |
| MOVLW | 1111 <b>0</b> 111B | ; Clear WKT interrupt flag by using byte operation |
| MOVWX | INTIF              | ; Don't use bit operation "BCX WKTIF" to clear     |
| MOVLW | 0000 <u>1</u> 000B |                                                    |
| MOVWX | INTIE              | ; Enable WKT interrupt function                    |



| 03h    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| STATUS | IRP   | RP1   | RP0   | ТО    | PD    | Z     | DC    | С     |
| R/W    | R/W   | R/W   | R/W   | R     | R     | R/W   | R/W   | R/W   |
| Reset  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

03h.4 **TO:** WDT time out flag, read-only

0: after Power On Reset, LVR Reset, or CLRWDT / SLEEP instructions 1: WDT time out occurs

| 0Ch   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIF | ADCIF | T2IF  | TM1IF | TM0IF | WKTIF | INT2IF | INT1IF | INTOIF |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

0Ch.3 WKTIF: Wakeup Timer interrupt event pending flag

This bit is set by H/W while Wakeup Timer is timeout, write 0 to this bit will clear this flag

| 0Bh   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIE | ADCIE | T2IE  | TM1IE | TM0IE | WKTIE | INT2IE | INT1IE | INT0IE |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

0Bh.3 WKTIE: Wakeup Timer interrupt enable

0: disable 1: enable

| 81h/181h | Bit 7  | Bit 6   | Bit 5   | Bit 4          | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|----------|--------|---------|---------|----------------|--------|-------|--------|-------|
| OPTION   | HWAUTO | INT0EDG | INT1EDG | <b>INTOSEL</b> | WDTPSC |       | WKTPSC |       |
| R/W      | R/W    | R/W     | R/W     | R/W            | R/W    | R/W   | R/W    | R/W   |
| Reset    | 0      | 0       | 0       | 0              | 1      | 1     | 1      | 1     |

<sup>81</sup>h.3~2 **WDTPSC:** WDT period (@VCC=5V) 00: 128 ms

01: 256 ms

10: 1024 ms

11: 2048 ms

- 81h.1~0 **WKTPSC:** WKT period (@VCC=5V)
  - 00: 16 ms
  - 01: 32 ms
  - 10: 64 ms
  - 11: 128 ms



#### 6.2 Timer0

The Timer0 is an 8-bit wide register 01h (TM0). It can be read or written as any other register. Besides, Timer0 increases itself periodically and automatically rolls over a new "offset value" (TM0RLD) while it rolls over based on the pre-scaled clock source, which can be Fsys/2 or TM0CKI (PA6) rising/falling input. The Timer0 increase rate is determined by "Timer0 Pre-Scale" (TM0PSC) register. The Timer0 always generates TM0IF when its count rolls over. It generates Timer0 Interrupt if (TM0IE) is set. Timer0 can be stopped counting if the TM0STP bit is set.



**Timer0 Block Diagram** 



The following timing diagram describes the Timer0 works in pure Timer mode.

When the Timer0 prescaler (TM0PSC) is written, the internal 8-bit prescaler will be cleared to 0 to make the counting period correct at the first Timer0 count. TM0CLK is the internal signal that causes the Timer0 to increase by 1 at the end of TM0CLK. TM0WR is also the internal signal that indicates the Timer0 is directly written by instruction; meanwhile, the internal 8-bit prescaler will be cleared. When Timer0 counts from FFh to TM0RLD, TM0IF (Timer0 Interrupt Flag) will be set to 1 and generate interrupt if TM0IE (Timer0 Interrupt Enable) is set.



Timer0 works in Timer mode (TM0CKS=0)



The equation of TM0 interrupt time value is as following:

TM0 interrupt interval cycle time = Fsys / 2 / TM0PSC / (256-TM0RLD)

#### ◇ Example: Setup Timer0 work in Timer mode, if Fsys = 8 MHz

| ; Setup Tim     | ner0 clock sou | rce and divider    |                                                 |
|-----------------|----------------|--------------------|-------------------------------------------------|
|                 | BSX            | CPUCKS             | ; Set Fast-clock as system clock                |
|                 | MOVLW          | 00x <u>00101</u> B | ; TM0CKS = 0, Timer0 clock is instruction cycle |
|                 | MOVWX          | TM0CTL             | ; TM0PSC = $0101b$ , divided by 32              |
| ; Setup Tim     | ner0 reload da | ta                 |                                                 |
|                 | MOVLW          | 80H                |                                                 |
|                 | MOVWX          | TMORLD             | ; Set Timer0 reload data = 128                  |
| ; Setup Tim     | ner0           |                    |                                                 |
|                 | BSX            | TM0STP             | ; Timer0 stops counting                         |
|                 | CLRX           | TM0                | ; Clear Timer0 content                          |
| ; Enable Ti     | mer0 and inte  | rrupt function     |                                                 |
|                 | MOVLW          | 111 <u>0</u> 1111B |                                                 |
|                 | MOVWX          | INTIF              | ; Clear Timer0 request interrupt flag           |
|                 | BSX            | TM0IE              | ; Enable Timer0 interrupt function              |
|                 | BCX            | TM0STP             | ; Enable Timer0 counting                        |
| <b>T</b> : 0: ( |                |                    |                                                 |

Timer0 interrupt frequency = Fsys / 2 / TM0PSC / (256-TM0RLD),

Fsys = 8MHz, TM0PSC = div 32

Timer0 interrupt frequency = 8 MHz / 2 / 32 / (256-128) = 0.976 KHz



The following timing diagram describes the Timer0 works in Counter mode.

If TM0CKS=1 then Timer0 counter source clock is from TM0CKI pin. TM0CKI signal is synchronized by instruction cycle (Fsys/2) that means the high/low time durations of TM0CKI must be longer than one instruction cycle time (Fsys/2) to guarantee each TM0CKI's change will be detected correctly by the synchronizer.



Timer0 works in Counter mode for TM0CKI (TM0EDG=0) , TM0CKS=1

• Example: Setup TM0 work in Counter mode and clock source from TM0CKI pin (PA6)

| ; Setup Tim | ner0 clock sour | rce and divider    |                                             |
|-------------|-----------------|--------------------|---------------------------------------------|
|             | MOVLW           | 00 <u>110000</u> B | ; TM0EDG = 1, counting edge is falling edge |
|             | MOVWX           | TM0CTL             | ; TM0CKS = 1, Timer0 clock is TM0CKI        |
|             |                 |                    | ; TM0PSC = $0000b$ , divided by 1           |
| ; Setup Tim | ner0            |                    |                                             |
|             | BSX             | TM0STP             | ; Timer0 stops counting                     |
|             | CLRX            | TM0                | ; Clear Timer0 content                      |
| ; Enable Ti | mer0 and read   | Timer0 counter     |                                             |
|             | BCX             | TM0STP             | ; Enable Timer0 counting                    |
|             |                 |                    |                                             |
|             | BSX             | TM0STP             | ; Timer0 stops counting                     |
|             | MOVXW           | TM0                | ; Read Timer0 content                       |
|             |                 |                    |                                             |



| 01h   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|--|
| TM0   |       | TM0   |       |       |       |       |       |       |  |
| R/W   |  |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |  |

#### 01h **TM0:** Timer0 content

| 0Bh   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIE | ADCIE | T2IE  | TM1IE | TM0IE | WKTIE | INT2IE | INT1IE | INTOIE |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

# 0Bh.4 **TM0IE:** Timer0 interrupt enable

0: disable 1: enable

| 0Ch   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIF | ADCIF | T2IF  | TM1IF | TM0IF | WKTIF | INT2IF | INT1IF | INTOIF |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

0Ch.4 **TM0IF:** Timer0 interrupt event pending flag This bit is set by H/W while Timer0 overflows, write 0 to this bit will clear this flag

| 10h    | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|--------|-------|--------|-------|-------|-------|-------|-------|-------|--|--|
| TMORLD |       | TMORLD |       |       |       |       |       |       |  |  |
| R/W    | R/W   | R/W    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |  |  |
| Reset  | 0     | 0      | 0     | 0     | 0     | 0     | 0     | 0     |  |  |

#### 10h **TM0RLD:** Timer0 Reload Data

| 11h    | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3  | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|-------|--------|--------|--------|-------|-------|-------|
| TM0CTL | _     | _     | TM0EDG | TM0CKS | TM0PSC |       |       |       |
| R/W    | _     | —     | R/W    | R/W    | R/W    | R/W   | R/W   | R/W   |
| Reset  | —     | —     | 0      | 0      | 0      | 0     | 0     | 0     |

11h.5**TM0EDG:** Timer0 prescaler counting edge for TM0CKI pin<br/>0: rising edge1: falling edge

0:Fsys/2 1: TMOCKI pin (PA6 pin)

11h.3~0 TM0PSC: Timer0 prescaler. Timer0 prescaler clock source divided by 0001:/2 0010: /4 0000: /1 0011:/8 0100:/16 0101:/32 0110:/64 0111:/128 1000: /256 1001:/512 1010: /1024 1011:/2048 1100: /4096 1101:/8192 1110:/16384 1111:/32768

| 16h   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-------|-------|-------|-------|--------|--------|--------|-------|-------|
| MF016 | LVDF  | LVDEN | T2CLR | TM1STP | TM0STP | LVRSAV | LV    | DS    |
| R/W   | R     | R/W   | R/W   | R/W    | R/W    | R/W    | R/W   | R/W   |
| Reset | _     | 0     | 1     | 0      | 0      | 1      | 0     | 1     |

16h.3 **TM0STP:** Timer0 counter stop 0: Release 1: Stop counting

<sup>11</sup>h.4 TM0CKS: Timer0 prescaler clock source



## 6.3 Timer1

The Timer1 is an 8-bit wide register. It can be read or written as any other register. Besides, Timer1 increases itself periodically and automatically reloads a new "offset value" (TM1RLD) while it rolls over based on the pre-scaled instruction clock (Fsys/2). The Timer1 increase rate is determined by TM1PSC register. It generates Timer1 interrupt if the TM1IE bit is set. Timer1 can be stopped counting if the TM1STP bit is set.



**Timer1 Block Diagram** 



Timer1 Timing Diagram



Timer1 Reload Diagram

♦ Example: CPU is running in SLOW mode, Fsys = Slow-clock / CPUPSC= 70 KHz / 2 = 35 KHz

| ; Setup Timer1 | clock sou   | rce and divider    |                                       |
|----------------|-------------|--------------------|---------------------------------------|
| M              | OVLW        | 00000 <u>010</u> B | ; Set Slow-clock as system clock      |
| M              | OVWX        | CLKCTL             | ; $CPUPSC = 10b$ , divided by 2       |
| Μ              | OVLW        | 0000 <u>0010</u> B |                                       |
| M              | OVWX        | TM1CTL             | ; TM1PSC = 0010b, divided by 8        |
| ; Setup Timer1 | reload dat  | ta                 |                                       |
| M              | OVLW        | FFH                |                                       |
| M              | OVWX        | TM1RLD             | ; Set Timer1 reload data = 255        |
| ; Setup Timer1 |             |                    |                                       |
| BS             | SX          | TM1STP             | ; Timer1 stops counting               |
| CI             | LRX         | TM1                | ; Clear Timer1 content                |
| ; Enable Timer | 1 and inter | rrupt function     |                                       |
| M              | OVLW        | 11 <b>0</b> 11111B |                                       |
| M              | OVWX        | INTIF              | ; Clear Timer1 request interrupt flag |
| BS             | SX          | TM1IE              | ; Enable Timer1 interrupt function    |
| BC             | CX          | TM1STP             | ; Enable Timer1 counting              |
|                |             |                    |                                       |

Timer1 clock source is Fsys/2 = 35 KHz / 2 = 17.5 KHz, Timer1 divided by 8 Timer1 interrupt frequency = 17.5 KHz / 2 / 8 / (256-255) = 1.09 Hz



| 0Bh   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIE | ADCIE | T2IE  | TM1IE | TM0IE | WKTIE | INT2IE | INT1IE | INT0IE |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

0Bh.5 **TM1IE:** Timer1 interrupt enable

0: disable

1: enable

| 0Ch   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0         |
|-------|-------|-------|-------|-------|-------|--------|--------|---------------|
| INTIF | ADCIF | T2IF  | TM1IF | TM0IF | WKTIF | INT2IF | INT1IF | <b>INT0IF</b> |
| R/W    | R/W    | R/W           |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0             |

0Ch.5 TM1IF: Timer1 interrupt event pending flag

This bit is set by H/W while Timer1 overflows, write 0 to this bit will clear this flag

| 12h   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| TM1   |       |       |       | TN    | М1    |       |       |       |
| R/W   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

12h **TM1:** Timer1 content

| 13h    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| TM1RLD |       |       |       | TM1   | RLD   |       |       |       |
| R/W    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

13h.7~0 **TM1RLD:** Timer1 reload offset value while it rolls over

| 14h    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| TM1CTL | _     | —     | —     | —     |       | TM1   | PSC   |       |
| R/W    | _     | —     | —     | —     | R/W   | R/W   | R/W   | R/W   |
| Reset  | _     | —     | —     | —     | 0     | 0     | 0     | 0     |

| 14h.3~0 | TM1PSC: Timer1 p | rescaler. Timer1 clock | source divided by |                |
|---------|------------------|------------------------|-------------------|----------------|
|         | 0000: Fsys/2     | 0001: Fsys/4           | 0010: Fsys/8      | 0011: Fsys/16  |
|         | 0100: Fsys/32    | 0101: Fsys/64          | 0110: Fsys/128    | 0111: Fsys/256 |
|         | 1xxx: Fsys/512   |                        |                   |                |

| 16h   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-------|-------|-------|-------|--------|--------|--------|-------|-------|
| MF016 | LVDF  | LVDEN | T2CLR | TM1STP | TM0STP | LVRSAV | LV    | DS    |
| R/W   | R     | R/W   | R/W   | R/W    | R/W    | R/W    | R/W   | R/W   |
| Reset | -     | 0     | 1     | 0      | 0      | 1      | 0     | 1     |

16h.4 **TM1STP:** Timer1 counter stop

0: Release

1: Stop counting



# 6.4 T2:15-bit Timer

The T2 is a 15-bit counter and the clock sources are from either Fsys/128 or Slow-clock. It is used to generate time base interrupt and T2 counter block clock. The T2 content cannot be read by instructions. It generates interrupt flag T2IF (0Ch.6) with the clock divided by 32768/16384/8192/128 depends on T2PSC[1:0] (15h.1~0) register bits. The following figure shows the block diagram of T2.



**T2 Block Diagram** 

◊Example: CPU is running at FAST mode, Fsys = Fast-clock / CPUPSC = FIRC 8 MHz,

T2 clock source is Fsys/128

| ; Setup FIF  | RC frequency     |                    |                                                    |
|--------------|------------------|--------------------|----------------------------------------------------|
|              | MOVLW            | 000001 <u>11</u> B |                                                    |
|              | MOVWX            | CLKCTL             | ; Fsys is 8 MHz                                    |
| · Sotup T2   | clock source a   | nd dividor         |                                                    |
| , setup 12   | CIOCK SOULCE a   |                    |                                                    |
|              | MOVLW            | 00000 <u>101</u> B | ; $T2CKS(15h.2) = 1$ , T2 clock source is Fsys/128 |
|              | MOVWX            | T2CTL              | ; $T2PSC(15h.1 \sim 0) = 1$ , divided by 16384     |
|              | BSX              | T2CLR              | ; $T2CLR = 1$ , clear T2 counter                   |
| · Enchlo T'  | 2 interrupt fund | ation              |                                                    |
| , Ellable 12 | 2 mierrupt rund  |                    |                                                    |
|              | MOVLW            | 1 <u>0</u> 111111B |                                                    |
|              | MOVWX            | INTIF              | ; Clear T2 request interrupt flag                  |
|              | BSX              | T2IE               | ; Enable T2 interrupt function                     |
|              | BCX              | T2CLR              | ; $T2CLR = 0$ , Enable T2 counting                 |
|              |                  |                    |                                                    |

T2 clock source is Fsys/128 = 8 MHz/128 = 62500 Hz, T2PSC = /16384

T2 frequency = 62500 Hz / 16384 = 3.815 Hz



| 0Bh   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIE | ADCIE | T2IE  | TM1IE | TM0IE | WKTIE | INT2IE | INT1IE | INT0IE |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

0Bh.6 **T2IE:** T2 interrupt enable

0: disable

1: enable

| 0Ch   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIF | ADCIF | T2IF  | TM1IF | TM0IF | WKTIF | INT2IF | INT1IF | INTOIF |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

0Ch.6 **T2IF:** T2 interrupt event pending flag

This bit is set by H/W while T2 overflows, write 0 to this bit will clear this flag

| 0Fh    | Bit 7 | Bit 6 | Bit 5 | Bit 4   | Bit 3   | Bit 2  | Bit 1 | Bit 0 |
|--------|-------|-------|-------|---------|---------|--------|-------|-------|
| CLKCTL | _     | —     | -     | SLOWSTP | FASTSTP | CPUCKS | CPU   | PSC   |
| R/W    | _     | —     | _     | R/W     | R/W     | R/W    | R/W   | R/W   |
| Reset  | _     | _     | -     | 0       | 1       | 0      | 1     | 1     |

0Fh.4 **SLOWSTP:** Stop Slow-clock in Stop Mode 0: no Stop 1: Stop

| 15h   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| T2CTL | —     |       |       |       | —     | T2CKS | T2F   | PSC   |
| R/W   | —     | _     | _     | _     | —     | R/W   | R/W   | R/W   |
| Reset | —     | _     | _     | _     | —     | 0     | 0     | 0     |

15h.2**T2CKS:** "T2 clock source" selection.1: Fsys/1280: Slow-clock

15h.1~0 **T2PSC:** T2 prescaler. "T2 clock source" divided by -00: 32768 01: 16384 10: 8192 11: 128

| 16h   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-------|-------|-------|-------|--------|--------|--------|-------|-------|
| MF016 | LVDF  | LVDEN | T2CLR | TM1STP | TM0STP | LVRSAV | LV    | DS    |
| R/W   | R     | R/W   | R/W   | R/W    | R/W    | R/W    | R/W   | R/W   |
| Reset | -     | 0     | 1     | 0      | 0      | 1      | 0     | 1     |

16h.5 **T2CLR:** T2 counter clear 0: Release 1: Stop counting





#### 6.5 PWM0: (8+2) bits PWM

The PWM0 can generate various frequency waveforms with 1024 duty resolution based on PWM0CLK, which can select Fsys or FIRC 8MHz or FIRC 16MHz, decided by PWM0CKS (95h.3~2). A spread LSB technique allows PWM0 to run its frequency at "PWM0CLK divided by 256" instead of "PWM0CLK divided by 1024", which means the PWM is 4 times faster than normal. The advantage of higher PWM frequency is that the post RC filter can transform the PWM signal to more stable DC voltage level. The PWM output signal reset to low level whenever the 8-bit base counter matches the 8-bit MSB of PWM duty register PWM0DH (93h.7~0). When the base counter rolls over, the 2-bit LSB of PWM duty register PWM0DL (94h.1~0) decides whether to set the PWM output signal high immediately or set it high after one clock cycle delay. **PWM0 clock is enabled and PWM0 is not hold after reset. (cf. the description of PWM0DIS and PWM0CLR)** 

The PWM0 period can be set by writing period value to PWM0PRD register (92h.7~0). Note that changing the PWM0PRD will immediately change the PWM0PRD values, which are different from PWM0DH / PWM0DL which has buffer to update the duty at the end of current period. The Programmer must pay attention to the current time to change PWM0PRD by observing the following figure. There is a digital comparator that compares the PWM0 counter and PWM0PRD, if PWM0 counter is larger than PWM0PRD after setting the PWM0PRD, a fault long PWM cycle will be generated because PWM0 counter must count to overflow then keep counting to PWM0PRD to finish the cycle.



#### **PWM0 Block Diagram**





PWM0 8+2 Timing Diagram



♦ Example: CPU running at Fast mode, Fsys = FIRC 8 MHz

| ; Setup Pir | n mode                                             |                                                                                         |                                                                                                                                          |
|-------------|----------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
|             | MOVLW                                              | xxxx <u>10</u> xxB                                                                      | ; PA1 Pin mode = Mode2                                                                                                                   |
|             | MOVWX                                              | PAMODL                                                                                  | ; Mode2: CMOS output                                                                                                                     |
|             |                                                    |                                                                                         |                                                                                                                                          |
|             | MOVLW                                              | xxxx <u>10</u> xxB                                                                      | ; PA5 Pin mode = Mode2                                                                                                                   |
|             | MOVWX                                              | PAMODH                                                                                  | ; Mode2: CMOS output                                                                                                                     |
|             |                                                    |                                                                                         |                                                                                                                                          |
| ; Setup PV  | VM0 clock pre                                      |                                                                                         |                                                                                                                                          |
|             | MOVLW                                              | xx0 <u>1</u> <u>10</u> <u>11</u> B                                                      | ; $95h.4 = 1$ , PWM0 clear and hold                                                                                                      |
|             | MOVWX                                              | PWM0CTL                                                                                 | ; $95h.3 \sim 2 = 2$ , PWM0 clock source = FIRC 8MHz                                                                                     |
|             |                                                    |                                                                                         | ; $95h.1 \sim 0 = 3$ , PWM0 prescaler div 8                                                                                              |
| ; Setup PV  | VM0 mode & I                                       | Non-overlap control                                                                     |                                                                                                                                          |
|             | MOVLW                                              | xxx <u>00 000</u> B                                                                     | ; 96h.4 $\sim$ 3 = 0, PWM0 mode = Mode0                                                                                                  |
|             | MOVWX                                              | PWM0CTL1                                                                                | ; 96h.2~ $0 = 0$ , PWM0 non-overlap time = 0                                                                                             |
|             |                                                    |                                                                                         |                                                                                                                                          |
|             |                                                    |                                                                                         |                                                                                                                                          |
|             | MOVLW                                              | 7FH                                                                                     |                                                                                                                                          |
|             | MOVLW<br>MOVWX                                     | 7FH<br>PWM0PRD                                                                          | ; Set PWM0 period = 7FH                                                                                                                  |
|             |                                                    |                                                                                         | ; Set PWM0 period = 7FH                                                                                                                  |
|             |                                                    |                                                                                         | ; Set PWM0 period = 7FH                                                                                                                  |
|             | MOVWX                                              | PWM0PRD                                                                                 | ; Set PWM0 period = 7FH<br>; Set PWM0DL duty = 00H                                                                                       |
|             | MOVWX<br>MOVLW                                     | PWM0PRD<br>xxxxxx <b>00</b> B                                                           |                                                                                                                                          |
|             | MOVWX<br>MOVLW                                     | PWM0PRD<br>xxxxxx <b>00</b> B                                                           |                                                                                                                                          |
|             | MOVWX<br>MOVLW<br>MOVWX                            | PWM0PRD<br>xxxxxx <b>00</b> B<br>PWM0DL                                                 |                                                                                                                                          |
|             | MOVWX<br>MOVLW<br>MOVWX<br>MOVLW<br>MOVWX          | PWM0PRD<br>xxxxxx <u>00</u> B<br>PWM0DL<br>20H<br>PWM0DH                                | ; Set PWM0DL duty = 00H<br>; Set PWM0DH duty = 20H                                                                                       |
|             | MOVWX<br>MOVLW<br>MOVLW<br>MOVLW<br>MOVLW          | PWM0PRD<br>xxxxxx <u>00</u> B<br>PWM0DL<br>20H                                          | ; Set PWM0DL duty = 00H<br>; Set PWM0DH duty = 20H<br>; 91h.1 = 1, Enable PWM0N output to PA1                                            |
|             | MOVWX<br>MOVLW<br>MOVWX<br>MOVLW<br>MOVWX          | PWM0PRD<br>xxxxxx <u>00</u> B<br>PWM0DL<br>20H<br>PWM0DH                                | ; Set PWM0DL duty = 00H<br>; Set PWM0DH duty = 20H                                                                                       |
|             | MOVWX<br>MOVLW<br>MOVLW<br>MOVLW<br>MOVLW<br>MOVLW | PWM0PRD<br>xxxxxx <u>00</u> B<br>PWM0DL<br>20H<br>PWM0DH<br>xxxxxx <u>11</u> B<br>PWM0E | ; Set PWM0DL duty = 00H<br>; Set PWM0DH duty = 20H<br>; 91h.1 = 1, Enable PWM0N output to PA1<br>; 91h.0 = 1, Enable PWM0P output to PA5 |
|             | MOVWX<br>MOVLW<br>MOVLW<br>MOVLW<br>MOVLW          | PWM0PRD<br>xxxxxx <u>00</u> B<br>PWM0DL<br>20H<br>PWM0DH<br>xxxxxx <u>11</u> B          | ; Set PWM0DL duty = 00H<br>; Set PWM0DH duty = 20H<br>; 91h.1 = 1, Enable PWM0N output to PA1                                            |

#### Example:

PWM0 clock source = FIRC 8M, PWM0PSC = div 8, PWM0PRD = 7FH, PWM0DL = 00H, PWM0DH = 20HPWM0 output frequency = 8 MHz / 8 / (PWM0PRD+1) = 8 MHz / 8 / 128 = 7.8125 KHz.PWM0P output duty = 32:128 = 25 %.



PWM0 can be output via PWM0P and PWM0N with four different modes. The edges of the PWM pulse can be separated with 6 different time non-overlap clocks intervals (Tnov), 0s, 4 PWM0CLKs, 5 PWM0CLKs, 6 PWM0CLKs, 7 PWM0CLKs, and 8 PWM0CLKs which are selected by PWM0NOV (96h.2~0). The default output form is Mode0. The waveforms of the four output modes are shown below.



PWM0 Waveform Modes



| 91h   | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1          | Bit 0          |
|-------|----------|----------|----------|----------|----------|----------|----------------|----------------|
| PWMOE | PWM1COE1 | PWM1COE0 | PWM1BOE1 | PWM1BOE0 | PWM1AOE1 | PWM1AOE0 | <b>PWM0NOE</b> | <b>PWM0POE</b> |
| R/W   | R/W      | R/W      | R/W      | R/W      | R/W      | R/W      | R/W            | R/W            |
| Reset | 0        | 0        | 0        | 0        | 0        | 0        | 0              | 0              |

91h.1 **PWM0NOE:** PWM0N output to PA1 enable 0: disable 1: enable, PWM0N output to PA1

91h.0 **PWM0POE:** PWM0P output to PA5 enable 0: disable 1: enable, PWM0P output to PA5

| 92h     | Bit 7 | Bit 6   | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|---------|-------|---------|-------|-------|-------|-------|-------|-------|--|--|--|
| PWM0PRD |       | PWM0PRD |       |       |       |       |       |       |  |  |  |
| R/W     | R/W   | R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |  |  |  |
| Reset   | 1     | 1       | 1     | 1     | 1     | 1     | 1     | 1     |  |  |  |

92h.7~0 **PWM0PRD:** PWM0 period data

| 93h    | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|--------|-------|--------|-------|-------|-------|-------|-------|-------|--|--|--|
| PWM0DH |       | PWM0DH |       |       |       |       |       |       |  |  |  |
| R/W    | R/W   | R/W    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |  |  |  |
| Reset  | 0     | 0      | 0     | 0     | 0     | 0     | 0     | 0     |  |  |  |

93h.7~0 **PWM0DH:** PWM0 duty MSB 8bit

| 94h    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|--------|-------|
| PWM0DL | _     | —     | —     | —     | —     | _     | PWM0DL |       |
| R/W    | _     | —     | —     | —     | —     | _     | R/W    | R/W   |
| Reset  | —     | —     | —     | —     | —     | —     | 0      | 0     |

94h.1~0 PWM0DL: PWM0 duty LSB 2bit

| 95h     | Bit 7 | Bit 6 | Bit 5          | Bit 4   | Bit 3   | Bit 2 | Bit 1   | Bit 0 |
|---------|-------|-------|----------------|---------|---------|-------|---------|-------|
| PWM0CTL | -     | -     | <b>PWM0DIS</b> | PWM0CLR | PWM0CKS |       | PWM0PSC |       |
| R/W     | _     | _     | R/W            | R/W     | R/W     | R/W   | R/W     | R/W   |
| Reset   | -     | -     | 0              | 0       | 0       | 0     | 0       | 0     |

| 95h.5   | <b>PWM0DIS:</b> PWM0 clock disable          |
|---------|---------------------------------------------|
|         | 0: clock enable                             |
|         | 1: clock disable                            |
| 95h.4   | <b>PWM0CLR:</b> PWM0 clear and hold         |
|         | 0: PWM0 enable                              |
|         | 1: PWM0 clear and hold                      |
| 95h.3~2 | <b>PWM0CKS:</b> PWM0 clock source select    |
|         | 0x: Fsys                                    |
|         | 10:FIRC 8MHz                                |
|         | 11:FIRC 16MHz                               |
| 95h.1~0 | <b>PWM0PSC:</b> PWM0 clock source prescaler |
|         | 00: divided by 1                            |
|         | 01: divided by 2                            |
|         | 10: divided by 4                            |
|         | 11: divided by 8                            |
|         |                                             |



| 96h      | Bit 7 | Bit 6 | Bit 5 | Bit 4    | Bit 3 | Bit 2   | Bit 1 | Bit 0 |  |
|----------|-------|-------|-------|----------|-------|---------|-------|-------|--|
| PWM0CTL1 | —     | —     | —     | PWM0MODE |       | PWM0NOV |       |       |  |
| R/W      | _     | —     | —     | R/W      | R/W   | R/W     | R/W   | R/W   |  |
| Reset    | _     | —     | —     | 0        | 0     | 0       | 0     | 0     |  |

96h.4~3 **PWM0MODE:** PWM0 differential output mode

00: Mode 0

01: Mode 1

10: Mode 2

11: Mode 3

96h.2~0 **PWM0NOV:** PWM0 non-overlap control

000: original PWM0

001: non-overlap 4 PWM0CLKs

010: non-overlap 5 PWM0CLKs

011: non-overlap 6 PWM0CLKs

100: non-overlap 7 PWM0CLKs

101: non-overlap 8 PWM0CLKs



#### 6.6 PWM1A / PWM1B / PWM1C: 16 bits PWMs

PWM1A, PWM1B and PWM1C are 3 PWMs which have independent duty and common period. The PWM1 can generate varies frequency waveform with 65536 duty resolution on the basis of the PWM1 clock. The PWM clock can select Fsys, FIRC 8 MHz or 16 MHz, decided by PWMCKS (97h.3~2). The PWM1 clock also can be stop by setting PWM1DIS (97h.5) bit. **PWM1 clock is enabled and PWM1 is not hold after reset. (cf. the description of PWM1DIS and PWM1CLR)** 

The pin mode SFR controls the PWM output waveform format. Mode1 makes the PWM open drain output and Mode2 makes the PWM CMOS push-pull output. (see section 5)

The 16-bit PWM1PRD, PWM1AD, PWM1BD, PWM1CD registers all have a low byte and high byte structure. The high bytes can be directly accessed, but the low bytes can only be accessed via an internal 8-bit buffer, reading or writing to these register pairs must be carried out in a specific way. The important point to notes is that data transfer to and from the 8-bit buffer and its related low byte only takes place when write or read operation to its corresponding high bytes is executed. Briefly speaking, **write low byte first and then high byte; read high byte first and then low byte**.

The PWM1 structure is shown as follow. When PWM1CLR (97h.4) bit is set, the PWM1 will be cleared and held, otherwise the PWM1 is running. The PWM1 duty cycle can be changed by writing to PWM1DH and PWM1DL. The PWM1 output signal resets to a low level whenever the 16-bit base counter matches the 16-bit PWM1 duty register {PWM1DH, PWM1DL}. The PWM1 period can be set by writing the period value to the PWM1PRDH and PWM1PRDL registers. After writing the PWM1D or PWM1PRD register, the new values will immediately save to their own buffer. H/W will update these values at the end of current period or while PWM1 is cleared.



**PWM1 Block Diagram** 



PWM1A, PWM1B and PWM1C have a corresponding interrupt flag PWM1AIF (0Eh.0), PWM1BIF (0Eh.1) and PWM1CIF (0Eh.2), and those interrupt flags are generated while PWM1 16-bit base counter count to the setting duties. The PWM1 also has a corresponding period interrupt flag PWM1PIF (0Eh.3), and an interrupt flag is generated at the end of the period. Setting their corresponding interrupt enable bit PWM1AIE (0Dh.0), PWM1BIE (0Dh.1), PWM1CIE (0Dh.2) and PWM1PIE (0Dh.3) can generate the corresponding interrupt.

The PWM1xOEn (91h.7~2) bits are used to select the related PWM output to I/O. No matter PWMOE is set or not, PWM1 can keep running in the background as a timer.



**PWM1 Timing Diagram** 

| 0Dh    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|--------|-------|-------|-------|-------|---------|---------|---------|---------|
| INTIE1 | _     | —     | —     | _     | PWM1PIE | PWM1CIE | PWM1BIE | PWM1AIE |
| R/W    | —     | —     | —     | —     | R/W     | R/W     | R/W     | R/W     |
| Reset  | —     | —     | —     | —     | 0       | 0       | 0       | 0       |

| 0Dh.3 | <b>PWM1PIE:</b> PWM1 period interrupt enable |
|-------|----------------------------------------------|
|       | 0: disable                                   |
|       | 1: enable                                    |
| 0Dh.2 | <b>PWM1CIE:</b> PWM1C duty interrupt enable  |
|       | 0: disable                                   |
|       | 1: enable                                    |
| 0Dh.1 | <b>PWM1BIE:</b> PWM1B duty interrupt enable  |
|       | 0: disable                                   |
|       | 1: enable                                    |
| 0Dh.0 | <b>PWM1AIE:</b> PWM1A duty interrupt enable  |
|       | 0: disable                                   |
|       | 1: enable                                    |



| 0Eh    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|--------|-------|-------|-------|-------|---------|---------|---------|---------|
| INTIF1 | _     | _     |       | _     | PWM1PIF | PWM1CIF | PWM1BIF | PWM1AIF |
| R/W    | —     | _     | _     | _     | R/W     | R/W     | R/W     | R/W     |
| Reset  | -     | _     |       |       | 0       | 0       | 0       | 0       |

 0Eh.3 PWM1PIF: PWM1 period interrupt event pending flag This bit is set by H/W after PWM1 counter count to the set period, write 0 to this bit will clear this flag
 0Eh.2 PWM1CIF: PWM1C duty interrupt event pending flag

This bit is set by H/W after PWM1 counter count to the set PWM1C duty, write 0 to this bit will clear this flag

0Eh.1 **PWM1BIF:** PWM1B duty interrupt event pending flag This bit is set by H/W after PWM1 counter count to the set PWM1B duty, write 0 to this bit will clear this flag

0Eh.0 **PWM1AIF:** PWM1A duty interrupt event pending flag This bit is set by H/W after PWM1 counter count to the set PWM1A duty, write 0 to this bit will clear this flag

| 91h   | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1          | Bit 0          |
|-------|----------|----------|----------|----------|----------|----------|----------------|----------------|
| PWMOE | PWM1COE1 | PWM1COE0 | PWM1BOE1 | PWM1BOE0 | PWM1AOE1 | PWM1AOE0 | <b>PWM0NOE</b> | <b>PWM0POE</b> |
| R/W   | R/W      | R/W      | R/W      | R/W      | R/W      | R/W      | R/W            | R/W            |
| Reset | 0        | 0        | 0        | 0        | 0        | 0        | 0              | 0              |

| 91h.7 | <b>PWM1COE1:</b> PWM1C output to PA3 enable |
|-------|---------------------------------------------|
|       | 0: disable 1: enable, PWM1C output to PA3   |
| 91h.6 | <b>PWM1COE0:</b> PWM1C output to PA4 enable |
|       | 0: disable 1: enable, PWM1C output to PA4   |
| 91h.5 | <b>PWM1BOE1:</b> PWM1B output to PA7 enable |
|       | 0: disable 1: enable, PWM1B output to PA7   |
| 91h.4 | <b>PWM1BOE0:</b> PWM1B output to PA2 enable |
|       | 0: disable 1: enable, PWM1B output to PA2   |
| 91h.3 | <b>PWM1AOE1:</b> PWM1A output to PA6 enable |
|       | 0: disable 1: enable, PWM1A output to PA6   |
| 91h.2 | <b>PWM1AOE0:</b> PWM1A output to PA0 enable |

0: disable 1: enable, PWM1A output to PA0

| 97h     | Bit 7 | Bit 6 | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|---------|---------|-------|-------|-------|-------|
| PWM1CTL | -     | _     | PWM1DIS | PWM1CLR | PWM   | 1CKS  | —     | —     |
| R/W     | -     | _     | R/W     | R/W     | R/W   | R/W   | —     | —     |
| Reset   | _     |       | 0       | 0       | 0     | 0     |       | —     |

| 97h.5   | <b>PWM1DIS:</b> PWM1 clock disable       |
|---------|------------------------------------------|
|         | 0: clock enable                          |
|         | 1: clock disable                         |
| 97h.4   | <b>PWM1CLR:</b> PWM1 clear and hold      |
|         | 0: PWM1 enable                           |
|         | 1: PWM1 clear and hold                   |
| 97h.3~2 | <b>PWM1CKS:</b> PWM1 clock source select |
|         | 0x: Fsys                                 |
|         | 10:FIRC 8MHz                             |
|         | 11:FIRC 16MHz                            |
|         |                                          |



| 98h      | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------|-------|----------|-------|-------|-------|-------|-------|-------|
| PWM1PRDH |       | PWM1PRDH |       |       |       |       |       |       |
| R/W      | R/W   | R/W      | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset    | 1     | 1        | 1     | 1     | 1     | 1     | 1     | 1     |

98h.7~0 PWM1PRDH: PWM1 (PWM1A / PWM1B / PWM1C) period data MSB 8bit

| 99h      | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------|-------|----------|-------|-------|-------|-------|-------|-------|
| PWM1PRDL |       | PWM1PRDL |       |       |       |       |       |       |
| R/W      | R/W   | R/W      | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset    | 1     | 1        | 1     | 1     | 1     | 1     | 1     | 1     |

99h.7~0 **PWM1PRDL:** PWM1 (PWM1A / PWM1B / PWM1C) period data LSB 8bit About 16-bit data write: Write PWM1PRDL first, then PWM1PRDH About 16-bit data read: Read PWM1PRDH first, then PWM1PRDL

| 9Ah     | Bit 7 | Bit 6   | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|---------|-------|-------|-------|-------|-------|-------|
| PWM1ADH |       | PWM1ADH |       |       |       |       |       |       |
| R/W     | R/W   | R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 1     | 0       | 0     | 0     | 0     | 0     | 0     | 0     |

9Ah.7~0 **PWM1ADH:** PWM1A duty MSB 8bit

| 9Bh     | Bit 7 | Bit 6   | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|---------|-------|-------|-------|-------|-------|-------|
| PWM1ADL |       | PWM1ADL |       |       |       |       |       |       |
| R/W     | R/W   | R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | 0       | 0     | 0     | 0     | 0     | 0     | 0     |

9Bh.7~0 PWM1ADL: PWM1A duty LSB 8bit

About 16-bit data write: Write PWM1ADL first, then PWM1ADH About 16-bit data read: Read PWM1ADH first, then PWM1ADL

| 9Ch     | Bit 7 | Bit 6   | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|---------|-------|-------|-------|-------|-------|-------|
| PWM1BDH |       | PWM1BDH |       |       |       |       |       |       |
| R/W     | R/W   | R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 1     | 0       | 0     | 0     | 0     | 0     | 0     | 0     |

9Ch.7~0 **PWM1BDH:** PWM1B duty MSB 8bit

| 9Dh     | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| PWM1BDL |       |       |       | PWM   | 1BDL  |       |       |       |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

9Dh.7~0 PWM1BDL: PWM1B duty LSB 8bit

About 16-bit data write: Write PWM1BDL first, then PWM1BDH About 16-bit data read: Read PWM1BDH first, then PWM1BDL

| 9Eh     | Bit 7 | Bit 6   | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|---------|-------|-------|-------|-------|-------|-------|
| PWM1CDH |       | PWM1CDH |       |       |       |       |       |       |
| R/W     | R/W   | R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 1     | 0       | 0     | 0     | 0     | 0     | 0     | 0     |

9Eh.7~0 **PWM1CDH:** PWM1Cduty MSB 8bit



| 9Fh     | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| PWM1CDL |       |       |       | PWM   | 1CDL  |       |       |       |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

9Fh.7~0 **PWM1CDL:** PWM1C duty LSB 8bit

About 16-bit data write: Write PWM1CDL first, then PWM1CDH About 16-bit data read: Read PWM1CDH first, then PWM1CDL



# 6.7 Analog-to-Digital Converter



The 12-bit ADC (Analog to Digital Converter) consists of a 16-channel analog input multiplexer, control register, clock generator, 12-bit successive approximation register, and output data register. To use the ADC, user needs to set ADCKS (18h.2~0) to choose a proper ADC clock frequency, which must be less than 1 MHz. User then launches the ADC conversion by setting the ADST (18h.3) control bit. After end of conversion, H/W automatic clears the ADST (18h.3) bit. User can poll this bit to know the conversion status. The PAMODH and PAMODL control registers are used for ADC pin configuration, user must set the Pin Mode=3 when the pin is used as an ADC input. The setting can disable the pin logical input path to save power consumption. User needs to set ADCHS (19h.3~0) to choose the input channel of ADC. Besides, there are some reference input channel can be selected, ADC12 is VSS and ADC13 is VR=3V. ADC reference voltage can select VCC or VR by ADCVREFS (19h.5~4).





Example:

[CPU running at FAST mode , Fsys = FIRC 8MHz ] ADC clock frequency = 1 MHz, ADC channel = ADC2 (PA2).

#### $\diamond$ Example:

|         | MOVLW<br>MOVWX | 00000 <u>111</u> B<br>CLKCTL         | ; Fsys = 8 MHz<br>;                                                                           |
|---------|----------------|--------------------------------------|-----------------------------------------------------------------------------------------------|
|         | MOVLW<br>MOVWX | 01 <u>11</u> 0101B<br>PAMODL;        | ; ADC2 (PA2) Pin Mode = 3 = ADC input                                                         |
|         | MOVLW<br>MOVWX | 00000 <u><b>101</b></u> B<br>ADCTL   | ; 18h.2~0 (ADCKS) = Fsys/8, ADC clock = 1MHz                                                  |
|         | MOVLW<br>MOVWX | 00 <u>1</u> 1 <u>0010</u> B<br>MF019 | ; 19h.5 = 0, ADC reference voltage select VCC<br>; 19h.3~0 = 2, ADC input channel select ADC2 |
|         | BSX            | ADST                                 | ; 18h.3 (ADST), ADC start conversion.                                                         |
| WAIT_AD | C:             |                                      |                                                                                               |
|         | BTXSC<br>GOTO  | ADST<br>WAIT_ADC                     | ; Wait ADC conversion finish.                                                                 |

| MOVXW | ADCH  | ; 17h.7~0, Read ADC result [11:4] into W |
|-------|-------|------------------------------------------|
| MOVXW | ADCTL | ; 18h.7~4, Read ADC result [3:0] into W  |

•••

| 0Bh/8Bh/10Bh/18Bh | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0         |
|-------------------|-------|-------|-------|-------|-------|--------|--------|---------------|
| INTIE             | ADCIE | T2IE  | TM1IE | TMOIE | WKTIE | INT2IE | INT1IE | <b>INTOIE</b> |
| R/W               | R/W   | R/W   | R/W   | R/W   | R/W   | R/W    | R/W    | R/W           |
| Reset             | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0             |

# INTIE.7 **ADCIE:** ADC interrupt enable 0: disable

1: enable

| 0Ch   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| INTIF | ADCIF | T2IF  | TM1IF | TM0IF | WKTIF | INT2IF | INT1IF | INT0IF |
| R/W    | R/W    | R/W    |
| Reset | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      |

0Ch.7 **ADCIF:** ADC interrupt event pending flag

This bit is set by H/W after end of ADC conversion, write 0 to this bit will clear this flag

| 17h   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
| ADCH  |       | ADCH  |       |       |       |       |       |       |  |  |  |
| R/W   | R     | R     | R     | R     | R     | R     | R     | R     |  |  |  |
| Reset | -     | —     | —     | —     | —     | —     | —     | -     |  |  |  |

17h.7~0 ADCH: ADC output data MSB, ADQ [11:4]



| 18h   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADCTL | ADCL  |       |       |       | ADST  | ADCKS |       |       |
| R/W   | R     | R     | R     | R     | R/W   | R/W   | R/W   | R/W   |
| Reset | _     | _     | _     | _     | 0     | 0     | 0     | 0     |

18h.7~4 ADCL: ADC output data LSB, ADQ [3:0]

18h.3 **ADST:** ADC start bit.

0: H/W clear after end of conversion

1: ADC start conversion

 18h.2~0 ADCKS: ADC clock frequency selection: 000: Fsys/256 100: Fsys/16 001: Fsys/128 101: Fsys/8 010: Fsys/64 110: Fsys/4 011: Fsys/32 111: Fsys/2

| 19h   | Bit 7 | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|-------|-------|-------|---------|-------|-------|-------|-------|-------|--|
| MF019 | -     | -     | ADVREFS | VREN  | ADCHS |       |       |       |  |
| R/W   | -     | -     | R/W     | R/W   | R/W   |       |       |       |  |
| Reset | -     | -     | 1       | 1     | 0     | 0     | 0     | 0     |  |

| 19h.5   | ADVREFS: ADC reference voltage select                                         |
|---------|-------------------------------------------------------------------------------|
|         | 0: VCC                                                                        |
|         | 1: VR                                                                         |
| 19h.4   | <b>VREN:</b> Internal reference voltage VR enable (3V ±1.2% @25°C, VCC=3V~5V) |
|         | 0: Disable                                                                    |
|         | 1: Enable and Auto disable in STOP/IDLE mode                                  |
| 19h.3~0 | ADCHS: ADC channel select                                                     |
|         | 0000: ADC0 (PA0) 1000: Reserved                                               |

 0000: ADC0 (PA0)
 1000: Reserved

 0001: ADC1 (PA1)
 1001: Reserved

 0010: ADC2 (PA2)
 1010: Reserved

 0011: ADC3 (PA3)
 1011: Reserved

 0100: ADC4 (PA4)
 1100: VSS

 0101: ADC5 (PA5)
 1101: VR

 0110: ADC6 (PA6)
 1110: Reserved

 0111: ADC7 (PA7)
 1111: Reserved



#### 6.8 Battery Charge Module (BCM)

The TM56F8225 contains a Battery Charging Module (BCM). The module consists of two 10-bit Digital-to-Analog converters (DAC) and two operational amplifiers (OPA). The DAC reference voltage comes from the internal reference voltage VR (VR =  $3V \pm 1.2\%$  @25°C, VCC =  $3V \times 5V$ ). The voltage of VR can be turned off by setting VREN = 0 (19h.4). After power-on, the default voltage output of DACO is about 0.18V, and DAC1 is about 2.4V. They are connected to the positive input of OPA0 and OPA1, respectively. In addition, the OPA0 and OPA1 are always enabled after power-on. The Battery Charging Module block diagram is shown below.



**BCM Block Diagram** 

The 10-bit DAC0D and DAC1D registers all have a low byte and high byte structure. When in read operation, the high bytes and the low bytes can be accessed directly. When in write operation, the high bytes can be accessed directly, but the low bytes can only be accessed via an internal 8-bit buffer. Writing to these register pairs must be carried out in a specific way. The important point to notes is that data transfer to and from the 8-bit buffer and its related low byte only takes place when write operation to its corresponding high bytes is executed. Briefly speaking, write low byte first and then high byte; read high byte and low byte directly.



| 1Ah            | Bit 7         | Bit 6  | Bit 5          | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|----------------|---------------|--------|----------------|---------|-------|-------|-------|-------|--|
| <b>OPA0CTL</b> | <b>OPA0PD</b> | DAC0SW | <b>OPA0PSW</b> | OPA0ADJ |       |       |       |       |  |
| R/W            | R/W           | R/W    | R/W            | R/W     | R/W   | R/W   | R/W   | R/W   |  |
| Reset          | 0             | 1      | 1              | by CFG  |       |       |       |       |  |

| 1Ah.7 | <b>OPA0PD:</b> OPA0 Power Down                              |
|-------|-------------------------------------------------------------|
|       | 0: OPA0 on                                                  |
|       | 1: OPA0 off                                                 |
| 1Ah.6 | DAC0SW: DAC0 to OPA0 non-inverting input switch on          |
|       | 0: switch off                                               |
|       | 1: switch on                                                |
| 1Ah.5 | <b>OPA0PSW:</b> OPA0P to OPA0 non-inverting input switch on |
|       | 0: switch off                                               |
|       | 1                                                           |

1: switch on

1Ah.4~0 **OPA0ADJ:** OPA0 input offset voltage calibration control

| 1Bh     | Bit 7  | Bit 6  | Bit 5          | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|--------|--------|----------------|---------|-------|-------|-------|-------|--|
| OPA1CTL | OPA1PD | DAC1SW | <b>OPA1PSW</b> | OPA1ADJ |       |       |       |       |  |
| R/W     | R/W    | R/W    | R/W            | R/W     | R/W   | R/W   | R/W   | R/W   |  |
| Reset   | 0      | 1      | 1              | by CFG  |       |       |       |       |  |

1Bh.7 OPA1PD: OPA1 Power Down

0: OPA1 on
1: OPA1 off

1Bh.6 DAC1SW: DAC1 to OPA1 non-inverting input switch on

0: switch off
1: switch on

1Bh.5 OPA1PSW: OPA1P to OPA1 non-inverting input switch on

0: switch off

1: switch on

1Bh.4~0 **OPA1ADJ:** OPA1 input offset voltage calibration control

| 1Ch    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|--------|-------|
| DAC0DH | _     | —     | —     | —     | —     | —     | DAC0DH |       |
| R/W    | _     | —     | —     | —     | _     | _     | R/W    | R/W   |
| Reset  |       | -     | -     | _     | —     | —     | 0      | 0     |

1Ch.1~0 **DAC0DH:** DAC0 input data MSB[9~8]

| 1Dh    | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|--------|-------|--------|-------|-------|-------|-------|-------|-------|--|--|--|
| DAC0DL |       | DAC0DL |       |       |       |       |       |       |  |  |  |
| R/W    | R/W   | R/W    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |  |  |  |
| Reset  | 0     | 1      | 0     | 0     | 0     | 0     | 0     | 0     |  |  |  |

1Dh.7~0 **DAC0DL:** DAC0 input data LSB[7~0] write DAC0DL first, then DAC0DH read DAC0DH and DAC0DL directly

| 1Eh    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| DAC1DH | _     | —     | _     | —     |       | _     | DAC   | 1DH   |
| R/W    | _     | —     | _     | —     | _     | —     | R/W   | R/W   |
| Reset  | -     | —     |       | —     | —     | _     | 1     | 1     |

1Eh.1~0 **DAC1DH:** DAC1 input data MSB[9~8]



| 1Fh    | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|-------|--------|-------|-------|-------|-------|-------|-------|
| DAC1DL |       | DAC1DL |       |       |       |       |       |       |
| R/W    | R/W   | R/W    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset  | 0     | 0      | 1     | 1     | 1     | 0     | 0     | 1     |

1Fh.7~0 **DAC1DL:** DAC1 input data LSB[7~0] write DAC1DL first, then DAC1DH read DAC1DH and DAC1DL directly



#### 6.9 Cyclic Redundancy Check (CRC)

The chip supports an integrated 16-bit Cyclic Redundancy Check function. The Cyclic Redundancy Check (CRC) calculation unit is an error detection technique test algorithm and uses to verify data transmission or storage data correctness. The CRC calculation takes a 8-bit data stream or a block of data as input and generates a 16-bit output remainder. The data stream is calculated by the same generator polynomial.



#### CRC16 Block Diagram

The CRC generator provides the 16-bit CRC result calculation based on the CRC-16-IBM polynomial. In this CRC generator, there is only one polynomial available for the numeric values calculation. It can't support the 16-bit CRC calculations based on any other polynomials. Each write operation to the CRCIN register creates a combination of the previous CRC value stored in the CRCDH and CRCDL registers. It will take one MCU instruction cycle to calculate.

# CRC-16-IBM (Modbus) Polynomial representation: $X^{16} + X^{15} + X^2 + 1$

| 187h  | Bit 7 | Bit 6           | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|-------|-------|-----------------|-------|-------|-------|-------|-------|-------|--|
| CRCDL |       | CRCDL           |       |       |       |       |       |       |  |
| R/W   |       | R/W             |       |       |       |       |       |       |  |
| Reset | 1     | 1 1 1 1 1 1 1 1 |       |       |       |       |       |       |  |

| 187h.7~0 | <b>CRCDL:</b> 16-bit CRC checksum data bit 7~0 |
|----------|------------------------------------------------|
| 10/11/0  |                                                |

| 188h  | Bit 7 | Bit 6           | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|-------|-------|-----------------|-------|-------|-------|-------|-------|-------|--|
| CRCDH |       | CRCDH           |       |       |       |       |       |       |  |
| R/W   |       | R/W             |       |       |       |       |       |       |  |
| Reset | 1     | 1 1 1 1 1 1 1 1 |       |       |       |       |       |       |  |

188h.7~0 CRCDL: 16-bit CRC checksum data bit 15~8

| 189h  | Bit 7 | Bit 6Bit 5Bit 4Bit 3Bit 2Bit 1Bit 0 |  |  |  |  |  |  |  |  |
|-------|-------|-------------------------------------|--|--|--|--|--|--|--|--|
| CRCIN |       | CRCIN                               |  |  |  |  |  |  |  |  |
| W     |       | W                                   |  |  |  |  |  |  |  |  |
| Reset |       |                                     |  |  |  |  |  |  |  |  |

189h.7~0 CRCIN: write this register to start CRC calculation





# MEMORY MAP

| Name         | Address    | R/W    | Rst | Description                                                                                                            |  |  |  |
|--------------|------------|--------|-----|------------------------------------------------------------------------------------------------------------------------|--|--|--|
| INDF (00h/80 | h/100h/18  | 0h)    |     | Function related to: RAM W/R                                                                                           |  |  |  |
| INDF         | 00.7~0     | R/W    | -   | Not a physical register, addressing INDF actually point to the register whose address is contained in the FSR register |  |  |  |
| TM0 (01h/101 | h)         |        |     | Function related to: Timer0                                                                                            |  |  |  |
| TM0          | 01.7~0     | R/W    | 0   | Timer0 content                                                                                                         |  |  |  |
| PCL (02h/82h | /105h/182  | h)     |     | Function related to: PROGRAM COUNT                                                                                     |  |  |  |
| PCL          | 02.7~0     | R/W    | 0   | Programming Counter LSB [7~0]                                                                                          |  |  |  |
| STATUS (03h  | /83h/103h  | /183h) |     | Function related to: STATUS                                                                                            |  |  |  |
| IRP          | 03.7       | R/W    | 0   | Register Bank Select bit (used for indirect addressing)                                                                |  |  |  |
| RP1          | 03.6       | R/W    | 0   | Register Bank Select bit 1 (assembly keep this bit is 0)                                                               |  |  |  |
| RP0          | 03.5       | R/W    | 0   | Register Bank Select bit 0 (assembly keep this bit is 0)                                                               |  |  |  |
| ТО           | 03.4       | R      | 0   | WDT timeout flag, cleared by PWRST, 'SLEEP' or 'CLRWDT' instruction                                                    |  |  |  |
| PD           | 03.3       | R      | 0   | Power down flag, set by 'SLEEP', cleared by 'CLRWDT' instruction                                                       |  |  |  |
| Z            | 03.2       | R/W    | 0   | Zero flag                                                                                                              |  |  |  |
| DC           | 03.1       | R/W    | 0   | Decimal Carry flag                                                                                                     |  |  |  |
| С            | 03.0       | R/W    | 0   | Carry flag                                                                                                             |  |  |  |
| FSR (04h/84h | /104h/184l | h)     |     | Function related to: RAM W/R                                                                                           |  |  |  |
| FSR          | 04.7~0     | R/W    | -   | File Select Register, indirect address mode pointer                                                                    |  |  |  |
| PAD (05h)    |            |        |     | Function related to: Port A                                                                                            |  |  |  |
| PAD          | 05.7~0     | R      | -   | Port A pin or "data register" state                                                                                    |  |  |  |
| FAD          | 03.7~0     | W      | FF  | Port A output data register                                                                                            |  |  |  |
| PCLATH (0A   | h/8Ah/10A  | Ah/18A | h)  | Function related to: PROGRAM COUNT                                                                                     |  |  |  |
| PCLATH       | 0A.2~0     | R/W    | 0   | Write Buffer for the upper 3 bits of the Program Counter                                                               |  |  |  |
| INTIE (0Bh/8 | 3h/10Bh/1  | 8Bh)   |     | Function related to: Interrupt Enable                                                                                  |  |  |  |
| ADCIE        | 0B.7       | R/W    | 0   | ADC interrupt enable<br>0: disable 1: enable                                                                           |  |  |  |
| T2IE         | 0B.6       | R/W    | 0   | T2 interrupt enable<br>0: disable 1: enable                                                                            |  |  |  |
| TM1IE        | 0B.5       | R/W    | 0   | Timer1 interrupt enable<br>0: disable 1: enable                                                                        |  |  |  |
| TM0IE        | 0B.4       | R/W    | 0   | Timer0 interrupt enable<br>0: disable 1: enable                                                                        |  |  |  |
| WKTIE        | 0B.3       | R/W    | 0   | Wakeup Timer interrupt enable, set 0 to clear & disable WKT timer<br>0: disable 1: enable                              |  |  |  |
| INT2IE       | 0B.2       | R/W    | 0   | INT2 pin (PA7) interrupt enable<br>0: disable 1: enable                                                                |  |  |  |
| INT1IE       | 0B.1       | R/W    | 0   | INT1 pin (PA1) interrupt enable<br>0: disable 1: enable                                                                |  |  |  |
| INTOIE       | 0B.0       | R/W    | 0   | INT0 pin (PA6 or PA2) interrupt enable<br>0: disable 1: enable                                                         |  |  |  |



| INTIF (0Ch)   |         |          |    | Function related to: Interrupt Flag                                                                |  |                             |
|---------------|---------|----------|----|----------------------------------------------------------------------------------------------------|--|-----------------------------|
| ADCIF         | 0C.7    | R        | -  | ADC interrupt flag, set by H/W after end of ADC conversion                                         |  |                             |
| ADCIF         | 0C.7    | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| T2IF          | 0C.6    | R        | -  | T2 interrupt event pending flag, set by H/W while T2 overflows                                     |  |                             |
| 121F          | UC.0    | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| TMILE         | 005     | R        | -  | Timer1 interrupt event pending flag, set by H/W while Timer1 overflows                             |  |                             |
| TM1IF         | 0C.5    | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| TMOLE         | 0C.4    | R        | -  | Timer0 interrupt event pending flag, set by H/W while Timer0 overflows                             |  |                             |
| TM0IF         | 0C.4    | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| WETIE         | 0C.3    | R        | -  | WKT interrupt event pending flag, set by H/W while WKT time out                                    |  |                             |
| WKTIF         | 00.5    | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
|               |         | R        | -  | INT2 (PA7) interrupt event pending flag, set by H/W at INT2 pin's                                  |  |                             |
| INT2IF        | 0C.2    |          |    | falling edge                                                                                       |  |                             |
|               |         | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| INT1IF 00     | 0C.1    | R        | -  | INT1 (PA1) interrupt event pending flag, set by H/W at INT1 pin's falling/rising edge              |  |                             |
|               | 00.1    | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
|               |         | D        |    | INTO (PA6) interrupt event pending flag, set by H/W at INTO pin's                                  |  |                             |
| <b>INT0IF</b> | 0C.0    | R        | -  | falling/rising edge                                                                                |  |                             |
|               |         | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| INTIE1 (0Dh)  |         |          |    | Function related to: Interrupt Enable                                                              |  |                             |
| PWM1PIE       | 0D.3    | R/W      | 0  | PWM1 period interrupt enable<br>0: disable 1: enable                                               |  |                             |
| PWM1CIE       | 0D.2    | R/W      | 0  | PWM1C duty interrupt enable<br>0: disable 1: enable                                                |  |                             |
| DWAIDE        | 0D 1    |          |    |                                                                                                    |  | PWM1B duty interrupt enable |
| PWM1BIE       | 0D.1    | R/W      | 0  | 0: disable 1: enable                                                                               |  |                             |
| PWM1AIE       | 0D.0    | R/W      | 0  | PWM1A duty interrupt enable<br>0: disable 1: enable                                                |  |                             |
| INTIF1 (0Eh)  |         |          |    | Function related to: Interrupt Flag                                                                |  |                             |
| PWM1PIF       | 0E.3    | R        | -  | PWM1 period interrupt event pending flag, set by H/W while PWM1 counter count to the set period    |  |                             |
|               |         | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
|               |         | R        | -  | PWM1C duty interrupt event pending flag, set by H/W while PWM1                                     |  |                             |
| PWM1CIF       | 0E.2    | W        | 0  | counter count to the set PWM1C duty<br>write 0: clear this flag; write 1: no action                |  |                             |
|               |         | vv       | 0  | PWM1B duty interrupt event pending flag, set by H/W while PWM1                                     |  |                             |
| PWM1BIF       | 0E.1    | R        | -  | counter count to the set PWM1B duty                                                                |  |                             |
|               |         | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| PWM1AIF       | 0E.0    | R        | -  | PWM1A duty interrupt event pending flag, set by H/W while PWM1 counter count to the set PWM1A duty |  |                             |
|               | 012.0   | W        | 0  | write 0: clear this flag; write 1: no action                                                       |  |                             |
| CLKCTL (0F    | h)      |          |    | Function related to: Fsys                                                                          |  |                             |
| SLOWSTP       | 0F.4    | R/W      | 0  | Stop Slow-clock in Stop Mode<br>0: no Stop 1: Stop                                                 |  |                             |
| FASTSTP       | 0F.3    | R/W      | 1  | Stop Fast-clock<br>0:no Stop 1:Stop                                                                |  |                             |
| CPUCKS        | 0F.2    | R/W      | 0  | Select Fast-clock<br>0: Fsys=Slow-clock 1: Fsys=Fast-clock                                         |  |                             |
|               | 0.5.4.0 | <b>D</b> |    | 0: Fsys=Slow-clock 1: Fsys=Fast-clock<br>Fsys Prescaler,                                           |  |                             |
| CPUPSC        | 0F.1~0  | R/W      | 11 | 00: div 8 01: div 4 10: div 2 11: div 1                                                            |  |                             |



| TMORLD (         | TM0RLD (10h)Function related to: TM0 |     |    |                                                                                                                                                                                                                                   |  |  |
|------------------|--------------------------------------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| TMORLD           | 10.7~0                               | R/W | 0  | Timer0 reload Data                                                                                                                                                                                                                |  |  |
| TM0CTL (         | 11h)                                 |     |    | Function related to: TM0                                                                                                                                                                                                          |  |  |
| TM0EDG           | 11.5                                 | R/W | 0  | Timer0 prescaler counting edge for TM0CKI pin<br>0: rising edge<br>1: falling edge                                                                                                                                                |  |  |
| TM0CKS           | 11.4                                 | R/W | 0  | Timer0 prescaler clock source<br>0: Fsys/2<br>1: TM0CKI pin (PA6 pin)                                                                                                                                                             |  |  |
| TM0PSC           | 11.3~0                               | R/W | 0  | Timer0 prescaler clock source divided by0000: /10100: /161000: /2561100: /40960001: /20101: /321001: /5121101: /81920010: /40110: /641010: /10241110: /163840011: /80111: /1281011: /20481111: /32768                             |  |  |
| TM1 (12h)        |                                      |     |    | Function related to: Timer1                                                                                                                                                                                                       |  |  |
| TM1              | 12.7~0                               | R/W | 0  | Timer1 content                                                                                                                                                                                                                    |  |  |
| TM1RLD (         | 13h)                                 |     |    | Function related to: Timer1                                                                                                                                                                                                       |  |  |
| TM1RLD           | 13.7~0                               | R/W | 0  | Timer1 reload Data                                                                                                                                                                                                                |  |  |
| TM1CTL (         | 14h)                                 |     |    | Function related to: Timer1                                                                                                                                                                                                       |  |  |
| TM1PSC           | 14.3~0                               | R/W | 0  | Timer1 prescaler. Timer1 clock source         0000: Fsys/2       0100: Fsys/32       1xxx: Fsys/512         0001: Fsys/4       0101: Fsys/64         0010: Fsys/8       0110: Fsys/128         0011: Fsys/16       0111: Fsys/256 |  |  |
| <b>T2CTL</b> (15 | h)                                   |     |    | Function related to: T2                                                                                                                                                                                                           |  |  |
| T2CKS            | 15.2                                 | R/W | 0  | T2 clock source<br>0: Slow-clock<br>1: Fsys/128                                                                                                                                                                                   |  |  |
| T2PSC            | 15.1~0                               | R/W | 0  | T2 prescaler. T2 clock source divided by -<br>00: 32768 01: 16384 10: 8192 11: 128                                                                                                                                                |  |  |
| MF016 (16)       | n)                                   |     |    | Function related to: T2/TM1/TM0/LVR/LVD                                                                                                                                                                                           |  |  |
| LVDF             | 16.7                                 | R   | -  | Low voltage detection flag, set by H/W while VCC $\leq$ LVD                                                                                                                                                                       |  |  |
| LVDEN            | 16.6                                 | R/W | 0  | Low voltage detection function enable, (When LVR=2.2V only)<br>0: disable 1: enable                                                                                                                                               |  |  |
| T2CLR            | 16.5                                 | R/W | 1  | T2 counter clear<br>0: Release<br>1: Stop counting                                                                                                                                                                                |  |  |
| TM1STP           | 16.4                                 | R/W | 0  | Timer1 counter stop<br>0: Release<br>1: Stop counting                                                                                                                                                                             |  |  |
| TM0STP           | 16.3                                 | R/W | 0  | Timer0 counter stop<br>0: Releas<br>1: Stop counting                                                                                                                                                                              |  |  |
| LVRSAV           | 16.2                                 | R/W | 1  | LVR/LVD power save<br>0: LVR/LVD enable in in STOP/IDLE mode<br>1: LVR/LVD auto power off in STOP/IDLE mode                                                                                                                       |  |  |
| LVDS             | 16.1~0                               | R/W | 01 | LVD select (when LVR=2.2V)<br>00: 3.6V<br>01: 2.8V<br>1x: 4.2V                                                                                                                                                                    |  |  |





| ADCH (17h) Function related to: ADC |                                      |     |          |                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|-------------------------------------|--------------------------------------|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ADCH                                | 17.7~0                               | R   | -        | ADC output data MSB, ADQ [11:4]                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| ADCTL (18h)                         | ADCTL (18h) Function related to: ADC |     |          |                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| ADCL                                | 18.7~4                               | R   | -        | ADC output data LSB, ADQ [3:0]                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| ADST                                | 18.3                                 | R/W | 0        | ADC start bit.<br>0: H/W clear after end of conversion                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| ADCKS                               | 18.2~0                               | R/W | 0        | 1: ADC start conversion         ADC clock frequency selection:         000: Fsys/256       100: Fsys/16         001: Fsys/128       101: Fsys/8         010: Fsys/64       110: Fsys/4         011: Fsys/32       111: Fsys/2                                                                                                                                                                                                 |  |  |
| MF019 (19h)                         |                                      | l   | <u> </u> | Function related to: ADC                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| ADVREFS                             | 19.5                                 | R/W | 1        | ADC reference voltage select<br>0: VCC 1: VR                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| VREN                                | 19.4                                 | R/W | 1        | Internal reference voltage VR enable (3V ±1.2% @25°C, VCC=3V~5V)<br>0: Disable<br>1: Enable and Auto disable in STOP/IDLE mode                                                                                                                                                                                                                                                                                                |  |  |
| ADCHS                               | 19.3~0                               | R/W | 0        | ADC channel select         0000: ADC0 (PA0)       0110: ADC6 (PA6)       1100: VSS         0001: ADC1 (PA1)       0111: ADC7 (PA7)       1101: VR         0010: ADC2 (PA2)       1000: Reserved       1110: Reserved         0011: ADC3 (PA3)       1001: Reserved       1111: Reserved         0100: ADC4 (PA4)       1010: Reserved       1011: Reserved         0101: ADC5 (PA5)       1011: Reserved       1011: Reserved |  |  |
| OPA0CTL (1A                         | Ah)                                  |     |          | Function related to: OPA                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| OPA0PD                              | 1A.7                                 | R/W | 0        | OPA0 Power Down<br>0: OPA0 on 1: OPA0 off                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| DAC0SW                              | 1A.6                                 | R/W | 1        | DAC0 to OPA0 non-inverting input switch on<br>0: switch off 1: switch on                                                                                                                                                                                                                                                                                                                                                      |  |  |
| OPA0PSW                             | 1A.5                                 | R/W | 1        | OPA0P to OPA0 non-inverting input switch on<br>0: switch off 1: switch on                                                                                                                                                                                                                                                                                                                                                     |  |  |
| OPA0ADJ                             | 1A.4~0                               | R/W | CFG      | OPA0 input offset voltage calibration control                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| OPA1CTL (11                         | Bh)                                  |     |          | Function related to: OPA                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| OPA1PD                              | 1B.7                                 | R/W | 0        | OPA1 Power Down<br>0: OPA1 on 1: OPA1 off                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| DAC1SW                              | 1B.6                                 | R/W | 1        | DAC1 to OPA1 non-inverting input switch on<br>0: switch off 1: switch on                                                                                                                                                                                                                                                                                                                                                      |  |  |
| OPA1PSW                             | 1B.5                                 | R/W | 1        | OPA1P to OPA1 non-inverting input switch on<br>0: switch off 1: switch on                                                                                                                                                                                                                                                                                                                                                     |  |  |
| OPA1ADJ                             | 1B.4~0                               | R/W | CFG      | OPA1 input offset voltage calibration control                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| DAC0DH (1C                          | h)                                   |     |          | Function related to: DAC                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| DAC0DH                              | 1C.1~0                               | R/W | 00       | DAC0 input data MSB[9~8]                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| DAC0DL (1D                          | h)                                   |     |          | Function related to: DAC                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| DAC0DL                              | 1D.7~0                               | R/W | 40       | DAC0 input data LSB[7~0], write DAC0DL first, then DAC0DH                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| DAC1DH (1E                          | h)                                   |     |          | Function related to: DAC                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| DAC1DH                              | 1E.1~0                               | R/W | 03       |                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| DAC1DL (1F                          | n)                                   |     |          | Function related to: DAC                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| DAC1DL                              | 1F.7~0                               | R/W | 39       | DAC1 input data LSB[7~0], write DAC1DL first, then DAC1DH                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| User Data Mer                       | nory                                 | •   |          |                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| RAM                                 | 20~6F                                | R/W | -        | RAM Bank0 area (80 Bytes)                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| RAM                                 | 70~7F                                | R/W | -        | RAM common area (16 Bytes)                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |



| <b>OPTION</b> (81h                                                                          | /181h)                                                                      |                                        |                                      | Function related to: STATUS/INT0/INT1/WDT/WKT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|----------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                             |                                                                             |                                        |                                      | Enter interrupt vector, HW auto save/restore WREG and STATUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| HWAUTO                                                                                      | 81.7                                                                        | R/W                                    | 0                                    | w/o TO,PD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                                                                                             |                                                                             |                                        |                                      | 0:disable 1: enable<br>INT0 pin edge interrupt event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| INT0EDG                                                                                     | 81.6                                                                        | R/W                                    | 0                                    | 0: falling edge to trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                                                                             | 01.0                                                                        | 10 11                                  | 0                                    | 1: rising edge to trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                                                                                             |                                                                             |                                        |                                      | INT1 pin edge interrupt event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| INT1EDG 81.5                                                                                |                                                                             | R/W                                    | 0                                    | 0: falling edge to trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                                                                             |                                                                             |                                        |                                      | 1: rising edge to trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| INT0SEL                                                                                     | 81.4                                                                        | R/W                                    | W = 0 INTO pin select,               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                                                                                             |                                                                             |                                        |                                      | 0: PA6 1: PA2<br>WDT pre-scale selections:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                                                                             |                                                                             |                                        |                                      | 00: 128mS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| WDTPSC                                                                                      | 81.3~2                                                                      | R/W                                    | 11                                   | 01: 256mS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                                                                                             |                                                                             |                                        |                                      | 10: 1024mS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                                                                             |                                                                             |                                        |                                      | 11: 2048mS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                                                                             |                                                                             |                                        |                                      | WKT pre-scale selections:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| WKTPSC                                                                                      | 81.1~0                                                                      | R/W                                    | 11                                   | 00: 16mS<br>01: 32mS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| WKIISC                                                                                      | 81.1~0                                                                      | K/ W                                   | 11                                   | 10: 64mS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|                                                                                             |                                                                             |                                        |                                      | 11: 128mS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| PAMODH (80                                                                                  | Ch)                                                                         |                                        |                                      | Function related to: Port A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| PA7MOD                                                                                      | 8C.7~6                                                                      | R/W                                    | 00                                   | PA7~PA4 I/O mode control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| PA6MOD                                                                                      | 8C.5~4                                                                      | R/W                                    | 01                                   | 00: Mode0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| PA5MOD                                                                                      | 8C.3~2                                                                      | R/W                                    | 01                                   | 01: Mode1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| PA4MOD                                                                                      | 8C.1~0                                                                      | R/W                                    | 01                                   | 10: Mode2<br>11: Mode3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| PAMODL (8D                                                                                  |                                                                             | 10 11                                  | •1                                   | Function related to: Port A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| PA3MOD                                                                                      | 8D.7~6                                                                      | R/W                                    | 01                                   | PA3~PA0 I/O mode control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| PA2MOD                                                                                      | 8D.5~4                                                                      | R/W                                    | 01                                   | 00: Mode0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| _                                                                                           |                                                                             |                                        |                                      | 01: Mode1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| PA1MOD                                                                                      | 8D.3~2                                                                      | R/W                                    | 01                                   | 10: Mode2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| PA0MOD                                                                                      | 8D.1~0                                                                      | R/W                                    | 01                                   | 11: Mode3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| PWMOE (91h                                                                                  | )                                                                           |                                        |                                      | Function related to: PWM0 / PWM1A / PWM1B / PWM1C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| PWM1COE1                                                                                    |                                                                             | 1                                      | 1                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                                                                                             | 91.7                                                                        | R/W                                    | 0                                    | PWM1C output to PA3 enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                                                                             | 91.7                                                                        | R/W                                    | 0                                    | PWM1C output to PA3 enable0: disable1:enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| PWM1COE0                                                                                    | 91.7<br>91.6                                                                | R/W<br>R/W                             | 0                                    | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                                                                                             | 91.6                                                                        | R/W                                    | 0                                    | PWM1C output to PA3 enable         0: disable       1:enable         PWM1C output to PA4 enable         0: disable       1:enable                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| PWM1COE0<br>PWM1BOE1                                                                        |                                                                             |                                        |                                      | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| PWM1BOE1                                                                                    | 91.6<br>91.5                                                                | R/W<br>R/W                             | 0                                    | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable0: disable1:enablePWM1B output to PA7 enable                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                                                                                             | 91.6                                                                        | R/W                                    | 0                                    | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable0: disable1:enablePWM1B output to PA7 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enable                                                                                                                                                                                                                                                                                                                                                                                             |  |
| PWM1BOE1                                                                                    | 91.6<br>91.5                                                                | R/W<br>R/W                             | 0                                    | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable0: disable1:enablePWM1B output to PA7 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enable                                                                                                                                                                                                                                                                                                     |  |
| PWM1BOE1<br>PWM1BOE0                                                                        | 91.6<br>91.5<br>91.4                                                        | R/W<br>R/W<br>R/W                      | 0 0 0                                | PWM1C output to PA3 enable         0: disable       1:enable         PWM1C output to PA4 enable         0: disable       1:enable         PWM1B output to PA7 enable         0: disable       1:enable         PWM1B output to PA2 enable         0: disable       1:enable         PWM1B output to PA2 enable         0: disable       1:enable         PWM1A output to PA6 enable         0: disable       1:enable                                                                                                                                                        |  |
| PWM1BOE1<br>PWM1BOE0                                                                        | 91.6<br>91.5<br>91.4                                                        | R/W<br>R/W<br>R/W                      | 0 0 0                                | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable0: disable1:enablePWM1B output to PA7 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1A output to PA6 enable0: disable1:enablePWM1A output to PA0 enable                                                                                                                                                                                                                                                                           |  |
| PWM1BOE1<br>PWM1BOE0<br>PWM1AOE1<br>PWM1AOE0                                                | 91.6<br>91.5<br>91.4<br>91.3<br>91.2                                        | R/W<br>R/W<br>R/W<br>R/W               | 0<br>0<br>0<br>0<br>0                | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable0: disable1:enablePWM1B output to PA7 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1A output to PA6 enable0: disable1:enablePWM1A output to PA0 enable0: disable1:enable                                                                                                                                                                                                                                                                                                     |  |
| PWM1BOE1<br>PWM1BOE0<br>PWM1AOE1                                                            | 91.6<br>91.5<br>91.4<br>91.3                                                | R/W<br>R/W<br>R/W                      | 0 0 0 0 0 0                          | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable0: disable1:enablePWM1B output to PA7 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1A output to PA6 enable0: disable1:enablePWM1A output to PA0 enable                                                                                                                                                                                                                                                                           |  |
| PWM1BOE1<br>PWM1BOE0<br>PWM1AOE1<br>PWM1AOE0<br>PWM0NOE                                     | 91.6<br>91.5<br>91.4<br>91.3<br>91.2<br>91.1                                | R/W<br>R/W<br>R/W<br>R/W<br>R/W        | 0<br>0<br>0<br>0<br>0<br>0           | PWM1C output to PA3 enable<br>0: disable 1:enablePWM1C output to PA4 enable<br>0: disable 1:enablePWM1B output to PA7 enable<br>0: disable 1:enablePWM1B output to PA2 enable<br>0: disable 1:enablePWM1B output to PA2 enable<br>0: disable 1:enablePWM1A output to PA6 enable<br>0: disable 1:enablePWM1A output to PA6 enable<br>0: disable 1:enablePWM1A output to PA0 enable<br>0: disable 1:enablePWM1A output to PA1 enable<br>0: disable 1:enablePWM0N output to PA1 enable<br>0: disable 1:enablePWM0P output to PA5 enable                                         |  |
| PWM1BOE1<br>PWM1BOE0<br>PWM1AOE1<br>PWM1AOE0<br>PWM0NOE<br>PWM0POE                          | 91.6       91.5       91.4       91.3       91.2       91.1       91.0      | R/W<br>R/W<br>R/W<br>R/W               | 0<br>0<br>0<br>0<br>0                | PWM1C output to PA3 enable0: disable1:enablePWM1C output to PA4 enable0: disable1:enablePWM1B output to PA7 enable0: disable1:enablePWM1B output to PA2 enable0: disable1:enablePWM1A output to PA2 enable0: disable1:enablePWM1A output to PA6 enable0: disable1:enablePWM1A output to PA0 enable0: disable1:enablePWM0N output to PA1 enable0: disable1:enablePWM0N output to PA5 enable0: disable1:enable                                                                                                                                                                 |  |
| PWM1BOE1<br>PWM1BOE0<br>PWM1AOE1<br>PWM1AOE0<br>PWM0NOE<br>PWM0POE<br>PWM0PRD (9            | 91.6<br>91.5<br>91.4<br>91.3<br>91.2<br>91.1<br>91.0<br>2h)                 | R/W<br>R/W<br>R/W<br>R/W<br>R/W<br>R/W | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | PWM1C output to PA3 enable<br>0: disable 1:enablePWM1C output to PA4 enable<br>0: disable 1:enablePWM1B output to PA7 enable<br>0: disable 1:enablePWM1B output to PA2 enable<br>0: disable 1:enablePWM1A output to PA2 enable<br>0: disable 1:enablePWM1A output to PA6 enable<br>0: disable 1:enablePWM1A output to PA0 enable<br>0: disable 1:enablePWM1A output to PA1 enable<br>0: disable 1:enablePWM0N output to PA1 enable<br>0: disable 1:enablePWM0P output to PA5 enable<br>0: disable 1:enable                                                                   |  |
| PWM1BOE1<br>PWM1BOE0<br>PWM1AOE1<br>PWM1AOE0<br>PWM0NOE<br>PWM0POE<br>PWM0PRD (9<br>PWM0PRD | 91.6<br>91.5<br>91.4<br>91.3<br>91.2<br>91.1<br>91.0<br><b>2h</b><br>92.7~0 | R/W<br>R/W<br>R/W<br>R/W<br>R/W        | 0<br>0<br>0<br>0<br>0<br>0           | PWM1C output to PA3 enable<br>0: disable 1:enablePWM1C output to PA4 enable<br>0: disable 1:enablePWM1B output to PA7 enable<br>0: disable 1:enablePWM1B output to PA2 enable<br>0: disable 1:enablePWM1A output to PA2 enable<br>0: disable 1:enablePWM1A output to PA6 enable<br>0: disable 1:enablePWM1A output to PA0 enable<br>0: disable 1:enablePWM1A output to PA1 enable<br>0: disable 1:enablePWM0N output to PA1 enable<br>0: disable 1:enablePWM0P output to PA5 enable<br>0: disable 1:enablePWM0P output to PA5 enable<br>0: disable 1:enablePWM0P period data |  |
| PWM1BOE1<br>PWM1BOE0<br>PWM1AOE1<br>PWM1AOE0<br>PWM0NOE<br>PWM0POE<br>PWM0PRD (9            | 91.6<br>91.5<br>91.4<br>91.3<br>91.2<br>91.1<br>91.0<br><b>2h</b><br>92.7~0 | R/W<br>R/W<br>R/W<br>R/W<br>R/W<br>R/W | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | PWM1C output to PA3 enable<br>0: disable 1:enablePWM1C output to PA4 enable<br>0: disable 1:enablePWM1B output to PA7 enable<br>0: disable 1:enablePWM1B output to PA2 enable<br>0: disable 1:enablePWM1A output to PA2 enable<br>0: disable 1:enablePWM1A output to PA6 enable<br>0: disable 1:enablePWM1A output to PA0 enable<br>0: disable 1:enablePWM1A output to PA1 enable<br>0: disable 1:enablePWM0N output to PA1 enable<br>0: disable 1:enablePWM0P output to PA5 enable<br>0: disable 1:enable                                                                   |  |



| PWM0DL (94                                                   | h)             |     |    | Function related to: PWM0                                                                                                                                                                                 |  |
|--------------------------------------------------------------|----------------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PWM0DL                                                       | 94.1~0         | R/W | 0  | PWM0 Duty LSB 2bit                                                                                                                                                                                        |  |
| <b>PWM0CTL</b> (9                                            | <b>)5h</b> )   |     |    | Function related to: PWM0                                                                                                                                                                                 |  |
| PWM0DIS                                                      | 95.5           | R/W | 0  | PWM0 clock disable<br>0: clock enable<br>1: clock disable                                                                                                                                                 |  |
| PWM0CLR                                                      | 95.4           | R/W | 0  | PWM0 clear and hold<br>0: PWM0 enable<br>1: PWM0 clear and hold                                                                                                                                           |  |
| PWM0CKS                                                      | 95.3~2         | R/W | 0  | PWM0 clock source select<br>0x: Fsys<br>10:FIRC 8MHz<br>11:FIRC 16MHz                                                                                                                                     |  |
| PWM0PSC                                                      | 95.1~0         | R/W | 0  | PWM0 clock source prescaler<br>00: div1 01: div2 10: div4 11: div8                                                                                                                                        |  |
| PWM0CTL1                                                     | ( <b>96h</b> ) |     |    | Function related to: PWM0                                                                                                                                                                                 |  |
| PWM0MODE                                                     | 96.4~3         | R/W | 0  | PWM0 differential output mode<br>00: Mode 0<br>01: Mode 1<br>10: Mode 2<br>11: Mode 3                                                                                                                     |  |
| PWM0NOV                                                      | 96.2~0         | R/W | 0  | PWM0 non-overlap control<br>000: original PWM0<br>001: non-overlap 4 PWM0CLKs<br>010: non-overlap 5 PWM0CLKs<br>011: non-overlap 6 PWM0CLKs<br>100: non-overlap 7 PWM0CLKs<br>101: non-overlap 8 PWM0CLKs |  |
| PWM1CTL (97h)     Function related to: PWM1A / PWM1B / PWM1C |                |     |    |                                                                                                                                                                                                           |  |
| PWM1DIS                                                      | 97.5           | R/W | 0  | PWM1 (PWM1A/PWM1B/PWM1C) clock disable<br>0: clock enable<br>1: clock disable                                                                                                                             |  |
| PWM1CLR                                                      | 97.4           | R/W | 0  | PWM1 (PWM1A/PWM1B/PWM1C) clear and hold<br>0: PWM1 enable<br>1: PWM1 clear and hold                                                                                                                       |  |
| PWM1CKS                                                      | 97.3~2         | R/W | 0  | PWM1 (PWM1A/PWM1B/PWM1C) clock source select<br>0x: Fsys<br>10:FIRC 8MHz<br>11:FIRC 16MHz                                                                                                                 |  |
| -                                                            | 97.1~0         | R/W | 0  | Reserved, keep the two bits are 00                                                                                                                                                                        |  |
| PWM1PRDH                                                     | (98h)          |     |    | Function related to: PWM1A / PWM1B / PWM1C                                                                                                                                                                |  |
| PWM1PRDH                                                     | 98.7~0         | R/W | FF | PWM1 (PWM1A/PWM1B/PWM1C) period data MSB 8bit                                                                                                                                                             |  |
| PWM1PRDL                                                     | ( <b>99h</b> ) |     |    | Function related to: PWM1A / PWM1B / PWM1C                                                                                                                                                                |  |
| PWM1PRDL                                                     | 99.7~0         | R/W | FF | PWM1 (PWM1A/PWM1B/PWM1C) period data LSB 8bit<br>About 16-bit data write: Write PWM1PRDL first, then PWM1PRDH<br>About 16-bit data read: Read PWM1PRDH first, then PWM1PRDL                               |  |
| PWM1ADH (                                                    | 9Ah)           |     |    | Function related to: PWM1A                                                                                                                                                                                |  |
| PWM1ADH                                                      | 9A.7~0         | R/W | 80 | PWM1A Duty MSB 8bit                                                                                                                                                                                       |  |
| PWM1ADL (9                                                   | (Bh)           | 1   |    | Function related to: PWM1A                                                                                                                                                                                |  |
| PWM1ADL                                                      | 9B.7~0         | R/W | 00 | PWM1A Duty LSB 8bit<br>About 16-bit data write: Write PWM1ADL first, then PWM1ADH<br>About 16-bit data read: Read PWM1ADH first, then PWM1ADL                                                             |  |



| PWM1BDH (9Ch)      |           |     |                            | Function related to: PWM1B                                                                                                                                                                                                                                                                 |  |
|--------------------|-----------|-----|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PWM1BDH            | 9C.7~0    | R/W | 80                         | PWM1B Duty MSB 8bit                                                                                                                                                                                                                                                                        |  |
| PWM1BDL (9Dh)      |           |     | Function related to: PWM1B |                                                                                                                                                                                                                                                                                            |  |
| PWM1BDL            | 9D.7~0    | R/W | 00                         | PWM1B Duty LSB 8bit<br>About 16-bit data write: Write PWM1BDL first, then PWM1BDH<br>About 16-bit data read: Read PWM1BDH first, then PWM1BDL                                                                                                                                              |  |
| PWM1CDH (9         | )<br>PEh) |     |                            | Function related to: PWM1C                                                                                                                                                                                                                                                                 |  |
| PWM1CDH            | 9E.7~0    | R/W | 80                         | PWM1C Duty MSB 8bit                                                                                                                                                                                                                                                                        |  |
| PWM1CDL (9         | Fh)       |     |                            | Function related to: PWM1C                                                                                                                                                                                                                                                                 |  |
| PWM1CDL            | 9F.7~0    | R/W | 00                         | PWM1C Duty LSB 8bit<br>About 16-bit data write: Write PWM1CDL first, then PWM1CDH<br>About 16-bit data read: Read PWM1CDH first, then PWM1CDL                                                                                                                                              |  |
| User Data Men      | nory      |     |                            |                                                                                                                                                                                                                                                                                            |  |
| RAM                | A0~EF     | R/W | -                          | RAM Bank1 area (80 Bytes)                                                                                                                                                                                                                                                                  |  |
| LVRPD (109h        | )         |     |                            | Function related to: LVR                                                                                                                                                                                                                                                                   |  |
| LVRPD              | 109       | W   | -                          | Write 37h to force LVR disable                                                                                                                                                                                                                                                             |  |
| <b>BGTRIM</b> (10) | Eh)       |     |                            | Function related to: Bandgap                                                                                                                                                                                                                                                               |  |
| BGTRIM             | 10E.3~0   | R/W | CFG                        | Bandgap voltage adjustment:<br>0000: Lowest voltage<br><br>1111: Highest voltage                                                                                                                                                                                                           |  |
| IRCF (10Fh)        |           |     | 1                          | Function related to: Internal RC                                                                                                                                                                                                                                                           |  |
| IRCF               | 10F.6~0   | R/W | CFG                        | FIRC frequency adjustment:<br>00h: Lowest frequency<br><br>7Fh: Highest frequency                                                                                                                                                                                                          |  |
| <b>DPL</b> (185h)  |           | 1   | 1                          | Function related to: Table Read                                                                                                                                                                                                                                                            |  |
| DPL                | 185.7~0   | R/W | 0                          | Table read low address, data ROM pointer (DPTR) low byte                                                                                                                                                                                                                                   |  |
| <b>DPH</b> (186h)  |           | 1   | 1                          | Function related to: Table Read                                                                                                                                                                                                                                                            |  |
| DPH                | 186.2~0   | R/W | 0                          | Table read high address, data ROM pointer (DPTR) high byte                                                                                                                                                                                                                                 |  |
| CRCDL (187h        | )         |     |                            | Function related to: CRC16                                                                                                                                                                                                                                                                 |  |
| CRCDL              | 187.7~0   | R/W | FF                         | 16-bit CRC data LSB 8bit                                                                                                                                                                                                                                                                   |  |
| CRCDH (188h        | ı)        | 1   | 1                          | Function related to: CRC16                                                                                                                                                                                                                                                                 |  |
| CRCDH              | 188.7~0   | R/W | FF                         | 16-bit CRC data MSB 8bit                                                                                                                                                                                                                                                                   |  |
| CRCIN (189h)       |           |     |                            | Function related to: CRC16                                                                                                                                                                                                                                                                 |  |
| CRCIN              | 189.7~0   | W   | -                          | CRC data input                                                                                                                                                                                                                                                                             |  |
| TABR (18Ch)        |           |     |                            | Function related to: Table Read                                                                                                                                                                                                                                                            |  |
| TABR               | 18C.7~0   | R/W | 0                          | <ol> <li>TABR write 01h = opcode TABRL</li> <li>TABR write 02h = opcode TABRH</li> <li>After step.1 or step.2, read TABR to get main ROM table read value<br/>After step.1, read TABR to get EEPROM value (when EEPEN = E2h)</li> <li>Table Read for ASM: TABRL / TABRH or TABR</li> </ol> |  |
|                    |           |     |                            | v                                                                                                                                                                                                                                                                                          |  |



| EEPCTL (18I  | Dh)     |     |   | Function related to: EEPROM                                                                                                                                                                                                     |
|--------------|---------|-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EEPTO        | 18D.2   | R/W | 0 | EEPROM write time-out flag<br>Set by H/W when EEPROM write time-out occurs<br>Cleared by H/W when EEPTE=0                                                                                                                       |
| EEPTE        | 18D.1~0 | R/W | 0 | EEPROM write watchdog timer enable ( <b>suggest set 11</b> )<br>00: disable<br>01: wait 1.6mS trigger watchdog time-out flag<br>10: wait 6.4mS trigger watchdog time-out flag<br>11: wait 12.8mS trigger watchdog time-out flag |
| EEPEN (18Eh) |         |     |   | Function related to: EEPROM                                                                                                                                                                                                     |
| EEPEN        | 18E.7~0 | W   | - | EEPROM read/write enable<br>E2h: enable EEPROM read/write<br>others: disable EEPROM read/write                                                                                                                                  |
| EEPDT (18Fh) |         |     |   | Function related to: EEPROM                                                                                                                                                                                                     |
| EEPDT        | 18F.7~0 | W   | - | EEPROM date to write                                                                                                                                                                                                            |



## **INSTRUCTION SET**

Each instruction is a 16-bit word divided into an Op Code, which specifies the instruction type, and one or more operands, which further specify the operation of the instruction. The instructions can be categorized as byte-oriented, bit-oriented and literal operations list in the following table.

For byte-oriented instructions, "f" represents the address designator and "d" represents the destination designator. The address designator is used to specify which address in Program memory is to be used by the instruction. The destination designator specifies where the result of the operation is to be placed. If "d" is "0", the result is placed in the W register. If "d" is "1", the result is placed in the address specified in the instruction.

For bit-oriented instructions, "b" represents a bit field designator, which selects the number of the bit affected by the operation, while "f" represents the address designator. For literal operations, "k" represents the literal or constant value.

| Field/Legend | Description                                                        |  |  |  |
|--------------|--------------------------------------------------------------------|--|--|--|
| f            | Register File Address                                              |  |  |  |
| b            | Bit address                                                        |  |  |  |
| k            | Literal. Constant data or label                                    |  |  |  |
| d            | Destination selection field, 0: Working register, 1: Register file |  |  |  |
| W            | Working Register                                                   |  |  |  |
| Z            | Zero Flag                                                          |  |  |  |
| С            | Carry Flag or/Borrow Flag                                          |  |  |  |
| DC           | Decimal Carry Flag or Decimal/Borrow Flag                          |  |  |  |
| PC           | Program Counter                                                    |  |  |  |
| TOS          | Top Of Stack                                                       |  |  |  |
| GIE          | Global Interrupt Enable Flag (i-Flag)                              |  |  |  |
| []           | Option Field                                                       |  |  |  |
| ()           | Contents                                                           |  |  |  |
|              | Bit Field                                                          |  |  |  |
| В            | Before                                                             |  |  |  |
| А            | After                                                              |  |  |  |
| ←            | Assign direction                                                   |  |  |  |



| Mnemonic             |      | Op Code             | Cycle       | Flag Affect      | Description                                      |
|----------------------|------|---------------------|-------------|------------------|--------------------------------------------------|
|                      |      | Byte-Oriente        | d File Reg  | ister Instructio | n                                                |
| ADDWX                | f, d | ff00 0111 dfff ffff | 1           | C, DC, Z         | Add W and "f"                                    |
| ANDWX                | f, d | ff00 0101 dfff ffff | 1           | Z                | AND W with "f"                                   |
| CLRX                 | f    | ff00 0001 1fff ffff | 1           | Z                | Clear "f"                                        |
| CLRW                 |      | 0000 0001 0100 0000 | 1           | Z                | Clear W                                          |
| COMX                 | f, d | ff00 1001 dfff ffff | 1           | Z                | Complement "f"                                   |
| DECX                 | f, d | ff00 0011 dfff ffff | 1           | Z                | Decrement "f"                                    |
| DECXSZ               | f, d | ff00 1011 dfff ffff | 1 or 2      | -                | Decrement "f", skip if zero                      |
| INCX                 | f, d | ff00 1010 dfff ffff | 1           | Z                | Increment "f"                                    |
| INCXSZ               | f, d | ff00 1111 dfff ffff | 1 or 2      | -                | Increment "f", skip if zero                      |
| IORWX                | f, d | ff00 0100 dfff ffff | 1           | Z                | OR W with "f"                                    |
| MOVX                 | f,d  | ff00 1000 dfff ffff | 1           | Z                | Move "f"                                         |
| MOVXW                | f    | ff00 1000 Offf ffff | 1           | Z                | Move "f" to W                                    |
| MOVWX                | f    | ff00 0000 1fff ffff | 1           | -                | Move W to "f"                                    |
| RLX                  | f, d | ff00 1101 dfff ffff | 1           | С                | Rotate left "f" through carry                    |
| RRX                  | f, d | ff00 1100 dfff ffff | 1           | С                | Rotate right "f" through carry                   |
| SUBW <mark>X</mark>  | f, d | ff00 0010 dfff ffff | 1           | C, DC, Z         | Subtract W from "f"                              |
| SWAP <mark>X</mark>  | f, d | ff00 1110 dfff ffff | 1           | -                | Swap nibbles in "f"                              |
| TST <mark>X</mark>   | f    | ff00 1000 1fff ffff | 1           | Z                | Test if "f" is zero                              |
| XORWX                | f, d | ff00 0110 dfff ffff | 1           | Z                | XOR W with "f"                                   |
|                      |      | Bit-Oriented        | l File Regi | ster Instruction | 1                                                |
| BCX                  | f, b | ff11 00bb bfff ffff | 1           | -                | Clear "b" bit of "f"                             |
| BSX                  | f, b | ff11 01bb bfff ffff | 1           | -                | Set "b" bit of "f"                               |
| BTXSC                | f, b | ff11 10bb bfff ffff | 1 or 2      | -                | Test "b" bit of "f", skip if clear               |
| BT <mark>X</mark> SS | f, b | ff11 11bb bfff ffff | 1 or 2      | -                | Test "b" bit of "f", skip if set                 |
|                      |      | Literal a           | nd Contro   | l Instruction    |                                                  |
| ADDLW                | k    | 0001 1100 kkkk kkkk | 1           | C, DC, Z         | Add Literal "k" and W                            |
| ANDLW                | k    | 0001 1011 kkkk kkkk | 1           | Z                | AND Literal "k" with W                           |
| CALL                 | k    | 0010 Okkk kkkk kkkk | 2           | -                | Call subroutine "k"                              |
| CLRWDT               |      | 0001 1110 0000 0100 | 1           | TO, PD           | Clear Watch Dog Timer                            |
| GOTO                 | k    | 0010 1kkk kkkk kkkk | 2           | -                | Jump to branch "k"                               |
| IORLW                | k    | 0001 1010 kkkk kkkk | 1           | Z                | OR Literal "k" with W                            |
| MOVLW                | k    | 0001 1001 kkkk kkkK | 1           | -                | Move Literal "k" to W                            |
| NOP                  |      | 0000 0000 0000 0000 | 1           | -                | No operation                                     |
| RET                  |      | 0000 0000 0100 0000 | 2           | -                | Return from subroutine                           |
| RETI                 |      | 0000 0000 0110 0000 | 2           | -                | Return from interrupt                            |
| RETLW                | k    | 0001 1000 kkkk kkkk | 2           | -                | Return with Literal in W                         |
| SLEEP                |      | 0001 1110 0000 0011 | 1           | TO, PD           | Go into Power-down mode, Clock oscillation stops |
| SUBLW                | k    | 0001 1111 kkkk kkkk | 1           | C, DC, Z         | Subtract W from literal                          |
| TABRH                |      | 0000 0000 0101 1000 | 2           | -                | Lookup ROM high data to W                        |
| TABRL                |      | 0000 0000 0101 0000 | 2           | -                | Lookup ROM low data to W                         |
| XORLW                | k    | 0001 1101 kkkk kkkk | 1           | Z                | XOR Literal "k" with W                           |



| ADDLW           | Add Literal "k" and       | W                                                               |
|-----------------|---------------------------|-----------------------------------------------------------------|
| Syntax          | ADDLW k                   |                                                                 |
| Operands        | k : 00h ~ FFh             |                                                                 |
| Operation       | $(W) \leftarrow (W) + k$  |                                                                 |
| Status Affected | C, DC, Z                  |                                                                 |
| OP-Code         | 0001 1100 kkkk kkkk       |                                                                 |
| Description     | The contents of the W reg | gister are added to the eight-bit literal 'k' and the result is |
|                 | placed in the W register. |                                                                 |
| Cycle           | 1                         |                                                                 |
| Example         | ADDLW 0x15                | B : W = 0x10                                                    |
|                 |                           | A : W =0x25                                                     |

| ADDWX           | Add W and "f"                        |                                                                  |  |  |  |  |  |
|-----------------|--------------------------------------|------------------------------------------------------------------|--|--|--|--|--|
| Syntax          | ADDWX f [,d]                         |                                                                  |  |  |  |  |  |
| Operands        | f : 00h ~ 1FFh, d : 0, 1             | $f: 00h \sim 1FFh, d: 0, 1$                                      |  |  |  |  |  |
| Operation       | $(destination) \leftarrow (W) + (f)$ |                                                                  |  |  |  |  |  |
| Status Affected | C, DC, Z                             |                                                                  |  |  |  |  |  |
| OP-Code         | ff00 0111 dfff ffff                  |                                                                  |  |  |  |  |  |
| Description     | Add the contents of the W            | register with register 'f'. If 'd' is 0, the result is stored in |  |  |  |  |  |
|                 | the W register. If 'd' is 1, the     | ne result is stored back in register 'f'.                        |  |  |  |  |  |
| Cycle           | 1                                    | -                                                                |  |  |  |  |  |
| Example         | ADDWX FSR, 0                         | B: W = 0x17, FSR $= 0xC2$                                        |  |  |  |  |  |
| -               |                                      | A : W =0xD9, FSR =0xC2                                           |  |  |  |  |  |

| ANDLW           | Logical AND Literal "      | s'' with W                                               |
|-----------------|----------------------------|----------------------------------------------------------|
| Syntax          | ANDLW k                    |                                                          |
| Operands        | k : 00h ~ FFh              |                                                          |
| Operation       | $(W) \leftarrow (W) AND k$ |                                                          |
| Status Affected | Z                          |                                                          |
| OP-Code         | 0001 1011 kkkk kkkk        |                                                          |
| Description     | The contents of W register | are AND'ed with the eight-bit literal 'k'. The result is |
|                 | placed in the W register.  |                                                          |
| Cycle           | 1                          |                                                          |
| Example         | ANDLW 0x5F                 | B: W = 0xA3                                              |
| -               |                            | A: W = 0x03                                              |

| ANDWX           | AND W with "f"                                                                                                                     |                                                  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|--|
| Syntax          | ANDWX f [,d]                                                                                                                       |                                                  |  |  |  |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                                                                                                           |                                                  |  |  |  |
| Operation       | $(destination) \leftarrow (W) ANE$                                                                                                 | <b>D</b> (f)                                     |  |  |  |
| Status Affected | Z                                                                                                                                  |                                                  |  |  |  |
| OP-Code         | ff00 0101 dfff ffff                                                                                                                |                                                  |  |  |  |
| Description     | AND the W register with register 'f'. If 'd' is 0, the result is register. If 'd' is 1, the result is stored back in register 'f'. |                                                  |  |  |  |
| Cycle           | 1                                                                                                                                  |                                                  |  |  |  |
| Example         | ANDWX FSR, 1                                                                                                                       | B : W =0x17, FSR =0xC2<br>A : W =0x17, FSR =0x02 |  |  |  |



| BCX             | Clear "b" bit of "f"                |                                          |  |
|-----------------|-------------------------------------|------------------------------------------|--|
| Syntax          | BCX f [,b]                          |                                          |  |
| Operands        | f : 00h ~ 1FFh, b : 0 ~ 7           |                                          |  |
| Operation       | $(f.b) \leftarrow 0$                | $(f.b) \leftarrow 0$                     |  |
| Status Affected | - ´ ´                               |                                          |  |
| OP-Code         | ff11 00bb bfff ffff                 |                                          |  |
| Description     | Bit 'b' in register 'f' is cleared. |                                          |  |
| Cycle           | 1                                   |                                          |  |
| Example         | BCX FLAG_REG, 7                     | B : FLAG_REG =0xC7<br>A : FLAG_REG =0x47 |  |

\_\_\_\_

| BSX             | Set "b" bit of "f"              |                                          |  |
|-----------------|---------------------------------|------------------------------------------|--|
| Syntax          | BSX f[,b]                       |                                          |  |
| Operands        | f : 00h ~ 1FFh, b : 0 ~ 7       |                                          |  |
| Operation       | $(f.b) \leftarrow 1$            |                                          |  |
| Status Affected | -                               |                                          |  |
| OP-Code         | ff11 01bb bfff ffff             |                                          |  |
| Description     | Bit 'b' in register 'f' is set. |                                          |  |
| Cycle           | 1                               |                                          |  |
| Example         | BSX FLAG_REG, 7                 | B : FLAG_REG =0x0A<br>A : FLAG_REG =0x8A |  |

| BTXSC           | Test "b" bit of "f", skip if o       | clear(0)                                                                                                            |
|-----------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| Syntax          | BTXSC f [,b]                         |                                                                                                                     |
| Operands        | f : 00h ~ 1FFh, b : 0 ~ 7            |                                                                                                                     |
| Operation       | Skip next instruction if $(f.b) = 0$ |                                                                                                                     |
| Status Affected | -                                    |                                                                                                                     |
| OP-Code         | ff11 10bb bfff ffff                  |                                                                                                                     |
| Description     | 6                                    | the next instruction is executed. If bit 'b' in register<br>on is discarded, and a NOP is executed instead,<br>ion. |
| Cycle           | 1 or 2                               |                                                                                                                     |
| Example         | LABEL1 BTXSC FLAG, 1                 | B : PC = LABEL1                                                                                                     |
|                 | TRUE GOTO SUB1                       | A : if FLAG.1 =0, PC =FALSE                                                                                         |
|                 | FALSE                                | if FLAG.1 =1, PC =TRUE                                                                                              |

| BTXSS           | Test "b" bit of "f", skip if set(1)                                                            |             |
|-----------------|------------------------------------------------------------------------------------------------|-------------|
| Syntax          | BTXSS f [,b]                                                                                   |             |
| Operands        | f : 00h ~ 1FFh, b : 0 ~ 7                                                                      |             |
| Operation       | Skip next instruction if $(f.b) = 1$                                                           |             |
| Status Affected | -                                                                                              |             |
| OP-Code         | ff11 11bb bfff ffff                                                                            |             |
| Description     | If bit 'b' in register 'f' is 0, then the next instruction is executed. If bit 'b' in register |             |
|                 | 'f' is 1, then the next instruction is discarded, and a NOP is execut                          | ed instead, |
|                 | making this a 2nd cycle instruction.                                                           |             |
| Cycle           | 1 or 2                                                                                         |             |
| Example         | LABEL1 BTXSS FLAG, 1 B : PC =LABEL1                                                            |             |
|                 | TRUE GOTO SUB1 A : if FLAG.1 =0, PC =TRUE                                                      |             |
|                 | FALSE if FLAG.1 =1, PC =FALSE                                                                  |             |



| CALL            | Call subroutine "k"                                                                                                                                                                                               |                                                 |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| Syntax          | CALL k                                                                                                                                                                                                            |                                                 |
| Operands        | k : 000h ~ FFFh                                                                                                                                                                                                   |                                                 |
| Operation       | Operation: TOS $\leftarrow$ (PC) + 1, 1                                                                                                                                                                           | $PC.10 \sim 0 \leftarrow k$                     |
| Status Affected | -                                                                                                                                                                                                                 |                                                 |
| OP-Code         | 0010 0kkk kkkk                                                                                                                                                                                                    |                                                 |
| Description     | Call Subroutine. First, return address (PC+1) is pushed onto the stack. The 11-bit immediate address is loaded into PC bits <10:0>. The upper bits of PC are loaded from PCLATH. CALL is a two-cycle instruction. |                                                 |
| Cycle           | 2                                                                                                                                                                                                                 |                                                 |
| Example         | LABEL1 CALL SUB1                                                                                                                                                                                                  | B : PC =LABEL1<br>A : PC =SUB1, TOS =LABEL1 + 1 |

| CLRX            | Clear "f"                                                      |                          |
|-----------------|----------------------------------------------------------------|--------------------------|
| Syntax          | CLRX f                                                         |                          |
| Operands        | f : 00h ~ 1FFh                                                 |                          |
| Operation       | (f) $\leftarrow$ 00h, Z $\leftarrow$ 1                         |                          |
| Status Affected | Z                                                              |                          |
| OP-Code         | ff00 0001 1fff ffff                                            |                          |
| Description     | The contents of register 'f' are cleared and the Z bit is set. |                          |
| Cycle           | 1                                                              |                          |
| Example         | CLRX FLAG_REG                                                  | $B : FLAG_REG = 0x5A$    |
| -               |                                                                | A : FLAG_REG =0x00, Z =1 |

| CLRW            | Clear W                                |                   |
|-----------------|----------------------------------------|-------------------|
| Syntax          | CLRW                                   |                   |
| Operands        | -                                      |                   |
| Operation       | (W) $\leftarrow$ 00h, Z $\leftarrow$ 1 |                   |
| Status Affected | Z                                      |                   |
| OP-Code         | 0000 0001 0100 0000                    |                   |
| Description     | W register is cleared                  | and Z bit is set. |
| Cycle           | 1                                      |                   |
| Example         | CLRW                                   | B: W = 0x5A       |
| *               |                                        | A : W =0x00, Z =1 |

| CLRWDT          | Clear Watchdog Ti                                   | mer                     |  |
|-----------------|-----------------------------------------------------|-------------------------|--|
| Syntax          | CLRWDT                                              |                         |  |
| Operands        | -                                                   |                         |  |
| Operation       | WDT/WKT Timer $\leftarrow 0$                        | OOh                     |  |
| Status Affected | TO, PD                                              | TO, PD                  |  |
| OP-Code         | 0001 1110 0000 0100                                 |                         |  |
| Description     | CLRWDT instruction clears the Watchdog/Wakeup Timer |                         |  |
| Cycle           | 1                                                   |                         |  |
| Example         | CLRWDT                                              | B : WDT counter =?      |  |
| *               |                                                     | A : WDT counter $=0x00$ |  |





| COMX            | Complement "f"                                                                             |                                                                                                                 |
|-----------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Syntax          | $\begin{array}{c} \text{COMX } f[,d] \\ f_{+} 00h & 1 \text{EFh} d_{+} 0 \\ 1 \end{array}$ |                                                                                                                 |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                                                                   |                                                                                                                 |
| Operation       | (destination) $\leftarrow$ (f)                                                             |                                                                                                                 |
| Status Affected | Z                                                                                          |                                                                                                                 |
| OP-Code         | ff00 1001 dfff ffff<br>The contents of register 'f' are s                                  | complemented. If 'd' is 0, the result is stored in W.                                                           |
| Description     | If 'd' is 1, the result is stored bac                                                      |                                                                                                                 |
| Cycle           | 1                                                                                          |                                                                                                                 |
| Example         | COMX REG1, 0                                                                               | B : REG1 =0x13                                                                                                  |
| 1               | ,                                                                                          | A : REG1 =0x13, W =0xEC                                                                                         |
| DECX            | Decrement "f"                                                                              |                                                                                                                 |
| Syntax          | DECX f [,d]                                                                                |                                                                                                                 |
| Operands        | $f: 00h \sim 1FFh, d: 0, 1$                                                                |                                                                                                                 |
| Operation       | (destination) $\leftarrow$ (f) - 1                                                         |                                                                                                                 |
| Status Affected | Ż                                                                                          |                                                                                                                 |
| OP-Code         | ff00 0011 dfff ffff                                                                        |                                                                                                                 |
| Description     |                                                                                            | , the result is stored in the W register. If 'd' is 1, the                                                      |
|                 | result is stored back in register '                                                        | f.                                                                                                              |
| Cycle           |                                                                                            |                                                                                                                 |
| Example         | DECX CNT, 1                                                                                | B : CNT = $0x01$ , Z = $0$                                                                                      |
|                 |                                                                                            | A : CNT = $0x00, Z = 1$                                                                                         |
| DECXSZ          | Decrement "f", Skip if 0                                                                   |                                                                                                                 |
| Syntax          | DECXSZ f [,d]                                                                              |                                                                                                                 |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                                                                   |                                                                                                                 |
| Operation       | $(destination) \leftarrow (f) - 1$ , skip nex                                              | t instruction if result is 0                                                                                    |
| Status Affected | -                                                                                          |                                                                                                                 |
| OP-Code         | ff00 1011 dfff ffff                                                                        |                                                                                                                 |
| Description     |                                                                                            | ecremented. If 'd' is 0, the result is placed in the W                                                          |
|                 |                                                                                            | blaced back in register 'f'. If the result is 1, the next<br>esult is 0, then a NOP is executed instead, making |
|                 | it a 2 cycle instruction.                                                                  | esuit is 0, then a NOF is executed histeau, making                                                              |
| Cycle           | 1 or 2                                                                                     |                                                                                                                 |
| Example         | LABEL1 DECXSZ CNT, 1                                                                       | B : PC =LABEL1                                                                                                  |
| . 1             | GOTO LOOP                                                                                  | A: CNT = CNT - 1                                                                                                |
|                 | CONTINUE                                                                                   | if CNT =0, PC =CONTINUE                                                                                         |
|                 |                                                                                            | if CNT $\neq 0$ , PC =LABEL1 + 1                                                                                |
| GOTO            | <b>Unconditional Branch</b>                                                                |                                                                                                                 |
| Syntax          | GOTO k                                                                                     |                                                                                                                 |
| Operands        | k : 000h ~ FFFh                                                                            |                                                                                                                 |
| Operation       | PC.10~0 $\leftarrow$ k                                                                     |                                                                                                                 |
| Status Affected | -                                                                                          |                                                                                                                 |
| OP-Code         | 0010 1kkk kkkk kkkk                                                                        |                                                                                                                 |
| Description     |                                                                                            | nch. The 11-bit immediate value is loaded into PC                                                               |
|                 |                                                                                            | PC are loaded from PCLATH. GOTO is a two-                                                                       |
|                 | cycle instruction.                                                                         |                                                                                                                 |
| Cycle           | 2                                                                                          |                                                                                                                 |

Cycle2ExampleLABEL1 GOTO SUB1B : PC =LABEL1A : PC =SUB1





| INCX            | Increment "f"                                                     |                                                  |
|-----------------|-------------------------------------------------------------------|--------------------------------------------------|
| Syntax          | INCX f [,d]                                                       |                                                  |
| Operands        | f : 00h ~ 1FFh                                                    |                                                  |
| Operation       | (destination) $\leftarrow$ (f) + 1                                |                                                  |
| Status Affected | Z                                                                 |                                                  |
| OP-Code         | ff00 1010 dfff ffff                                               |                                                  |
| Description     | The contents of register 'f' are increme                          | nted. If 'd' is 0, the result is placed in the W |
|                 | register. If 'd' is 1, the result is placed back in register 'f'. |                                                  |
| Cycle           | 1                                                                 |                                                  |
| Example         | INCX CNT, 1 B:                                                    | CNT = 0xFF, Z = 0                                |
|                 | A :                                                               | CNT =0x00, Z =1                                  |

| INCXSZ          | Increment ''f'', Skip if 0                   |                                                                                                                                                                             |
|-----------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax          | INCXSZ f [,d]                                |                                                                                                                                                                             |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                     |                                                                                                                                                                             |
| Operation       | (destination) $\leftarrow$ (f) + 1, skip nex | t instruction if result is 0                                                                                                                                                |
| Status Affected | -                                            |                                                                                                                                                                             |
| OP-Code         | ff00 1111 dfff ffff                          |                                                                                                                                                                             |
| Description     | register. If 'd' is 1, the result is p       | ncremented. If 'd' is 0, the result is placed in the W<br>placed back in register 'f'. If the result is 1, the next<br>esult is 0, a NOP is executed instead, making it a 2 |
| Cycle           | 1 or 2                                       |                                                                                                                                                                             |
| Example         | LABEL1 INCXSZ CNT, 1                         | B : PC = LABEL1                                                                                                                                                             |
| -               | GOTO LOOP                                    | A: CNT = CNT + 1                                                                                                                                                            |
|                 | CONTINUE                                     | if CNT =0, PC =CONTINUE                                                                                                                                                     |
|                 |                                              | if CNT $\neq 0$ , PC =LABEL1 + 1                                                                                                                                            |

| IORLW           | <b>Inclusive OR Literal</b>                                                                                      | l with W           |
|-----------------|------------------------------------------------------------------------------------------------------------------|--------------------|
| Syntax          | IORLW k                                                                                                          |                    |
| Operands        | k : 00h ~ FFh                                                                                                    |                    |
| Operation       | $(W) \leftarrow (W) OR k$                                                                                        |                    |
| Status Affected | Z                                                                                                                |                    |
| OP-Code         | 0001 1010 kkkk kkkk                                                                                              |                    |
| Description     | The contents of the W register are OR'ed with the eight-bit literal 'k'. The result is placed in the W register. |                    |
| Cycle           | 1                                                                                                                |                    |
| Example         | IORLW 0x35                                                                                                       | B: W = 0x9A        |
| -               |                                                                                                                  | A: W = 0xBF, Z = 0 |

| IORWX           | Inclusive OR W with "f                                                                                                                                      |                                                              |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|
| Syntax          | IORWF f [,d]                                                                                                                                                |                                                              |  |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                                                                                                                                    |                                                              |  |
| Operation       | $(destination) \leftarrow (W) OR k$                                                                                                                         |                                                              |  |
| Status Affected | Ž                                                                                                                                                           |                                                              |  |
| OP-Code         | ff00 0100 dfff ffff                                                                                                                                         |                                                              |  |
| Description     | Inclusive OR the W register with register 'f'. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'. |                                                              |  |
| Cycle           | 1                                                                                                                                                           | uit is placed back in register 1.                            |  |
| Example         | IORWX RESULT, 0                                                                                                                                             | B : RESULT =0x13, W =0x91<br>A : RESULT =0x13, W =0x93, Z =0 |  |



| MOVX            | Move f                                                                                                                                                                                                                                                   |                                               |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--|
| Syntax          | MOVX f,d                                                                                                                                                                                                                                                 |                                               |  |
| Operands        | f : 00h ~ 1FFh                                                                                                                                                                                                                                           |                                               |  |
| Operation       | $(destination) \leftarrow (f)$                                                                                                                                                                                                                           |                                               |  |
| Status Affected | Z                                                                                                                                                                                                                                                        |                                               |  |
| OP-Code         | ff00 1000 dfff ffff                                                                                                                                                                                                                                      |                                               |  |
| Description     | The contents of register 'f' are moved to a destination dependent upon the status of d. If d=0, destination is W register. If d =1, the destination is file register f itself. $d=1$ is useful to test a file register, since status flag Z is affected. |                                               |  |
| Cycle           | 1                                                                                                                                                                                                                                                        |                                               |  |
| Example         | MOVX FSR,0                                                                                                                                                                                                                                               | B : FSR =0xC2, W =?<br>A : FSR =0xC2, W =0xC2 |  |

| MOVXW           | Move "f" to W                                         |                             |  |
|-----------------|-------------------------------------------------------|-----------------------------|--|
| Syntax          | MOVXW f                                               |                             |  |
| Operands        | f : 00h ~ 1FFh                                        |                             |  |
| Operation       | $(W) \leftarrow (f)$                                  |                             |  |
| Status Affected | Z                                                     |                             |  |
| OP-Code         | ff00 1000 Offf ffff                                   |                             |  |
| Description     | The contents of register 'f' are moved to W register. |                             |  |
| Cycle           | 1                                                     | -                           |  |
| Example         | MOVXW FSR                                             | B : FSR = 0xC2, W = ?       |  |
| -               |                                                       | A : FSR $=0xC2$ , W $=0xC2$ |  |

| MOVLW           | Move Literal to W                                                                     |             |  |
|-----------------|---------------------------------------------------------------------------------------|-------------|--|
| Syntax          | MOVLW k                                                                               |             |  |
| Operands        | k : 00h ~ FFh                                                                         |             |  |
| Operation       | $(W) \leftarrow k$                                                                    |             |  |
| Status Affected | -                                                                                     |             |  |
| OP-Code         | 0001 1001 kkkk kkkk                                                                   |             |  |
| Description     | The eight-bit literal 'k' is loaded into W register. The don't cares will assemble as |             |  |
|                 | 0's.                                                                                  |             |  |
| Cycle           | 1                                                                                     |             |  |
| Example         | MOVLW 0x5A                                                                            | B : W =?    |  |
|                 |                                                                                       | A: W = 0x5A |  |

| MOVWX           | Move W to "f"                              |                                |  |
|-----------------|--------------------------------------------|--------------------------------|--|
| Syntax          | MOVWX f                                    |                                |  |
| Operands        | f : 00h ~ 1FFh                             |                                |  |
| Operation       | $(f) \leftarrow (W)$                       |                                |  |
| Status Affected | -                                          |                                |  |
| OP-Code         | ff00 0000 1fff ffff                        |                                |  |
| Description     | Move data from W register to register 'f'. |                                |  |
| Cycle           | 1                                          |                                |  |
| Example         | MOVWX REG1 B : REG1 =0xFF, W =0x4F         |                                |  |
| -               |                                            | A : REG1 = $0x4F$ , W = $0x4F$ |  |



| No Operation         NOP         No Operation         0000 0000 0000 0000         No Operation         1         NOP         Return from Subroutine         RET         -         PC $\leftarrow$ TOS         0000 0000 0100 0000         Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle instruction.         2         PET |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NOP<br>-<br>No Operation<br>-<br>0000 0000 0000 0000<br>No Operation<br>1<br>NOP<br>-<br>Return from Subroutine<br>RET<br>-<br>PC $\leftarrow$ TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                       |
| <ul> <li>0000 0000 0000 0000</li> <li>No Operation <ol> <li>NOP</li> </ol> </li> <li>Return from Subroutine RET PC ← TOS 0000 0000 0100 0000 Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle instruction. 2</li></ul>                                                                                                        |
| <ul> <li>0000 0000 0000 0000</li> <li>No Operation <ol> <li>NOP</li> </ol> </li> <li>Return from Subroutine RET PC ← TOS 0000 0000 0100 0000 Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle instruction. 2</li></ul>                                                                                                        |
| <ul> <li>0000 0000 0000 0000</li> <li>No Operation <ol> <li>NOP</li> </ol> </li> <li>Return from Subroutine RET PC ← TOS 0000 0000 0100 0000 Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle instruction. 2</li></ul>                                                                                                        |
| No Operation<br>1<br>NOP -<br>Return from Subroutine<br>RET<br>-<br>PC ← TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                             |
| 1<br>NOP -<br>Return from Subroutine<br>RET<br>-<br>PC ← TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                             |
| 1<br>NOP -<br>Return from Subroutine<br>RET<br>-<br>PC ← TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                             |
| Return from Subroutine<br>RET<br>-<br>PC ← TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                                           |
| RET<br>-<br>PC ← TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                                                                     |
| RET<br>-<br>PC ← TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                                                                     |
| PC ← TOS<br>-<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                                                                                 |
| -<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                                                                                             |
| -<br>0000 0000 0100 0000<br>Return from subroutine. The stack is POPed and the top of the stack (TOS) is<br>loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                                                                                             |
| Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle instruction. 2                                                                                                                                                                                                                                                               |
| Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle instruction. 2                                                                                                                                                                                                                                                               |
| loaded into the program counter. This is a two-cycle instruction.<br>2                                                                                                                                                                                                                                                                                                                                         |
| 2                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1717 A 110 Y 117 ALY                                                                                                                                                                                                                                                                                                                                                                                           |
| RET A : PC =TOS                                                                                                                                                                                                                                                                                                                                                                                                |
| Return from Interrupt                                                                                                                                                                                                                                                                                                                                                                                          |
| RETI                                                                                                                                                                                                                                                                                                                                                                                                           |
| -                                                                                                                                                                                                                                                                                                                                                                                                              |
| $PC \leftarrow TOS, GIE \leftarrow 1$                                                                                                                                                                                                                                                                                                                                                                          |
| -                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0000 0000 0110 0000                                                                                                                                                                                                                                                                                                                                                                                            |
| Return from Interrupt. Stack is POPed and Top-of-Stack (TOS) is loaded in to the                                                                                                                                                                                                                                                                                                                               |
| PC. Interrupts are enabled. This is a two-cycle instruction.                                                                                                                                                                                                                                                                                                                                                   |
| 2                                                                                                                                                                                                                                                                                                                                                                                                              |
| RETI A : PC =TOS, GIE =1                                                                                                                                                                                                                                                                                                                                                                                       |
| Return with Literal in W                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                |
| RETLW k<br>k: 00h ~ FFh                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                |
| $PC \leftarrow TOS, (W) \leftarrow k$                                                                                                                                                                                                                                                                                                                                                                          |
| -                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0001 1000 kkk kkk                                                                                                                                                                                                                                                                                                                                                                                              |
| The W register is loaded with the eight-bit literal 'k'. The program counter is                                                                                                                                                                                                                                                                                                                                |
| loaded from the top of the stack (the return address). This is a two-cycle instruction.                                                                                                                                                                                                                                                                                                                        |
| 2                                                                                                                                                                                                                                                                                                                                                                                                              |
| CALL TABLE B: W=0x07                                                                                                                                                                                                                                                                                                                                                                                           |
| : $A: W = value of k8$                                                                                                                                                                                                                                                                                                                                                                                         |
| TABLE ADDWX PCL, 1                                                                                                                                                                                                                                                                                                                                                                                             |
| RETLW k1                                                                                                                                                                                                                                                                                                                                                                                                       |
| RETLW k2                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                |
| RETLW kn                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                |



| RLX                                    | Rotate Left "f" through Carry                                                                                                                                                                            |
|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax                                 | RLX f[,d]                                                                                                                                                                                                |
| Operands                               | $f: 00h \sim 1FFh, d: 0, 1$                                                                                                                                                                              |
| Operation                              | C Register f                                                                                                                                                                                             |
| Status Affected                        | С                                                                                                                                                                                                        |
| OP-Code                                | ff00 1101 dfff ffff                                                                                                                                                                                      |
| Description                            | The contents of register 'f' are rotated one bit to the left through the Carry Flag. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is stored back in register 'f'.        |
| Cycle                                  | 1                                                                                                                                                                                                        |
| Example                                | RLX REG1, 0 B : REG1 =1110 0110, C =0                                                                                                                                                                    |
|                                        | A : REG1 =1110 0110                                                                                                                                                                                      |
|                                        | W =1100 1100, C =1                                                                                                                                                                                       |
| RRX<br>Syntax<br>Operands<br>Operation | Rotate Right "f" through Carry         RRX f [,d] $f: 00h \sim 1FFh, d: 0, 1$ C       Register f                                                                                                         |
| Status Affected                        | C                                                                                                                                                                                                        |
| OP-Code                                | ff00 1100 dfff ffff                                                                                                                                                                                      |
| Description                            | The contents of register 'f' are rotated one bit to the right through the Carry Flag.<br>If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back<br>in register 'f'. |
| Cycle                                  | 1                                                                                                                                                                                                        |
| Example                                | RRX REG1, 0 B : REG1 =1110 0110, C =0                                                                                                                                                                    |
|                                        | A : REG1 =1110 0110                                                                                                                                                                                      |
|                                        | W =0111 0011, C =0                                                                                                                                                                                       |
| SLEEP                                  | Go into Power-down mode, Clock oscillation stops                                                                                                                                                         |

| SLEEP           | Go into Power-down mode, Clock oscination stops    |
|-----------------|----------------------------------------------------|
| Syntax          | SLEEP                                              |
| Operands        | -                                                  |
| Operation       | -                                                  |
| Status Affected | TO, PD                                             |
| OP-Code         | 001 1110 0000 0011                                 |
| Description     | Go into Power-down mode with the oscillator stops. |
| Cycle           | 1                                                  |
| Example         | SLEEP -                                            |
|                 |                                                    |



| SUBLW           | Subtract W from Lite                                      | ral                                                                       |
|-----------------|-----------------------------------------------------------|---------------------------------------------------------------------------|
| Syntax          | SUBLW k                                                   |                                                                           |
| Operands        | k : 00h ~ FFh                                             |                                                                           |
| Operation       | $(W) \leftarrow k - (W)$                                  |                                                                           |
| Status Affected | C, DC, Z                                                  |                                                                           |
| OP-Code         | 0001 1111 kkkk kkkk                                       |                                                                           |
| Description     | The W register is subtrace<br>"k". The result is placed i | cted (2's complement method) from the eight-bit literal n the W register. |
| Cycle           | 1                                                         | C                                                                         |
| Example         | SUBLW 0x15                                                | B : W =0x25                                                               |
| 1               |                                                           | A: W = 0xF0                                                               |
|                 |                                                           |                                                                           |
| SUBWX           | Subtract W from "f"                                       |                                                                           |
| Syntax          | SUBWX f[d]                                                |                                                                           |

| BUDWA           |                                                                                        |                                                  |  |
|-----------------|----------------------------------------------------------------------------------------|--------------------------------------------------|--|
| Syntax          | SUBWX f [,d]                                                                           |                                                  |  |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                                                               |                                                  |  |
| Operation       | $(destination) \leftarrow (f) - (W)$                                                   |                                                  |  |
| Status Affected | C, DC, Z                                                                               |                                                  |  |
| OP-Code         | ff00 0010 dfff ffff                                                                    |                                                  |  |
| Description     | Subtract (2's complement method) W register from register 'f'. If 'd' is 0, the result |                                                  |  |
|                 | is stored in the W register. If 'd'                                                    | is 1, the result is stored back in register 'f'. |  |
| Cycle           | 1                                                                                      |                                                  |  |
| Example         | SUBWX REG1, 1                                                                          | B : REG1 =0x03, W =0x02, C =?, Z =?              |  |
|                 |                                                                                        | A : REG1 =0x01, W =0x02, C =1, Z =0              |  |
|                 |                                                                                        |                                                  |  |
|                 | SUBWX REG1, 1                                                                          | B : REG1 =0x02, W =0x02, C =?, Z =?              |  |
|                 |                                                                                        | A : REG1 =0x00, W =0x02, C =1, Z =1              |  |
|                 |                                                                                        |                                                  |  |
|                 | SUBWX REG1, 1                                                                          | B : REG1 =0x01, W =0x02, C =?, Z =?              |  |
|                 |                                                                                        | A : REG1 =0xFF, W =0x02, C =0, Z =0              |  |
|                 |                                                                                        |                                                  |  |

| SWAPX           | Swap Nibbles in ''f''                                                                                                                                          |                                           |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|
| Syntax          | SWAPX f [,d]                                                                                                                                                   |                                           |  |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                                                                                                                                       |                                           |  |
| Operation       | (destination, 7~4) $\leftarrow$ (f.3~0), (destination.3~0) $\leftarrow$ (f.7~4)                                                                                |                                           |  |
| Status Affected |                                                                                                                                                                |                                           |  |
| OP-Code         | ff00 1110 dfff ffff                                                                                                                                            |                                           |  |
| Description     | The upper and lower nibbles of register 'f' are exchanged. If 'd' is 0, the result is placed in W register. If 'd' is 1, the result is placed in register 'f'. |                                           |  |
| Cycle           | 1                                                                                                                                                              |                                           |  |
| Example         | SWAPX REG, 0                                                                                                                                                   | B : REG1 =0xA5<br>A : REG1 =0xA5, W =0x5A |  |



| TABRH                  | Return Dl                                                                                                    | PTR high byte to W |                        |
|------------------------|--------------------------------------------------------------------------------------------------------------|--------------------|------------------------|
| Syntax                 | TABRH                                                                                                        |                    |                        |
| Operands               | -                                                                                                            |                    |                        |
| Operation              | (W) $\leftarrow$ ROM[DPTR] high byte content, Where DPTR = {DPH[max:8], DPL[7:0]}                            |                    |                        |
| Status Affected        | -                                                                                                            |                    |                        |
| OP-Code                | 0000 0000 0101 1000                                                                                          |                    |                        |
| Description            | The W register is loaded with high byte of ROM[DPTR]. This is a two-cycle instruction.                       |                    |                        |
| Cycle                  | 2                                                                                                            |                    |                        |
| Example                | MOVLW                                                                                                        | (TAB1&0xFF)        |                        |
| -                      | MOVWX                                                                                                        | DPL                | ;Where DPL is register |
|                        | MOVLW                                                                                                        | (TAB1>>8)&0xFF     |                        |
|                        | MOVWX                                                                                                        | DPH                | ;Where DPH is register |
|                        | TABRL                                                                                                        |                    | ;W =0x89               |
|                        | TABRH                                                                                                        |                    | ;W =0x37               |
|                        |                                                                                                              | ORG 0234H          |                        |
|                        | TAB1:                                                                                                        |                    |                        |
|                        | DT                                                                                                           | 0x3789, 0x2277     | ;ROM data 16 bits      |
| TABRL                  | Return DPTR low byte to W                                                                                    |                    |                        |
| Syntax                 | TABRL                                                                                                        | U                  |                        |
| Operands               | -                                                                                                            |                    |                        |
| Operation              | (W) $\leftarrow$ ROM[DPTR] low byte content, Where DPTR = {DPH[max:8], DPL[7:0]}                             |                    |                        |
| Status Affected        | -                                                                                                            |                    |                        |
| OP-Code<br>Description | 0000 0000 0101 0000<br>The W register is loaded with low byte of ROM[DPTR]. This is a two-cycle instruction. |                    |                        |
| Cycle                  | 2                                                                                                            |                    |                        |
| Example                | MOVLW                                                                                                        | (TAB1&0xFF)        |                        |
| Example                | MOVEW                                                                                                        | DPL                | ;Where DPL register    |
|                        | MOVWX<br>MOVLW                                                                                               | (TAB1>>8)&0xFF     | , where DFL register   |
|                        | MOVEW                                                                                                        | DPH                | ;Where DPH register    |
|                        | TABRL                                                                                                        |                    | ;W =0x89               |
|                        | TABRH                                                                                                        |                    | ;W =0x37               |
|                        |                                                                                                              |                    |                        |

| TAD1        | ORG 0234H      |                   |
|-------------|----------------|-------------------|
| TAB1:<br>DT | 0x3789, 0x2277 | ;ROM data 16 bits |



| TSTX            | Test if "f" is zero        |                                  |
|-----------------|----------------------------|----------------------------------|
| Syntax          | TSTX f                     |                                  |
| Operands        | f : 00h ~ 1FFh             |                                  |
| Operation       | Set Z flag if (f) is 0     |                                  |
| Status Affected | Z                          |                                  |
| OP-Code         | ff00 1000 1fff ffff        |                                  |
| Description     | If the content of register | 'f' is 0, Zero flag is set to 1. |
| Cycle           | 1                          |                                  |
| Example         | TSTX REG1                  | B : REG1 =0, Z =?                |
|                 |                            | A : REG1 =0, Z =1                |

| XORLW           | Exclusive OR Literal           | with W                                                          |
|-----------------|--------------------------------|-----------------------------------------------------------------|
| Syntax          | XORLW k                        |                                                                 |
| Operands        | k : 00h ~ FFh                  |                                                                 |
| Operation       | $(W) \leftarrow (W) XOR k$     |                                                                 |
| Status Affected | Z                              |                                                                 |
| OP-Code         | 0001 1101 kkkk kkkk            |                                                                 |
| Description     | The contents of the W register | gister are XOR'ed with the eight-bit literal 'k'. The result r. |
| Cycle           | 1                              |                                                                 |
| Example         | XORLW 0xAF                     | B: W = 0xB5                                                     |
| -               |                                | A: W = 0x1A                                                     |

| XORWX           | Exclusive OR W with '                                                                                                                                                       | 'f''                                             |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|
| Syntax          | XORWX f [,d]                                                                                                                                                                |                                                  |  |  |
| Operands        | f : 00h ~ 1FFh, d : 0, 1                                                                                                                                                    |                                                  |  |  |
| Operation       | $(destination) \leftarrow (W) XOR$                                                                                                                                          | (f)                                              |  |  |
| Status Affected | Z                                                                                                                                                                           |                                                  |  |  |
| OP-Code         | ff00 0110 dfff ffff                                                                                                                                                         |                                                  |  |  |
| Description     | Exclusive OR the contents of the W register with register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |                                                  |  |  |
| Cycle           | 1                                                                                                                                                                           |                                                  |  |  |
| Example         | XORWX REG, 1                                                                                                                                                                | B : REG =0xAF, W =0xB5<br>A : REG =0x1A, W =0xB5 |  |  |



## **ELECTRICAL CHARACTERISTICS**

### **1.** Absolute Maximum Ratings $(T_A = 25^{\circ}C)$

| Parameter                       | Rating                         | Unit |
|---------------------------------|--------------------------------|------|
| Supply voltage                  | $V_{SS}$ -0.3 to $V_{SS}$ +5.5 |      |
| Input voltage                   | $V_{SS}$ -0.3 to $V_{CC}$ +0.3 | V    |
| Output voltage                  | $V_{SS}$ -0.3 to $V_{CC}$ +0.3 |      |
| Output current high per 1 PIN   | -25                            |      |
| Output current high per all PIN | -80                            |      |
| Output current low per 1 PIN    | +30                            | - mA |
| Output current low per all PIN  | +150                           |      |
| Maximum operating voltage       | 5.5                            | V    |
| Operating temperature           | -40 to +85                     | ംറ   |
| Storage temperature             | -65 to +150                    |      |

#### 2. DC Characteristics (TA =25 °C, V<sub>CC</sub> =5.0V, unless otherwise specified)

| Parameter                           | Sym                                                                                                | Co                  | onditions                            | Min    | Тур  | Max    | Unit |
|-------------------------------------|----------------------------------------------------------------------------------------------------|---------------------|--------------------------------------|--------|------|--------|------|
| Operating Voltage                   | V                                                                                                  | Fsy                 | s = 8Mhz                             | 2.1    | -    | 5.5    |      |
| Operating voltage                   | $V_{cc}$                                                                                           | Fsy                 | s = 4Mhz                             | 1.6    | -    | 5.5    |      |
| Input High Voltage                  | $V_{\mathrm{IH}}$                                                                                  | All Input           | $V_{CC} = 3 \sim 5V$                 | 0.6Vcc | _    | Vcc    | V    |
| Input Low Voltage                   | V <sub>IL</sub>                                                                                    | All Input           | $V_{CC} = 3 \sim 5V$                 | Vss    | _    | 0.2Vcc | V    |
| Output High Current                 | I <sub>OH</sub>                                                                                    | All Output          | $V_{\rm CC} = 5V, V_{\rm OH} = 4.5V$ | 6      | 12   | -      | mA   |
| Output High Current                 | TOH                                                                                                | An Output           | $V_{\rm CC} = 3V, V_{\rm OH} = 2.7V$ | 2.5    | 5    | -      | шд   |
| Output Low Current                  | I <sub>OL</sub>                                                                                    | All Output          | $V_{\rm CC} = 5V, V_{\rm OL} = 0.5V$ | 20     | 40   | -      | mA   |
| *                                   | -01                                                                                                | i in o uip ui       | $V_{\rm CC} = 3V, V_{\rm OL} = 0.3V$ | 8      | 16   | -      |      |
| Input Leakage Current<br>(pin high) | I <sub>ILH</sub>                                                                                   | All Input           | $V_{\rm IN} = V_{\rm CC}$            | -      | -    | 1      | uA   |
| Input Leakage Current<br>(pin low)  | I <sub>ILL</sub>                                                                                   | All Input           | $V_{\rm IN} = 0V$                    | -      | -    | -1     | uA   |
|                                     | FAST mode<br>FIRC 8 MHz<br>FAST mode<br>FIRC 4 MHz<br>FAST mode<br>FIRC 2 MHz                      |                     | $V_{CC} = 5V$                        | -      | 3.5  | -      |      |
|                                     |                                                                                                    |                     | $V_{\rm CC} = 5V$                    | _      | 2.7  | _      |      |
|                                     |                                                                                                    | $V_{CC} = 5V$       | -                                    | 2.3    | -    | mA     |      |
|                                     |                                                                                                    | FAST mode           | $V_{\rm CC} = 5V$                    | _      | 2.1  | _      |      |
|                                     |                                                                                                    | FIRC 1 MHz          | $V_{CC} = 3V$                        | _      | 1.5  | _      |      |
| Power Supply Current<br>(No Load)   | I <sub>CC</sub><br>SIRC 70KHz<br>OPA ON<br>VR ON<br>SLOW mode<br>SIRC 70KHz<br>OPA STOP<br>VR STOP | $V_{CC} = 5.0 V$    | -                                    | 1300   | _    |        |      |
|                                     |                                                                                                    |                     | $V_{CC} = 3.0V$                      | _      | 1100 | -      | uA   |
|                                     |                                                                                                    |                     | $V_{CC} = 5.0 V$                     | -      | 750  | -      | 4    |
|                                     |                                                                                                    | OPA STOP<br>VR STOP | $V_{CC} = 3.0V$                      | -      | 620  | -      | uA   |
|                                     |                                                                                                    | STOP mode           | $V_{\rm CC} = 5.0 V$                 | _      | 0.1  | -      | uA   |
|                                     |                                                                                                    | LVRSAV = 1          | $V_{CC} = 3.0V$                      | -      | 0.1  |        |      |

|  |  | Parameter | Sym | Conditions | Min | Тур | Max | Unit |
|--|--|-----------|-----|------------|-----|-----|-----|------|
|--|--|-----------|-----|------------|-----|-----|-----|------|



| Power Supply Current             | Т               | IDLE mode<br>SIRC 70 KHz | $V_{CC} = 5.0 V$                 | _ | 4.2 | _    | A           |
|----------------------------------|-----------------|--------------------------|----------------------------------|---|-----|------|-------------|
| (No Load)                        | I <sub>CC</sub> | LVRSAV = 1               | $V_{CC} = 3.0V$                  | _ | 1.2 | _    | uA          |
| Dull up Desistor                 | р               | $V_{IN} = 0 V$           | $V_{CC} = 5.0V$                  | - | 41  | -    | KΩ          |
| Pull-up Resistor R <sub>UP</sub> | ĸ <sub>UP</sub> | Ports A                  | $V_{\rm CC} = 3.0 V$             | - | 76  | -    | <b>K</b> 12 |
| Internal Reference<br>Voltage    | VR              | VCC=5.0V, at             | VCC=5.0V, at least 1uF to ground |   | 3   | 1.2% | v           |

### 3. Clock Timing $(T_A = -40^{\circ}C \text{ to } +85^{\circ}C)$

| Parameter          | Condition                                            | Min   | Тур | Max   | Unit |
|--------------------|------------------------------------------------------|-------|-----|-------|------|
| FIRC Frequency (*) | $-40^{\circ}$ C ~ 85°C, V <sub>CC</sub> = 3.0 ~ 5.0V | -2%   | 8   | +2%   |      |
|                    | $-40^{\circ}$ C ~ 85°C, V <sub>CC</sub> = 4.0 V      | -2%   | 8   | +1.5% |      |
|                    | $0^{\circ}C \sim 70^{\circ}C, V_{CC} = 4.0 V$        | -2%   | 8   | +1.5% | MHz  |
|                    | $25^{\circ}$ C, V <sub>CC</sub> = $3.0 \sim 5.0$ V   | -1.0% | 8   | +2%   |      |
|                    | 25°C, V <sub>CC</sub> =4.0 V                         | -0.5% | 8   | +0.5% |      |

(\*) FIRC frequency can be divided by 1/2/4/8.

# 4. Reset Timing Characteristics $(T_A = 25^{\circ}C)$

| Parameter                    | Conditions                     | Min | Тур  | Max | Unit |
|------------------------------|--------------------------------|-----|------|-----|------|
| <b>RESET</b> Input Low width | Input $V_{CC} = 5 V \pm 10 \%$ | 30  | _    | _   | μs   |
| WDT time                     | $V_{CC} = 3 V$ , WDTPSC = 11   |     | 1920 | -   |      |
| WDT time                     | $V_{CC} = 5 V$ , WDTPSC = 11   | _   | 1760 |     | ms   |
| WKT time                     | $V_{CC} = 3 V, WKTPSC = 11$    |     | 120  | _   |      |
| WKT time                     | $V_{CC} = 5 V, WKTPSC = 11$    | _   | 108  |     | ms   |
| CPU start up time            | $V_{CC} = 5 V$                 | -   | 24   | -   | ms   |

#### **5. LVR Circuit Characteristics** (TA = $25^{\circ}$ C)

| Parameter                     | Symbol            | Min | Тур  | Max | Unit |
|-------------------------------|-------------------|-----|------|-----|------|
| LVR Reference Voltage         |                   | -   | 2.2  | -   | V    |
|                               | LVR <sub>th</sub> | _   | 2.8  | -   |      |
|                               | LVK <sub>th</sub> | -   | 3.6  | -   |      |
|                               |                   | _   | 4.2  | _   |      |
| LVR Hysteresis Voltage        | V <sub>HYST</sub> | -   | ±0.1 | -   | V    |
| Low Voltage<br>Detection time | t <sub>LVR</sub>  | 100 | -    | -   | μs   |



| Parameter                                 | Conditions                                        | Min             | Тур  | Max        | Units |  |
|-------------------------------------------|---------------------------------------------------|-----------------|------|------------|-------|--|
| Total Accuracy                            |                                                   | -               | ±2.5 | ±13        |       |  |
| Integral Non-Linearity                    | $V_{CC} = 5V$ , $V_{SS} = 0V$ , $f_{ADC} = 1$ MHz | -               | ±3.2 | ±15        | LSB   |  |
| Differential Non-linearity                |                                                   | -               | ±1   | <u>±</u> 4 |       |  |
| Max Input Clock freq. (f <sub>ADC</sub> ) | Source impedance (Rs<10K omh)                     | -               | -    | 2          |       |  |
|                                           | Source impedance (Rs<20K omh)                     | -               | _    | 1          | MHz   |  |
|                                           | Source impedance (Rs<50K omh)                     | -               | -    | 0.5        | MHZ   |  |
|                                           | Source is VR (ADCHS=1101)                         | -               | -    | 2          |       |  |
| Conversion Time                           | $f_{ADC} = 1 MHz$                                 | _               | 50   | _          | μs    |  |
| Input Voltage                             | _                                                 | V <sub>ss</sub> | -    | Vcc        | V     |  |

### 6. ADC Electrical Characteristics ( $T_A = 25 \,^{\circ}C$ , $V_{CC} = 3.0V$ to 5.5V, $V_{SS} = 0V$ )

## 7. BCM Electrical Characteristics ( $T_A = 25 \,^{\circ}C$ , $V_{CC} = 5V$ , $V_{SS} = 0V$ )

| Parameter                         | Conditions                                                | Min | Тур | Max                  | Units  |
|-----------------------------------|-----------------------------------------------------------|-----|-----|----------------------|--------|
| Power supply V <sub>CC</sub>      | -                                                         | 2.2 | -   | 5.5                  | V      |
| OPA offset                        | After trim, OPA_input=2.5 V                               | -   | ±1  | -                    | mV     |
| OPA Vcm                           | -                                                         | 0.1 | -   | V <sub>CC</sub> -1.2 | V      |
| OPA IOL                           | $V_i = V_{CC}, V_{i+} = V_{SS}, T_{in} = 100 \text{ ohm}$ | -   | 20  | -                    | mA     |
| OPAAOL                            | RL=1M ohm, CL=100 pF                                      | 60  | 80  | -                    | dB     |
| OPA GBW                           | RL=1M ohm, CL=100 pF                                      | -   | 1   | -                    | MHz    |
| OPA SR                            | No load                                                   | -   | 1   | 2                    | V/usec |
| OPA current consumption           | V <sub>CC</sub> =5 V                                      | -   | -   | 150                  | uA     |
| DAC reference VR                  | V <sub>CC</sub> =5 V, internal LDO                        | -   | 3   | -                    | V      |
| DAC output range                  | VR=3 V                                                    | 0   | -   | 3                    | V      |
| DAC current consumption           | VCC=5 V                                                   | -   | 100 | 200                  | uA     |
| DAC Integral<br>Non-Linearity     | VCC=5 V, VSS=0 V, VR=3 V                                  | -   | ±2  | -                    | LCD    |
| DAC Differential<br>Non-Linearity | (DAC0DL >3Ch & DAC1DL >3Ch)                               | -   | ±2  | -                    | LSB    |
| DAC output impedance              | R-2R+R structure                                          | -   | 10  | -                    | Kohm   |

## 8. EEPROM Block Characteristics ( $T_A = 25 \text{ °C}$ , $V_{CC} = 5V$ , $V_{SS} = 0V$ )

| Parameter              | Conditions      | Min | Тур | Max    | Units  |
|------------------------|-----------------|-----|-----|--------|--------|
| Read Voltage           | VCC             | 1.8 | _   | 5.5    | V      |
| Write Voltage          | VCC             | 2.7 | -   | 5.5    | V      |
| Write Current          | _               | -   | 5   | 30     | mA     |
| Write Time             | Byte Write Time | -   | 0.7 | _      | ms     |
| Endurance (Byte Write) | _               | _   | -   | 50,000 | cycles |



### 9. Electrical Characteristics Graphs

















## PACKAGING INFORMATION

Please note that the package information provided is for reference only. Since this information is frequently updated, users can contact Sales to consult the latest package information and stocks.

The ordering information:

| Ordering number  | Package                 |
|------------------|-------------------------|
| TM56F8225-MTP    | Wafer / Dice blank chip |
| TM56F8225-COD    | Wafer / Dice with code  |
| TM56F8225-MTP-16 | SOP 16-pin (150 mil)    |
| TM56F8225-MTP-03 | DIP 16-pin (300 mil)    |



### **16-SOP Package Dimension**



| SYMBOL | DI          | DIMENSION IN MM |             | DIMENSION IN INCH |        |             |  |
|--------|-------------|-----------------|-------------|-------------------|--------|-------------|--|
|        | MIN         | NOM             | MAX         | MIN               | NOM    | MAX         |  |
| А      | 1.35        | 1.55            | 1.75        | 0.0532            | 0.0610 | 0.0688      |  |
| A1     | 0.10        | 0.18            | 0.25        | 0.0040            | 0.0069 | 0.0098      |  |
| В      | 0.33        | 0.42            | 0.51        | 0.0130            | 0.0165 | 0.0200      |  |
| С      | 0.19        | 0.22            | 0.25        | 0.0075            | 0.0087 | 0.0098      |  |
| D      | 9.80        | 9.90            | 10.00       | 0.3859            | 0.3898 | 0.3937      |  |
| Е      | 5.80        | 6.00            | 6.20        | 0.2284            | 0.2362 | 0.2440      |  |
| E1     | 3.80        | 3.90            | 4.00        | 0.1497            | 0.1536 | 0.1574      |  |
| e      | 1.27 BSC    |                 |             | 0.050 BSC         |        |             |  |
| h      | 0.25        | 0.38            | 0.50        | 0.0099            | 0.0148 | 0.0196      |  |
| L      | 0.40        | 0.84            | 1.27        | 0.0160            | 0.0330 | 0.0500      |  |
| θ      | $0^{\circ}$ | $4^{\circ}$     | $8^{\circ}$ | 0°                | 4°     | $8^{\circ}$ |  |
| JEDEC  | MS-012 (AC) |                 |             |                   |        |             |  |

\* NOTES : DIMENSION " D" DOES NOT INCLUDE MOLD FLASH, PROTRUSIONS OR GATE BURRS. MOLD FLASH, PROTRUSIONS AND GATE BURRS SHALL NOT EXCEED 0.15 MM ( 0.006 INCH ) PER SIDE.

98



#### **16-DIP Package Dimension**





| SYMBOL         | DIMENSION IN MM DIMENS |        |        | MENSION IN IN | SION IN INCH |       |  |
|----------------|------------------------|--------|--------|---------------|--------------|-------|--|
|                | MIN                    | NOM    | MAX    | MIN           | NOM          | MAX   |  |
| А              | -                      | -      | 4.369  | -             | -            | 0.172 |  |
| A1             | 0.381                  | 0.673  | 0.965  | 0.015         | 0.027        | 0.038 |  |
| A2             | 3.175                  | 3.302  | 3.429  | 0.125         | 0.130        | 0.135 |  |
| D              | 18.669                 | 19.177 | 19.685 | 0.735         | 0.755        | 0.775 |  |
| Е              | 7.620 BSC              |        |        |               | 0.300 BSC    |       |  |
| E1             | 6.223                  | 6.350  | 6.477  | 0.245         | 0.250        | 0.255 |  |
| L              | 2.921                  | 3.366  | 3.810  | 0.115         | 0.133        | 0.150 |  |
| е <sub>В</sub> | 8.509                  | 9.017  | 9.525  | 0.335         | 0.355        | 0.375 |  |
| θ              | $0^{\circ}$            | 7.5°   | 15°    | 0°            | 7.5°         | 15°   |  |
| JEDEC          | MS-001 (BB)            |        |        |               |              |       |  |

NOTES :

1. "D", "EI" DIMENSIONS DO NOT INCLUDE MOLD FLASH OR PROTRUSIONS. MOLD FLASH OR PROTRUSIONS SHALL NOTEXCEED .010 INCH.

2. eB IS MEASURED AT THE LEAD TIPS WITH THE LEADS UNCONSTRAINED.

3. POINTED OR ROUNDED LEAD TIPS ARE PREFERRED TO EASE INSERTION.

4. DISTANCE BETWEEN LEADS INCLUDING DAM BAR PROTRUSIONS TO BE .005 INCH MININUM.

5. DATUM PLANE III COINCIDENT WITH THE BOTTOM OF LEAD, WHERE LEAD EXITS BODY.