

# NY8BE64A

## 18 I/O, 13-ch ADC

## 8-bit EPROM-Based MCU

# DATA SHEET

#### Version 1.0

#### Jun. 30, 2022

NYQUEST TECHNOLOGY CO. reserves the right to change this document without prior notice. Information provided by NYQUEST is believed to be accurate and reliable. However, NYQUEST makes no warranty for any errors which may appear in this document. Contact NYQUEST to obtain the latest version of device specifications before placing your orders. No responsibility is assumed by NYQUEST for any infringement of patent or other rights of third parties which may result from its use. In addition, NYQUEST products are not authorized for use as critical components in life support devices/systems or aviation devices/systems, where a malfunction or failure of the product may reasonably be expected to result in significant injury to the user, without the express written approval of NYQUEST.

#### **Revision History**

| Version | Date       | Description    | Modified Page |
|---------|------------|----------------|---------------|
| 1.0     | 2022/06/30 | First release. |               |

### **Table of Contents**

| 1. | 概述.                |                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9                                                                                                        |
|----|--------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
|    | 1.1                | 功能                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9                                                                                                        |
| 1. | Gene               | ral Desc                                                                                                      | ription                                                                                                                                                                                                                                                                                                                                                                                                                         | 12                                                                                                       |
|    | 1.1                | Features                                                                                                      | 3                                                                                                                                                                                                                                                                                                                                                                                                                               | 12                                                                                                       |
|    | 1.2                | Block Dia                                                                                                     | agram                                                                                                                                                                                                                                                                                                                                                                                                                           | 15                                                                                                       |
|    | 1.3                | Pin Assig                                                                                                     | gnment                                                                                                                                                                                                                                                                                                                                                                                                                          | 16                                                                                                       |
|    | 1.4                | Pin Desc                                                                                                      | -<br>cription                                                                                                                                                                                                                                                                                                                                                                                                                   | 17                                                                                                       |
| 2. | Memo               | orv Orga                                                                                                      | nization                                                                                                                                                                                                                                                                                                                                                                                                                        | 19                                                                                                       |
|    | 2.1                |                                                                                                               | n Memory                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                          |
|    | 2.2                | ·                                                                                                             | mory                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                          |
|    | 2.3                | EEPRON                                                                                                        | M Memory                                                                                                                                                                                                                                                                                                                                                                                                                        | 23                                                                                                       |
|    |                    | 2.3.1                                                                                                         | EEA (EEPROM Address Register)                                                                                                                                                                                                                                                                                                                                                                                                   | 25                                                                                                       |
|    |                    | 2.3.2                                                                                                         | EED (EEPROM Data Register)                                                                                                                                                                                                                                                                                                                                                                                                      | 25                                                                                                       |
|    |                    | 2.3.3                                                                                                         | EEPL (EEPROM write protect Register)                                                                                                                                                                                                                                                                                                                                                                                            | 25                                                                                                       |
|    |                    | 2.3.4                                                                                                         | EETO (EEPROM Time-Out Register)                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                          |
|    |                    |                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                          |
| 3. | Funct              | tion Des                                                                                                      | cription                                                                                                                                                                                                                                                                                                                                                                                                                        | 27                                                                                                       |
| 3. | <b>Func</b><br>3.1 |                                                                                                               | <b>cription</b><br>Special Function Register                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                          |
| 3. |                    |                                                                                                               | •                                                                                                                                                                                                                                                                                                                                                                                                                               | 27                                                                                                       |
| 3. |                    | R-page \$                                                                                                     | Special Function Register                                                                                                                                                                                                                                                                                                                                                                                                       | 27<br>27                                                                                                 |
| 3. |                    | R-page \$<br>3.1.1                                                                                            | Special Function Register                                                                                                                                                                                                                                                                                                                                                                                                       | 27<br>27<br>27                                                                                           |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2                                                                                   | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)                                                                                                                                                                                                                                                                                                                                      | 27<br>27<br>27<br>27<br>27                                                                               |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3                                                                          | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])                                                                                                                                                                                                                                                                                                        | 27<br>27<br>27<br>27<br>27<br>28                                                                         |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4                                                                 | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])<br>STATUS (Status Register)                                                                                                                                                                                                                                                                            | 27<br>27<br>27<br>27<br>27<br>28<br>28                                                                   |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5                                                        | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])<br>STATUS (Status Register)<br>FSR (Register File Selection Register)                                                                                                                                                                                                                                  | 27<br>27<br>27<br>27<br>28<br>28<br>28<br>29                                                             |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5<br>3.1.6                                               | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])<br>STATUS (Status Register)<br>FSR (Register File Selection Register)<br>PortA (PortA Data Register)                                                                                                                                                                                                   | 27<br>27<br>27<br>27<br>28<br>28<br>28<br>28<br>29<br>29                                                 |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5<br>3.1.6<br>3.1.7                                      | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])<br>STATUS (Status Register)<br>FSR (Register File Selection Register)<br>PortA (PortA Data Register)<br>PortB (PortB Data Register)                                                                                                                                                                    | 27<br>27<br>27<br>27<br>28<br>28<br>28<br>29<br>29<br>29                                                 |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5<br>3.1.6<br>3.1.7<br>3.1.8                             | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])<br>STATUS (Status Register)<br>FSR (Register File Selection Register)<br>PortA (PortA Data Register)<br>PortB (PortB Data Register)<br>PortC (PortC Data Register)                                                                                                                                     | 27<br>27<br>27<br>27<br>27<br>28<br>28<br>29<br>29<br>29<br>29<br>29                                     |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5<br>3.1.6<br>3.1.7<br>3.1.8<br>3.1.9                    | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])<br>STATUS (Status Register)<br>STATUS (Status Register)<br>FSR (Register File Selection Register)<br>PortA (PortA Data Register)<br>PortB (PortB Data Register)<br>PortC (PortC Data Register)<br>PCON (Power Control Register)                                                                        | 27<br>27<br>27<br>27<br>27<br>28<br>28<br>29<br>29<br>29<br>29<br>29<br>29<br>29<br>29<br>29<br>         |
| 3. |                    | R-page \$<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5<br>3.1.6<br>3.1.7<br>3.1.8<br>3.1.9<br>3.1.10          | Special Function Register                                                                                                                                                                                                                                                                                                                                                                                                       | 27<br>27<br>27<br>27<br>27<br>28<br>28<br>29<br>29<br>29<br>29<br>29<br>29<br>29<br>29<br>29<br>30<br>30 |
| 3. |                    | R-page 3<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5<br>3.1.6<br>3.1.7<br>3.1.8<br>3.1.9<br>3.1.10<br>3.1.11 | Special Function Register<br>INDF (Indirect Addressing Register)<br>TMR0 (Timer0 Register)<br>PCL (Low Byte of PC[11:0])<br>STATUS (Status Register)<br>STATUS (Status Register)<br>FSR (Register File Selection Register)<br>PortA (PortA Data Register)<br>PortB (PortB Data Register)<br>PortC (PortC Data Register)<br>PCON (Power Control Register)<br>BWUCON (PortB Wake-up Control Register)<br>PCHBUF (High Byte of PC) | 27<br>27<br>27<br>27<br>28<br>28<br>28<br>29<br>29<br>29<br>29<br>29<br>29<br>30<br>30<br>31             |

|     | 3.1.15   | INTE (Interrupt Enable Register)                                | . 31 |
|-----|----------|-----------------------------------------------------------------|------|
|     | 3.1.16   | INTF (Interrupt Flag Register)                                  | . 32 |
|     | 3.1.17   | ADMD (ADC mode Register)                                        | . 33 |
|     | 3.1.18   | ADR (ADC clock, ADC interrupt flag and ADC LSB output Register) | . 34 |
|     | 3.1.19   | ADD (ADC output data Register)                                  | . 34 |
|     | 3.1.20   | ADVREFH (ADC high reference voltage Register)                   | . 34 |
|     | 3.1.21   | ADCR (Sampling pulse and ADC bit Register)                      | . 35 |
|     | 3.1.22   | AWUCON (PortA Wake-up Control Register)                         | . 35 |
|     | 3.1.23   | PACON (ADC analog pin Register)                                 | . 35 |
|     | 3.1.23   | ADJMD (ADC analog pin Register)                                 | . 36 |
|     | 3.1.24   | INTEDG (Interrupt Edge Register)                                | . 36 |
|     | 3.1.25   | TMRH (Timer High Byte Register)                                 | . 37 |
|     | 3.1.26   | ANAEN (Analog Circuit Enable Register)                          | . 37 |
|     | 3.1.27   | RFC (RFC Register)                                              | . 37 |
|     | 3.1.28   | TM4RH (Timer4 High Byte Register)                               | . 38 |
|     | 3.1.29   | OSCCAL (Internal Oscillator Calibration)                        | . 38 |
|     | 3.1.30   | INTE2 (Interrupt Enable and Flag 2nd. Register)                 | . 39 |
| 3.2 | T0MD Re  | egister                                                         | .39  |
| 3.3 | F-page S | pecial Function Register                                        | .41  |
|     | 3.3.1    | IOSTA (PortA I/O Control Register)                              | . 41 |
|     | 3.3.2    | IOSTB (PortB I/O Control Register)                              | . 41 |
|     | 3.3.3    | IOSTC (PortC I/O Control Register)                              | . 41 |
|     | 3.3.4    | APHCON (PortA Pull-High Resistor Control Register)              | . 41 |
|     | 3.3.5    | PS0CV (Prescaler0 Counter Value Register)                       | . 42 |
|     | 3.3.6    | CPLCON (PortC Pull-Low Resistor Control Register)               | . 42 |
|     | 3.3.7    | BODCON (PortB Open-Drain Control Register)                      | . 42 |
|     | 3.3.8    | CODCON (PortC Open-Drain Control Register)                      | . 42 |
|     | 3.3.9    | CMPCR (Comparator voltage select Control Register)              | . 43 |
|     | 3.3.10   | PCON1 (Power Control Register1)                                 | . 44 |
| 3.4 | S-page S | Special Function Register                                       | .45  |
|     | 3.4.1    | TMR1 (Timer1 Register)                                          | . 45 |
|     | 3.4.2    | T1CR1 (Timer1 Control Register1)                                | . 45 |
|     | 3.4.3    | T1CR2 (Timer1 Control Register2)                                | . 46 |
|     | 3.4.4    | PWM1DUTY (PWM1 Duty Register)                                   | . 47 |
|     | 3.4.5    | PS1CV (Prescaler1 Counter Value Register)                       | . 47 |
|     | 3.4.6    | BZ1CR (Buzzer1 Control Register)                                | . 47 |
|     |          |                                                                 |      |

|     | 3.4.7    | IRCR (IR Control Register)                                   | . 48 |
|-----|----------|--------------------------------------------------------------|------|
|     | 3.4.8    | TBHP (Table Access High Byte Address Pointer Register)       | . 49 |
|     | 3.4.9    | TBHD (Table Access High Byte Data Register)                  | . 49 |
|     | 3.4.10   | P2CR1 (PWM2 Control Register1)                               | . 49 |
|     | 3.4.11   | PWM2DUTY (PWM2 Duty Register)                                | . 50 |
|     | 3.4.12   | OSCCR (Oscillation Control Register)                         | . 50 |
|     | 3.4.13   | P3CR1 (PWM3 Control Register1)                               | . 51 |
|     | 3.4.14   | PWM3DUTY (PWM3 Duty Register)                                | . 51 |
|     | 3.4.15   | TMR4 (Timer4 Register)                                       | . 51 |
|     | 3.4.16   | 4CR1 (Timer4 Control Register1)                              | . 52 |
|     | 3.4.17   | T4CR2 (Timer4 Control Register2)                             | . 53 |
|     | 3.4.18   | PWM4DUTY (PWM4 Duty Register)                                | . 54 |
|     | 3.4.19   | PS4CV (Prescaler4 Counter Value Register)                    | . 54 |
|     | 3.4.20   | TMR5 (Timer5 Register)                                       | . 54 |
|     | 3.4.21   | T5CR1 (Timer5 Control Register1)                             | . 54 |
|     | 3.4.22   | T5CR2 (Timer5 Control Register2)                             | . 55 |
|     | 3.4.23   | PWM5DUTY (PWM5 Duty Register)                                | . 56 |
|     | 3.4.24   | PS5CV (Prescaler5 Counter Value Register)                    | . 56 |
|     | 3.4.25 T | M5RH (Timer5 High Byte Register)                             | . 57 |
| 3.5 | T-page S | pecial Function Register                                     | .57  |
|     | 3.5.1    | SIMCR (Serial interface Mode Control Register )              | . 57 |
|     | 3.5.2    | MADR (IIC mode Address register )                            | . 58 |
|     | 3.5.3    | MFDR (IIC mode frequency register )                          | . 58 |
|     | 3.5.4    | MCR (IIC mode control register )                             | . 59 |
|     | 3.5.5    | MSR (IIC mode status register )                              | . 59 |
|     | 3.5.6    | SIMDR (Serial interface mode data register )                 | . 60 |
|     | 3.5.7    | SPCR (SPI control & status register )                        | . 61 |
|     | 3.5.8    | INTE3 (Interrupt Enable 3th Register )                       | . 62 |
|     | 3.5.9    | INTF3 (Interrupt Flag 3th Register )                         | . 62 |
|     | 3.5.10   | THR/RBR (Transmit holding register /Receive Buffer Register) | . 63 |
|     | 3.5.11   | LCR (Line Control Register)                                  | . 63 |
|     | 3.5.12   | LSR (Line Status Register)                                   | . 65 |
|     | 3.5.13   | DLL (Baud Rate Divisor Latch LSB Register)                   | . 65 |
|     | 3.5.14   | DLH (Baud Rate Divisor Latch MSB Register)                   | . 65 |
|     | 3.5.15   | CCPCON (CCP Control Register)                                | . 66 |
|     | 3.5.16   | PWMDB (PWM Dead Band Control Register)                       | . 67 |

| 3.6  | I/O Port . |                                                          | 68    |
|------|------------|----------------------------------------------------------|-------|
|      | 3.6.1      | Block Diagram of IO Pins                                 | 70    |
| 3.7  | Timer0     |                                                          | 83    |
| 3.8  | Timer1 /   | PWM1 / Buzzer1/ PWM2 /PWM3                               | 84    |
| 3.9  | PWM2.      |                                                          | 86    |
| 3.10 | PWM3.      |                                                          | 87    |
| 3.11 | Timer4 /   | PWM4                                                     | 88    |
| 3.12 | Timer5 /   | PWM5                                                     | 90    |
| 3.13 | CCP Mod    | de                                                       | 92    |
|      | 3.13.1     | Capture Mode                                             |       |
|      | 3.13.2     | Compare Mode                                             |       |
|      | 3.13.3     | CCP PWM Mode                                             |       |
| 3.14 | RFC Mod    | de                                                       | 95    |
| 3.15 | IR Carrie  | r                                                        | 96    |
| 3.16 | Low Volta  | age Detector (LVD)                                       | 97    |
| 3.17 | Voltage (  | Comparator                                               | 99    |
|      | 3.17.1     | Comparator Reference Voltage (Vref)                      | 99    |
| 3.18 | Analog-to  | p-Digital Convertor (ADC)                                |       |
|      | 3.18.1     | ADC reference voltage                                    | . 102 |
|      | 3.18.2     | ADC analog input channel                                 | . 103 |
|      | 3.18.3     | ADC clock (ADCLK), sampling clock (SHCLK) and bit number | . 104 |
|      | 3.18.4     | ADC offset calibration                                   | . 105 |
|      | 3.18.5     | ADC operation                                            | . 105 |
| 3.19 | Watch-D    | og Timer (WDT)                                           | .105  |
| 3.20 | Interrupt  |                                                          | .106  |
|      | 3.20.1     | Timer0 Overflow Interrupt                                | . 107 |
|      | 3.20.2     | Timer1 Underflow Interrupt                               | . 107 |
|      | 3.20.3     | Timer4 Underflow Interrupt                               | . 107 |
|      | 3.20.4     | Timer5 Underflow/CCP Interrupt (Not Support)             | . 107 |
|      | 3.20.5     | WDT Timeout Interrupt                                    | . 107 |
|      | 3.20.6     | PA/PB Input Change Interrupt                             | . 107 |
|      | 3.20.7     | External 0 Interrupt                                     | . 108 |
|      | 3.20.8     | External 1 Interrupt                                     |       |
|      | 3.20.9     | External 2 Interrupt                                     | . 108 |

|    |        | 3.20.10    | LVD Interrupt                             | 108 |
|----|--------|------------|-------------------------------------------|-----|
|    |        | 3.20.11    | Comparator Output Status Change Interrupt | 108 |
|    |        | 3.20.12    | ADC end of conversion Interrupt           | 108 |
|    |        | 3.20.13    | EEPROM write complete Interrupt           | 108 |
|    |        |            | ERAIL interface mode interrupt            |     |
|    | 3.21   | Oscillatio | on Configuration                          | 109 |
|    | 3.22   | Operatin   | g Mode                                    | 112 |
|    |        | 3.22.1     | Normal Mode                               |     |
|    |        | 3.22.2     | Slow Mode                                 |     |
|    |        | 3.22.3     | Standby Mode                              |     |
|    |        | 3.22.4     | Halt Mode                                 | 114 |
|    |        | 3.22.5     | Wake-up Stable Time                       | 114 |
|    |        | 3.22.6     | Summary of Operating Mode                 | 115 |
|    | 3.23   | Reset Pr   | ocess                                     | 115 |
|    | 3.24   | SPI MOI    | DE                                        | 117 |
|    |        | 3.24.1 S   | Serial Clock Polarity and Phase           | 119 |
|    |        | 3.24.2 S   | PI error Conditions                       | 120 |
|    | 3.25   | IIC MOE    | DE                                        | 121 |
|    |        | 3.25.1 II  | C MODE protocol                           | 122 |
|    |        | 3.25.2 II  | C MODE operating                          | 123 |
|    |        | 3.25.3 A   | rbitration Lost                           | 124 |
|    | 3.26   | UART       |                                           | 125 |
|    | 3.27   | On-Chip    | Debug (OCD)                               | 126 |
|    |        | 3.27.1     | Function Description                      | 126 |
|    |        | 3.27.2     | Limitation of OCD                         | 126 |
| 4. | Instru | ction Se   | et                                        |     |
| 5  | Confi  | nuration   | Words                                     | 144 |
|    |        | -          |                                           |     |
| 6. |        |            | racteristics                              |     |
|    | 6.1    | Absolute   | Maximum Rating                            | 146 |
|    | 6.2    | DC Char    | acteristics                               | 146 |
|    | 6.3    | Compara    | ator / LVD Characteristics                | 148 |
|    | 6.4    | ADC Cha    | aracteristics                             | 148 |
|    | 6.5    | Characte   | eristic Graph                             | 149 |

|    |       | 6.5.1      | Frequency vs. $V_{DD}$ of I_HRC and I_LRC            | 149 |
|----|-------|------------|------------------------------------------------------|-----|
|    |       | 6.5.2      | Frequency vs. Temperature of I_HRC and I_LRC         | 149 |
|    |       | 6.5.5      | Low Dropout Regulator vs. $V_{DD}$                   | 150 |
|    |       | 6.5.6      | Low Dropout Regulator vs. Temperature                | 150 |
|    |       | 6.5.7      | Pull High Resistor vs. V <sub>DD</sub>               | 151 |
|    |       | 6.5.8      | Pull High Resistor vs. Temperature                   | 151 |
|    |       | 6.5.9      | V <sub>IH</sub> /V <sub>IL</sub> vs. V <sub>DD</sub> | 152 |
|    |       | 6.5.10     | V <sub>IH</sub> /V <sub>IL</sub> vs. Temperature     | 153 |
|    | 6.6   | Recomm     | ended Operating Voltage                              | 154 |
|    | 6.7   | LVR vs.    | Temperature                                          | 154 |
|    | 6.8   | LVD vs.    | Temperature                                          | 154 |
| 7. | Packa | age Dime   | nsion                                                | 155 |
|    | 7.1   | 16-Pin P   | lastic SOP (150 mil)                                 | 155 |
|    | 7.2   | 20-Pin P   | lastic SOP (300 mil)                                 | 155 |
| 8. | Order | ring Infor | mation                                               | 155 |

#### 1. 概述

NY8BE64A 是以MTP作為程式記憶體,並以EEPROM作為非揮發性資料記憶體的 8 位元微控制器,專為家電或量測 等等的I/O應用設計。採用CMOS製程並同時提供客戶低成本、高性能、及高抗電磁干擾等顯著優勢。NY8BE64A 核 心建立在RISC精簡指令集架構可以很容易地做編輯和控制,共有 55 條指令。除了少數指令需要 2 個時序,大多數指 令都是 1 個時序即能完成,可以讓使用者輕鬆地以程式控制完成不同的應用。因此非常適合各種中低記憶容量但又複 雜的應用。

NY8BE64A 內建高精度十二加二通道十二位元類比數位轉換器,與高精度電壓比較器,足以應付各種類比介面的偵測 與量測。

在I/O的資源方面,NY8BE64A 有 18 根彈性的雙向I/O腳,每個I/O腳都有單獨的暫存器控制為輸入或輸出腳。而且每 一個I/O腳位都有附加的程式控制功能如上拉或下拉電阻或開漏極(Open-Drain)輸出。此外針對紅外線搖控的產品方 面,NY8BE64A內建了可選擇頻率的大電流輸出紅外載波發射口(PA3)。

NY8BE64A 有四組計時器,可用系統頻率當作一般的計時的應用或者從外部訊號觸發來計數。另外NY8BE64A 提供 5 組 10 位元解析度的PWM輸出,1 組蜂鳴器輸出可用來驅動馬達、LED、或蜂鳴器等等。NY8BE64A的計時器同時 具有捕捉/比較/可編程死區時間的增強型PWM模塊(ECCP)

NY8BE64A 採用雙時鐘機制,高速振盪或者低速振盪都可以分別選擇內部RC振盪或外部Crystal輸入。在雙時鐘機制下,NY8BE64A 可選擇多種工作模式如正常模式(Normal)、慢速模式(Slow mode)、待機模式(Standby mode) 與睡眠 模式(Halt mode)可節省電力消耗延長電池壽命。並且微控制器在使用內部RC高速振盪時,低速振盪可以同時使用外 部精準的Crystal計時。可以維持高速處理同時又能精準計算真實時間。

在省電的模式下如待機模式(Standby mode) 與睡眠模式(Halt mode)中,有多種事件可以觸發中斷喚醒NY8BE64A 進入正常操作模式(Normal) 或 慢速模式(Slow mode) 來處理突發事件。

NY8BE64A內建除錯仿真電路,利用兩個脚位與很少的外接硬體,就能實現在線仿真器的大多數功能,例如設定程式 執行條件與中斷條件,片上單步執行,以及查看及設定各種暫存器的內容。仿真的執行效果將比一般的仿真器更接近 實際IC運作。

NY8BE64A內建的一組變頻振盪器,能彈性選擇輸出頻率區段,以適用於多樣的霧化器元件,更可以程式細調輸出頻率, 細度足以應付霧化器的元件偏差。

#### 1.1 功能

- 寬廣的工作電壓:
  - > 3.3V ~ 5.5V @ FINST = 8MHz •
  - $\succ~$  2.2 V ~ 5.5V @ Finst  ${<}\,4MHz$   ${\circ}$
- 寬廣的工作温度:-40°C~85°C。
- 超過 **±8KV** 的ESD。
- 雜訊過濾功能(Noise Filter) 打開時可容忍超過 ±4KV 的EFT。(操作電壓@5V)
- 4Kx14 bits MTP •

- 288 bytes SRAM •
- 256 bytes EEPROM。(一萬次讀寫)
- 18 根可分別單獨控制輸入輸出方向的I/O腳(GPIO)、PA[7:0]、PB[7:0]、PC[1:0]。
- PA[5:0]、PB[3:0] 及 PC[1:0]可選擇輸入時使用內建下拉電阻。
- PA[7:0]、PB[7:0] 及 PC[1:0]可選擇輸入時使用上拉電阻。
- PB[7:0]、PC[1:0]可選擇開漏極輸出(Open-Drain)。
- 所有I/O腳輸出可選擇小灌電流(Small Sink Current) 或一般灌電流(Normal Sink Current)或大灌電流(Large Sink Current)。PA[4]可另外選擇Ultra Sink Current。
- 所有I/O腳輸出可選擇小推電流(Small Drive Current)或一般推電流(Normal Drive Current)。PA[4]可另外選擇 Ultra Drive Current。
- 8 層程式堆棧(Stack)。
- 存取資料有直接或間接定址模式。
- 一組 8 位元上數計時器(Timer0)包含可程式化的頻率預除線路。
- 三組 10 位元下數計時器(Timer1, 4, 5)可選重複載入或連續下數計時。
- 五個 10 位元脈衝寬度調變(PWM1, 2, 3, 4, 5)。
- 一個蜂鳴器輸出(BZ1)。
- 38/57KHz紅外線載波頻率可供選擇,同時載波之極性也可以根據數據作選擇。
- 大電流輸出紅外線載波發射口。
- 內建準確的低電壓偵測電路(LVD)。
- 內建十二加二通道 12 位元類比數位轉換器(Analog to Digital Converter)。
- 內建準確的電壓比較器(Voltage Comparator)。
- 內建上電復位電路(POR)。
- 內建低壓復位功能(LVR)。
- 內建看門狗計時(WDT),可由程式韌體控制開關。
- 內建電阻頻率轉換器(RFC)功能。
- 雙時鐘機制,系統可以隨時切換高速振盪或者低速振盪。
  - ▶ 高速振盪: E\_HXT (超過 6MHz外部高速石英振盪)
    E\_XT (455K~6MHz外部石英振盪)

I\_HRC (1~20MHz内部高速RC振盪)

- K速振盪: E\_LXT (32KHz外部低速石英振盪)
   I\_LRC (內部 32KHz低速RC振盪)
- 四種工作模式可隨系統需求調整電流消耗:正常模式(Normal)、慢速模式(Slow mode)、待機模式(Standby mode) 與 睡眠模式(Halt mode)。

- 十三種硬體中斷:
  - ➤ Timer0 溢位中斷。
  - ➤ Timer1 借位中斷。
  - ➤ Timer4 借位中斷。
  - > Timer5 借位中斷/CCPI 中斷。
  - ≻ WDT 中斷。
  - > PA/PB 輸入狀態改變中斷。
  - > 三組外部中斷輸入。
  - ▶ 低電壓偵測中斷。
  - > 比較器輸出轉態中斷。
  - > 類比數位轉換完成中斷。
  - ▶ 串接介面模組(SIM)中斷
  - > UART 介面模組讀或寫中斷。
  - ≻ EE中斷。
- NY8BE64A在待機模式(Standby mode)下的十一種喚醒中斷:
  - ➤ Timer0 溢位中斷。
  - ➤ Timer1 借位中斷。
  - ➤ Timer4 借位中斷。
  - ➤ Timer5 借位中斷。
  - ➤ WDT 中斷。
  - > PA/PB 輸入狀態改變中斷。
  - ▶ 三組外部中斷輸入。
  - ▶ 低電壓偵測中斷。
  - ▶ 比較器輸出轉態中斷。
  - > 類比數位轉換完成中斷。
  - ▶ 串接介面模組(SIM)中斷
- NY8BE64A在睡眠模式(Halt mode)下的三種喚醒中斷:
  - ➤ WDT 中斷。
  - > PA/PB 輸入狀態改變中斷。
  - ▶ 三組外部中斷輸入。
- 內建變頻振盪器(V\_HRC) 提供 32MHz/20.8MHz/16MHz/13.6MHz 四種選擇。可微調精度至 ±0.1%。
- 內建二線控制的除錯仿真電路(On Chip Debug)。

#### 1. General Description

NY8BE64A is a MTP based 8-bit MCU with EEPROM data memory built-in, tailored for I/O based applications like home appliances or meter equipment. NY8BE64A adopts advanced CMOS technology to provide customers remarkable solution with low cost, high performance and high noise immunity benefits. RISC architecture is applied to NY8BE64A and it provides 55 instructions. All instructions are executed in single instruction cycle except program branch and skip instructions which will take two instruction cycles. Therefore, NY8BE64A is very suitable for those applications that are sophisticated but compact program size is required.

NY8BE64A provides 12 + 2 channel high-precision 12-bit analog-to-digital converter (ADC), and high-precision analog voltage comparator. They are suitable for any analog interface detection and measurement applications.

As NY8BE64A address I/O type applications, it can provide 18 I/O pins for applications which require abundant input and output functionality. Moreover, each I/O pin may have additional features, like Pull-High/Pull-Low resistor and open-drain output type through programming. Moreover, NY8BE64A has built-in large infrared (IR) carrier generator with selectable IR carrier frequency and polarity for applications which demand remote control feature.

NY8BE64A also provides 3 sets of timers which can be used as regular timer based on system oscillation or event counter with external trigger clock. Moreover, NY8BE64A provides 5 sets of 10-bit resolution Pulse Width Modulation (PWM) output and 1 sets of buzzer output in order to drive motor/LED and buzzer.

NY8BE64A employs dual-clock oscillation mechanism, either high oscillation or low oscillation can be derived from internal resistor/capacitor oscillator or external crystal oscillator. Moreover, based on dual-clock mechanism, NY8BE64A provides kinds of operation mode like Normal mode, Slow mode, Standby mode and Halt mode in order to save power consumption and lengthen battery operation life. Moreover, it is possible to use internal high-frequency oscillator as CPU operating clock source and external 32KHz crystal oscillator as timer clock input, so as to accurate count real time and maintain CPU working power.

While NY8BE64A operates in Standby mode and Halt mode, kinds of event will issue interrupt requests and can wake-up NY8BE64A to enter Normal mode and Slow mode in order to process urgent events.

NY8BE64A provide on-chip debug (OCD) facilities as a low cost alternative to ICE. With OCD and a minimum of extra hardware, NY8BE62D can do ICE tasks such as free running, single stepping, break point setting and internal ram/register accessing.

NY8BE64A built-in a variable high speed oscillator can be optioned for different center frequency. Users can adjust this frequency in the program in a very small frequency step. With this feature ensures that NY8BE64A will find excellent use in different ultrasonic nebulizer applications.

#### 1.1 Features

- Wide operating voltage range:
  - > 3.3V ~ 5.5V @ F<sub>INST</sub> = 8MHz ·
  - $\succ$  2.2V ~ 5.5V @ F\_INST  ${<}$  4MHz  ${\scriptstyle \circ}$

- Wide operating temperature: -40°C ~ 85°C.
- High ESD over ±8KV.
- High EFT over ±4KV with Noise Filter Enable. (operating voltage @5V)
- 4K x 14 bits MTP.
- 288 bytes SRAM.
- 256 bytes EEPROM. (Endurance: 10,000 times)
- 18 general purpose I/O pins (GPIO), PA[7:0], PB[7:0], PC[1:0] with independent direction control.
- PA[5, 3:0] and PB[3:0] and PC[1:0] have features of Pull-Low resistor for input pin.
- PA[7:0] and PB[7:0] and PC[1:0] have features of Pull-High resistor, the value of Pull-High resistor can be 100KΩ or 1MΩ. (PA5 is about 80KΩ)
- PB[7:0] and PC[1:0] have features of Open-Drain output.
- I/O ports output current mode can be small sink, normal sink or large sink. PA[4] cab be ultra sink current mode.
- I/O ports output current mode can be small drive, normal drive. PA[4] cab be ultra drive current mode.
- 8-level hardware Stack.
- Direct and indirect addressing modes for data access.
- One 8-bit up-count timer (Timer0) with programmable prescaler.
- Three 10-bit reload or continuous down-count timers (Timer1, 4, 5).
- Five 10-bit resolution PWM (PWM1, 2, 3, 4, 5) output.
- One buzzer (BZ1) output.
- Selectable 38/57KHz IR carrier frequency and high/low polarity according to data value.
- Built-in high-precision Low-Voltage Detector (LVD).
- Built-in 12+2 channel high-precision 12-bit ADC.
- Built-in high-precision Voltage Comparator.
- Built-in Power-On Reset (POR).
- Built-in Low-Voltage Reset (LVR).
- Built-in Watch-Dog Timer (WDT) enabled/disabled by firmware control.
- Built-in Resistance to Frequency Converter (RFC) function.
- Dual-clock oscillation: System clock can switch between high oscillation and low oscillation.
  - > High oscillation: E\_HXT (External High Crystal Oscillator, above 6MHz)

E\_XT (External Crystal Oscillator, 455K~6MHz)

I\_HRC (Internal High Resistor/Capacitor Oscillator ranging from 1M~20MHz)

> Low oscillation: E\_LXT (External Low Crystal Oscillator, about 32KHz)

I\_LRC (Internal 32KHz oscillator)

- Four kinds of operation mode to reduce system power consumption:
  - > Normal mode, Slow mode, Standby mode and Halt mode.
- Thirteen hardware interrupt events:
  - > Timer0 overflow interrupt.
  - > Timer1 underflow interrupt.
  - > Timer4 underflow interrupt.
  - > Timer5 underflow interrupt.
  - > WDT timeout interrupt.
  - > PA/PB input change interrupt.
  - > 3 set External interrupt.
  - > LVD interrupt.
  - > Comparator output status change interrupt.
  - > ADC end-of-convert interrupt.
  - > Serial Interface Module (SIM)interrupt.
  - > UART interface module read interrupt or write interrupt.
  - > EE interrupt.
- Eleven interrupt events to wake-up NY8BE64A from Standby mode:
  - > Timer0 overflow interrupt.
  - > Timer1 underflow interrupt.
  - > Timer4 underflow interrupt.
  - > Timer5 underflow interrupt.
  - > WDT timeout interrupt.
  - > PA/PB input change interrupt.
  - > External interrupts. (INT0, INT1, INT2).
  - > LVD interrupt.
  - > Comparator output status change interrupt.
  - > ADC end-of-convert interrupt.
  - > Serial Interface Module (SIM) interrupt.
- Three kinds of interrupt events to wake-up NY8BE64A from Halt mode:
  - > WDT timeout interrupt.
  - > PA/PB input change interrupt.
  - > External interrupts. (INT0, INT1, INT2)
- Build-in 4 variable oscillator options: 32MHz/20.8MHz/16MHz/13.6MHz. Fine-tuned accuracy to ±0.1%.
- Build-in 2 wires on chip debug circuit (OCD).

#### 1.2 Block Diagram



#### 1.3 Pin Assignment

NY8BE64A provides two kinds of package type which are SOP20 and SOP-16.

|        |      |         |        |      |            | 20 pin |            |       |        |        |          |        |          |
|--------|------|---------|--------|------|------------|--------|------------|-------|--------|--------|----------|--------|----------|
|        |      |         |        |      | VSS        | 1 20   | VDD        |       |        |        |          |        |          |
|        | XIN  |         |        |      | PA6        | 2 19   | PA4        | AIN4  | PWM4   |        | EX_CK0   | INT0   | 1        |
|        | XOUT |         | (PWM3) |      | PA7        | 3 18   | PA3 (SCL1) | AIN3  |        | COMPIN | (IR)     | INT1   | P1D      |
| INT2   | RSTB | P1B     |        |      | PA5        | 4 17   | PA2 (SDA1) | AIN2  | PWM3   | COMPIN | EXCKI    | BZ3    | P1C      |
| T3OUT  | BZ1  | CMPO    | PWM2   | AIN7 | PB3        | 5 16   | PA1        | AIN1  | 1      | COMPIN | (EX_CKI) |        |          |
| CCP1   | BZ2  | P1A     | PWM5   | AIN6 | PB2        | 6 15   | PA0        | AIN0  | 1      | COMPIN | VREFH    |        |          |
| (INT1) | IR   | (VREFH) | PWM1   | AIN5 | PB1        | 7 14   | PB5        | AIN9  | (PWM2) |        | IIC_SDA  | (INTO) | SPI_MISO |
|        |      |         |        |      | PB0        | 8 13   | PB4        | AIN8  | PWM1   | 1      | IIC_SCL  | T10UT  | SPI_SCK  |
|        |      |         |        |      | (SDA0) PC0 | 9 12   | PB6        | AIN10 | 1      |        | UART_TX  |        | SPI_MOSI |
|        |      |         |        |      | (SCL0) PC1 |        | PB7        | AIN11 | 1      | 1      | UART_RX  |        | SPI_SSB  |
|        |      | ·       |        |      |            | 16 Pin | 1          |       | ······ |        | ·····    | T      | ·······  |
|        |      |         |        |      | VDD        | -      | VSS        |       |        |        |          | ļ      |          |
|        | XIN  |         |        |      | PA6        | 2 15   | PA4        | AIN4  | PWM4   |        | EX_CK0   | INT0   |          |
|        | XOUT |         | (PWM3) |      | PA7        | 3 14   | PA3 (SCL1) | AIN3  |        | COMPIN | (IR)     | INT1   | P1D      |
| INT2   | RSTB | P1B     |        |      | PA5        | 4 13   | PA2 (SDA1) | AIN2  | PWM3   | COMPIN | EXCKI    | BZ3    | P1C      |
| T3OUT  | BZ1  | CMPO    | PWM2   | AIN7 | PB3        | 5 12   | PB5        | AIN9  | (PWM2) |        | IIC_SDA  | (INTO) | SPI_MISO |
|        | BZ2  | P1A     | PWM5   | AIN6 | PB2        | 6 11   | PB4        | AIN8  | PWM1   |        | IIC_SCL  | T10UT  | SPI_SCK  |
| CCP1   |      |         |        |      |            |        |            |       | - T    |        |          |        | 1011_001 |
| (INT1) |      | (VREFH) | PWM1   | AIN5 | PB1        | 7 10   | PB6        | AIN10 |        |        | UART_TX  |        | SPI_MOSI |

Figure 2 Package pin assignment of NY8BE64A

#### 1.4 Pin Description

| Pin Name                                            | I/O | Description                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PA0<br>AIN0<br>VREFH                                | I/O | PA0 is bidirectional I/O pin, and can be comparator input pin.<br>PA0 can be ADC analog input pin.<br>PA0 can be ADC external high reference voltage source.                                                                                                                                                           |
| PA1<br>AIN1<br>EX_CKI1                              | I/O | PA1 is bidirectional I/O pin, and can be comparator input pin.<br>PA1 can be ADC analog input pin.<br>PA1 can be Timer4/5 clock source EX_CKI1.                                                                                                                                                                        |
| PA2<br>AIN2<br>PWM3<br>EX_CKI1<br>P1CO<br>(OCD_SDA) | I/O | PA2 is bidirectional I/O pin, and can be comparator input pin.<br>PA2 can be ADC analog input pin.<br>PA2 can be output of PWM3.<br>PA2 can be Timer4/5 clock source EX_CKI1.<br>PA2 can be P1C output in CCP mode.<br>PA2 can be programming pad SDA.                                                                 |
| PA3<br>AIN3<br>IR<br>INT1<br>P1DO<br>(OCD_SDA)      | I/O | <ul> <li>PA3 is bidirectional I/O pin, and can be comparator input pin.</li> <li>PA3 can be ADC analog input pin.</li> <li>PA3 can be IR carrier output pin.</li> <li>PA3 can be input pin of external interrupt INT1.</li> <li>PA3 can be P1D output in CCP mode.</li> <li>PA3 can be programming pad SDA.</li> </ul> |
| PA4<br>AIN4<br>EX_CKI0<br>INT0<br>PWM4              | I/O | PA4 is a bidirectional I/O pin.<br>PA4 can be ADC analog input pin.<br>PA4 can be the Timer0/1 clock source EX_CKI0.<br>PA4 can be the input pin of external interrupt INT0.<br>PA4 can be output of PWM4.                                                                                                             |
| PA5<br>RSTb<br>INT2<br>P1BO                         | I/O | PA5 is a bidirectional I/O pin.<br>PA5 can be the reset pin RSTb.<br>PA5 can be the input pin of external interrupt INT2.<br>PA5 can be P1B output in CCP mode.                                                                                                                                                        |
| PA6<br>Xin                                          | I/O | PA6 is a bidirectional I/O pin, and can be comparator analog input pin.<br>PA6 can be the input pin of crystal oscillator Xin.                                                                                                                                                                                         |
| PA7<br>Xout<br>PWM3                                 | I/O | PA7 is a bidirectional I/O pin, and can be comparator analog input pin.<br>PA7 can be the output pin of crystal oscillator Xout.<br>PA7 also can be output of instruction clock.<br>PA7 can be output of PWM3 by option select.                                                                                        |
| PB0                                                 | I/O | PB0 is a bidirectional I/O pin.                                                                                                                                                                                                                                                                                        |
| PB1<br>AIN5<br>VREFH<br>IR<br>PWM1<br>INT1          | I/O | PB1 is a bidirectional I/O pin.<br>PB1 can be ADC analog input pin.<br>PB1 can be ADC external high reference voltage source.<br>PB1 can be IR carrier output pin.<br>PB1 can be output of PWM1.<br>PB1 can be input pin of external interrupt INT1.                                                                   |

| Pin Name                                           | I/O | Description                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB2<br>AIN6<br>PWM5<br>P1AO<br>CCP                 | I/O | PB2 is a bidirectional I/O pin.<br>PB2 can be ADC analog input pin.<br>PB2 can be output of PWM5.<br>PB2 can be P1A output in CCP mode.<br>PB2 can be CCP capture input or compare output.                                                                                                              |
| PB3<br>AIN7<br>BZ1<br>CMPO<br>PWM2                 | I/O | PB3 is a bidirectional I/O pin.<br>PB3 can be ADC analog input pin<br>PB3 can be the output Buzzer1.<br>PB3 can be comparator output.<br>PB3 can be output of PWM2.                                                                                                                                     |
| PB4<br>AIN8<br>PWM1<br>T1OUT<br>SPI_SCK<br>IIC_SCL | I/O | <ul> <li>PB4 is a bidirectional I/O pin.</li> <li>PB4 can be analog input pin.</li> <li>PB4 can be output of PWM1.</li> <li>PB4 can be Timer1 output pin. (T1OUT toggles when Timer1 underflow occurs)</li> <li>PB4 can be clock pin in SPI mode.</li> <li>PB4 can be clock pin in IIC mode.</li> </ul> |
| PB5<br>AIN9<br>SPI_MISO<br>IIC_SDA                 | I/O | PB5 is a bidirectional I/O pin.<br>PB5 can be analog input.<br>PB5 can be MISO(Master In Slave Out) pin in SPI mode.<br>PB5 can be Data pin in IIC mode.                                                                                                                                                |
| PB6<br>AIN10<br>SPI_MOSI<br>UART_TX                | I/O | PB6 is a bidirectional I/O pin.<br>PB6 can be MOSI(Master Out Slave In) pin in SPI mode.<br>PB6 can be Tx pin in UART mode.                                                                                                                                                                             |
| PB7<br>AIN11<br>SPI_SSB<br>UART_RX                 | I/O | PB7 is a bidirectional I/O pin.<br>PB7 can be analog input pin.<br>PB7 can SSB(Slave Select, active-low) pin in SPI mode.<br>PB7 can be Rx pin in UART mode.                                                                                                                                            |
| PC0<br>OCD_SDA                                     | I/O | PC0 is a bidirectional I/O pin.<br>PC0 also can be programming pad SDA.                                                                                                                                                                                                                                 |
| PC1<br>OCD_SCL                                     | I/O | PC1 is a bidirectional I/O pin<br>PC1 can be programming pad SCL.                                                                                                                                                                                                                                       |
| VDD                                                | -   | Positive power supply.                                                                                                                                                                                                                                                                                  |
| VSS                                                | -   | Ground.                                                                                                                                                                                                                                                                                                 |

#### 2. Memory Organization

NY8BE64A memory is divided into two categories: one is program memory and the other is data memory.

#### 2.1 Program Memory

The program memory space of NY8BE64A is 4K words. Therefore, the Program Counter (PC) is 12-bit wide in order to address any location of program memory.

Some locations of program memory are reserved as interrupt entrance. Power-On Reset vector is located at 0x000. Software interrupt vector is located at 0x001. Internal and external hardware interrupt vector is located at 0x008.

NY8BE64A provides instruction GOTOA, CALLA to address 256 location of program space. NY8BE64A also provides instructions FCALL and FGOTO to address any location of program space.

When a call or interrupt is happening, next ROM address is written to top of the stack, when RET, RETIA or RETIE instruction is executed, the top of stack data is read and load to PC.

NY8BE64A program ROM address 0xFFE~0xFFF are reserved space, if user tries to write code in these addresses will get unexpected false functions.

NY8BE64A program ROM address 0x00E~0x00F are preset rolling code can be released and used as normal program space.



#### Figure 3 Program Memory Address Mapping

#### 2.2 Data Memory

According to instructions used to access data memory, the data memory can be divided into three kinds of categories: one is R-page Special-function register (SFR) + General Purpose Register (GPR), another is F-page SFR and the other is S-page SFR. GPR are made of SRAM and user can use them to store variables or intermediate results.

R-page data memory is divided into 4 banks and can be accessed directly or indirectly through a SFR register which is File Select Register (FSR). STATUS [7:6] are used as Bank register BK[1:0] to select one bank out of the 4 banks.

R-page register can be divided into addressing mode: direct addressing mode and indirect addressing mode.

The indirect addressing mode of data memory access is described in the following graph. This indirect addressing mode is implied by accessing register INDF. The bank selection is determined by STATUS[7:6] and the location selection is from FSR[6:0].



Figure 4 Indirect Addressing Mode of Data Memory Access

The direct addressing mode of data memory access is described below. The bank selection is determined by STATUS [7:6] and the location selection is from instruction op-code[6:0] immediately.





## NY8BE64A

R-page SFR can be accessed by general instructions like arithmetic instructions and data movement instructions. The R-page SFR occupies address from 0x0 to 0x1F of Bank 0. However, the same address range of Bank 1, Bank 2 and Bank 3 are mapped back to Bank 0. In other words, R-page SFR physically existed at Bank 0. The GPR physically occupy address from 0x20 to 0x7F of Bank 0 and 0x40 to 0x7F of Bank 1, 2 and 3. Other bank in address from 0x20 to 0x3F are mapped back as the Table 1 shows.

The NY8BE64A register name and address mapping of R-page SFR are described in the following table.

| Status [7:6] | 00<br>(Bank 0) | 01<br>(Bank 1) | 10<br>(Bank 2)    | 11<br>(Pank 2) |
|--------------|----------------|----------------|-------------------|----------------|
| Address      | (Bank 0)       | (Bank 1)       | (Bank 2)          | (Bank 3)       |
| 0x0          |                | -              |                   |                |
| 0x1          | TMR0           | -              |                   |                |
| 0x2          | PCL            | -              |                   |                |
| 0x3          | STATUS         | -              |                   |                |
| 0x4          | FSR            | -              |                   |                |
| 0x5          | PORTA          | -              |                   |                |
| 0x6          | PORTB          |                |                   |                |
| 0x7          | PORTC          | -              |                   |                |
| 0x8          | PCON           |                |                   |                |
| 0x9          | BWUCON         | •              |                   |                |
| 0xA          | PCHBUF         |                |                   |                |
| 0xB          | ABPLCON        |                |                   |                |
| 0xC          | BPHCON         | -              |                   |                |
| 0xD          | CPHCON         | The            | same mapping as B | ank 0          |
| 0xE          | INTE           | -              |                   |                |
| 0xF          | INTF           |                |                   |                |
| 0x10         | ADMD           |                |                   |                |
| 0x11         | ADR            |                |                   |                |
| 0x12         | ADD            | _              |                   |                |
| 0x13         | ADVREFH        |                |                   |                |
| 0x14         | ADCR           |                |                   |                |
| 0x15         | AWUCON         |                |                   |                |
| 0x16         | PACON          |                |                   |                |
| 0x17         | ADJMD          |                |                   |                |
| 0x18         | INTEDG         |                |                   |                |
| 0x19         | TMRH           |                |                   |                |
| 0x1A         | ANAEN          |                |                   |                |
| 0x1B         | RFC            |                |                   | Dank           |
| 0x1C         | TM4RH          | ] //           | e same mapping as | Darik U        |
| 0x1D         | OSCCALH        |                | -                 |                |
| 0x1E         | OSCCALL        |                |                   |                |
| 0x1F         | INTE2          | Th             | e same mapping as | Bank 0         |

## NY8BE64A

| Status [7:6] | 00              | 01              | 10              | 11              |
|--------------|-----------------|-----------------|-----------------|-----------------|
| Address      | (Bank 0)        | (Bank 1)        | (Bank 2)        | (Bank 3)        |
| 0x20 ~ 0x3F  | General Purpose | Mapped to       | Mapped to       | Mapped to       |
|              | Register        | bank0           | bank0           | bank0           |
| 0x40 ~ 0x7F  | General Purpose | General Purpose | General Purpose | General Purpose |
|              | Register        | Register        | Register        | Register        |

#### Table 1 R-page SFR Address Mapping

F-page SFR can be accessed only by instructions IOST and IOSTR. S-page SFR can be accessed only by instructions SFUN and SFUNR. T-page SFR can be accessed only by instructions TFUN and TFUNR. STATUS[7:6] bank select bits are ignored while F-page, S-page and T-Page register is accessed. The register name and address mapping of F-page, S-page and T-page are depicted in the following table.

| SFR Category<br>Address | F-page SFR | S-page SFR | T-page SFR |
|-------------------------|------------|------------|------------|
| 0x0                     | -          | TMR1       | SIMCR      |
| 0x1                     | -          | T1CR1      | MADR       |
| 0x2                     | -          | T1CR2      | MFDR       |
| 0x3                     | -          | PWM1DUTY   | MCR        |
| 0x4                     | -          | PS1CV      | MSR        |
| 0x5                     | IOSTA      | BZ1CR      | SIMDR      |
| 0x6                     | IOSTB      | IRCR       | SPCR       |
| 0x7                     | IOSTC      | ТВНР       | INTE3      |
| 0x8                     | -          | TBHD       | INTF3      |
| 0x9                     | APHCON     | -          | -          |
| 0xA                     | PS0CV      | P2CR1      | -          |
| 0xB                     | CPLCON     | -          | -          |
| 0xC                     | BODCON     | PWM2DUTY   | -          |
| 0xD                     | CODCON     | -          | -          |
| 0xE                     | CMPCR      | -          | -          |
| 0xF                     | PCON1      | OSCCR      | -          |
| 0X10                    | -          | -          | -          |
| 0X11                    | -          | P3CR1      | -          |
| 0X12                    | -          | -          | -          |
| 0X13                    | -          | PWM3DUTY   | -          |
| 0X14                    | -          | -          | -          |
| 0X15                    | -          | TMR4       | -          |
| 0X16                    | -          | T4CR1      | -          |
| 0X17                    | -          | T4CR2      | -          |
| 0X18                    |            | PWM4DUTY   | THR/RBR    |
| 0X19                    | -          | PS4CV      | LCR        |
| 0X1A                    | -          | TMR5       | LSR        |

| SFR Category<br>Address | F-page SFR | S-page SFR | T-page SFR |
|-------------------------|------------|------------|------------|
| 0X1B                    | -          | T5CR1      | DLL        |
| 0X1C                    | -          | T5CR2      | DLH        |
| 0X1D                    | -          | PWM5DUTY   | -          |
| 0X1E                    | -          | PS5CV      | CCPCON     |
| 0X1F                    | -          | TM5RH      | PWMDB      |

Table 2 F-page, S-page and T-page SFR Address Mapping

#### 2.3 EEPROM Memory

Read and write access to EEPROM memory take place indirectly through 3 special function registers, namely, EEA, EED and EEP. EEA register holds the EEPROM address to be access. EED register holds the data to be written, or the data read at the address in EEA. EEP holds the unlock key to write EEPROM data. The following figure shows the block diagram how EEPROM operates.



NY8BE64A provides 7 instructions to control the data flow between these 3 special register and 128-byte EEPROM. EEAR/EEAW read/write the EEA register. EEDR/EEDW read/write the EED register. EERD/EEWR /EEPL instructions, on the other hand, control the data path between EEPROM and EED register, according to the EEPROM address provided by EEA. The following table describes the EEPROM instructions.

## NY8BE64A

| Mnemonic Operands | Description                           | Status affected |
|-------------------|---------------------------------------|-----------------|
| EEAR              | Read EEA to ACC                       | -               |
| EEAW              | Write EEA from ACC                    | -               |
| EEDR              | Read EED to ACC                       | -               |
| EEDW              | Write EED from ACC                    | -               |
| EERD              | Read EEPROM(EEA),and wite to EED      | ACC is unknown  |
| EERD              | register                              | ACC IS UNKNOWN  |
| EEWR              | Write EEPROM(EEA) with data from      |                 |
| EEVVR             | EED register                          | -               |
| EEPL              | Write serial codes to unlock EE write |                 |
|                   | protect                               | -               |

Before writing EEPROM data with the EEWR instruction, 3 consecutive code must be written to the EEP register with the EEPL instruction. These 3 code are C9H, 3AH and D3H. After these 3 code are written to EEP register, the EEPROM write protection is unlocked and data will be written to EEPROM by applying the EEWR instruction. The following are example code of EEPROM write unlock process.

; Write serial codes to lock/unlock EEP

| DISI  |      |
|-------|------|
| MOVIA | 0xC9 |
| EEPL  |      |
| MOVIA | 0x3A |
| EEPL  |      |
| MOVIA | 0xD3 |
| EEPL  |      |
| ENI   |      |

; Write EEPROM data

| DISI         |           |
|--------------|-----------|
| MOVIA        | 0x45      |
| EEAW         |           |
| MOVIA        | 0x23      |
| EEDW         |           |
| MOVIA        | EE_TO_8ms |
| EEWR         |           |
| ENI          |           |
| ; Read EEPRO | M data    |
| DISI         |           |
| MOVIA        |           |
| EEAW         |           |

EERD

EEDR

ENI

When EEWR is successfully executed and completed, an EEWIF interrupt will be launched if the EEWIE is set to 1 and the global interrupt GIE is enabled.

Note:

- 1. To prevent unwanted halt in a running program if EEPROM writes fail, enabling the watchdog reset or enabling EEPROM write time-out functions is suggested.
- 2. When user writes data to EEPROM, it is suggested to turn on LVD =2.4V function to monitor VDD.
- 3. When VDD is under 2.4v, data cannot be written into EEPROM. User can use LVD & LVR function to prevent writing data to EEPROM fail.

#### 2.3.1 EEA (EEPROM Address Register)

| Name   | SFR Type | Bit7     | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|--------|----------|----------|------|------|------|------|------|------|------|
| EEA    | EE       | EEA[7:0] |      |      |      |      |      |      |      |
| R/W I  | Property | R/W      |      |      |      |      |      |      |      |
| Initia | Il Value | XXXXXXX  |      |      |      |      |      |      |      |

**EEA[7:0]:** Point to EEPROM address.

#### 2.3.2 EED (EEPROM Data Register)

| Name   | SFR Type      | Bit7     | Bit6    | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|--------|---------------|----------|---------|------|------|------|------|------|------|
| EED    | EE            | EED[7:0] |         |      |      |      |      |      |      |
| R/W F  | Property      | R/W      |         |      |      |      |      |      |      |
| Initia | Initial Value |          | xxxxxxx |      |      |      |      |      |      |

**EED[7:0]:** EEPROM data register . Read/Write this register by instruction EEDR/EEDW.

#### 2.3.3 EEPL (EEPROM write protect Register)

| Name   | SFR Type      | Bit7    | Bit6    | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|--------|---------------|---------|---------|------|------|------|------|------|------|
| EEPL   | EE            | PL[7:0] |         |      |      |      |      |      |      |
| R/W F  | Property      | W       |         |      |      |      |      |      |      |
| Initia | Initial Value |         | xxxxxxx |      |      |      |      |      |      |

PL[7:0]: EEPROM lock/unlock code. Written by instruction EEPL.

#### 2.3.4 EETO (EEPROM Time-Out Register)

| Name  | SFR Type | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|----------|------|------|------|------|------|------|------|------|
| EETO  | EE       | -    | -    | -    | -    | -    | TO2  | TO1  | TO0  |
| R/W   | Property | -    | -    | -    | -    | -    | W    | W    | W    |
| Initi | al Value | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    |

**TO[2:0]:** EEPROM write time out period register. Written by EEWR instruction.

| The time-out period is sh | hown in the | following table: |
|---------------------------|-------------|------------------|
|---------------------------|-------------|------------------|

|         | <b>J</b>        |
|---------|-----------------|
| TO[2:0] | Time-out period |
| 000     | 1ms             |
| 001     | 2ms             |
| 010     | 4ms             |
| 011     | 8ms             |
| 100     | 16ms            |
| 101     | 32ms            |
| 110     | 16ms            |
| 111     | 32ms            |
|         |                 |

Ex:

| MOVIA | 0x01 | ; setting write time-out period as 4ms |
|-------|------|----------------------------------------|
| EEWR  |      | ; write EEPROM                         |

Note:

- 1. Before writing EEPROM, be sure to set initial data into EETO[2:0] at first.
- 2. EEPROM time-out reference:

*Time-out period set 4ms, if V*<sub>OPL</sub> = 2.2V ~2.3V

Time-out period set 2ms, if V<sub>OPL</sub> = 2.4V ~2.6V

Time-out period set 1ms, if  $V_{OPL} \ge 2.7V$ 

#### 3. Function Description

This chapter will describe the detailed operations of NY8BE64A.

#### 3.1 R-page Special Function Register

#### 3.1.1 INDF (Indirect Addressing Register)

| Name | SFR Type      | Addr.    | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2 | Bit1 | Bit0 |
|------|---------------|----------|------|------|------|------|--------|------|------|------|
| INDF | R             | 0x0      |      |      |      | IND  | F[7:0] |      |      |      |
|      | R/W Propert   | ty       |      |      |      | R    | /W     |      |      |      |
|      | Initial Value | <b>;</b> |      |      |      | XXXX | xxxx   |      |      |      |

The register INDF is not physically existed and it is used as indirect addressing mode. Any instruction accessing INDF actually accesses the register pointed by register FSR

#### 3.1.2 TMR0 (Timer0 Register)

| Name | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|------|------|------|------|--------|------|------|------|
| TMR0 | R             | 0x1   |      |      |      | TMR  | 0[7:0] |      |      |      |
|      | R/W Property  |       |      |      |      | R    | /W     |      |      |      |
|      | Initial Value |       |      |      |      | XXXX | xxxx   |      |      |      |

When read the register TMR0, it actually read the current running value of Timer0.

Write the register TMR0 will change the current value of Timer0.

Timer0 clock source can be from instruction clock F<sub>INST</sub>, or from external pin EX\_CKI0, or from Low Oscillator Frequency according to T0MD and configuration word setting.

#### 3.1.3 PCL (Low Byte of PC[11:0])

| Name | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3  | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|------|------|------|------|-------|------|------|------|
| PCL  | R             | 0x2   |      |      |      | PCL  | [7:0] |      |      |      |
|      | R/W Property  |       |      |      |      | R    | W     |      |      |      |
|      | Initial Value |       | 0x00 |      |      |      |       |      |      |      |

The register PCL is the least significant byte (LSB) of 12-bit PC. PCL will be increased by one after one instruction is executed except some instructions which will change PC directly. The high byte of PC, i.e. PC[11:8], is not directly accessible. Update of PC[11:8] must be done through register PCHBUF.

For FGOTO instruction, PC[11:0] is from instruction word.

For FCALL instruction, PC[11:0] is from instruction word. Moreover the next PC address, i.e. PC+1, will push onto top of Stack.

#### 3.1.4 STATUS (Status Register)

| Name   | SFR Type     | Addr. | Bit7  | Bit6  | Bit5 | Bit4    | Bit3    | Bit2 | Bit1 | Bit0 |
|--------|--------------|-------|-------|-------|------|---------|---------|------|------|------|
| STATUS | R            | 0x3   | BK[1] | BK[0] | GP5  | /TO     | /PD     | Z    | DC   | С    |
| R/     | /W Property  |       | R/W   | R/W   | R/W  | R/W(*2) | R/W(*1) | R/W  | R/W  | R/W  |
| li     | nitial Value |       | 0     | 0     | 0    | 1       | 1       | Х    | Х    | Х    |

The register STATUS contains result of arithmetic instructions and reasons to cause reset.

C: Carry/Borrow bit

C=1, carry is occurred for addition instruction or borrow is not occurred for subtraction instruction.

C=0, carry is not occurred for addition instruction or borrow is occurred for subtraction instruction.

DC: Half Carry/half Borrow bit

DC=1, carry from the 4th LSB is occurred for addition instruction or borrow from the 4th LSB is not occurred for subtraction instruction.

DC=0, carry from the 4th LSB is not occurred for addition instruction or borrow from the 4th LSB is occurred for subtraction instruction.

#### Z: Zero bit

Z=1, result of logical operation is zero.

Z=0, result of logical operation is not zero.

/PD: Power down flag bit\*1

/PD=1, after power-up or after instruction CLRWDT is executed.

/PD=0, after instruction SLEEP is executed.

/TO: Time overflow flag bit\*2

/TO=1, after power-up or after instruction CLRWDT or SLEEP is executed.

/TO=0, WDT timeout is occurred.

**GP5:** General purpose read/write register bit.

BK[1:0]: Bank register is used to select one specific bank of data memory. BK[1:0]=00b, Bank 0 is selected.

BK[1:0]=01b, Bank 1 is selected. BK[1:0]=10b, Bank 2 is selected. BK[1:0]=11b, Bank 3 is selected.

(\*1) can be cleared by SLEEP instruction.

(\*2) can be set by CLRWDT instruction.

#### 3.1.5 FSR (Register File Selection Register)

| Name | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3     | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|------|------|------|------|----------|------|------|------|
| FSR  | R             | 0x4   | GP7  |      |      |      | FSR[6:0] |      |      |      |
|      | R/W Property  | /     |      |      |      | R    | /W       |      |      |      |
|      | Initial Value |       | 0    | Х    | Х    | Х    | Х        | Х    | Х    | Х    |

FSR[6:0]: Select one register out of 128 registers of specific Bank.

GP7: general register.

#### 3.1.6 PortA (PortA Data Register)

| Name  | SFR Type      | Addr. | Bit7                                                                    | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|-------------------------------------------------------------------------|------|------|------|------|------|------|------|
| PortA | R             | 0x5   | PA7                                                                     | PA6  | PA5  | PA4  | PA3  | PA2  | PA1  | PA0  |
|       | R/W Propert   | у     |                                                                         |      |      | R/   | W    |      |      |      |
|       | Initial Value |       | Data latch value is xxxxxxx, read value is xxxxxxxx port value(PA7~PA0) |      |      |      |      |      |      |      |

While reading PortA, it will get the status of the specific pin if that pin is configured as input pin. However, if that pin is configured as output pin, whether it will get the status of the pin or the value of the corresponding output data latch is depend on the configuration option RD\_OPT. While writing to PortA, data is written to PA's output data latch.

#### 3.1.7 PortB (PortB Data Register)

| Name  | SFR Type      | Addr. | Bit7     | Bit6       | Bit5      | Bit4       | Bit3       | Bit2      | Bit1       | Bit0    |
|-------|---------------|-------|----------|------------|-----------|------------|------------|-----------|------------|---------|
| PortB | R             | 0x6   | PB7      | PB6        | PB5       | PB4        | PB3        | PB2       | PB1        | PB0     |
| F     | R/W Property  |       |          |            |           | R/         | W          |           |            |         |
|       | Initial Value |       | Data lat | ch value i | s xxxxxxx | x, read va | lue is xxx | xxxxx por | t value(PE | 87~PB0) |

While reading PortB, it will get the status of the specific pin if that pin is configured as input pin. However, if that pin is configured as output pin, whether it will get the status of the pin or the value of the corresponding output data latch is depend on the configuration option RD\_OPT. While writing to PortB, data is written to PB's output data latch.

#### 3.1.8 PortC (PortC Data Register)

| Name  | SFR Type      | Addr. | Bit7                                                         | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|--------------------------------------------------------------|------|------|------|------|------|------|------|
| PortC | R             | 0x7   | -                                                            | -    | -    | -    | -    | -    | PC1  | PC0  |
| I     | R/W Property  | ,     |                                                              |      | -    |      |      |      | R    | /W   |
|       | Initial Value |       | Data latch value is xx, read value is xx port value(PC1~PC0) |      |      |      |      |      |      | 0)   |

While reading PortC, it will get the status of the specific pin if that pin is configured as input pin. However, if that pin is configured as output pin, whether it will get the status of the pin or the value of the corresponding output data latch is depend on the configuration option RD\_OPT. While writing to PortC, data is written to PC's output data latch.

#### 3.1.9 PCON (Power Control Register)

| Name | SFR<br>Type | Addr | Bit7  | Bit6   | Bit5  | Bit4   | Bit3  | Bit2 | Bit1    | Bit0   |
|------|-------------|------|-------|--------|-------|--------|-------|------|---------|--------|
| PCON | R           | 0x8  | WDTEN | /PLPA4 | LVDEN | /PHPA5 | LVREN | GP2  | EEW_ERR | EELOCK |
| R/W  | / Proper    | ty   |       |        | R/V   | V      |       |      | R       |        |
| Ini  | tial Valu   | е    | 1     | 1      | 0     | 1      | 1     | 0    | 0       | 1      |

**GP2:** General read/write register bits.

**EELOCK:** EEPROM write LOCK flag.

EELOCK=1, the EEPROM write is in lock state.

## **())** Nyquest

EELOCK=0, the EEPROM write is in unlock state.

**EEW\_ERR:** EEPROM write Time-out flag. (Note: EEWR\_TO configuration must be enabled)

EEW\_ERR=1, the EEPROM write is time-out.

EEW\_ERR=0, the EEPROM write is not time-out.

LVREN: Enable/disable LVR.

LVREN=1, enable LVR.

LVREN=0, disable LVR.

/PHPA5: Disable/enable PA5 Pull-High resistor.

/PHPA5=1, disable PA5 Pull-High resistor.

/PHPA5=0, enable PA5 Pull-High resistor.

LVDEN: Enable/disable LVD.

LVDEN=1, enable LVD.

LVDEN=0, disable LVD.

/PLPA4: Disable/enable PA4 Pull-Low resistor.

/PLPA4=1, disable PA4 Pull-Low resistor.

/PLPA4=0, enable PA4 Pull-Low resistor.

WDTEN: Enable/disable WDT.

WDTEN=1, enable WDT.

WDTEN=0, disable WDT.

#### 3.1.10 BWUCON (PortB Wake-up Control Register)

| Name   | SFR Type   | Addr. | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|--------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| BWUCON | R          | 0x9   | WUPB7 | WUPB6 | WUPB5 | WUPB4 | WUPB3 | WUPB2 | WUPB1 | WUPB0 |
| R/V    | V Property |       | R/W   |
| Ini    | tial Value |       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**WUPBx:** Enable/disable PBx wake-up function,  $0 \le x \le 7$ .

WUPBx=1, enable PBx wake-up function.

WUPBx=0, disable PBx wake-up function.

#### 3.1.11 PCHBUF (High Byte of PC)

| Name   | SFR Type     | Addr. | Bit7 | Bit6     | Bit5 | Bit4 | Bit3 | Bit2 | Bit1    | Bit0 |
|--------|--------------|-------|------|----------|------|------|------|------|---------|------|
| PCHBUF | R            | 0xA   | -    | XSPD_STP |      | -    |      | PCHB | JF[3:0] |      |
| R/     | W Property   |       | -    | W        |      | -    |      | R/   | W       |      |
| h      | nitial Value |       | Х    | 0 X 0    |      |      |      |      |         |      |

PCHBUF[3:0]: Buffer of the 11<sup>th</sup> ~ 8<sup>th</sup> bit of PC.

XSPD\_STP: Write 1 to stop crystal 32.768K speed-up function, write-only.

#### 3.1.12 ABPLCON (PortA/PortB Pull-Low Resistor Control Register)

| Name    | SFR<br>Type | Addr. | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|---------|-------------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| ABPLCON | R           | 0xB   | /PLPB3 | /PLPB2 | /PLPB1 | /PLPB0 | /PLPA3 | /PLPA2 | /PLPA1 | /PLPA0 |
| R/W     | Property    | /     |        |        |        | R/     | W      |        |        |        |
| Initia  | al Value    |       | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

**/PLPAx:** Disable/enable PAx Pull-Low resistor,  $0 \le x \le 3$ .

/PLPAx=1, disable PAx Pull-Low resistor.

/PLPAx=0, enable PAx Pull-Low resistor.

#### **/PLPBx:** Disable/enable PBx Pull-Low resistor, $0 \le x \le 3$ .

/PLPBx=1, disable PBx Pull-Low resistor.

/PLPBx=0, enable PBx Pull-Low resistor.

#### 3.1.13 BPHCON (PortB Pull-High Resistor Control Register)

| Name   | SFR<br>Type | Addr. | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|--------|-------------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| BPHCON | R           | 0xC   | /PHPB7 | /PHPB6 | /PHPB5 | /PHPB4 | /PHPB3 | /PHPB2 | /PHPB1 | /PHPB0 |
| R/W    | Propert     | у     | R/W    |
| Initia | al Value    |       | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

**/PHPBx:** Disable/enable PBx Pull-High resistor,  $0 \le x \le 7$ .

/PHPBx=1, disable PBx Pull-High resistor.

/PHPBx=0, enable PBx Pull-High resistor.

#### 3.1.14 CPHCON (PortC Pull-High Resistor Control Register)

| Name   | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1   | Bit0   |
|--------|---------------|-------|------|------|------|------|------|------|--------|--------|
| CPHCON | R             | 0xD   | I    | I    | I    | I    | I    | I    | /PHPC1 | /PHPC0 |
| RA     | N Property    |       | -    | -    | -    | -    | -    | -    | R/W    | R/W    |
| In     | Initial Value |       |      | Х    | Х    | Х    | Х    | Х    | 1      | 1      |

**/PHPCx:** Disable/enable PCx Pull-High resistor,  $0 \le x \le 1$ .

/PHPCx=1, disable PCx Pull-High resistor.

/PHPCx=0, enable PCx Pull-High resistor.

#### 3.1.15 INTE (Interrupt Enable Register)

| Name | SFR Type      | Addr. | Bit7   | Bit6  | Bit5 | Bit4  | Bit3 | Bit2   | Bit1  | Bit0 |
|------|---------------|-------|--------|-------|------|-------|------|--------|-------|------|
| INTE | R             | 0xE   | INT1IE | WDTIE | -    | LVDIE | T1IE | INT0IE | PABIE | T0IE |
| F    | R/W Property  |       | R/W    | R/W   | -    | R/W   | R/W  | R/W    | R/W   | R/W  |
|      | Initial Value |       | 0      | 0     | Х    | 0     | 0    | 0      | 0     | 0    |

TOIE: Timer0 overflow interrupt enable bit. T0IE=1, enable Timer0 overflow interrupt. T0IE=0, disable Timer0 overflow interrupt. PABIE: PortA/PortB input change interrupt enable bit. PABIE=1, enable PortA/PortB input change interrupt. PABIE=0, disable PortA/PortB input change interrupt. **INTOIE:** External interrupt 0 enable bit. INT0IE=1, enable external interrupt 0. INT0IE=0, disable external interrupt 0. **T1IE:** Timer1 underflow interrupt enable bit. T1IE=1, enable Timer1 underflow interrupt. T1IE=0, disable Timer1 underflow interrupt. LVDIE: Low-voltage detector interrupt enable bit. LVDIE=1, enable low-voltage detector interrupt. LVDIE=0, disable low-voltage detector interrupt. WDTIE: WDT timeout interrupt enable bit.

WDTIE=1, enable WDT timeout interrupt.

WDTIE=0, disable WDT timeout interrupt.

**INT1IE:** External interrupt 1 enable bit.

INT1IE=1, enable external interrupt 1.

INT1IE=0, disable external interrupt 1.

#### 3.1.16 INTF (Interrupt Flag Register)

| Name   | SFR<br>Type | Addr. | Bit7   | Bit6  | Bit5 | Bit4  | Bit3 | Bit2          | Bit1  | Bit0 |
|--------|-------------|-------|--------|-------|------|-------|------|---------------|-------|------|
| INTF   | R           | 0xF   | INT1IF | WDTIF | -    | LVDIF | T1IF | <b>INT0IF</b> | PABIF | TOIF |
| R      | /W Proper   | ty    | R/W    | R/W   | -    | R/W   | R/W  | R/W           | R/W   | R/W  |
| Initia | al Value(no | ote*) | 0      | 0     | Х    | 0     | 0    | 0             | 0     | 0    |

TOIF: Timer0 overflow interrupt flag bit.

T0IF=1, Timer0 overflow interrupt is occurred.

T0IF must be clear by firmware.

**PABIF:** PortA/PortB input change interrupt flag bit.

PABIF=1, PortA/PortB input change interrupt is occurred.

PABIF must be clear by firmware.

**INTOIF:** External interrupt 0 flag bit.

INT0IF=1, external interrupt 0 is occurred.

INT0IF must be clear by firmware.

T1IF: Timer1 underflow interrupt flag bit.

T1IF=1, Timer1 underflow interrupt is occurred.

T1IF must be clear by firmware.

LVDIF: Low-voltage detector interrupt flag bit.

LVDIF=1, Low-voltage detector interrupt is occurred.

LVDIF must be clear by firmware.

#### **WDTIF:** WDT timeout interrupt flag bit.

WDTIF=1, WDT timeout interrupt is occurred.

WDTIF must be clear by firmware.

#### INT1IF: External interrupt 1 flag bit.

INT1IF=1, external interrupt 1 is occurred.

INT1IF must be clear by firmware.

#### Note: When corresponding INTE bit is not enabled, the read interrupt flag is 0.

#### 3.1.17 ADMD (ADC mode Register)

| Name | SFR Type      | Addr. | Bit7 | Bit6  | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|------|-------|------|------|------|------|------|------|
| ADMD | R             | 0x10  | ADEN | START | EOC  | GCHS | CHS3 | CHS2 | CHS1 | CHS0 |
| F    | R/W Property  |       | R/W  | W     | R    | R/W  | R/W  | R/W  | R/W  | R/W  |
|      | Initial Value |       | 0    | 0     | 1    | 0    | 0    | 0    | 0    | 0    |

ADEN: ADC enable bit.

ADEN=1, ADC is enabled.

START: Start an ADC conversion session.

When write 1 to this bit, start to execute ADC converting. This bit is write-only. Read this bit will get 0.

EOC: ADC status bit, read-only.

EOC=1 : ADC is end-of-convert, the ADC data present in ADR and ADD is available.

EOC=0 : ADC is in procession.

#### GCHS: ADC global channel select bit.

GCHS=0 : disable all ADC input channel.

GCHS=1 : enable ADC input channel.

CHS3~0: ADC input channel select bits.

0000=select PA0 pad as ADC input,

0001=select PA1 pad as ADC input,

- 0010=select PA2 pad as ADC input,
- 0011=select PA3 pad as ADC input,

0100=select PA4 pad as ADC input,

0101=select PB1 pad as ADC input,

0110=select PB2 pad as ADC input, 0111=select PB3 pad as ADC input, 1000=select PB4 pad as ADC input, 1001=select PB5 pad as ADC input, 1010=select PB6 pad as ADC input, 1011=select PB7 pad as ADC input, 1100=select 1/4 VDD as ADC input.

#### 3.1.18 ADR (ADC clock, ADC interrupt flag and ADC LSB output Register)

| Name | SFR Type     | Addr. | Bit7 | Bit6 | Bit5  | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|------|--------------|-------|------|------|-------|-------|------|------|------|------|
| ADR  | R            | 0x11  | ADIF | ADIE | ADCK1 | ADCK0 | AD3  | AD2  | AD1  | AD0  |
| R    | /W Property  | /     | R/W  | R/W  | R/W   | R/W   | R    | R    | R    | R    |
| I    | nitial Value |       | 0    | 0    | 0     | 0     | Х    | Х    | Х    | Х    |

ADIF: ADC interrupt flag bit.

ADIF=1, ADC end-of-convert interrupt is occurred.

ADIF must be clear by firmware.

ADIE: ADC end-of-convert interrupt enable bit.

ADIE=1 : enable ADC interrupt.

ADIE=0 : disable ADC interrupt.

ADCK1~0: ADC clock select.

00: ADC clock= FINST/16, 01: ADC clock= FINST/8, 10: ADC clock= FINST/1, 11: ADC clock= FINST/2.

AD3~0: 12-bit low-nibble ADC data buffer.

| 3.1.19 | ADD (ADC | output data | Register) |
|--------|----------|-------------|-----------|
|--------|----------|-------------|-----------|

| Name | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|------|------|------|------|------|------|------|------|
| ADD  | R             | 0x12  | AD11 | AD10 | AD9  | AD8  | AD7  | AD6  | AD5  | AD4  |
|      | R/W Property  | y     | R    | R    | R    | R    | R    | R    | R    | R    |
|      | Initial Value |       | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    |

**AD11~4:** High-byte ADC data buffer.

#### 3.1.20 ADVREFH (ADC high reference voltage Register)

| Name    | SFR Type    | Addr. | Bit7   | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------|-------------|-------|--------|------|------|------|------|------|------|------|
| ADVREFH | R           | 0x13  | EVHENB | -    | -    | -    | -    | -    | VHS1 | VHS0 |
| R/      | W Property  |       | R/W    | -    | -    | -    | -    | -    | R/W  | R/W  |
| In      | itial Value |       | 0      | Х    | Х    | Х    | Х    | Х    | 1    | 1    |

EVHENB: ADC reference high voltage (VREFH) select control bit.

EVHENB=0: ADC reference high voltage is internal generated, the voltage selected depends on VHS1~0.

EVHENB=1: ADC reference high voltage is supplied by external pin PA0.

VHS1~0: ADC internal reference high voltage select bits.

11: VREFH=VDD, 10: VREFH=4V, 01: VREFH=3V, 00: VREFH=2V.

#### 3.1.21 ADCR (Sampling pulse and ADC bit Register)

| Name | SFR<br>Type | Addr. | Bit7       | Bit6       | Bit5       | Bit4       | Bit3  | Bit2  | Bit1  | Bit0  |
|------|-------------|-------|------------|------------|------------|------------|-------|-------|-------|-------|
| ADCR | R           | 0x14  | PB<br>CON7 | PB<br>CON6 | PB<br>CON5 | PB<br>CON4 | SHCK1 | SHCK0 | ADCR1 | ADCR0 |
| R/\  | N Prope     | rty   | R/W        | R/W        | R/W        | R/W        | R/W   | R/W   | R/W   | R/W   |
| In   | itial Valu  | е     | 0          | 0          | 0          | 0          | 1     | 0     | 1     | 0     |

SHCK1~0: Sampling pulse width select.

00: 1 ADC clock, 01: 2 ADC clock, 10: 4 ADC clock, 11: 8 ADC clock.

ADCR1~0: ADC conversion bit no. select.

00: 8-bit ADC, 01: 10-bit ADC, 1x: 12-bit ADC.

**PBCONx:** PBx analog pin select,  $4 \le x \le 7$ .

0=PBx can be analog ADC input or digital I/O pin.

1=PBx is pure analog ADC input pin for power-saving.

#### 3.1.22 AWUCON (PortA Wake-up Control Register)

| Name   | SFR<br>Type | Addr. | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|--------|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| AWUCON | R           | 0x15  | WUPA7 | WUPA6 | WUPA5 | WUPA4 | WUPA3 | WUPA2 | WUPA1 | WUPA0 |
| R/W    | Propert     | y     | R/W   |
| Initia | al Value    |       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**WUPAx:** Enable/disable PAx wake-up function,  $0 \le x \le 7$ .

WUPAx=1, enable PAx wake-up function.

WUPAx=0, disable PAx wake-up function.

#### 3.1.23 PACON (ADC analog pin Register)

| Name  | SFR<br>Type | Addr | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|-------|-------------|------|--------|--------|--------|--------|--------|--------|--------|--------|
| PACON | R           | 0x16 | PBCON3 | PBCON2 | PBCON1 | PACON4 | PACON3 | PACON2 | PACON1 | PACON0 |
| R/W   | Proper      | ty   | R/W    |
| Init  | ial Value   | ;    | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

**PACONX:** PAx analog pin select,  $0 \le x \le 4$ .

0=PAx can be analog ADC input or digital I/O pin.

1=PAx is pure analog ADC input pin for power-saving.

#### **PBCONx:** PBx analog pin select, $1 \le x \le 3$ .

0=PBx can be analog ADC input or digital I/O pin.

1=PBx is pure analog ADC input pin for power-saving.

#### 3.1.23 ADJMD (ADC analog pin Register)

| Name          | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5     | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|-------------|-------|------|------|----------|------|------|------|------|------|
| ADJMD         | R           | 0x17  | -    | -    | ADJ_SIGN | ADJ4 | ADJ3 | ADJ2 | ADJ1 | ADJ0 |
| R/W Property  |             |       | -    | -    | R/W      | R/W  | R/W  | R/W  | R/W  | R/W  |
| Initial Value |             |       | Х    | Х    | 0        | 0    | 0    | 0    | 0    | 0    |

#### **ADJ[x]:** adjustment bit select, $0 \le x \le 4$ .

00000 = offset 0mV 11111 = offset 11mV.

#### ADJ\_SIGN: adjustment sign bit

0 = adc data decrease

1 = adc data increase

Note: For application, please refer to NYIDE example code "ADC\_Interrupt \_AutoK".

#### 3.1.24 INTEDG (Interrupt Edge Register)

| Name          | SFR<br>Type | Addr. | Bit7    | Bit6 | Bit5 | Bit4 | Bit3   | Bit2   | Bit1   | Bit0   |
|---------------|-------------|-------|---------|------|------|------|--------|--------|--------|--------|
| INTEDG        | R           | 0x18  | INT2DEG | EIS2 | EIS1 | EIS0 | INT1G1 | INT1G0 | INT0G1 | INT0G0 |
| R/W Property  |             |       | R/W     | R/W  | R/W  | R/W  | R/W    | R/W    | R/W    | R/W    |
| Initial Value |             |       | 0       | 0    | 0    | 0    | 0      | 1      | 0      | 1      |

**EIS2**: External interrupt 2 select bit

EIS2=1, PA5 is external interrupt 2.

EIS2=0, PA5 is GPIO.

**EIS1**: External interrupt 1 select bit

EIS1=1, PB1/PA3 is external interrupt 1.

EIS1=0, PB1/PA3 is GPIO.

EIS0: External interrupt 0 select bit

EIS0=1, PB5/PA4 is external interrupt 0.

EIS0=0, PB5/PA4 is GPIO.

INT1G1~0: INT1 edge trigger select bit.

00: reserved, 01: rising edge, 10: falling edge, 11: rising/falling edge.

#### INT0G1~0: INT0 edge trigger select bit.

00: reserved, 01: rising edge, 10: falling edge, 11: rising/falling edge.

#### INT2DEG: INT2 edge trigger select bit.

0: falling edge, 1: rising edge.

#### 3.1.25 TMRH (Timer High Byte Register)

| Name | SFR<br>Type   | Addr. | Bit7 | Bit6 | Bit5  | Bit4  | Bit3          | Bit2          | Bit1          | Bit0          |
|------|---------------|-------|------|------|-------|-------|---------------|---------------|---------------|---------------|
| TMRH | R             | 0x19  | -    | -    | TMR19 | TMR18 | PWM2<br>DUTY9 | PWM2<br>DUTY8 | PWM1<br>DUTY9 | PWM1<br>DUTY8 |
| R/W  | R/W Property  |       | -    | -    | R/W   | R/W   | R/W           | R/W           | R/W           | R/W           |
| Init | Initial Value |       | Х    | Х    | Х     | Х     | Х             | Х             | Х             | Х             |

**TMR19, TMR18:** Timer1 MSB 2 bits. Write these 2 bits will overwrite the 10-bit Timer1 load value of bit 9 and 8. Read these 2 bits will get the Timer1 bit9-8 current value.

PWM2DUTY9~8: PWM2 duty data MSB 2 bits.

PWM1DUTY9~8: PWM1 duty data MSB 2 bits.

#### 3.1.26 ANAEN (Analog Circuit Enable Register)

| Name          | SFR Type     | Addr. | Bit7  | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|--------------|-------|-------|------|------|------|------|------|------|------|
| ANAEN         | R            | 0x1A  | CMPEN | -    | -    | -    | -    | -    | -    | -    |
| F             | R/W Property |       |       | -    | -    | -    | -    | -    | -    | -    |
| Initial Value |              |       | 0     | Х    | Х    | Х    | Х    | Х    | Х    | Х    |

CMPEN: Enable/disable voltage comparator.

CMPEN=1, enable voltage comparator.

CMPEN=0, disable voltage comparator.

#### 3.1.27 RFC (RFC Register)

| Name | SFR Type      | Addr. | Bit7  | Bit6 | Bit5 | Bit4 | Bit3 | Bit2      | Bit1 | Bit0 |  |
|------|---------------|-------|-------|------|------|------|------|-----------|------|------|--|
| RFC  | R             | 0x1B  | RFCEN | -    | -    | -    |      | PSEL[3:0] |      |      |  |
| F    | R/W Property  |       | R/W   | -    | -    | -    | R/W  |           |      |      |  |
|      | Initial Value |       |       | Х    | Х    | Х    | 0    |           |      |      |  |

**RFCEN:** Enable/disable RFC function.

RFCEN=1, enable RFC function.

RFCEN=0, disable RFC function.

PSEL[3:0]: Select RFC pad.

| PSEL[3:0] | RFC PAD |
|-----------|---------|
| 0000      | PA0     |
| 0001      | PA1     |
| 0010      | PA2     |
| 0011      | PA3     |
| 0100      | PA4     |
| 0101      | PA5     |
| 0110      | PA6     |
| 0111      | PA7     |
| 1000      | PB0     |
| 1001      | PB1     |
| 1010      | PB2     |
| 1011      | PB3     |
| 1100      | PB4     |
| 1101      | PB5     |
| 1110      | PB6     |
| 1111      | PB7     |

Table 3 RFC pad select

#### 3.1.28 TM4RH (Timer4 High Byte Register)

| Name  | SFR<br>Type   | Addr. | Bit7  | Bit6  | Bit5 | Bit4 | Bit3   | Bit2   | Bit1   | Bit0   |
|-------|---------------|-------|-------|-------|------|------|--------|--------|--------|--------|
| TM4RH | R             | 0x1C  | TMR49 | TMR48 | -    | -    | PWM4D9 | PWM4D8 | PWM3D9 | PWM3D8 |
| R/    | R/W Property  |       | R/W   | R/W   | -    | -    | R/W    | R/W    | R/W    | R/W    |
| Ir    | Initial Value |       |       | Х     | Х    | Х    | Х      | Х      | Х      | Х      |

TMR49, TMR48: Timer4 MSB 2 bits. Write these 2 bits will overwrite the 10-bit Timer4 load value of bit 9 and

8. Read these 2 bits will get the Timer4 bit9-8 current value.

PWM4DUTY9~8: PWM4 duty data MSB 2 bits.

PWM3DUTY9~8: PWM3 duty data MSB 2 bits.

#### 3.1.29 OSCCAL (Internal Oscillator Calibration)

| Name    | SFR<br>Type   | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2                                  | Bit1        | Bit0        |
|---------|---------------|-------|------|------|------|------|------|---------------------------------------|-------------|-------------|
| OSCCALH | R             | 0x1D  | -    | -    | -    | -    | -    | OSC<br>CAL10                          | OSC<br>CAL9 | OSC<br>CAL8 |
| R/W     | R/W Property  |       | -    | -    | -    | -    | -    | R/W                                   | R/W         | R/W         |
| Initi   | Initial Value |       |      | Х    | Х    | Х    | Х    | V_HRC 8 bits option trim data bit[7:5 |             |             |

| Name    | SFR<br>Type  | Addr. | Bit7        | Bit6            | Bit5        | Bit4        | Bit3        | Bit2        | Bit1        | Bit0        |
|---------|--------------|-------|-------------|-----------------|-------------|-------------|-------------|-------------|-------------|-------------|
| OSCCALL | R            | 0x1E  | OSC<br>CAL7 | OSC<br>CAL6     | OSC<br>CAL5 | OSC<br>CAL4 | OSC<br>CAL3 | OSC<br>CAL2 | OSC<br>CAL1 | OSC<br>CAL0 |
| R/V     | R/W Property |       |             | R/W R/W R/W R/W |             |             |             | R/W         | R/W         | R/W         |
| Ini     | е            | V_H   | RC 8 bits   | option tri      | 1           | 0           | 0           |             |             |             |

**OSCCAL10~0:** V\_HRC 8 bits calibration data load to OSCCAL10~OSCCAL3 and user can adjust OSCCAL10~0 at slow mode.

#### 3.1.30 INTE2 (Interrupt Enable and Flag 2nd. Register)

| Name  | SFR Type      | Addr. | Bit7   | Bit6 | Bit5 | Bit4 | Bit3   | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|--------|------|------|------|--------|------|------|------|
| INTE2 | R             | 0x1F  | INT2IF | T4IF | -    | -    | INT2IE | T4IE | -    | -    |
| F     | R/W Property  |       | R/W    | R/W  | -    | -    | R/W    | R/W  | -    | -    |
|       | Initial Value |       |        | 0    | Х    | Х    | 0      | 0    | Х    | Х    |

INT2IF: External interrupt 2 flag bit. INT2IF=1, external interrupt 2 is occurred. INT2IF must be clear by firmware.

- T4IF:Timer4 underflow interrupt flag bit.T4IF=1, Timer4 underflow interrupt is occurred.T4IF must be clear by firmware.
- INT2IE: External interrupt 2 enable bit. INT2IE=1, enable external interrupt 2. INT2IE=0, disable external interrupt 2.
- T4IE:Timer4 underflow interrupt enable bit.T4IE=1, enable Timer4 underflow interrupt.T4IE=0, disable Timer4 underflow interrupt.

#### 3.2 T0MD Register

TOMD is a readable/writeable register which is only accessed by instruction TOMD / TOMDR.

| Name | SFR Type             | Addr. | Bit7   | Bit6         | Bit5 | Bit4 | Bit3   | Bit2 | Bit1 | Bit0 |
|------|----------------------|-------|--------|--------------|------|------|--------|------|------|------|
| T0MD | -                    | -     | LCKTM0 | GP6          | TOCS | T0CE | PS0WDT | Р    | 0]   |      |
| I    | R/W Property         | /     | R/W    |              |      |      |        |      |      |      |
| Init | Initial Value(note*) |       |        | 0 0 1 1 1 11 |      |      |        | 111  |      |      |

PS0SEL[2:0]: Prescaler0 dividing rate selection. The rate depends on Prescaler0 is assigned to Timer0 or WDT. When Prescaler0 is assigned to WDT, the dividing rate is dependent on which timeout mechanism is selected.

|             |                      | Dividing Rate           |                             |
|-------------|----------------------|-------------------------|-----------------------------|
| PS0SEL[2:0] | PS0WDT=0<br>(Timer0) | PS0WDT=1<br>(WDT Reset) | PS0WDT=1<br>(WDT Interrupt) |
| 000         | 1:2                  | 1:1                     | 1:2                         |
| 001         | 1:4                  | 1:2                     | 1:4                         |
| 010         | 1:8                  | 1:4                     | 1:8                         |
| 011         | 1:16                 | 1:8                     | 1:16                        |
| 100         | 1:32                 | 1:16                    | 1:32                        |
| 101         | 1:64                 | 1:32                    | 1:64                        |
| 110         | 1:128                | 1:64                    | 1:128                       |
| 111         | 1:256                | 1:128                   | 1:256                       |

Table 4 Prescaler0 Dividing Rate

**PS0WDT:** Prescaler0 assignment.

PS0WDT=1, Prescaler0 is assigned to WDT.

PS0WDT=0, Prescaler0 is assigned to Timer0.

### Note: Always set PS0WDT and PS0SEL[2:0] before enabling watchdog or timer0 interrupt, or reset or interrupt may be falsely triggered.

**T0CE:** Timer0 external clock edge selection.

T0CE=1, Timer0 will increase one while high-to-low transition occurs on pin EX\_CKI0.

T0CE=0, Timer0 will increase one while low-to-high transition occurs on pin EX\_CKI0.

#### Note: T0CE is also applied to Low Oscillator Frequency as Timer0 clock source condition.

**T0CS:** Timer0 clock source selection.

T0CS=1, External clock on pin EX\_CKI0 or Low Oscillator Frequency (I\_LRC or E\_LXT) is selected. T0CS=0, Instruction clock F<sub>INST</sub> is selected.

GP6: General register.

**LCKTM0:** When T0CS=1, timer 0 clock source can be optionally selected to be low-frequency oscillator.

T0CS=0, Instruction clock  $\mathsf{F}_{\mathsf{INST}}$  is selected as Timer0 clock source.

T0CS=1, LCKTM0=0, external clock on pin EX\_CKI0 is selected as Timer0 clock source.

T0CS=1, LCKTM0=1, Low Oscillator Frequency (I\_LRC or E\_LXT, depends on configuration word Low Oscillator Frequency) output replaces pin EX\_CKI0 as Timer0 clock source.

#### *Note: For more detail descriptions of Timer0 clock source select, please see Timer0 section.*

#### 3.3 F-page Special Function Register

#### 3.3.1 IOSTA (PortA I/O Control Register)

| Name  | SFR Type      | Addr. | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|-------|---------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| IOSTA | F             | 0x5   | IOPA7 | IOPA6 | IOPA5 | IOPA4 | IOPA3 | IOPA2 | IOPA1 | IOPA0 |
| F     | R/W Property  |       |       | R/W   |
|       | Initial Value |       |       | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

**IOPAx:** PAx I/O mode selection,  $0 \le x \le 7$ .

IOPAx=1, PAx is input mode.

IOPAx=0, PAx is output mode.

#### 3.3.2 IOSTB (PortB I/O Control Register)

| Name          | SFR Type     | Addr. | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|---------------|--------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| IOSTB         | F            | 0x6   | IOPB7 | IOPB6 | IOPB5 | IOPB4 | IOPB3 | IOPB2 | IOPB1 | IOPB0 |
|               | R/W Property |       |       | R/W   |
| Initial Value |              | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |       |

**IOPBx:** PBx I/O mode selection,  $0 \le x \le 7$ .

IOPBx=1, PBx is input mode.

IOPBx=0, PBx is output mode.

#### 3.3.3 IOSTC (PortC I/O Control Register)

| Name          | SFR Type     | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1  | Bit0  |
|---------------|--------------|-------|------|------|------|------|------|------|-------|-------|
| IOSTC         | F            | 0x7   | -    | -    | -    | -    | -    | -    | IOPC1 | IOPC0 |
| F             | R/W Property |       | -    | -    | -    | -    | -    | -    | R/W   | R/W   |
| Initial Value |              | Х     | Х    | Х    | Х    | Х    | Х    | 1    | 1     |       |

**IOPCx:** PCx I/O mode selection,  $0 \le x \le 1$ .

IOPCx=1, PCx is input mode.

IOPCx=0, PCx is output mode.

#### 3.3.4 APHCON (PortA Pull-High Resistor Control Register)

| Name          | SFR Type   | Addr. | Bit7   | Bit6   | Bit5    | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|---------------|------------|-------|--------|--------|---------|--------|--------|--------|--------|--------|
| APHCON        | F          | 0x9   | /PHPA7 | /PHPA6 | /PLPA5* | /PHPA4 | /PHPA3 | /PHPA2 | /PHPA1 | /PHPA0 |
| R/V           | V Property |       |        |        |         | R/     | W      |        |        |        |
| Initial Value |            |       | 1      | 1      | 1       | 1      | 1      | 1      | 1      | 1      |

**/PHPAx:** Enable/disable Pull-High resistor of PAx, x=0~4, 6~7.

/PHPAx=1, disable Pull-High resistor of PAx.

/PHPAx=0, enable Pull-High resistor of PAx.

\*/PLPA5: Enable/disable Pull-Low resistor of PA5.

/PLPA5=1, disable Pull-Low resistor of PA5.

/PLPA5=0, enable Pull-Low resistor of PA5.

### Note: When PA6 and PA7 are used as crystal oscillator pads, the Pull-High resistor should not enable. Or the oscillation may fail.

#### 3.3.5 PS0CV (Prescaler0 Counter Value Register)

| Name  | SFR Type      | Addr. | Bit7       | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|------------|------|------|------|------|------|------|------|
| PS0CV | F             | 0xA   | PS0CV[7:0] |      |      |      |      |      |      |      |
| F     | R/W Property  |       |            |      |      | I    | R    |      |      |      |
|       | Initial Value | 1     | 1          | 1    | 1    | 1    | 1    | 1    | 1    |      |

While reading PS0CV, it will get current value of Prescaler0 counter.

#### 3.3.6 CPLCON (PortC Pull-Low Resistor Control Register)

| Name   | SFR Type     | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1   | Bit0   |
|--------|--------------|-------|------|------|------|------|------|------|--------|--------|
| CPLCON | F            | 0xB   | -    | -    | -    | -    | -    | -    | /PLPC1 | /PLPC0 |
|        | R/W Property |       |      |      |      | -    |      |      | R      | /W     |
|        | Х            | Х     | Х    | Х    | Х    | Х    | 1    | 1    |        |        |

**/PLPCx:** Disable/enable PCx Pull-Low resistor,  $0 \le x \le 1$ .

/PLPCx=1, disable PCx Pull-Low resistor.

/PLPCx=0, enable PCx Pull-Low resistor.

#### 3.3.7 BODCON (PortB Open-Drain Control Register)

| Name          | SFR Type     | Addr. | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|---------------|--------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| BODCON        | F            | 0xC   | ODPB7 | ODPB6 | ODPB5 | ODPB4 | ODPB3 | ODPB2 | ODPB1 | ODPB0 |
| R/V           | R/W Property |       |       | R/W   |
| Initial Value |              |       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**ODPBx:** Enable/disable open-drain of PBx,  $0 \le x \le 7$ .

ODPBx=1, enable open-drain of PBx.

ODPBx=0, disable open-drain of PBx.

#### 3.3.8 CODCON (PortC Open-Drain Control Register)

| Name          | SFR Type     | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1  | Bit0  |
|---------------|--------------|-------|------|------|------|------|------|------|-------|-------|
| CODCON        | F            | 0xD   | -    | -    | -    | -    | -    | -    | ODPC1 | ODPC0 |
| R/V           | R/W Property |       |      | -    | -    | -    | -    | -    | R/W   | R/W   |
| Initial Value |              |       | Х    | Х    | Х    | Х    | Х    | Х    | 0     | 0     |

**ODPCx:** Enable/disable open-drain of PCx,  $0 \le x \le 1$ .

ODPCx=1, enable open-drain of PCx.

ODPCx=0, disable open-drain of PCx.

#### 3.3.9 CMPCR (Comparator voltage select Control Register)

| Name          | SFR Type     | Addr | Bit7 | Bit6    | Bit5    | Bit4    | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|--------------|------|------|---------|---------|---------|------|------|------|------|
| CMPCR         | F            | 0xE  | -    | RBIAS_H | RBIAS_L | CMP_INV | PS1  | PS0  | NS1  | NS0  |
| R             | R/W Property |      |      |         | R/W     |         |      |      |      |      |
| Initial Value |              |      | 0    | 0       | 0       | 0       | 1    | 1    | 0    | 0    |

NS[1:0]: Comparator inverting input select.

| NS[1:0] | Inverting input |
|---------|-----------------|
| 00      | PA1             |
| 01      | PA3             |
| 10      | Bandgap (0.6V)  |
| 11      | Vref            |

PS[1:0]: Comparator non-inverting input select

| PS[1:0] | Non-inverting input |
|---------|---------------------|
| 00      | PA0                 |
| 01      | PA2                 |
| 10      | Vref                |
| 11      |                     |

CMPF\_INV: Comparator output inverse control bit.

CMPF\_INV = 1, Inverse comparator output.

CMPF\_INV = 0, Non-inverse comparator output.

**RBIAS\_L**, **RBIAS\_H**: Set corresponding voltage reference levels

(please refer to chapter 3.16.1)

*Note: RBIAS\_H* and *RBIAS\_L* must be set as "0" to avoid power consumption in Halt mode or Standby mode.

#### 3.3.10 PCON1 (Power Control Register1)

| Name          | SFR Type     | Addr. | Bit7 | Bit6   | Bit5  | Bit4  | Bit3  | Bit2  | Bit1 | Bit0 |
|---------------|--------------|-------|------|--------|-------|-------|-------|-------|------|------|
| PCON1         | F            | 0xF   | GIE  | LVDOUT | LVDS3 | LVDS2 | LVDS1 | LVDS0 | GP1  | T0EN |
| F             | R/W Property |       |      | R      | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  |
| Initial Value |              |       | 0    | Х      | 0     | 1     | 1     | 1     | 0    | 1    |

TOEN: Enable/disable Timer0.

T0EN=1, enable Timer0.

T0EN=0, disable Timer0.

**GIE:** Global interrupt enable bit.

GIE=1, enable all unmasked interrupts.

GIE=0, disable all interrupts.

Set by instruction ENI, clear by instruction DISI, read by instruction IOSTR.

**GP1:** General purpose register bit.

**LVDOUT:** Low voltage detector output, read-only.

LVDS3~0 : Select LVD voltage.

| LVDS[3:0] | Voltage |
|-----------|---------|
|           |         |
| 0000      | 1.9V    |
| 0001      | 2.0V    |
| 0010      | 2.2V    |
| 0011      | 2.4V    |
| 0100      | 2.6V    |
| 0101      | 2.8V    |
| 0110      | 2.9V    |
| 0111      | 3.0V    |
| 1000      | 3.15V   |
| 1001      | 3.30V   |
| 1010      | 3.45V   |
| 1011      | 3.60V   |
| 1100      | 3.75V   |
| 1101      | 3.90V   |
| 1110      | 4.05V   |
| 1111      | 4.15V   |

Table 4 LVD voltage select

#### 3.4 S-page Special Function Register

#### 3.4.1 TMR1 (Timer1 Register)

| Name | SFR Type      | Addr. | Bit7     | Bit6      | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |  |
|------|---------------|-------|----------|-----------|------|------|------|------|------|------|--|--|
| TMR1 | S             | 0x0   |          | TMR1[7:0] |      |      |      |      |      |      |  |  |
|      | R/W Property  |       | R/W      |           |      |      |      |      |      |      |  |  |
|      | Initial Value |       | XXXXXXXX |           |      |      |      |      |      |      |  |  |

When reading register TMR1, it will obtain current value of 10-bit down-count Timer1 at TMR1[9:0]. When writing register TMR1, it will write data from TMRH[5:4] and Timer1 reload register to TMR1[9:0] current content.

#### 3.4.2 T1CR1 (Timer1 Control Register1)

| Name  | SFR<br>Type | Addr. | Bit7    | Bit6    | Bit5  | Bit4   | Bit3    | Bit2 | Bit1 | Bit0 |
|-------|-------------|-------|---------|---------|-------|--------|---------|------|------|------|
| T1CR1 | S           | 0x1   | PWM10EN | PWM10AL | TM10E | VFSEL1 | TM1_HRC | T10S | T1RL | T1EN |
| R/V   | V Proper    | ty    | R/W     | R/W     | R/W   | R/W    | R/W     | R/W  | R/W  | R/W  |
| Ini   | tial Valu   | e     | 0       | 0       | 0     | 0      | 0       | 0    | 0    | 0    |

This register is used to configure Timer1 functionality.

T1EN: Enable/disable Timer1.

T1EN=1, enable Timer1.

T1EN=0, disable Timer1.

#### T1RL: Configure Timer1 down-count mechanism while Non-Stop mode is selected (T1OS=0).

T1RL=1, initial value is reloaded from reload register TMR1[9:0].

T1RL=0, continuous down-count from 0x3FF when underflow is occurred.

T1OS: Configure Timer1 operating mode while underflow is reached.

T1OS=1, One-Shot mode. Timer1 will count once from the initial value to 0x00.

T1OS=0, Non-Stop mode. Timer1 will keep down-count after underflow.

| T10S | T1RL | Timer1 Down-Count Functionality                                                                                                   |  |  |  |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0    | 0    | Timer1 will count from reload value down to 0x00.<br>When underflow is reached, 0x3FF is reloaded and continues down-count.       |  |  |  |
| 0    | 1    | 1Timer1 will count from reload value down to 0x00.When underflow is reached, reload value is reloaded and continues to down-court |  |  |  |
| 1    | x    | Timer1 will count from initial value down to 0x00.<br>When underflow is reached, Timer1 will stop down-count.                     |  |  |  |

#### Table 8 Timer1 Functionality

TM1\_HRC: Timer1 clock source selection.

TM1HRC=1, PWM1, 2, 3 & Timer 1 clock source is High Oscillator clock.

TM1HRC=0, PWM1, 2, 3 & Timer 1 clock source selection depends on T1CS register bit

Note: If set Timer1 clock source is high oscillator clock (TM1HRC=1), user must disable precaler1.

VFSEL1: Timer1 special clock source selection.

TM1HRC=1, PWM1, 2, 3 & Timer 1 clock source is special High Oscillator clock.

TM1HRC=0, PWM1, 2, 3 & Timer 1 clock source selection depends on T1CS register bit

Note: VFSEL1 has higher priority than TM1\_HRC.

**PWM1OAL:** Define PWM1 output active state.

PWM1OAL=1, PWM1 output is active low.

PWM1OAL=0, PWM1 output is active high.

**PWM10EN:** Enable/disable PWM1 output. PWM10EN=1, PWM1 output will be present on PB1/PB4. PWM10EN=0, PB1/PB4 is GPI0.

**TM1OE:** Enable/disable Timer1 match output, T1OUT toggle output when Timer1 underflow occurs. TM1OE=1, enable T1OUT output to pad PB4. TM1OE=0, PB4 is GPIO.

*Note:* **T1OUT** *output to pad PB4 has higher priority than PWM1 output.* 

#### 3.4.3 T1CR2 (Timer1 Control Register2)

| Name          | SFR Type     | Addr. | Bit7 | Bit6 | Bit5 | Bit4   | Bit3        | Bit2 | Bit1 | Bit0 |
|---------------|--------------|-------|------|------|------|--------|-------------|------|------|------|
| T1CR2 S 0x2   |              | -     | -    | T1CS | T1CE | /PS1EN | PS1SEL[2:0] |      | :0]  |      |
|               | R/W Property |       |      | -    | R/W  | R/W    | R/W         | R/W  | R/W  | R/W  |
| Initial Value |              |       | Х    | Х    | 1    | 1      | 1           | 1    | 1    | 1    |

This register is used to configure Timer1 functionality.

| PS1SEL[2:0] | Dividing Rate |  |  |  |
|-------------|---------------|--|--|--|
| 000         | 1:2           |  |  |  |
| 001         | 1:4           |  |  |  |
| 010         | 1:8           |  |  |  |
| 011         | 1:16          |  |  |  |
| 100         | 1:32          |  |  |  |
| 101         | 1:64          |  |  |  |
| 110         | 1:128         |  |  |  |
| 111         | 1:256         |  |  |  |

Table 9Prescaler1 Dividing Rate

Note: Always set PS1SEL[2:0] at /PS1EN=1, or interrupt may be falsely triggered.

/PS1EN: Disable/enable Prescaler1.

/PS1EN=1, disable Prescaler1.

/PS1EN=0, enable Prescaler1.

**T1CE:** Timer1 external clock edge selection.

T1CE=1, Timer1 will decrease one while high-to-low transition occurs on pin EX\_CKI0.

T1CE=0, Timer1 will decrease one while low-to-high transition occurs on pin EX\_CKI0.

**T1CS:** Timer1 clock source selection.

T1CS=1, External clock on pin EX\_CKI0 is selected.

T1CS=0, Instruction clock is selected.

#### 3.4.4 PWM1DUTY (PWM1 Duty Register)

| Name     | SFR Type     | Addr. | Bit7          | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |  |  |
|----------|--------------|-------|---------------|------|------|------|------|------|------|------|--|--|--|
| PWM1DUTY | S            | 0x3   | PWM1DUTY[7:0] |      |      |      |      |      |      |      |  |  |  |
| R        | R/W Property |       |               |      |      | W    |      |      |      |      |  |  |  |
| l        | XXXXXXXX     |       |               |      |      |      |      |      |      |      |  |  |  |

The reload value of 10-bit Timer1 stored on registers TMRH[5:4] and TMR1[7:0] is used to define the PWM1 frame rate, and registers TMRH[1:0] and PWM1DUTY[7:0] is used to define the duty cycle of PWM1.

#### 3.4.5 PS1CV (Prescaler1 Counter Value Register)

| Name  | SFR Type      | Addr. | Bit7       | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|------------|------|------|------|------|------|------|------|
| PS1CV | S             | 0x4   | PS1CV[7:0] |      |      |      |      |      |      |      |
|       | R/W Property  |       |            |      | F    | र    |      |      |      |      |
|       | Initial Value |       |            | 1    | 1    | 1    | 1    | 1    | 1    | 1    |

While reading PS1CV, it will get current value of Prescaler1 counter.

#### 3.4.6 BZ1CR (Buzzer1 Control Register)

| Name  | SFR Type      | Addr. | Bit7  | Bit6 | Bit5 | Bit4 | Bit3 | Bit2  | Bit1    | Bit0 |
|-------|---------------|-------|-------|------|------|------|------|-------|---------|------|
| BZ1CR | S             | 0x5   | BZ1EN | -    | -    | -    |      | BZ1FS | EL[3:0] |      |
|       | R/W Property  |       |       | -    | -    | -    | W    |       |         |      |
|       | Initial Value |       |       | Х    | Х    | Х    | 1    | 1     | 1       | 1    |

#### BZ1FSEL[3:0]: Frequency selection of BZ1 output.

| BZ1FSEL[3:0] | <b>BZ1 Frequency Selection</b> |               |  |  |  |  |  |
|--------------|--------------------------------|---------------|--|--|--|--|--|
| BZIFSEL[3.0] | Clock Source                   | Dividing Rate |  |  |  |  |  |
| 0000         |                                | 1:2           |  |  |  |  |  |
| 0001         |                                | 1:4           |  |  |  |  |  |
| 0010         | Prescaler1 output              | 1:8           |  |  |  |  |  |
| 0011         |                                | 1:16          |  |  |  |  |  |

| <b>B71ESEL [2:0]</b> | BZ1 Frequen   | cy Selection  |  |  |
|----------------------|---------------|---------------|--|--|
| BZ1FSEL[3:0]         | Clock Source  | Dividing Rate |  |  |
| 0100                 |               | 1:32          |  |  |
| 0101                 |               | 1:64          |  |  |
| 0110                 |               | 1:128         |  |  |
| 0111                 |               | 1:256         |  |  |
| 1000                 |               | Timer1 bit 0  |  |  |
| 1001                 |               | Timer1 bit 1  |  |  |
| 1010                 |               | Timer1 bit 2  |  |  |
| 1011                 | Timor1 output | Timer1 bit 3  |  |  |
| 1100                 | Timer1 output | Timer1 bit 4  |  |  |
| 1101                 |               | Timer1 bit 5  |  |  |
| 1110                 |               | Timer1 bit 6  |  |  |
| 1111                 |               | Timer1 bit 7  |  |  |

Table 10 Buzzer1 Output Frequency Selection

**BZ1EN:** Enable/Disable BZ1 output.

BZ1EN=1, enable Buzzer1.

BZ1EN=0, disable Buzzer1.

#### 3.4.7 IRCR (IR Control Register)

| Name          | SFR Type     | Addr. | Bit7      | Bit6 | Bit5 | Bit4 | Bit3 | Bit2   | Bit1   | Bit0 |
|---------------|--------------|-------|-----------|------|------|------|------|--------|--------|------|
| IRCR          | S            | 0x6   | IROSC358M | -    | -    | -    | -    | IRCSEL | IRF57K | IREN |
| 1             | R/W Property |       | W         | -    | -    | -    | -    | W      | W      | W    |
| Initial Value |              | 0     | Х         | Х    | Х    | Х    | 0    | 0      | 0      |      |

**IREN:** Enable/Disable IR carrier output.

IREN=1, enable IR carrier output.

IREN=0, disable IR carrier output.

**IRF57K:** Selection of IR carrier frequency.

IRF57K=1, IR carrier frequency is 57KHz.

IRF57K=0, IR carrier frequency is 38KHz.

IRCSEL: Polarity selection of IR carrier.

IRCSEL=0, IR carrier will be generated when I/O pin data is 1.

IRCSEL=1, IR carrier will be generated when I/O pin data is 0.

**IROSC358M:** When external crystal is used, this bit is determined according to what kind of crystal is used.

This bit is ignored if internal high frequency oscillation is used.

IROSC358M=1, crystal frequency is 3.58MHz.

IROSC358M=0, crystal frequency is 455KHz.

Note:

#### 1. Only high oscillation (FHOSC) (See section 3.17) can be used as IR clock source.

#### 2. Division ratio for different oscillation type.

| OSC. Type      | 57KHz | 38KHz | Conditions                                                                       |
|----------------|-------|-------|----------------------------------------------------------------------------------|
| High IRC(4MHz) | 64    | 96    | HIRC mode (the input to IR module is set to 4MHz no matter what system clock is) |
| Xtal 3.58MHz   | 64    | 96    | Xtal mode & IROSC358M=1                                                          |
| Xtal 455KHz    | 8     | 12    | Xtal mode & IROSC358M=0                                                          |

 Table 11
 Division ratio for different oscillation type

#### 3.4.8 TBHP (Table Access High Byte Address Pointer Register)

| Name | SFR Type     | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3  | Bit2  | Bit1  | Bit0  |
|------|--------------|-------|------|------|------|------|-------|-------|-------|-------|
| TBHP | S            | 0x7   | -    | -    | -    | -    | TBHP3 | TBHP2 | TBHP1 | TBHP0 |
| F    | R/W Property |       |      |      | -    | -    | R/W   | R/W   | R/W   | R/W   |
|      | Х            | Х     | Х    | Х    | Х    | Х    | Х     | Х     |       |       |

When instruction CALLA, GOTOA or TABLEA is executed, the target address is constituted by TBHP[3:0] and ACC. ACC is the Low Byte of PC[11:0] and TBHP[3:0] is the high byte of PC[11:0].

#### 3.4.9 TBHD (Table Access High Byte Data Register)

| Name          | SFR Type     | Addr. | Bit7 | Bit6 | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|---------------|--------------|-------|------|------|-------|-------|-------|-------|-------|-------|
| TBHD          | S            | 0x8   | -    | -    | TBHD5 | TBHD4 | TBHD3 | TBHD2 | TBHD1 | TBHD0 |
| I             | R/W Property |       |      | -    | R     | R     | R     | R     | R     | R     |
| Initial Value |              |       | Х    | Х    | Х     | Х     | Х     | Х     | Х     | Х     |

When instruction TABLEA is executed, high byte of content of addressed ROM is loaded into TBHD[5:0] register. The Low Byte of content of addressed ROM is loaded to ACC.

#### 3.4.10 P2CR1 (PWM2 Control Register1)

| Name  | SFR<br>Type   | Addr. | Bit7    | Bit6    | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|---------|---------|------|------|------|------|------|------|
| P2CR1 | S             | 0xA   | PWM2OEN | PWM2OAL | -    | -    | -    | -    | -    | -    |
| R/    | R/W Property  |       | R/W     | R/W     | -    | -    | -    | -    | -    | -    |
| Ir    | Initial Value |       | 0       | 0       | Х    | Х    | Х    | Х    | Х    | Х    |

This register is used to configure PWM2 functionality.

#### **PWM2OAL:** Define PWM2 output active state.

PWM2OAL=1, PWM2 output is active low.

PWM2OAL=0, PWM2 output is active high.

PWM2OEN: Enable/disable PWM2 output.

PWM2OEN=1, PWM2 output will be present on PB3/PB5.

PWM2OEN=0, PB3/PB5 is GPIO.

#### 3.4.11 PWM2DUTY (PWM2 Duty Register)

| Name     | SFR Type    | Addr. | Bit7          | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |
|----------|-------------|-------|---------------|------|------|------|------|------|------|------|--|
| PWM2DUTY | S           | 0xC   | PWM2DUTY[7:0] |      |      |      |      |      |      |      |  |
| R/V      | V Property  |       | W             |      |      |      |      |      |      |      |  |
| In       | itial Value |       | XXXXXXXX      |      |      |      |      |      |      |      |  |

The reload value of 10-bit Timer1 stored on registers TMRH [5:4] and TMR1[7:0] is used to define the PWM2 frame rate, and registers TMRH[3:2] and PWM2DUTY[7:0] is used to define the duty cycle of PWM2.

#### 3.4.12 OSCCR (Oscillation Control Register)

| Name  | SFR<br>Type   | Addr. | Bit7   | Bit6  | Bit5  | Bit4  | Bit3 | Bit2   | Bit1    | Bit0    |
|-------|---------------|-------|--------|-------|-------|-------|------|--------|---------|---------|
| OSCCR | S             | 0xF   | CMPOUT | CMPOE | CMPIF | CMPIE | OPMI | D[1:0] | STPHOSC | SELHOSC |
| R/W   | Proper        | ty    | R      | R/W   | R/W   | R/W   | R/   | W      | R/W     | R/W     |
| Initi | Initial Value |       | Х      | 0     | 0     | 0     | 00   |        | 0       | 1       |

SELHOSC: Selection of system oscillation (Fosc).

SELHOSC=1, Fosc is high-frequency oscillation (FHOSC).

SELHOSC=0, Fosc is low-frequency oscillation (FLOSC).

**STPHOSC:** Disable/enable high-frequency oscillation (F<sub>HOSC</sub>).

STPHOSC=1, FHOSC will stop oscillation and be disabled.

STPHOSC=0, FHOSC keep oscillation.

#### **OPMD[1:0]:** Selection of operating mode.

| OPMD[1:0] | Operating Mode |
|-----------|----------------|
| 00        | Normal mode    |
| 01        | Halt mode      |
| 10        | Standby mode   |
| 11        | reserved       |

Table 15Selection of Operating Mode by OPMD[1:0]

**CMPIE:** Enable/Disable of comparator interrupt.

CMPIE=1, Enable of comparator interrupt.

CMPIE=0, Disable of comparator interrupt.

**CMPIF:** Comparator output change state interrupt is occurred.

CMPIF=1, comparator interrupt is occurred.

CMPIF must be clear by firmware.

**CMPOE:** Disable/enable comparator output to pad PB3.

CMPOE=1, enable comparator output to pad PB3.

CMPOE=0, disable comparator output to pad PB3.

#### Note: Comparator output to pad PB3 has higher priority than buzzer1 output.

CMPOUT: Comparator output status, read-only.

## Note: STPHOSC cannot be changed with SELHOSC or OPMD at the same time. STPHOSC cannot be changed with OPMD at the same time during SELHOSC=1.

#### 3.4.13 P3CR1 (PWM3 Control Register1)

| Name  | SFR<br>Type   | Addr. | Bit7    | Bit6    | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|---------|---------|------|------|------|------|------|------|
| P3CR1 | S             | 0x11  | PWM30EN | PWM3OAL | -    | -    | -    | -    | -    | -    |
| R۸    | R/W Property  |       | R/W     | R/W     | -    | -    | -    | -    | -    | -    |
| In    | Initial Value |       | 0       | 0       | Х    | Х    | Х    | Х    | Х    | Х    |

This register is used to configure PWM3 functionality.

**PWM3OAL:** Define PWM3 output active state.

PWM3OAL=1, PWM3 output is active low.

PWM3OAL=0, PWM3 output is active high.

PWM3OEN: Enable/disable PWM3 output.

PWM3OEN=1, PWM3 output will be present on PA2/PA7.

PWM3OEN=0, PA2/PA7 is GPIO.

#### 3.4.14 PWM3DUTY (PWM3 Duty Register)

| Name     | SFR Type     | Addr. | Bit7          | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |  |  |  |
|----------|--------------|-------|---------------|------|------|------|------|------|------|------|--|--|--|--|
| PWM3DUTY | S            | 0x13  | PWM3DUTY[7:0] |      |      |      |      |      |      |      |  |  |  |  |
| R        | R/W Property |       |               |      |      | W    |      |      |      |      |  |  |  |  |
| l        |              |       |               | XXXX | XXXX |      |      |      |      |      |  |  |  |  |

The reload value of 10-bit Timer1 stored on registers TMRH[5:4] and TMR1[7:0] is used to define the PWM3 frame rate, and registers TM4RH[1:0] and PWM3DUTY[7:0] is used to define the duty cycle of PWM3.

#### 3.4.15 TMR4 (Timer4 Register)

| Name | SFR Type     | Addr. | Bit7      | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |
|------|--------------|-------|-----------|------|------|------|------|------|------|------|--|
| TMR4 | S            | 0x15  | TMR4[7:0] |      |      |      |      |      |      |      |  |
|      | R/W Property |       | R/W       |      |      |      |      |      |      |      |  |



Initial Value

XXXXXXXX

When reading register TMR4, it will obtain current value of 10-bit down-count Timer4 at TMR4[9:0]. When writing register TMR4, it will write data from TM4RH[7:6] and Timer4 reload register to TMR4[9:0] current content.

#### 3.4.16 4CR1 (Timer4 Control Register1)

| Name          | SFR<br>Type  | Addr | Bit7    | Bit6    | Bit5 | Bit4   | Bit3    | Bit2 | Bit1 | Bit0 |
|---------------|--------------|------|---------|---------|------|--------|---------|------|------|------|
| T4CR1         | S            | 0x16 | PWM40EN | PWM4OAL | -    | VFSEL4 | TM4_HRC | T4OS | T4RL | T4EN |
| R/V           | R/W Property |      | R/W     | R/W     | -    | R/W    | R/W     | R/W  | R/W  | R/W  |
| Initial Value |              | 0    | 0       | Х       | 0    | 0      | 0       | 0    | 0    |      |

This register is used to configure Timer4 functionality.

T4EN: Enable/disable Timer4.

T4EN=1, enable Timer4.

T4EN=0, disable Timer4.

T4RL: Configure Timer4 down-count mechanism while Non-Stop mode is selected (T4OS=0).

T4RL=1, initial value is reloaded from reload register TMR4[9:0].

T4RL=0, continuous down-count from 0x3FF when underflow is occurred.

T4OS: Configure Timer4 operating mode while underflow is reached.

T4OS=1, One-Shot mode. Timer4 will count once from the initial value to 0x00.

T4OS=0, Non-Stop mode. Timer4 will keep down-count after underflow.

| T4OS | T4RL | Timer4 Down-Count Functionality                                                                                                       |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | Timer4 will count from reload value down to 0x00.<br>When underflow is reached, 0x3FF is reloaded and continues down-count.           |
| 0    | 1    | Timer4 will count from reload value down to 0x00.<br>When underflow is reached, reload value is reloaded and continues to down-count. |
| 1    | x    | Timer4 will count from initial value down to 0x00.<br>When underflow is reached, Timer4 will stop down-count.                         |

Table 8 Timer4 Functionality

TM4\_HRC: Timer4 clock source selection.

TM4HRC=1, PWM4 & Timer 4 clock source is High Oscillator clock.

TM4HRC=0, PWM4 & Timer 4 clock source selection depends on T4CS register bit

Note: If set Timer4 clock source is high oscillator clock (TM4HRC=1), user must disable precaler4.

**VFSEL4:** Timer4 special clock source selection.

TM4HRC=1, PWM4 & Timer 4 clock source is special High Oscillator clock.

TM4HRC=0, PWM4 & Timer 4 clock source selection depends on T4CS register bit

#### *Note: VFSEL4 has higher priority than TM4\_HRC.*

**PWM4OAL:** Define PWM4 output active state.

PWM4OAL=1, PWM4 output is active low.

PWM4OAL=0, PWM4 output is active high.

PWM4OEN: Enable/disable PWM4 output.

PWM4OEN=1, PWM4 output will be present on PA4. PWM4OEN=0, PA4 is GPIO.

#### 3.4.17 T4CR2 (Timer4 Control Register2)

| Name  | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|------|------|------|------|--------|------|------|------|
| T4CR2 | 4CR2 S 0x17   |       |      | -    | T4CS | T4CE | /PS4EN | PS   | :0]  |      |
|       | R/W Property  | -     | -    | R/W  | R/W  | R/W  | R/W    | R/W  | R/W  |      |
|       | Initial Value | Х     | Х    | 1    | 1    | 1    | 1      | 1    | 1    |      |

This register is used to configure Timer4 functionality.

|             | -             |
|-------------|---------------|
| PS4SEL[2:0] | Dividing Rate |
| 000         | 1:2           |
| 001         | 1:4           |
| 010         | 1:8           |
| 011         | 1:16          |
| 100         | 1:32          |

#### **PS4SEL[2:0]:** Prescaler4 dividing rate selection.

1:64

1:128

1:256

Table 9 Prescaler4 Dividing Rate

101

110

111

#### Note: Always set PS4SEL[2:0] at /PS1EN=1, or interrupt may be falsely triggered.

/PS4EN: Disable/enable Prescaler4

/PS4EN=1, disable Prescaler4.

/PS4EN=0, enable Prescaler4.

**T4CE:** Timer4 external clock edge selection.

T4CE=1, Timer4 will decrease one while high-to-low transition occurs on pin EX\_CKI1. T4CE=0, Timer4 will decrease one while low-to-high transition occurs on pin EX\_CKI1.

T4CS: Timer4 clock source selection.

T1CS=1, External clock on pin EX\_CKI1 is selected.(option=1:PA2, option=0:PA1) T1CS=0, Instruction clock is selected.

#### 3.4.18 PWM4DUTY (PWM4 Duty Register)

| Name     | SFR Type | Addr. | Bit7          | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------|----------|-------|---------------|------|------|------|------|------|------|------|
| PWM4DUTY | S        | 0x18  | PWM4DUTY[7:0] |      |      |      |      |      |      |      |
| R        | W        |       |               |      |      |      |      |      |      |      |
| l        |          |       |               | XXXX | XXXX |      |      |      |      |      |

The reload value of 10-bit Timer4 stored on registers TM4RH[7:6] and TMR4[7:0] is used to define the PWM4 frame rate, and registers TM4RH[3:2] and PWM4DUTY[7:0] is used to define the duty cycle of PWM4.

#### 3.4.19 PS4CV (Prescaler4 Counter Value Register)

| Name           | SFR Type      | Addr. | Bit7       | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------|---------------|-------|------------|------|------|------|------|------|------|------|
| PS1CV          | S             | 0x19  | PS4CV[7:0] |      |      |      |      |      |      |      |
| R/W Property R |               |       |            |      |      |      |      |      |      |      |
|                | Initial Value | 1     | 1          | 1    | 1    | 1    | 1    | 1    | 1    |      |

While reading PS4CV, it will get current value of Prescaler4 counter.

#### 3.4.20 TMR5 (Timer5 Register)

| Name | SFR Type      | Addr. | Bit7      | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|-----------|------|------|------|------|------|------|------|
| TMR5 | S             | 0x1A  | TMR5[7:0] |      |      |      |      |      |      |      |
| I    | R/W Property  |       | R/W       |      |      |      |      |      |      |      |
|      | Initial Value |       | XXXXXXXX  |      |      |      |      |      |      |      |

When reading register TMR5, it will obtain current value of 10-bit down-count Timer5 at TMR5[9:0]. When writing register TMR5, it will write data from TM5RH[5:4] and Timer5 reload register to TMR5[9:0] current content.

#### 3.4.21 T5CR1 (Timer5 Control Register1)

| Name  | SFR<br>Type   | Addr | Bit7    | Bit6    | Bit5 | Bit4   | Bit3    | Bit2 | Bit1 | Bit0 |
|-------|---------------|------|---------|---------|------|--------|---------|------|------|------|
| T5CR1 | S             | 0x1B | PWM5OEN | PWM5OAL | -    | VFSEL5 | TM5_HRC | T5OS | T5RL | T5EN |
| R/V   | R/W Property  |      | R/W     | R/W     | -    | R/W    | R/W     | R/W  | R/W  | R/W  |
| In    | Initial Value |      | 0       | 0       | Х    | 0      | 0       | 0    | 0    | 0    |

This register is used to configure Timer5 functionality.

**T5EN:** Enable/disable Timer5.

T5EN=1, enable Timer5.

T5EN=0, disable Timer5.

T5RL: Configure Timer5 down-count mechanism while Non-Stop mode is selected (T5OS=0).

T5RL=1, initial value is reloaded from reload register TMR5[9:0].

T5RL=0, continuous down-count from 0x3FF when underflow is occurred.

T5OS: Configure Timer5 operating mode while underflow is reached.

T5OS=1, One-Shot mode. Timer5 will count once from the initial value to 0x00.

T5OS=0, Non-Stop mode. Timer5 will keep down-count after underflow.

| T5OS | T5RL | Timer5 Down-Count Functionality                                                                                                       |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | Timer5 will count from reload value down to 0x00.<br>When underflow is reached, 0x3FF is reloaded and continues down-count.           |
| 0    | 1    | Timer5 will count from reload value down to 0x00.<br>When underflow is reached, reload value is reloaded and continues to down-count. |
| 1    | x    | Timer5 will count from initial value down to 0x00.<br>When underflow is reached, Timer5 will stop down-count.                         |

Table 8 Timer5 Functionality

**TM5\_HRC:** Timer5 clock source selection.

TM5HRC=1, PWM5 & Timer 5 clock source is High Oscillator clock.

TM5HRC=0, PWM5 & Timer 5 clock source selection depends on T5CS register bit

#### Note: If set Timer5 clock source is high oscillator clock (TM5HRC=1), user must disable precaler5.

**VFSEL5:** Timer5 special clock source selection.

TM5HRC=1, PWM5 & Timer 5 clock source is special High Oscillator clock.

TM5HRC=0, PWM5 & Timer 5 clock source selection depends on T5CS register bit

#### Note: VFSEL5 has higher priority than TM5\_HRC.

**PWM5OAL:** Define PWM5 output active state.

PWM5OAL=1, PWM5 output is active low.

PWM5OAL=0, PWM5 output is active high.

#### **PWM50EN:** Enable/disable PWM5 output.

PWM5OEN=1, PWM5 output will be present on PB2.

PWM5OEN=0, PB2 is GPIO.

#### 3.4.22 T5CR2 (Timer5 Control Register2)

| Name         | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2        | Bit1 | Bit0 |
|--------------|---------------|-------|------|------|------|------|--------|-------------|------|------|
| T5CR2 S 0x1C |               |       | -    | -    | T5CS | T5CE | /PS5EN | PS5SEL[2:0] |      |      |
|              | R/W Property  |       |      | -    | R/W  | R/W  | R/W    | R/W         | R/W  | R/W  |
|              | Initial Value |       |      | Х    | 1    | 1    | 1      | 1           | 1    | 1    |

55

This register is used to configure Timer5 functionality.

**PS5SEL[2:0]:** Prescaler5 dividing rate selection.

PS5SEL[2:0] Dividing Rate

| PS5SEL[2:0] | Dividing Rate |
|-------------|---------------|
| 000         | 1:2           |
| 001         | 1:4           |
| 010         | 1:8           |
| 011         | 1:16          |
| 100         | 1:32          |
| 101         | 1:64          |
| 110         | 1:128         |
| 111         | 1:256         |

Table 9Prescaler5 Dividing Rate

#### Note: Always set PS5SEL[2:0] at /PS5EN=1, or interrupt may be falsely triggered.

/PS5EN: Disable/enable Prescaler5

/PS5EN=1, disable Prescaler5.

/PS5EN=0, enable Prescaler5.

**T5CE:** Timer5 external clock edge selection.

T5CE=1, Timer1 will decrease one while high-to-low transition occurs on pin EX\_CKI1. T5CE=0, Timer1 will decrease one while low-to-high transition occurs on pin EX\_CKI1.

T5CS: Timer5 clock source selection.

T5CS=1, External clock on pin EX\_CKI1 is selected.(option=1:PA2, option=0:PA1) T5CS=0, Instruction clock is selected.

#### 3.4.23 PWM5DUTY (PWM5 Duty Register)

| Name     | SFR Type | Addr. | Bit7          | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1            | Bit0 |  |  |  |
|----------|----------|-------|---------------|------|------|------|------|------|-----------------|------|--|--|--|
| PWM5DUTY | S        | 0x1D  | PWM5DUTY[7:0] |      |      |      |      |      | D PWM5DUTY[7:0] |      |  |  |  |
| R        | W        |       |               |      |      |      |      |      |                 |      |  |  |  |
| I        |          |       |               | XXXX | XXXX |      |      |      |                 |      |  |  |  |

The reload value of 10-bit Timer4 stored on registers TM5RH[5:4] and TMR5[7:0] is used to define the PWM5 frame rate, and registers TM5RH[1:0] and PWM5DUTY[7:0] is used to define the duty cycle of PWM5.

#### 3.4.24 PS5CV (Prescaler5 Counter Value Register)

| Name  | SFR Type       | Addr. | Bit7          | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|----------------|-------|---------------|------|------|------|------|------|------|------|
| PS1CV | S              | 0x1E  | PS5CV[7:0]    |      |      |      |      |      |      |      |
|       | R/W Property R |       |               |      |      |      |      |      |      |      |
|       | Initial Value  |       | 1 1 1 1 1 1 1 |      |      |      |      | 1    | 1    |      |

While reading PS5CV, it will get current value of Prescaler5 counter.

#### 3.4.25 TM5RH (Timer5 High Byte Register)

| Name  | SFR Type      | Addr. | Bit7 | Bit6 | Bit5  | Bit4  | Bit3 | Bit2 | Bit1   | Bit0   |
|-------|---------------|-------|------|------|-------|-------|------|------|--------|--------|
| TM5RH | S             | 0x1F  | -    | -    | TMR59 | TMR58 | -    | -    | PWM5D9 | PWM5D8 |
| F     | R/W Property  |       | -    | -    | R/W   | R/W   | -    | -    | R/W    | R/W    |
|       | Initial Value |       | Х    | Х    | Х     | Х     | Х    | Х    | Х      | Х      |

**TMR59~8:** Timer5 MSB 2 bits. Write these 2 bits will overwrite the 10-bit Timer5 load value of bit 9 and 8.Read these 2 bits will get the Timer5 bit9-8 current value.

PWM5DUTY9~8: PWM5 duty data MSB 2 bits.

#### 3.5 T-page Special Function Register

#### 3.5.1 SIMCR (Serial interface Mode Control Register )

| Name          | SFR<br>Type | Addr | Bit7           | Bit6           | Bit5 | Bit4    | Bit3         | Bit2         | Bit1           | Bit0             |
|---------------|-------------|------|----------------|----------------|------|---------|--------------|--------------|----------------|------------------|
| SIMCR         | Т           | 0x0  | SIMC1<br>(SPE) | SIMC0<br>(MEN) | MSTA | SSB_PAD | RX_PAD<br>EN | TX_PAD<br>EN | RCLK_P<br>ADEN | BAUDOZ<br>_PADEN |
| R/W           | Propert     | ÿ    | R/W            | R/W            | R/W  | R/W     | R/W          | R/W          | R/W            | R/W              |
| Initial Value |             |      | 0              | 0              | 0    | 0       | 0            | 0            | 0              | 0                |

**SIMC1 :** SPI mode enable

SIMC1 =1, SPI mode enable .

SIMC1 =0, SPI mode disable .

**SIMC0**: IIC mode enable

SIMC0 =1, IIC mode enable .

SIMC0 =0, IIC mode disable .

MSTA: Selection of master mode /slave mode . ( include IIC mode and SPI mode ) MSTA =1, select master mode . MSTA =0, select slave mode .

**SSB\_PAD :** Decide PB7 is pin share as SSBEN or not , this functionality is used at SPI mode . SSB\_PAD =1, set PB7 as SSB(Slave Select Bar).

SSB\_PAD =0, set PB7 as GPIO.

**RX\_PADEN :** UART interface RXPAD .

RX\_PADEN =1, set PB7 as UART RX signal input .

RX\_PADEN =0, set PB7 as GPIO.

**TX\_PADEN :** UART interface TXPAD.

TX\_PADEN =1, set PB6 as UART TX signal output.

TX\_PADEN =0, set PB6 as GPIO.

#### **RCLK\_PADEN :** UART interface RCLK\_PADEN .

RCLK\_PADEN =1, set PB5 as UART RX CKT clock input ,frequency =baud rate\*/16 . RCLK\_PADEN =0, set PB5 as GPIO.

#### **BAUDOZ\_PADEN :** UART interface Baudrate Freq\*16 ouput pad .

RCLK\_PADEN =1, set PB4 as UART TX CKT clock output ,frequency =baud rate \*16 . RCLK\_PADEN =0, set PB4 as GPIO.

Note: Do NOT enable SPI mode with IIC mode or UART mode at the same time.

#### 3.5.2 MADR (IIC mode Address register )

| Name          | SFR<br>Type  | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|--------------|-------|------|------|------|------|------|------|------|------|
| MADR          | Т            | 0x1   | MAD7 | MAD6 | MAD5 | MAD4 | MAD3 | MAD2 | MAD1 | -    |
| R/            | R/W Property |       | R/W  | -    |
| Initial Value |              | 0     | 0    | 0    | 0    | 0    | 0    | 0    | Х    |      |

MAD1-MAD7: MAD1-MAD7 are the slave address bits of IIC mode

#### 3.5.3 MFDR (IIC mode frequency register )

| Name          | SFR<br>Type  | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|--------------|-------|------|------|------|------|------|------|------|------|
| MFDR          | Т            | 0x2   | -    | -    | -    | FD4  | FD3  | FD2  | FD1  | FD0  |
| R/            | R/W Property |       | -    | -    | -    | R/W  | R/W  | R/W  | R/W  | R/W  |
| Initial Value |              | Х     | Х    | Х    | 0    | 0    | 0    | 0    | 0    |      |

**FD0-FD4:** FD0-FD4 are used for clock rate selection, the serilal bit clock frequency is equal to the CPU clock divide by the divider shown in table as below.

#### Example : CPU CLOCK=1MHZ , FD[4 :0]=2 , IIC MODE CLK FREQ=1MHZ/28=35.7KHZ

| FD4 | FD3 | FD2 | FD1 | FD0 | DIVIDER |
|-----|-----|-----|-----|-----|---------|
| 0   | 0   | 0   | 0   | 0   | 22      |
| 0   | 0   | 0   | 0   | 1   | 24      |
| 0   | 0   | 0   | 1   | 0   | 28      |
| 0   | 0   | 0   | 1   | 1   | 34      |
| 0   | 0   | 1   | 0   | 0   | 44      |
| 0   | 0   | 1   | 0   | 1   | 48      |
| 0   | 0   | 1   | 1   | 0   | 56      |
| 0   | 0   | 1   | 1   | 1   | 68      |
| 0   | 1   | 0   | 0   | 0   | 88      |
| 0   | 1   | 0   | 0   | 1   | 96      |
| 0   | 1   | 0   | 1   | 0   | 112     |

| FD4 | FD3 | FD2 | FD1 | FD0 | DIVIDER |
|-----|-----|-----|-----|-----|---------|
| 1   | 0   | 0   | 0   | 0   | 352     |
| 1   | 0   | 0   | 0   | 1   | 384     |
| 1   | 0   | 0   | 1   | 0   | 448     |
| 1   | 0   | 0   | 1   | 1   | 544     |
| 1   | 0   | 1   | 0   | 0   | 704     |
| 1   | 0   | 1   | 0   | 1   | 768     |
| 1   | 0   | 1   | 1   | 0   | 896     |
| 1   | 0   | 1   | 1   | 1   | 1088    |
| 1   | 1   | 0   | 0   | 0   | 1408    |
| 1   | 1   | 0   | 0   | 1   | 1536    |
| 1   | 1   | 0   | 1   | 0   | 1792    |

58

### Nyquest 🚺

### NY8BE64A

| FD4 | FD3 | FD2 | FD1 | FD0 | DIVIDER |
|-----|-----|-----|-----|-----|---------|
| 0   | 1   | 0   | 1   | 1   | 136     |
| 0   | 1   | 1   | 0   | 0   | 176     |
| 0   | 1   | 1   | 0   | 1   | 192     |
| 0   | 1   | 1   | 1   | 0   | 224     |
| 0   | 1   | 1   | 1   | 1   | 272     |

| FD4 | FD3 | FD2 | FD1 | FD0 | DIVIDER |
|-----|-----|-----|-----|-----|---------|
| 1   | 1   | 0   | 1   | 1   | 2176    |
| 1   | 1   | 1   | 0   | 0   | 2816    |
| 1   | 1   | 1   | 0   | 1   | 3072    |
| 1   | 1   | 1   | 1   | 0   | 3584    |
| 1   | 1   | 1   | 1   | 1   | 4352    |

#### 3.5.4 MCR (IIC mode control register)

| Name          | SFR<br>Type  | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|--------------|-------|------|------|------|------|------|------|------|------|
| MCR           | Т            | 0x3   | -    | -    | -    | MTX  | TXAK | -    | -    | -    |
| R/            | R/W Property |       | -    | -    | -    | R/W  | R/W  | -    | -    | -    |
| Initial Value |              | Х     | Х    | Х    | 0    | 0    | Х    | Х    | Х    |      |

MTX : Select transmit or receive mode in IIC mode.

1 = Transmit mode.

0 = Receive mode.

**TXAK**: Set acknowledge bit in IIC mode.

1 = Do not send acknowledge signal

0 = Send acknowledge at 9<sup>th</sup> lock bit

#### 3.5.5 MSR (IIC mode status register )

| Name | SFR<br>Type   | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|------|------|------|------|------|------|------|------|
| MSR  | Т             | 0x4   | MCF  | MAAS | MBB  | MAL  | -    | SRW  | MIF  | RXAK |
| R/   | R/W Property  |       | R    | R    | R    | R/W  | -    | R    | R/W  | R    |
| Ir   | Initial Value |       | 1    | 0    | 0    | 0    | Х    | 0    | 0    | 1    |

The MIF and MAL bits are software clearable, while the other bits are read only.

MCF : Data Transfer Complete

1 = A byte has been completed

0 = A byte is being transfer

#### MAAS: Addressed as Slave

1 = Currently addressed as slave

0 = not currently addressed

When MAAS is set, the MIF (IIC MODE interrupt) bit is also set.

IF MAAS=1, Then CPU needs to check the SRW bit and set its MTX bit accordingly.

MBB : Bus Busy

1 = Bus busy

0 = Bus idle

When a START signal is detected, MBB is set. When a STOP signal is detected, it is cleared.

MAL : Arbitration Lost

- 1 = lost arbitration in master mode
- 0 = No arbitration lost

This arbitration lost flag is set when the IIC MODE master loses arbitration

during a Master transmission mode. When MAL is set, the MIF bit is also set. This bit must be cleared by software

#### SRW : Slave R/W select

1 = Read from slave, from calling master

0 = Write to slave from calling master

When MAAS is set, the R/W command bit of the calling address sent from the master is latched into this SRW bit. By checking this bit, device can then select slave transmit/receive mode by configuring MTX bit of the IIC MODE Control register

- MIF : IIC interrupt
  - 1 = IIC interrupt has occurred.
  - 0 = IIC interrupt has not occurred.
  - When this bit is set, an interrupt is generated to the CPU if SIMIE is set. This bit is set when one of the following events occurs:
  - 1) Completion of one byte of data transfer. It is set at the falling edge of the 9th clock MCF set.
  - 2) A match of the calling address with its own specific address in slave mode -

MAAS set.

3) A loss of bus arbitration - MAL set.

This bit must be cleared by software in the interrupt routine.

#### **RXAK** : Receive Acknowledge

1 = No acknowledgment signal detected.

0 = Acknowledge signal detected after 8 bits data transmitted.

#### 3.5.6 SIMDR (Serial interface mode data register )

| Name          | SFR<br>Type  | Addr. | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|---------------|--------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| SIMDR         | Т            | 0x5   | SIMD7 | SIMD6 | SIMD5 | SIMD4 | SIMD3 | SIMD2 | SIMD1 | SIMD0 |
| R/W           | R/W Property |       | R/W   |
| Initial Value |              | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |       |

 $\ensuremath{\textbf{SIMD7-SIMD0}}$  : if iic mode enable , they are iic mode data register .

If spi mode enable , they are spi mode data register .

#### 3.5.7 SPCR (SPI control & status register )

| Name          | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0  |
|---------------|-------------|-------|------|------|------|------|------|------|------|-------|
| SPCR          | Т           | 0x6   | SPIF | WCOL | -    | MODF | CPOL | CKEG | SPR  | [1:0] |
| R/W           | V Prope     | rty   | R/W  | R/W  | -    | R/W  | R/W  | R/W  | R/W  | R/W   |
| Initial Value |             | 0     | 0    | Х    | 0    | 0    | 0    | 0    | 0    |       |

SPIF: SPI Flag

1 = Transmission complete

0 = Transmission not complete

Read SPCR ,and then read or write SIMDR will clear SPIF and WCOL .

#### WCOL: Write Collision Bit

1 = Invalid write to SIMDR

0 = No invalid write to SIMDR

Read SPCR ,and then read or write SIMDR will clear SPIF and WCOL .

#### MODF: Mode Fault Bit

1 = SSBEN pulled low while MODF bit set

0 = SSBEN not pulled low while MODF bit set

Read SPCR , and then write SPCR will clear MODF

#### **CPOL**: Clock Polarity Bit

1 = SCK pin at logic 1 between transmissions, idle high

0 = SCK pin at logic 0 between transmissions, idle low

CKEG: SPI SCK clock active edge type selection

CPOL=1

0: SCK is high base level and data capture at SCK rising edge

1: SCK is high base level and data capture at SCK falling edge

CPOL=0

0: SCK is low base level and data capture at SCK falling edge

1: SCK is low base level and data capture at SCK rising edge

#### **SPR[1:0]** — SPI Clock Rate Bits

| SPR[1:0] | SPI clock rate   |
|----------|------------------|
| 00       | system Clock  2  |
| 01       | system Clock 🛛 4 |
| 10       | system Clock  16 |
| 11       | system Clock     |

#### 3.5.8 INTE3 (Interrupt Enable 3th Register )

| Name  | SFR Type     | Addr | Bit7  | Bit6 | Bit5       | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|--------------|------|-------|------|------------|-------|------|------|------|------|
| INTE3 | Т            | 0x7  | SIMIE | EEIE | T5IE/CCPIE | LSRIE | TXIE | RXIE | -    | -    |
| R     | W Property   |      | R/W   | R/W  | R/W        | R/W   | R/W  | R/W  | -    | -    |
| l I   | nitial Value |      | 0     | 0    | 0          | 0     | 0    | 0    | -    | -    |

SIMIE: Serial interface mode interrupt enable bit

1 = Enable Serial interface mode interrupt

0 = Disable Serial interface mode interrupt

**T5IE/CCPIE:** When CCP capture or compare mode is enabled, this interrupt is used as CCP interrupt enable bits, otherwise it is T5 underflow interrupt enable bit.

T5IE/CCPIE=1, enable interrupt.

T5IE/CCPIE=0, disable interrupt.

- EEIE:End of EEPROM Writing interrupt enable bit.EEIE=1, enable End of EEPROM Writing interrupt.EEIE=0, disable End of EEPROM Writing interrupt.
- **LSRIE**: LSR interrupt enable bit
  - 1 = enable receiver line status interrupt
  - 0 = disable receiver line status interrupt
- **TXIE** : Transmitt holding register (THR) empty interrupt enable bit
  - 1 = enable Transmitt holding register (THR) empty interrupt
  - 0 = disable Transmitt holding register (THR) empty interrupt
- $\label{eq:relation} \textbf{RXIE}: \quad \text{Receive} \quad \text{one bye completely interrupt enable bit}$

1 = enable Receive one bye completely interrupt

0 = disable Receive one bye completely interrupt

#### 3.5.9 INTF3 (Interrupt Flag 3th Register )

| Name  | SFR Type     | Addr | Bit7  | Bit6 | Bit5       | Bit4  | Bit3 | Bit2  | Bit1 | Bit0 |
|-------|--------------|------|-------|------|------------|-------|------|-------|------|------|
| INTF3 | Т            | 0x8  | SIMIF | EEIF | T5IF/CCPIF | LSRIF | THRE | READY | -    | -    |
| R/    | W Property   |      | R     | R/W  | R/W        | R/W   | R/W  | R/W   | -    | -    |
| li    | nitial Value |      | 0     | 0    | 0          | 0     | 1    | 0     | -    | -    |

#### SIMIF: Serial interface mode interrupt Flag bit

1 = Serial interface mode interrupt is occurred

0 = Serial interface mode interrupt is not occurred

SIMIF show status of MIF if IIC mode enable, and SIMIF show status of SPIF if SPI mode enable .

**EEIF:** End of EEPROM writing interrupt flag bit.

EEIF=1, End of EEPROM writing interrupt is occurred.

EEIF must be clear by firmware.

**T5IF/CCPIF:** When CCP capture or compare mode is enabled, this interrupt is used as CCP interrupt flag bits, otherwise it is T5 underflow interrupt flag bit.

T5IF/CCPIF=1, interrupt is occurred.

T5IF/CCPIF must be clear by firmware.

**LSRIF**: LSR interrupt flag.

1: line status interrupt flag.

0: line status

THRE: Transmitter holding register(THR) empty flag

This bit indicates the controller is ready to accept a new character for transmission. It is set to logical 1 when a character is transferred from the transmitter holding register(TBR) into the transmitter shift register.

Write data to TBR will clear this flag.

**READY:** Data ready flag

It is set logical 1 whenever a complete incoming character has been received and transferred into the receiver buffer register.

Read the RBR data will clear this flag.

#### 3.5.10 THR/RBR (Transmit holding register /Receive Buffer Register)

| Name          | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|-------------|-------|------|------|------|------|------|------|------|------|
| THR/RBR       | Т           | 0x18  | URD7 | URD6 | URD5 | URD4 | URD3 | URD2 | URD1 | URD0 |
| R/W           | Property    | /     | R/W  |
| Initial Value |             |       | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    |

URD7~URD0: If write data to the register, they are UART transmit data register.

If read data from the register, they are UART receive data register.

#### 3.5.11 LCR (Line Control Register)

| Name          | SFR Type     | Addr. | Bit7 | Bit6 | Bit5   | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|--------------|-------|------|------|--------|-------|------|------|------|------|
| LCR           | Т            | 0x19  | LOOP | SBRK | PSTUCK | PEVEN | PREN | STPS | WL1  | WL0  |
|               | R/W Property | /     | R/W  | R/W  | R/W    | R/W   | R/W  | R/W  | R/W  | R/W  |
| Initial Value |              | 0     | 0    | 0    | 0      | 0     | 0    | 0    | 0    |      |

#### WL1~WL0: Word length select bits:

| WL[1:0] | Word length bits     |
|---------|----------------------|
| 00      | 5 bits per character |
| 01      | 6 bits per character |
| 10      | 7 bits per character |
| 11      | 8 bits per character |

### Nyquest 🚺

#### STPS: number of STOP bits.

| STPS | Word Length | Number of Stop bits |
|------|-------------|---------------------|
| 0    | Х           | 1                   |
| 1    | 5           | 1.5                 |
| 1    | 6,7,8       | 2                   |

**PREN:** Parity Enable

- 1: A parity bit is generated(transmit data) or check(receive data) between the last data word and stop bit of the serial data.
- 0: No parity is generated.

PEVEN: Even parity select

- 1: an even number of bits is sent or checked.
- 0: an odd number of bits is sent or checked.

#### PSTUCK: Stuck Parity

1: With PEVEN=1, the parity bit is sent and then detected by the receiver as a logic 0.

With PEVEN=0, the parity bit is logic 1.

SBRK: Set Break.

1: the serial output is forced to the spacing (logic 0) state and remains there regardless of other transmitter activity.

LOOP: loop back test enable

- 1: The output of the transmitter shift is loop back to the receiver shift register input.
- 0: disable the loop back test.

#### 3.5.12 LSR (Line Status Register)

| Name | SFR Type      | Addr. | Bit7 | Bit6 | Bit5 | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|------|---------------|-------|------|------|------|-------|------|------|------|------|
| LSR  | Т             | 0x1A  | -    | TSRE | -    | BKINT | FERR | PERR | OERR | -    |
| I    | R/W Property  | ,     | -    | R    | -    | -     | -    | -    | -    | -    |
|      | Initial Value |       |      | 1    | Х    | 0     | 0    | 0    | 0    | Х    |

**OVERR**: Over run error flag.

This bit indicates that data in the receiver's buffer register was not read by MCU before the next character was transferred into the register thereby destroying the previous character.

1: Over run happen.

0: Not happen over run.

#### PERR: Parity error flag

1: Detect a parity error.

0: No parity error.

#### FERR: Frame error flag

This bit indicates the received character did not have a valid stop bit. It is set to logical 1 whenever the stop bit following the last data bit or parity bit is detected as a zero bit.

#### BKINT: Break interrupt flag

This bit is set to logical 1 whenever the receiver data input is held in the spacing state (logical 0) for longer than a full word transmission time.

#### **TSRE:** Transmitter shift register(TSR) empty:

This bit is set to logical 1 whenever the transmitter holding register and the transmitter shift register are both empty. It is reset to logical 0 whenever THR or TSR contains a data character,

3.5.13 DLL (Baud Rate Divisor Latch LSB Register)

| Name  | SFR<br>Type   | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|------|------|------|------|------|------|------|------|
| DLL   | Т             | 0x1B  | DLL7 | DLL6 | DLL5 | DLL4 | DLL3 | DLL2 | DLL1 | DLL0 |
| R/W   | R/W Property  |       | R/W  |
| Initi | Initial Value |       |      | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

DLL[7:0]: Baud rate divider LSB bit.

#### 3.5.14 DLH (Baud Rate Divisor Latch MSB Register)

| Name  | SFR<br>Type   | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-------|---------------|-------|------|------|------|------|------|------|------|------|
| DLH   | Т             | 0x1C  | DLH7 | DLH6 | DLH5 | DLH4 | DLH3 | DLH2 | DLH1 | DLH0 |
| R/W   | R/W Property  |       | R/W  |
| Initi | Initial Value |       |      | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

DLH[7:0]: Baud rate divider MSB bit.

Baud rate = HIRC\_freg : (16xN), N = [ DLH[7:0], DLL[7:0] ]

#### 3.5.15 CCPCON (CCP Control Register)

| Name                 | SFR<br>Type  | Addr | Bit7   | Bit6   | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------|--------------|------|--------|--------|-------|-------|-------|-------|-------|-------|
| CCPCON               | Т            | 0x1E | PWM5M1 | PWM5M0 | FBCH1 | FBCH0 | CCPM3 | CCPM2 | CCPM1 | CCPM0 |
| R/W                  | R/W Property |      | R/W    | R/W    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Initial Value(note*) |              | 0    | 0      | 0      | 0     | 0     | 0     | 0     | 0     |       |

CCPCON[3:2] = 00/01/10: Capture or Compare mode. PB2 is capture input or compare output. CCPCON [3:2] = 11  $\rightarrow$ 

 $PWM1M[1:0] = 00 \rightarrow PWM$  Single output. (N.C.)

 $PWM1M[1:0] = 01 \rightarrow PWM$  Full-bridge output forward.

 $PWM1M[1:0] = 10 \rightarrow PWM$  Half-bridge output.

 $PWM1M[1:0] = 11 \rightarrow PWM$  Full-bridge output reverse.

#### CCP1M[3:0] (mode select)

0000 = OFF

0010 = Compare mode, toggle output on match.

0100 = Capture mode, capture at every falling edge.

0101 = Capture mode, capture at every rising edge.

0110 = Capture mode, capture at every 4th rising edge.

0111 = Capture mode, capture at every 16th rising edge.

- 1000 = Compare mode, set output on match.
- 1001 = Compare mode, clear output on match.
- 1010 = Compare mode, interrupt on match.

1011 = Compare mode, trigger special event event.

1100 = PWM mode, P1A/P1C active high , P1D/P1B active high

1101 = PWM mode, P1A/P1C active high , P1D/P1B active low

1110 = PWM mode, P1A/P1C active low , P1D/P1B active high

1111 = PWM mode, P1A/P1C active low , P1D/P1B active low

#### FBCH[1:0] : Full band change direction gap

00 = 1 cpu cycle

01= 4 cpu cycle

1x = 16 cpu cycle

#### CCP user note :

Compare/Capture mode step:

- a. Set Timer 5 operating mode : continue/one-shot (T5OS), underflow reload mode (T5RL) (Keep T5EN=PWM5OEN=0).
- b. Set timer 4 clock source, timer 4 pre-scalar.
- c. Set timer4/timer5 reload/initial value.
- d. Set pwm4duty/pwm5duty.
- e. Enter Compare/capture mode(Setting CCPCON register) to start timer.
- f. Please disable Compare/capture mode before update PWM/timer data.

3.5.16 PWMDB (PWM Dead Band Control Register)

| Name          | SFR<br>Type | Addr | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|---------------|-------------|------|------|------|------|------|------|------|------|------|
| PWMDB         | Т           | 0x1F | DB7  | DB6  | DB5  | DB4  | DB3  | DB2  | DB1  | DB0  |
| R/W           | Propert     | ÿ    | R/W  |
| Initial Value |             | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    |      |

PWMDB[7:0]: PWM dead band (delay) count for Half-Bridge output mode.

Numbers of CPU cycles (FINST) between the P1A transition and P1B transition.



#### 3.6 I/O Port

NY8BE64A provides 18 I/O pins which are PA[7:0], PB[7:0] and PC[1:0]. User can read/write these I/O pins through registers PORTA, PORTB and PORTC respectively. Each I/O pin has a corresponding register bit to define it is input pin or output pin. Register IOSTA[7:0] define the input/output direction of PA[7:0]. Register IOSTB[7:0] define the input/output direction of PB[7:0]. Register IOSTC[1:0] define the input/output direction of PC[1:0].

When an I/O pin is configured as input pin, it may have Pull-High resistor or Pull-Low resistor which is enabled or disabled through registers. Register APHCON[7:6], PCON[4] and APHCON[4:0] are used to enable or disable Pull-High resistor of PA[7:0]. Register APHCON[5], PCON[6] and ABPLCON[3:0] are used to enable or disable Pull-Low resistor of PA[5:0]. Register BPHCON[7:0] are used to enable or disable Pull-High resistor of PA[5:0]. Register BPHCON[7:0] are used to enable or disable Pull-High resistor of PB[3:0]. Register ABPLCON[7:4] are used to enable or disable Pull-Low resistor of PB[3:0]. Register CPHCON[1:0] are used to enable or disable Pull-Low resistor of PB[3:0]. Register CPHCON[1:0] are used to enable or disable Pull-High resistor of PC[1:0]. Register CPLCON[1:0] are used to enable or disable Pull-Low resistor of PC[1:0] are used to enable or disable Pull-Low resistor of PC[1:0] are used to enable or disable Pull-Low resistor of PC[1:0]. Register CPLCON[1:0] are used to enable or disable Pull-Low resistor of PC[1:0]. Register CPLCON[1:0] are used to enable or disable Pull-Low resistor of PC[1:0]. When an PortB I/O pin is configured as output pin, there is a corresponding and individual register to select as Open-Drain output pin. Register BODCON[7:0] determine PB[7:0] is Open-Drain or not. When an PortC I/O pin is configured as output pin, there is a corresponding and individual register to select as Open-Drain output pin, there is a corresponding and individual register to select as Open-Drain output pin. Register PC[1:0] is Open-Drain or not.

|        | Feature            | PA[5:0] | PA[7:6] | PB[3:0] | PB[7:4] | PC[1:0] |
|--------|--------------------|---------|---------|---------|---------|---------|
| lagut  | Pull-High Resistor | V       | V       | V       | V       | V       |
| Input  | Pull-Low Resistor  | V       | Х       | V       | Х       | V       |
| Output | Open-Drain         | Х       | Х       | V       | V       | V       |

#### The summary of Pad I/O feature is listed in the table below.

Table 19 Summary of Pad I/O Feature

The level change on each I/O pin of PA and PB may generate interrupt request. Register AWUCON[7:0] and BWUCON[7:0] will select which I/O pin of PA and PB may generate this interrupt. As long as any pin of PA and PB is selected by corresponding bit of AWUCON and BWUCON, the register bit PABIF (INTF[1]) will set to 1 if there is a level change occurred on any selected pin. An interrupt request will occur and interrupt service routine will be executed if register bit PABIE (INTE[1]) and GIE (PCON1[7]) are both set to 1.

There is three external interrupt provided by NY8BE64A. When register bit EIS0 (INTEDG[4]) is set to 1, PB5/PA4 is used as input pin for external interrupt 0. When register bit EIS1 (INTEDG[5]) is set to 1, PB1/PA3 is used as input pin for external interrupt 1. When register bit EIS2 (INTEDG[6]) is set to 1, PA5 is used as input pin for external interrupt 2.

# Note: When PB1/PA3, PB5/PA4 or PA5 is both set as level change operation and external interrupt, the external interrupt will have higher priority, and the PB1/PA3, PB5/PA4 or PA5 level change operation will be disabled.

NY8BE64A provides IR carrier generation output. It is depended both on register bit IREN (IRCR[0]) and configuration word IR Current. As the table 20 shows : When IREN=1 and IR current option=Normal, the IR sink current=20mA and carrier output will be presented on PB1/PA3 pad. When IREN=0, the IR carrier will not be generated.

| IREN Register | IR Current Option | Current Value (mA) | IR Pad  |
|---------------|-------------------|--------------------|---------|
| 0             | Х                 | -                  | -       |
| 1             | Normal            | 20                 | PB1/PA3 |

Table 20 IR carrier selection

PA5 can be used as external reset input determined by a configuration word. When an active-low signal is applied to PA5, it will cause NY8BE64A to enter reset process.

When external crystal (E\_HXT, E\_XT or E\_LXT) is adopted for high oscillation or low oscillation according to setting of configuration words, PA6 will be used as crystal input pin (Xin) and PA7 will be used as crystal output pin (Xout).

When I\_HRC or I\_LRC mode is selected as system oscillation and E\_HXT, E\_XT or E\_LXT is not adopted, instruction clock is observable on PA7 if a configuration word is enabled.

Moreover, PA4 can be timer 0 external clock source EX\_CKI0 if T0MD T0CS=1 and LCK\_TM0=0. PA4 can be timer 1 external clock source EX\_CKI0 if T1CS=1. PA2 or PA1 can be Timer4/Timer5 external clock source EX\_CKI1 if T4CS/T5CS=1.

Moreover, PB3 can be comparator output if CMPOE=1. PB3 can be Buzzer1 output if BZ1CR[7] BZ1EN=1..The output priority of PB3 is comparator output >Buzzer1 output.

PA2/PA7 can be PWM3 output If P3CR1[7] PWM3OEN=1.

PB3/PB5 can be PWM2 output If P2CR1[7] PWM2OEN=1.

PB1/PB4 can be PWM1 output If T1CR1[7] PWM1OEN=1. PB4 can be T1OUT output if T1CR1[5] TM1OE=1.The output priority of PB4 is T1OUT > PWM1.

When configured as output, the sink current of each pin can be normal (15mA for  $V_{DD}$  =3V), large (35mA for  $V_{DD}$  =3V) or small (3mA for  $V_{DD}$  =2~5.5V) according to configuration words. Check the following table for sink current mode setting:

| Configuration Word | Small Sink | Normal Sink | Large Sink |
|--------------------|------------|-------------|------------|
| PXcurrent          | 0          | 1           | 1          |
| PXcsc              | 0          | 0           | 1          |

Table 21 Sink current mode setting (X=A, B, C)

IIC mode, PB4 is used as SCK, PB5 is used as SDA.

SPI mode, PB4 is used as SCK, PB5is used as MISO , PB6 is used as MOSI ,PB7 can be SSBEN if SIMCR[4]=1 .

UART mode, PB4 TX clock output, PB5 RX clock input PB6 is used as TX and PB7 is used as RX.

#### 3.6.1 Block Diagram of IO Pins

IO\_SEL: set pad attribute as input or output

WRITE\_EN: write data to pad.

READ\_EN: read pad.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

VPEN: enable pad to comparator non-inverting input.

CMPV: comparator non-inverting i

RD\_TYPE: select read pin or read latch.



Figure 6 Block Diagram of PA0

IO\_SEL: set pad attribute as input or output

### Nyquest 🚺

WRITE\_EN: write data to pad.

READ\_EN: read pad.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

VNEN: enable pad to comparator inverting input.

CMPVN: comparator inverting i

RD\_TYPE: select read pin or read latch.



Figure 7 Block Diagram of PA1

### Nyquest 🚺

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

VPEN: enable pad to comparator non-inverting input.

VNEN: enable pad to comparator inverting input.

CMPVP, CMPVN: comparator non-inverting and inverting input.

RD\_TYPE: select read pin or read latch.

EX\_CKI1: external clock for Timer4, 5.



Figure 8 Block Diagram of PA2

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

VPEN: enable pad to comparator non-inverting input.

VNEN: enable pad to comparator inverting input.

CMPVP, CMPVN: comparator non-inverting and inverting input.

EIS1: external interrupt function enable.

EX\_INT1: external interrupt signal.

RD\_TYPE: select read pin or read latch.



Figure 9 Block Diagram of PA3

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

VPEN: enable pad to comparator non-inverting input.

CMPVP: comparator non-inverting input.

EIS0: external interrupt function enable.

EX\_INT0 external interrupt signal.

RD\_TYPE: select read pin or read latch.

EX\_CKI0: external clock for Timer0, 1.



Figure 10 Block Diagram of PA4

RSTPAD\_EN: enable PA5 as reset pin.

RSTB\_IN: reset signal input.

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

EIS2: external interrupt function enable.

EX\_INT2: external interrupt signal.

RD\_TYPE: select read pin or read latch.



Figure 11 Block Diagram of PA5

- XTL\_EN: enable crystal oscillation mode.
- IO\_SEL: set pad attribute as input or output.
- WRITE\_EN: write data to pad.
- READ\_EN: read pad.
- PULLUP\_ENB: enable Pull-High.
- RD\_TYPE: select read pin or read latch.



Figure 12 Block Diagram of PA6, PA7

# Nyquest 🕪

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

OD\_EN: enable open-Drain.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

RD\_TYPE: select read pin or read latch.

WUB: port B wake-up enable.

SET\_PBIF: port B wake-up flag.

CAP\_EN: enable pad to external capacitor.

INITIAL: Discharge capacitor



Figure 13 Block Diagram of PB0

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

OD\_EN: enable open-Drain.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

RD\_TYPE: select read pin or read latch.

WUB: port B wake-up enable.

SET\_PBIF: port B wake-up flag.

EIS: external interrupt function enable.

EX\_INT: external interrupt signal.



Figure 14 Block Diagram of PB1

# Nyquest 🕪

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

OD\_EN: enable open-Drain.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

RD\_TYPE: select read pin or read latch.

WUB: port B wake-up enable.

SET\_PBIF: port B wake-up flag.



Figure 15 Block Diagram of PB2 & PB3

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

OD\_EN: enable open-Drain.

PULLUP\_ENB: enable Pull-High.

CMPVP, CMPVN: comparator non-inverting and inverting input.

RD\_TYPE: select read pin or read latch.

WUB: port B wake-up enable.

SET\_PBIF: port B wake-up flag.



Figure 16 Block Diagram of PB4 & PB6 & PB7

IO\_SEL: set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

OD\_EN: enable open-Drain.

PULLUP\_ENB: enable Pull-High.

CMPVP, CMPVN: comparator non-inverting and inverting input.

RD\_TYPE: select read pin or read latch.

WUB: port B wake-up enable.

SET\_PBIF: port B wake-up flag.

EIS: external interrupt function enable.

EX\_INT: external interrupt signal.



Figure 17 Block Diagram of PB5

 $\ensuremath{\mathsf{IO\_SEL}}\xspace$  set pad attribute as input or output.

WRITE\_EN: write data to pad.

READ\_EN: read pad.

OD\_EN: enable open-Drain.

PULLUP\_ENB: enable Pull-High.

PULLDOWN\_EN: enable Pull-Low.

RD\_TYPE: select read pin or read latch.



Figure 18 Block Diagram of PC0, PC1

### 3.7 Timer0

Timer0 is an 8-bit up-count timer and its operation is enabled by register bit T0EN (PCON1[0]). Writing to Timer0 will set its initial value. Reading from Timer0 will show its current count value.

The clock source to Timer0 can be from instruction clock, external pin EX\_CKI0 or low speed clock Low Oscillator Frequency according to register bit T0CS and LCK\_TM0 (T0MD[5] and T0MD[7]). When T0CS is 0, instruction clock is selected as Timer0 clock source. When T0CS is 1 and LCK\_TM0 is 0, EX\_CKI0 is selected as Timer0 clock source. When T0CS is 1 and LCK\_TM0 is 1 (and Timer0 source must set to 1), Low Oscillator Frequency (I\_LRC or E\_LXT, depends on configuration word) output is selected. Summarized table is shown below. (Also check Table 22)

| Timer0 clock source | T0CS | LCKTM0 | Timer0 source | Low Oscillator Frequency |
|---------------------|------|--------|---------------|--------------------------|
| Instruction clock   | 0    | Х      | х             | Х                        |
|                     |      | 0      | х             | Y                        |
| EX_CKI0             | I    | Х      | 0             | ^                        |
| E_LXT               | 1    | 1      | 1             | 1                        |
| I_LRC               | 1    | 1      | 1             | 0                        |

Table 22 Summary of Timer0 clock source control

Moreover the active edge of EX\_CKI0 or Low Oscillator Frequency to increase Timer0 can be selected by register bit T0CE (T0MD[4]). When T0CE is 1, high-to-low transition on EX\_CKI0 or Low Oscillator Frequency will increase Timer0. When T0CE is 0, low-to-high transition on EX\_CKI0 or Low Oscillator Frequency will increase Timer0. When using Low Oscillator Frequency as Timer0 clock source, it is suggested to use prescaler0 (see below descriptions) and the ratio set to more than 4, or missing count may happen.

Before Timer0 clock source is supplied to Timer0, it can be divided by Prescaler0 if register bit PS0WDT (T0MD[3]) is clear to 0. When writing 0 to PS0WDT by instruction, Prescaler0 is assigned to Timer0 and Prescaler0 will be clear after this instruction is executed. The dividing rate of Prescaler0 is determined by register bits PS0SEL[2:0] which is from 1:2 to 1:256.

When Timer0 is overflow, the register bit T0IF (INTF[0]) will be set to 1 to indicate Timer0 overflow event is occurred. If register bit T0IE (INTE[0]) and GIE are both set to 1, interrupt request will occur and interrupt service routine will be executed. T0IF will not be clear until firmware writes 0 to T0IF.

The block diagram of Timer0 and WDT is shown in the figure below.



Figure 19 Block Diagram of Timer0 and WDT

### 3.8 Timer1 / PWM1 / Buzzer1/ PWM2 /PWM3

Timer1 is an 10-bit down-count timer with Prescaler1 whose dividing rate is programmable. The output of Timer1 can be used to generate PWM1 output/PWM2 output/PWM3 output and Buzzer1 output. Timer1 builds in auto-reload function and Timer1 reload register stores reload data with double buffers. When user write Timer1 reload register, write Timer1 MSB 2 bits(TMRH[5:4]) first and write TMR1 second, Timer1 reload register will be updated to Timer1 counter after Timer1 overflow occurs when T1EN=1. If T1EN=0, Timer1 reload register will be updated to Timer1 counter after write TMR1 immediately. A read to the Timer1 will show the content of the Timer1 current count value.



The block diagram of Timer1 is shown in the figure below.

Figure 20 Block Diagram of Timer1

The operation of Timer1 can be enabled or disabled by register bit T1EN (T1CR1[0]). After Timer1 is enabled, its clock source can be instruction clock or pin EX\_CKI0 which is determined by register bit T1CS (T1CR2[5]). When T1CS is 1, EX\_CKI0 is selected as clock source. When T1CS is 0, instruction clock is selected as clock source. When EX\_CKI0 is selected, the active edge to decrease Timer1 is determined by register bit T1CE

## NY8BE64A

(T1CR2[4]). When T1CE is 1, high-to-low transition on EX\_CKI0 will decrease Timer1. When T1CE is 0, low-to-high transition on EX\_CKI0 will decrease Timer1. The selected clock source can be divided further by Prescaler1 before it is applied to Timer1. Prescaler1 is enabled by writing 0 to register bit /PS1EN (T1CR2[3]) and the dividing rate is from 1:2 to 1:256 determined by register bits PS1SEL[2:0] (T1CR2[2:0]). Current value of Prescaler1 can be obtained by reading register PS1CV.

Timer1 provides two kinds of operating mode: one is One-Shot mode and the other is Non-Stop mode. When register bit T1OS (T1CR1[2]) is 1, One-Shot mode is selected. Timer1 will count down once from initial value stored on register TMR1[9:0] to 0x00, i.e. underflow is occurred. When register bit T1OS (T1CR1[2]) is 0, Non-Stop mode is selected. When underflow is occurred, there are two selections to start next down-count which is determined by register bit T1RL (T1CR1[1]). When T1RL is 1, the initial value stored on register TMR1[9:0] will be restored and start next down-count from this initial value. When T1RL is 0, Timer1 will start next down-count from 0x3FF.

When Timer1 is underflow, the register bit T1IF (INTF[3]) will be set to 1 to indicate Timer1 underflow event is occurred. If register bit T1IE (INTE[3]) and GIE are both set to 1, interrupt request will occur and interrupt service routine will be executed. T1IF will not be clear until firmware writes 0 to T1IF.



The timing chart of Timer1 is shown in the following figure.

Figure 21 Timer1 Timing Chart

The PWM1 output can be available on I/O pin PB4 or PB1 which is decided by option ,when register bit PWM1OEN (T1CR1[7]) is set to 1. Moreover, PB4 or PB1 will become output pin automatically. The active state of PWM1 output is determined by register bit PWM1OAL (T1CR1[6]). When PWM1OAL is 1, PWM1 output is active low. When PWM1OAL is 0, PWM1 output is active high. Moreover, the duty cycle and frame rate of PWM1 are both programmable. The duty cycle is determined by registers TMRH[1:0] and PWM1DUTY[7:0]. When PWM1DUTY is 0, PWM1 output will be never active. When PWM1DUTY is 0x3FF, PWM1 output will be active for 1023 Timer1 input clocks. The frame rate is determined by TMRH[5:4] + TMR1[7:0] initial value. Therefore, PWM1DUTY value must be less than or equal to TMRH[5:4] + TMR1[7:0]. When user write

PWM1DUTY, write PWM1DUTY[9:8] MSB 2 bits(TMRH[1:0]) first and write PWM1DUTY[7:0] second, PWM1 duty register will be updated after Timer1 overflow occurs. The block diagram of PWM1 is illustrated in the following figure.



Figure 22 PWM1 Block Diagram

The Buzzer1 output (BZ1) can be available on I/O pin PB3 when register bit BZ1EN (BZ1CR1[7]) is set to 1. Moreover, PB3 will become output pin automatically. The frequency of BZ1 can be derived from Timer1 output or Prescaler1 output and dividing rate is determined by register bits BZ1FSEL[3:0] (BZ1CR[3:0]). When BZ1FSEL[3] is 0, Prescaler1 output is selected to generate BZ1 output. When BZ1FSEL[3] is 1, Timer1 output is selected to generate BZ1 output. When BZ1FSEL[3] is 1, Timer1 output is selected to generate BZ1 output. The dividing rate can be from 1:2 to 1:256 in order to generate all kinds of frequency. The block diagram of Buzzer1 is illustrated in the following figure.



Figure 23 Buzzer1 Block Diagram

### 3.9 PWM2

The PWM2 output can be available on I/O pin PB3 or PB5 when register bit PWM2OEN (P2CR1[7]) is set to 1. Moreover, PB3 or PB5 will become output pin automatically. The active state of PWM2 output is determined by register bit PWM2OAL (P2CR1[6]). When PWM2OAL is 1, PWM2 output is active low. When PWM2OAL is 0, PWM2 output is active high. Moreover, the duty cycle and frame rate of PWM2 are both programmable. The duty cycle is determined by register TMRH[3:2],PWM2DUTY[7:0]. When PWM2DUTY is 0, PWM2 output will be

never active. When PWM2DUTY is 0x3FF, PWM2 output will be active for 1023 Timer1 input clocks. The frame rate is determined by TMRH[5:4],TMR1[7:0] initial value. Therefore, PWM2DUTY value must be less than or equal to TMR1[9:0]. When user write PWM2DUTY, write PWM2DUTY[9:8] MSB 2 bits(TMRH[3:2]) first and write PWM2DUTY[7:0] second, PWM2 duty register will be updated after Timer1 overflow occurs. The block diagram of PWM2 is illustrated in the following figure.



Figure 24 PWM2 Block Diagram

### 3.10 PWM3

The PWM3 output can be available on I/O pin PA2 or PA7 which is decided by option, when register bit PWM3OEN (P3CR1[7]) is set to 1. Moreover, PA2 or PA7 will become output pin automatically. The active state of PWM3 output is determined by register bit PWM3OAL (P3CR1[6]). When PWM3OAL is 1, PWM3 output is active low. When PWM3OAL is 0, PWM3 output is active high. Moreover, the duty cycle and frame rate of PWM3 are both programmable. The duty cycle is determined by register TM4RH[1:0],PWM3DUTY[7:0]. When PWM3DUTY is 0, PWM3 output will be never active. When PWM3DUTY is 0x3FF, PWM3 output will be active for 1023 Timer1 input clocks. The frame rate is determined by TMRH[5:4],TMR1[7:0] initial value. Therefore, PWM3DUTY value must be less than or equal to TMR1[9:0]. When user write PWM3DUTY, write PWM3DUTY[9:8] MSB 2 bits(TM4RH[1:0]) first and write PWM3DUTY[7:0] second, PWM3 duty register will be updated after Timer1 overflow occurs. The block diagram of PWM3 is illustrated in the following figure.



Figure 25 PWM3 Block Diagram

### 3.11 Timer4 / PWM4

Timer4 is an 10-bit down-count timer with Prescaler4 whose dividing rate is programmable. The output of Timer4 can be used to generate PWM4 output. Timer4 builds in auto-reload function and Timer4 reload register stores reload data with double buffers. When user write Timer4 reload register, write Timer4 MSB 2 bits(TM4RH[7:6]) first and write TMR4 second, Timer4 reload register will be updated to Timer4 counter after Timer4 overflow occurs when T4EN=1. If T4EN=0, Timer4 reload register will be updated to Timer4 counter after write TMR4 immediately. A read to the Timer4 will show the content of the Timer4 current count value. The block diagram of Timer4 is shown in the figure below.



Figure 26 Block Diagram of Timer4

The operation of Timer4 can be enabled or disabled by register bit T4EN (T4CR1[0]). After Timer4 is enabled, its clock source can be instruction clock, pin EX\_CKI1 or I\_HRC output, which is determined by register bit T4CS (T4CR2[5]) and TM4\_HRC(T4CR1[3]). When T4CS is 1 and TM4\_HRC is 0, EX\_CKI1 is selected as clock source. When T4CS is 0 and TM4\_HRC is 0, instruction clock is selected as clock source. When T4CS is 0 and TM4\_HRC is 0, instruction clock is selected, the active edge to decrease Timer4 is determined by register bit T4CE (T4CR2[4]). When T4CE is 1, high-to-low transition on EX\_CKI1 will decrease Timer4 is determined by register bit T4CE (T4CR2[4]). When T4CE is 1, high-to-low transition on EX\_CKI1 will decrease Timer1. When T4CE is 0, low-to-high transition on EX\_CKI1 will decrease Timer4. The selected clock source can be divided further by Prescaler4 before it is applied to Timer4. Prescaler4 is enabled by writing 0 to register bit /PS4EN (T4CR2[3]) and the dividing rate is from 1:2 to 1:256 determined by register bits PS4SEL[2:0] (T4CR2[2:0]). Current value of Prescaler4 can be obtained by reading register PS4CV.

Timer4 provides two kinds of operating mode: one is One-Shot mode and the other is Non-Stop mode. When register bit T4OS (T4CR1[2]) is 1, One-Shot mode is selected. Timer4 will count down once from initial value stored on register TMR4[9:0] to 0x00, i.e. underflow is occurred. When register bit T4OS (T4CR1[2]) is 0, Non-Stop mode is selected. When underflow is occurred, there are two selections to start next down-count which is determined by register bit T4RL (T4CR1[1]). When T4RL is 1, the initial value stored on register TMR4[9:0] will be restored and start next down-count from this initial value. When T4RL is 0, Timer1 will start next down-count from 0x3FF.

When Timer4 is underflow, the register bit T4IF (INTE2[6]) will be set to 1 to indicate Timer4 underflow event is occurred. If register bit T4IE (INTE2[2]) and GIE are both set to 1, interrupt request will occur and interrupt service routine will be executed. T4IF will not be clear until firmware writes 0 to T4IF.

The timing chart of Timer4 is shown in the following figure.





The PWM4 output is available on I/O pin PA4. When register bit PWM4OEN (T4CR1[7]) is set to 1, the corresponded PWM4 pin will became output pin automatically. The active state of PWM4 output is determined by register bit PWM4OAL (T4CR1[6]). When PWM4OAL is 1, PWM4 output is active low. When PWM4OAL is 0, PWM4 output is active high. Moreover, the duty cycle and frame rate of PWM4 are both programmable. The duty cycle is determined by registers TM4RH[3:2] and PWM4DUTY[7:0]. When PWM4DUTY is 0, PWM4 output will be never active. When PWM4DUTY is 0x3FF, PWM4 output will be active for 1023 Timer4 input clocks. The frame rate is determined by TM4RH[7:6] + TMR4[7:0] initial value. Therefore, PWM4DUTY value must be less than or equal to TM4RH[7:6] + TMR4[7:0]. When user write PWM4DUTY, write PWM4DUTY[9:8] MSB 2 bits(TM4RH[3:2]) first and write PWM4DUTY[7:0] second, PWM4 duty register will be updated after Timer4 overflow occurs. The block diagram of PWM4 is illustrated in the following figure.



Figure 28 PWM4 Block Diagram

### 3.12 Timer5 / PWM5

Timer5 is an 10-bit down-count timer with Prescaler5 whose dividing rate is programmable. The output of Timer5 can be used to generate PWM5 output. Timer5 builds in auto-reload function and Timer5 reload register stores reload data with double buffers. When user write Timer5 reload register, write Timer5 MSB 2 bits(TM5RH[5:4]) first and write TMR5 second, Timer5 reload register will be updated to Timer5 counter after Timer5 overflow occurs when T5EN=1. If T5EN=0, Timer1 reload register will be updated to Timer5 counter after write TMR5 immediately. A read to the Timer5 will show the content of the Timer5 current count value. The block diagram of Timer5 is shown in the figure below.



The operation of Timer5 can be enabled or disabled by register bit T5EN (T5CR1[0]). After Timer5 is enabled, its clock source can be instruction clock, pin EX\_CKI1 or I\_HRC output, which is determined by register bit T5CS (T5CR2[5]) and TM5\_HRC(T5CR1[3]). When T5CS is 1 and TM5\_HRC is 0, EX\_CKI1 is selected as clock source. When T5CS is 0 and TM5\_HRC is 0, instruction clock is selected as clock source. When TM5\_HRC is 1, I\_HRC output is selected as clock source. When EX\_CKI1 is selected, the active edge to decrease Timer5 is determined by register bit T5CE (T5CR2[4]). When T5CE is 1, high-to-low transition on EX\_CKI1 will decrease

Timer1. When T5CE is 0, low-to-high transition on EX\_CKI1 will decrease Timer5. The selected clock source can be divided further by Prescaler5 before it is applied to Timer5. Prescaler5 is enabled by writing 0 to register bit /PS5EN (T5CR2[3]) and the dividing rate is from 1:2 to 1:256 determined by register bits PS5SEL[2:0] (T5CR2[2:0]). Current value of Prescaler1 can be obtained by reading register PS5CV.

Timer5 provides two kinds of operating mode: one is One-Shot mode and the other is Non-Stop mode. When register bit T5OS (T5CR1[2]) is 1, One-Shot mode is selected. Timer5 will count down once from initial value stored on register TMR5[9:0] to 0x00, i.e. underflow is occurred. When register bit T5OS (T5CR1[2]) is 0, Non-Stop mode is selected. When underflow is occurred, there are two selections to start next down-count which is determined by register bit T5RL (T5CR1[1]). When T5RL is 1, the initial value stored on register TMR5[9:0] will be restored and start next down-count from this initial value. When T5RL is 0, Timer1 will start next down-count from 0x3FF.

When Timer5 is underflow, the register bit T5IF (INTF3[5]) will be set to 1 to indicate Timer5 underflow event is occurred. If register bit T5IE (INTE3[5]) and GIE are both set to 1, interrupt request will occur and interrupt service routine will be executed. T5IF will not be clear until firmware writes 0 to T5IF.

The timing chart of Timer5 is shown in the following figure.





The PWM5 output is available on I/O pin PB2. When register bit PWM5OEN (T5CR1[7]) is set to 1, the corresponded PWM5 pin will became output pin automatically. The active state of PWM5 output is determined by register bit PWM5OAL (T5CR1[6]). When PWM5OAL is 1, PWM5 output is active low. When PWM5OAL is 0, PWM5 output is active high. Moreover, the duty cycle and frame rate of PWM5 are both programmable. The duty cycle is determined by registers TM5RH[1:0] and PWM5DUTY[7:0]. When PWM5DUTY is 0, PWM5 output will be never active. When PWM5DUTY is 0x3FF, PWM5 output will be active for 1023 Timer5 input clocks. The frame rate is determined by TM5RH[5:4] + TMR5[7:0] initial value. Therefore, PWM5DUTY value must be less than or equal to TM5RH[5:4] + TMR5[7:0]. When user write PWM5DUTY, write PWM5DUTY[9:8] MSB 2

bits(TM5RH[1:0]) first and write PWM5DUTY[7:0] second, PWM5 duty register will be updated after Timer5 overflow occurs. The block diagram of PWM5 is illustrated in the following figure.



Figure 31 PWM5 Block Diagram

### 3.13 CCP Mode

The CCP (Capture/Compare/PWM) register (CCPR) is comprised of two 8-bit registers : CCPRL (low byte) and CCPRH (high byte). The CCPCON and PWMDB registers control the operation of CCP. The capture, compare mode use16-bit timer and PWM mode use10-bit timer respectively. The CCP timers and registers utilize the existing timers and registers. The following table shows the registers and timers resources shared with CCP modules. Note that when NY8BE62D is in CCP mode, related timer/PWM function are disabled.

| CCP mode        | CCP register/timer       | Shared Timers                            | Shared Registers |
|-----------------|--------------------------|------------------------------------------|------------------|
| Capture/Compare | CCPL                     | -                                        | PWM4DUTY[7:0]    |
| Capture/Compare | ССРН                     | -                                        | PWM5DUTY[7:0]    |
| PWM             | PWMDUTY                  | -                                        | PWM5DUTY[9:0]    |
| PWM             | PWMDB                    | -                                        | -                |
| Capture/Compare | Capture/Compare<br>timer | Timer5[7:0] (MSB) + Timer4[7:0]<br>(LSB) | -                |
| PWM             | PWM timer                | Timer5[9:0]                              | -                |

#### 3.13.1 Capture Mode

In capture mode, CCPRH:CCPRL (That is, PWM5DUTY[7:0]:PWM4DUTY[7:0]) captures the 16-bit value of capture timer register when an event occurs on pin P1A(PB2). An event is defined as:

- every falling edge
- every rising edge

- every 4<sup>th</sup> rising edge
- every 16<sup>th</sup> rising edge

The block diagram of capture mode is as the following:



An event is selected by control bits CCPM[3:0]. When a capture is made, the interrupt request flag bit CCPIF is set.

In capture mode, the CCP(PB2) should be configured ad an input. If it is an output pin, a write to the port can cause a capture condition.

In capture mode, capture timer must be running in CPU clock synchronous mode, or the capture operation may not work.

The capture event counter (or prescaler) is cleared when not in capture mode. Switching from one capture prescaler to another may generate an interrupt. Also, the prescaler counter will not be cleared.

#### 3.13.2 Compare Mode

In compare mode, the 16-bit CCPR (That is, PWM5DUTY[7:0]:PWM4DUTY[7:0]) register value is constantly compared against the compare timer value. When a match occurs, the CCP(PB2) pin is :

- driven high
- driven low
- toggle output
- remain unchanged (only interrupt)
- Trigger ADC if ADC is enabled

The compare mode block diagram is as the below shown:



The action on the pin is based on the value of control bit CCPM[3:0]. When compare match occurs, interrupt flag bit CCPIF is set.

In compare mode, the user must configure the CCP(PB2) pin as an output.

In compare mode, compare timer must be running in CPU clock synchronous mode, or the compare operation may not work.

### 3.13.3 CCP PWM Mode

In CCP PWM mode, the CCP module produces up to a 10-bit resolution PWM output. The PWM pads are P1A(PB2), P1B(PA5), P1C(PA2) and P1D(PA4). The PWM period and duty are specified by timer5[9:0] and PWM5DUTY[9:0] registers.

Register PWM5M[1:0] in the CCPCON register allows one of the following configurations:

- Single output : P1A output. P1B, P1C, P1D assigned as normal I/O.
- Half-Bridge output : P1A, P1B modulated with deadband control. P1C, P1D assign as normal I/O.
- Full-Bridge output, Forward mode: P1D modulated, P1A active. P1B, P1C inactive.
- Full-Bridge output, Reverse mode: P1B modulated, P1C active. P1A, P1D inactive.

In single output mode, P1A(PB2) pin is used as PWM output. PB2 must be set as output.

In Half-Bridge mode, P1A(PB2) pin has the PWM output signal, P1B(PA5) pin has the complementary PWM output signal. In this mode, PB2 and PA5 must be set as outputs.

In the Half-Bridge output mode, a digitally programmable deadband delay is available to avoid shoot-through current from destroying the bridge power switch. PWMDB[7:0] is deadband delay count for Half-Bridge mode, the delay unit is in CPU cycle.



As the above timing shown, timer5 is a 10-bit down counter, P1A is PWM5 output, P1B is PWM5 complementary output. AT point B, Timer5 value is equal to PWM5DUTY. At point D, Timer5 count to zero and reload value. If there no deadband control, P1A output should be active from point B to Point D. P1B output should be active from point D to point F. A non-zero deadband will delay P1A rising point from B to C and delay P1B rising point from D to E. The deadband zone are the time from B to C and from D to E.

In Full-Bridge mode, four pins are used as outputs; however, only two outputs are active at a time. In the Forward mode, P1A(PB2) is continuously actived and P1D(PA4) is modulated. In the Reverse mode, P1C(PA2) is continuously actived and P1B(PA5) is modulated. In this mode, PB2, PA5, PA2 and PA4 must be set as outputs. The following timing diagram shows Full-Bridge Forward and Reverse condition.

#### 3.14 RFC Mode



NY8BE64A has built-in RFC mode. Once RFC mode is enabled, the selected input pad state will take control of the Timer1 counting. When the selected input pad is recognized as 0 state (The input pad voltage is smaller

than  $V_{IL}$ ), Timer1 keeps counting. When this selected pad is recognized as 1 (The input pad voltage is larger than  $V_{IH}$ ), Timer1 stops counting. The following figure shows how RFC mode operates: PSEL3~0 is used to select one RFC input pad out of 16 NY8BE64A pads. RFCEN is used to switch the Timer1 enable signal between the normal enable signal T1EN and RFC selected input state.

One application of RFC mode is to measure the capacitor-resistor charging time, As the figure shows, when PSEL3~0=0x01, PA1 is selected as RFC input pad. At first the PA1 is set as output low (the voltage of PA1 is discharged to 0). Next step, clear Timer1 content, set PA1 as input and enable RFC mode. Then Timer1 will start counting, and the RC circuit will start charging PA1. As PA1 is charged to the  $V_{IH}$  voltage, the Timer1 counting is stopped because PA1 input is high. The Timer1 content will show the RC circuit charging time. (Note: Timer1 is down-count.)



Figure 32 RFC Block Diagram

### 3.15 IR Carrier

According to the IR pad configuration, the IR output pad of NY8BE64A can be PB1 or PA3. The IR carrier will be generated after register bit IREN (IRCR[0]) is set to 1. Moreover, PB1 or PA3 will become output pin automatically. When IREN is clear to 0, PB1 or PA3 will become general I/O pin as it was configured.

The IR carrier frequency is selectable by register bit IRF57K (IRCR[1]). When IRF57K is 1, IR carrier frequency is 57KHz. When IRF57K is 0, IR carrier frequency is 38KHz. Because IR carrier frequency is derived from high frequency system oscillation F<sub>HOSC</sub>, it is necessary to specify what frequency is used as system oscillation when external crystal is used. Register bit IROSC358M (IRCR[7]) is used to provide NY8BE64A this information. When IROSC358M is 1, frequency of external crystal is 3.58MHz and when IROSC358M is 0, frequency of external crystal is 455KHz. When internal high frequency oscillation is adopted, this register will be ignored, and it will provide 4MHz clock to IR module.

The active state (polarity) of IR carrier is selectable according to PB1 or PA3 output data. When register bit IRCSEL (IRCR[2]) is 1, IR carrier will be present on pin PB1 or PA3 when its output data is 0. When register bit IRCSEL (IRCR[2]) is 0, IR carrier will be present on pin PB1 or PA3 when its output data is 1. The polarity of IR carrier is shown in the following figure.

|              | IRCSEL=0 |              | IRCSEL=1 |
|--------------|----------|--------------|----------|
| PA3/PB1 Data |          | PA3/PB1 Data |          |
| IR Carrier   |          | IR Carrier   |          |

Figure 33 Polarity of IR Carrier vs. Output Data

### 3.16 Low Voltage Detector (LVD)

NY8BE64A low voltage detector (LVD) built-in precise band-gap reference for accurately detecting  $V_{DD}$  level. If LVDEN(register PCON[5])=1 and  $V_{DD}$  voltage value falls below LVD voltage which is selected by LVDS[3:0] as table shown below, the LVD output will become low. If the LVD interrupt is enabled, the LVD interrupt flag will be high and if GIE=1 it will force the program to execute interrupt service routine. Moreover, LVD real-state output can be polled by register PCON[6]. The following is LVD block diagram:





### The following table is LVD voltage select table.

| LVDS[3:0] | Voltage |
|-----------|---------|
| 0000      | 1.9V    |
| 0001      | 2.0V    |
| 0010      | 2.2V    |
| 0011      | 2.4V    |
| 0100      | 2.6V    |
| 0101      | 2.8V    |
| 0110      | 2.9V    |
| 0111      | 3.0V    |
| 1000      | 3.15V   |
| 1001      | 3.30V   |

| LVDS[3:0] | Voltage |
|-----------|---------|
| 1010      | 3.45V   |
| 1011      | 3.60V   |
| 1100      | 3.75V   |
| 1101      | 3.90V   |
| 1110      | 4.05V   |
| 1111      | 4.15V   |

Table 23 LVD voltage select

#### Note:

- 1. The hysteresis voltage (from low to high) of LVD is about 0.1V.
- 2. In battery charging applications (detected voltage is from low to high), the LVD voltage select table

| LVDS[3:0] | Voltage      |  |
|-----------|--------------|--|
| 0000      |              |  |
| 0001      |              |  |
| 0010      | (2.2+0.1) V  |  |
| 0011      | (2.4+0.1) V  |  |
| 0100      | (2.6+0.1) V  |  |
| 0101      | (2.8+0.1) V  |  |
| 0110      | (2.9+0.1) V  |  |
| 0111      | (3.0+0.1) V  |  |
| 1000      | (3.15+0.1) V |  |
| 1001      | (3.30+0.1) V |  |
| 1010      | (3.45+0.1) V |  |
| 1011      | (3.60+0.1) V |  |
| 1100      | (3.75+0.1) V |  |
| 1101      | (3.90+0.1) V |  |
| 1110      | (4.05+0.1) V |  |
| 1111      | (4.15+0.1) V |  |

should be as followed:

The LVD control flow is as the following:

- Step1: Select LVD voltage by LVDS[3:0]
- Step2: Set CMPCR = 0x0A
- Step3: Set PCON[5]=1 (enable LVD)
- Step4: Check LVD status by PCON1[6]

Note: If LVD voltage LVDS[3:0] is changed, user must wait at least 50us(@F<sub>HOSC</sub>=1MHz) to get correct LVD status by PCON1[6]

### 3.17 Voltage Comparator

NY8BE64A provides 1 set of voltage comparator and internal reference voltage with various analog comparing mode. The comparator non-inverting and inverting input can share with GPIO. The internal reference voltage can only routed to inverting input of comparator.

CMPEN (register ANAEN[7]) is used to enable and disable comparator. When CMPEN=0(default), comparator is disabled. When CMPEN=1, the comparator is enabled. In halt mode the comparator is disabled automatically.

The structure of comparator is shown in the following figure:



Figure 35 Vref hardware connection

### 3.17.1 Comparator Reference Voltage (Vref)

The internal reference voltage Vref is built by series resistance to provide different level of reference voltage. RBIAS\_H and RBIAS\_L are used to select the maximum and minimum values of Vref, and LVDS[3:0] are used to select one of 16 voltage levels.



Figure 36 Vref hardware connection

The **Vref** is determined by RBIAS\_H, RBIAS\_L and LVDS[3:0]. The LVDS[3:0] is used to select one out of 16 reference voltages, the table shown below.

| LVDS[3:0] | RBIAS_H=1<br>RBIAS_L=0 | RBIAS_H=0<br>RBIAS_L=1 |
|-----------|------------------------|------------------------|
| 0000      | 65/128 V <sub>DD</sub> | 31/128 V <sub>DD</sub> |
| 0001      | 62/128 V <sub>DD</sub> | 29/128 V <sub>DD</sub> |
| 0010      | 56/128 VDD             | 26/128 V <sub>DD</sub> |
| 0011      | 52/128 V <sub>DD</sub> | 23/128 V <sub>DD</sub> |
| 0100      | 48/128 V <sub>DD</sub> | 20/128 V <sub>DD</sub> |
| 0101      | 44/128 V <sub>DD</sub> | 18/128 V <sub>DD</sub> |
| 0110      | 43/128 V <sub>DD</sub> | 17/128 V <sub>DD</sub> |
| 0111      | 41/128 V <sub>DD</sub> | 16/128 V <sub>DD</sub> |
| 1000      | 39/128 V <sub>DD</sub> | 14/128 V <sub>DD</sub> |
| 1001      | 37/128 V <sub>DD</sub> | 13/128 V <sub>DD</sub> |
| 1010      | 35/128 V <sub>DD</sub> | 12/128 V <sub>DD</sub> |
| 1011      | 34/128 V <sub>DD</sub> | 11/128 V <sub>DD</sub> |
| 1100      | 32/128 V <sub>DD</sub> | 10/128 V <sub>DD</sub> |
| 1101      | 31/128 V <sub>DD</sub> | 9/128 V <sub>DD</sub>  |
| 1110      | 30/128 V <sub>DD</sub> | 8/128 V <sub>DD</sub>  |
| 1111      | 29/128 V <sub>DD</sub> | 7/128 V <sub>DD</sub>  |

 Table 13
 The reference voltage Vref selection table

### Note: The deviation of Vref is ±0.1V.

The non-inverting input of the comparator is determined by PS[1:0] (register CMPCR[3:2]).

The table is shown below

| PS[1:0] | Non-inverting input |
|---------|---------------------|
| 00      | PA0                 |
| 01      | PA2                 |
| 10      | Vref                |
| 11      |                     |

Table 14 Non-inverting input select

The inverting input of the comparator is determined by NS[1:0] (register CMPCR[1:0]).

The table is shown below

| NS[1:0] | Inverting input |
|---------|-----------------|
| 00      | PA1             |
| 01      | PA3             |
| 10      | Bandgap (0.6V)  |
| 11      | Vref            |

Table 15 Inverting input select

There are two ways to get the comparator output result: one is through register polling, the other is through probing output pad.

Comparator output can be polled by LVDOUT (register PCON1[6]).

To probe comparator output at output pad, set CMPOE (register OSCCR[6]) to 1, then PB3 will be the real-time state of the comparator output. It is noted that when CMPOE=1, the PWM3 function will be disabled if it is enabled.

### 3.18 Analog-to-Digital Convertor (ADC)

NY8BE64A provide 12+2 channel 12-bit SAR ADC to transfer analog signal into 12-bits digital data. The ADC high reference voltage is selectable. They can be external voltage from PA0, or internal generated voltage VDD, 4V, 3V or 2V. The Analog input is selected from analog signal input pin PA0~PA4, PB1~PB7 or from internal generated 1 / 4 \*VDD. The ADC clock ADCLK can be selected to be F<sub>INST</sub>/1, F<sub>INST</sub>/2, F<sub>INST</sub>/8 or F<sub>INST</sub>/16. The Sampling pulse width can be selected to be ADCLK\*1, ADCLK\*2, ADCLK\*4 or ADCLK\*8. Set ADEN=1 before ADC take into operation. Then set START=1, the ADC will start to convert analog signal to digital. EOC=0 means ADC is in processing. EOC=1 indicate ADC is at end of conversion. If ADIE=1 and global interrupt is enabled, the ADC interrupt will issue after EOC low go high. The block diagram is as following figure.



Figure 37 ADC block diagram

#### 3.18.1 ADC reference voltage

ADC is built-in five high reference voltage source controlled by ADVREFH register. These high reference voltage source are one external voltage source (PA0/PB1) and four internal voltage source (VDD, 4V, 3V, 2V). When EVHENB bit is "1", ADC reference voltage is external voltage source from PA0. In this mode PA0 must input a voltage between VDD and 2V. If EVHENB bit is 0, ADC reference voltage is from internal voltage source selected by VHS[1:0]. If VHS[1:0] is "11", ADC reference voltage is VDD. If VHS[1:0] is "10", ADC reference voltage is 4V. If VHS[1:0] is "01", ADC reference voltage is 3V. If VHS[1:0] is "00", ADC reference voltage is 2V. The limitation of internal reference voltage application is VDD can't below each of internal voltage level, or the level is equal to VDD. ADC sampling voltage range is limited by high/low reference voltage includes internal VDD/4V/3V/2V and external reference voltage source from PA0 pin. The ADC reference voltage range limitation is (ADC high reference voltage – low reference voltage)  $\ge$  2V. ADC low reference voltage is VSS=0V. So ADC high reference voltage range is 2V ~ VDD.

ADC analog input signal voltage must be from ADC low reference voltage to ADC high reference voltage. If the ADC analog input signal voltage is over this range, The ADC converting result is unexpected (full scale or zero).

| EVHENB | VHS[1:0] | Reference voltage |
|--------|----------|-------------------|
| 1      | хх       | PA0/PB1           |
| 0      | 11       | VDD               |
| 0      | 10       | 4V                |
| 0      | 0 1      | 3V                |
| 0      | 0 0      | 2V                |

Table 27 ADC reference voltage select

#### 3.18.2 ADC analog input channel

ADC use CHS[3:0] and GCHS to select analog input source. GCHS is global channel select. Namely, GCHS must be 1 before any analog input source can be selected and converted.

| GCHS | CHS[3:0] | ADC analog input source |
|------|----------|-------------------------|
| 0    | x x x x  | x                       |
| 1    | 0000     | PA0                     |
| 1    | 0001     | PA1                     |
| 1    | 0010     | PA2                     |
| 1    | 0011     | PA3                     |
| 1    | 0100     | PA4                     |
| 1    | 0101     | PB1                     |
| 1    | 0110     | PB2                     |
| 1    | 0111     | PB3                     |
| 1    | 1000     | PB4                     |
| 1    | 1001     | PB5                     |
| 1    | 1010     | PB6                     |
| 1    | 1011     | PB7                     |
| 1    | 1100     | 1 / 4 * VDD             |
| 1    | 1101     | VSS                     |
| 1    | 1 1 1 X  | N.C.                    |

Table 28ADC analog input source select

ADC input pins are shared with digital I/O pins. Connect an analog signal to these pin may cause extra current leakage in I/O pins. In the power down mode, the above leakage current will be a big problem. Register bit PACONx/PBCONx is PAx/PBx configuration register bit to solve above problem. Write "1" to PACONx/ PBCONx register bit will configure related PAx/PBx pin as pure analog input pin to avoid current leakage, and it can't be use as normal I/O.

Except setting the PACONx/PBCONx register bit, the selected analog input pin must be set as input mode and the internal pull-high / pull-down must be disabled, otherwise the analog input level may be affected.

#### 3.18.3 ADC clock (ADCLK), sampling clock (SHCLK) and bit number

Conversion speed and conversion accuracy are affected by the selection of the ADC clock (ADCLK), sampling pulse width (SHCLK) and conversion bit number. ADCLK is the base clock of ADC. During the operation of SAR ADC, bit operation is synchronized with ADCLK. SHCLK is the duration of analog signal sampling time, larger SHCLK will restore original analog signal level more closely but it will slow down the ADC conversion speed. Vise versa. The ADC can select different conversion bit number which is depended on ADCR[1:0] register bits. There are 2 bit number to select, which is 12-bit, 10-bit and 8-bit. Less conversion bit number will speed up the ADC conversion rate but the effective ADC bit is less. More conversion bit number will slow down the accuracy is more.

The ADC clock is derived from FINST and is selectable from ADCK[1:0].

| ADCK[1:0] | ADC clock |
|-----------|-----------|
| 0 0       | FINST/16  |
| 0 1       | FINST/8   |
| 10        | FINST/1   |
| 11        | FINST/2   |

Table 29 ADC clock select

The Sampling clock width is derived from ADCLK and is selectable from SHCK[1:0].

| SHCK[1:0] | Sampling clock |  |  |  |  |
|-----------|----------------|--|--|--|--|
| 0 0       | 1 ADCLK        |  |  |  |  |
| 0 1       | 2 ADCLK        |  |  |  |  |
| 10        | 4 ADCLK        |  |  |  |  |
| 11        | 8 ADCLK        |  |  |  |  |

Table 30 ADC sampling clock select

ADC bit number select is from ADCR[1:0].

| ADCR[1:0] | Conversion bit number |
|-----------|-----------------------|
| 0 0       | 8-bit                 |
| 0 1       | 10-bit                |
| 1 x       | 12-bit                |

Table 31conversion bit number select

The ADC converting time is from START(Start to ADC convert) to EOC=1 (End of ADC convert). The duration is depending on ADC resolution and ADC clock rate and sampling clock width.

### ADC conversion time ≈ sampling clock width + (ADC bit number + 2) \* ADCLK width.

The following table is some example conversion time and conversion rate of ADC.

## NY8BE64A

| Bit No. | ADC clock            | SHCLK   | Conversion<br>Time<br>(ADCLK No.) | F <sub>INST</sub> = 2MHz |          | F <sub>INST</sub> = 250K |         |
|---------|----------------------|---------|-----------------------------------|--------------------------|----------|--------------------------|---------|
|         |                      |         |                                   | Time                     | Rate     | Time                     | Rate    |
| 12      | FINST/16             | 8 ADCLK | 22                                | 176us                    | 5.68kHz  | 1408us                   | 710Hz   |
| 12      | FINST/1              | 1 ADCLK | 15                                | 7.5us                    | 133.3kHz | 60us                     | 16.7kHz |
| 10      | F <sub>INST</sub> /1 | 1 ADCLK | 13                                | 6.5us                    | 153.8kHz | 52us                     | 19.2kHz |
| 8       | FINST/1              | 1 ADCLK | 11                                | 5.5us                    | 181.8kHz | 44us                     | 22.7kHz |

Table 32 ADC Conversion time

#### 3.18.4 ADC offset calibration

ADC offset error is defined as the deviation between the first ideal code transition and the first actual code transition. The first ideal code transition take place at 0.5LSB. ADC offset error varies with temperature, process and voltage. ADC offset error can be real-time adjusted in NY8BE62D through ADJMD register. Nyquest provides the NYIDE example code "ADC\_Interrupt\_AutoK" for ADC offset calibration process.

#### 3.18.5 ADC operation

Set ADC clock (ADCLK), sampling clock width (SHCLK), conversion bit number (ADCR), ADC high reference voltage (ADVREFH), select input channel and PACON or PBCON related bit. Then set ADEN=1.

After setting ADEN=1, it must wait at least 256us (ADC internal bias stable time) before ADC can operate. Write START to 1 to start an ADC conversion session. During ADC is in processing EOC=0. Polling EOC=1 or wait for ADC interrupt at the end of ADC conversion.

#### 3.19 Watch-Dog Timer (WDT)

There is an on-chip free-running oscillator in NY8BE64A which is used by WDT. As this oscillator is independent of other oscillation circuits, WDT may still keep working during Standby mode and Halt mode.

WDT can be enabled or disabled by a configuration word. When WDT is enabled by configuration word, its operation still can be controlled by register bit WDTEN (PCON[7]) during program execution. Moreover, the mechanism after WDT time-out can reset NY8BE64A or issue an interrupt request which is determined by another configuration word. At the same time, register bit /TO (STATUS[4]) will be clear to 0 after WDT time-out.

The baseline of WDT time-out period can be 3.5 ms, 15 ms, 60 ms or 250 ms which is determined by two configuration words. The time-out period can be lengthened if Prescaler0 is assigned to WDT. Prescaler0 will be assigned to WDT by writing 1 to register bit PS0WDT. The dividing rate of Prescaler0 for WDT is determined by register bits PS0SEL[2:0] and depends on WDT time-out mechanism. The dividing rate is from 1:1 to 1:128 if WDT time-out will reset NY8BE64A and dividing rate is from 1:2 to 1:256 if WDT time-out will interrupt NY8BE64A.

When Prescaler0 is assigned to WDT, the execution of instruction CLRWDT will clear WDT, Prescaler0 and set /TO flag to 1.

If user selects interrupt for WDT time-out mechanism, register bit WDTIF (INTF[6]) will set to 1 after WDT is expired. It may generate an interrupt request if register bit WDTIE (INTE[6]) and GIE both set to 1. WDTIF will not be clear until firmware writes 0 to WDTIF.

### 3.20 Interrupt

NY8BE64A provides two kinds of interrupt: one is software interrupt and the other is hardware interrupt. Software interrupt is caused by execution of instruction INT. There are 13 hardware interrupts:

- Timer0 overflow interrupt.
- Timer1 underflow interrupt.
- Timer4 underflow interrupt.
- Timer5 underflow interrupt.
- WDT timeout interrupt.
- PA/PB input change interrupt.
- External 0 interrupt.
- External 1 interrupt
- External 2 interrupt
- LVD interrupt.
- Comparator output status change interrupt.
- ADC end-of-convert interrupt.
- SIM interrupt.(serial interface mode interrupt )

GIE is global interrupt enable flag. It has to be 1 to enable hardware interrupt functions. GIE can be set by ENI instruction and clear to 0 by DISI instruction.

After instruction INT is executed, no matter GIE is set or clear, the next instruction will be fetched from address 0x001. At the same time, GIE will be clear to 0 by NY8BE64A automatically. This will prevent nested interrupt from happening. The last instruction of interrupt service routine of software interrupt has to be RETIE. Execution of this instruction will set GIE to 1 and return to original execution sequence.

While any of hardware interrupts is occurred, the corresponding bit of interrupt flag will be set to 1. This bit will not be clear until firmware writes 0 to this bit. Therefore user can obtain information of which event causes hardware interrupt by polling the corresponding bit of interrupt flag. Note that only when the corresponding interrupt enable bit is set to 1, will the corresponding interrupt flag be read. And if the corresponding interrupt enable bit is set to 1 and GIE is also 1, hardware interrupt will occur and next instruction will be fetched from 0x008. At the same time, the register bit GIE will be clear by NY8BE64A automatically. If user wants to implement nested interrupt, instruction ENI can be used as the first instruction of interrupt service routine which will set GIE to 1 again and allow other interrupt events to interrupt NY8BE64A again. Instruction RETIE has to

be the last instruction of interrupt service routine which will set GIE to 1 and return to original execution sequence.

It should be noted that ENI instruction cannot be placed right before RETIE instruction because ENI instruction in interrupt service routine will trigger nested interrupt, but RETIE will clear internal interrupt processing after jump out of ISR, so it is possible for interrupt flag to be falsely cleared.

#### 3.20.1 Timer0 Overflow Interrupt

Timer0 overflow (from 0x00 to 0xFF) will set register bit T0IF. This interrupt request will be serviced if T0IE and GIE are set to 1.

### 3.20.2 Timer1 Underflow Interrupt

Timer1 underflow (from 0x3FF to 0x00) will set register bit T1IF. This interrupt request will be serviced if T1IE and GIE are set to 1.

#### 3.20.3 Timer4 Underflow Interrupt

Timer4 underflow (from 0x3FF to 0x00) will set register bit T4IF. This interrupt request will be serviced if T4IE and GIE are set to 1.

### 3.20.4 Timer5 Underflow/CCP Interrupt (Not Support)

Timer5 underflow (from 0x3FF to 0x00) will set register bit T5IF. This interrupt request will be serviced if T5IE and GIE are set to 1. When CCP capture / compare mode is enabled, timer5 interrupt is replaced by CCP interrupt.

#### 3.20.5 WDT Timeout Interrupt

When WDT is timeout and the configuration word selects WDT timeout will generate interrupt request, it will set register bit WDTIF. This interrupt request will be serviced if WDTIE and GIE are set to 1.

### 3.20.6 PA/PB Input Change Interrupt

When PAx,  $0 \le x \le 7$ , PBy,  $0 \le y \le 7$  is configured as input pin and corresponding register bit WUPAx, WUPBx is set to 1, a level change on these selected I/O pin(s) will set register bit PABIF. This interrupt request will be serviced if PABIE and GIE are set to 1. Note when PA3, PA4 or PA5 is both set as level change interrupt and external interrupt, the external interrupt enable EIS0, EIS1 or EIS2=1 will disable PA3, PA4 or PA5 level change operation.

#### 3.20.7 External 0 Interrupt

According to the configuration of EIS0=1 and INTEDG, the selected active edge on I/O pin PA4 will set register bit INTOIF and this interrupt request will be served if INTOIE and GIE are set to 1.

#### 3.20.8 External 1 Interrupt

According to the configuration of EIS1=1 and INTEDG, the selected active edge on I/O pin PA3 will set register bit INT1IF and this interrupt request will be served if INT1IE and GIE are set to 1.

#### 3.20.9 External 2 Interrupt

According to the configuration of EIS2=1 and INTEDG, the selected active edge on I/O pin PA5 will set register bit INT2IF and this interrupt request will be served if INT2IE and GIE are set to 1.

#### 3.20.10 LVD Interrupt

When  $V_{DD}$  level falls below LVD voltage, LVD flag will from high to low, and set the register bit LVDIF=1. This interrupt request will be serviced if LVDIE and GIE are set to 1.

#### 3.20.11 Comparator Output Status Change Interrupt

The comparator interrupt is triggered whenever a change occurs on the comparator output status. This interrupt request will be serviced if CMPIE and GIE are set to 1. Note that before the comparator interrupt could happen, reading register OSCCR is needed to clear the previous comparator output status difference.

#### 3.20.12 ADC end of conversion Interrupt

The ADC interrupt is triggered whenever an ADC end-of-convert signal is issued. This interrupt request will be serviced if ADIE and GIE are set to 1.

#### 3.20.13 EEPROM write complete Interrupt

When EEPROM write is completed, the EEPROM write complete flag is issued. This interrupt request will be serviced if EEIE and GIE are set to 1.

#### 3.20.14 SERAIL interface mode interrupt

The SIM interrupt is triggered whenever an SPIF of spi mode or MIFof iic mode is issued. This interrupt request will be serviced if SIMIE and GIE are set to 1.

### 3.21 Oscillation Configuration

Because NY8BE64A is a dual-clock IC, there are high oscillation ( $F_{HOSC}$ ) and low oscillation ( $F_{LOSC}$ ) that can be selected as system oscillation ( $F_{OSC}$ ). The oscillators which could be used as  $F_{HOSC}$  are internal high RC oscillator ( $I_{HRC}$ ), external high crystal oscillator ( $E_{HXT}$ ) and external crystal oscillator ( $E_{XT}$ ). The oscillators which could be used as  $F_{LOSC}$  are internal low RC oscillator ( $I_{LRC}$ ) and external low crystal oscillator ( $E_{LXT}$ ).



Figure 38 Oscillation Configuration of NY8BE64A

There are two configuration words to determine which oscillator will be used as  $F_{HOSC}$ . When I\_HRC is selected as  $F_{HOSC}$ , I\_HRC output frequency is determined by three configuration words and it can be 1M, 2M, 4M, 8M, 16M or 20MHz. Moreover, external crystal oscillator pads PA6 and PA7 can be used as I/O pins. On the other hand, PA7 can be the output pin of instruction clock according to a configuration word's setting. If  $F_{HOSC}$  required external crystal whose frequency ranges from 8MHz to 20MHz, E\_HXT is recommended. If  $F_{HOSC}$  required external crystal whose frequency ranges from 455KHz to 6MHz, E\_XT is recommended. When E\_HXT or E\_XT is adopted, PA6/PA7 cannot be used as I/O pins. They must be used as crystal output pin and input pin. PA7 is crystal output pin (Xout) and PA6 is crystal input pin (Xin).

There is one configuration word to determine which oscillator will be used as  $F_{LOSC}$ . When I\_LRC is selected, its frequency is centered on 32768Hz. If  $F_{LOSC}$  required external crystal, E\_LXT is selected and only 32768Hz crystal is allowed. When E\_LXT is adopted, PA6/PA7 cannot be used as I/O pins. They must be used as crystal output pin and input pin. PA7 is crystal output pin (Xout) and PA6 is crystal input pin (Xin). The dual-clock combinations of  $F_{HOSC}$  and  $F_{LOSC}$  are listed below.

| No. | FHOSC         | FLOSC |
|-----|---------------|-------|
| 1   | I_HRC         | I_LRC |
| 2   | E_HXT or E_XT | I_LRC |
| 3   | I_HRC         | E_LXT |

Table 33 Dual-clock combinations

When E\_HXT, E\_XT or E\_LXT is used as one of oscillations, the crystal or resonator is connected to Xin and Xout to provide oscillation. Moreover, a resistor and two capacitors are recommended to connect as following figure in order to provide reliable oscillation, refer to the specification of crystal or resonator to adopt appropriate C1 or C2 value. The recommended value of C1 and C2 are listed in the table below.

| Oscillation Mode | C1, C2 (pF) |          |
|------------------|-------------|----------|
|                  | 16M         | 5 ~ 10   |
| E_HXT            | 10M         | 5 ~ 30   |
|                  | 8M          | 5 ~ 20   |
|                  | 4M          | 5 ~ 30   |
| E_XT             | 1M          | 5 ~ 30   |
|                  | 455K        | 10 ~ 100 |
| E_LXT            | 32768       | 5 ~ 30   |

Table 34 Recommended C1 and C2 Value for Different Kinds of Crystal Oscillation

For 20MHZ resonator in 2 clock CPU cycle mode, an 18pF C2 capacitor is a must.

To get precise and stable 32.768k frequency, choosing the right C1 and C2 value is important. You need to match the C1 / C2 capacitance to the specific crystal you chose. Every crystal datasheet lists something called the Load Capacitance (CL), C1 and C2 value is chosen with the following formula:

### C1=C2=2\*CL-Cbt

Where Cbt is the NY8BE64A crystal pad built-in capacitance, which is about 5pF. For example, for crystal CL=12.5P, C1=C2=20pF is recommended.

The accuracy of I\_HRC is  $\pm 1\%$  at 25°C commercial conditions.



Figure 39 Connection for External Crystal Oscillation

Either  $F_{HOSC}$  or  $F_{LOSC}$  can be selected as system oscillation  $F_{OSC}$  according to the value of register bit SELHOSC (OSCCR[0]). When SELHOSC is 1,  $F_{HOSC}$  is selected as  $F_{OSC}$ . When SELHOSC is 0,  $F_{LOSC}$  is selected as  $F_{OSC}$ . Once  $F_{OSC}$  is determined, the instruction clock  $F_{INST}$  can be  $F_{OSC}/2$  or  $F_{OSC}/4$  according to value of a configuration word.

### 3.22 Operating Mode

NY8BE64A provides four kinds of operating mode to tailor all kinds of application and save power consumptions. These operating modes are Normal mode, Slow mode, Standby mode and Halt mode. Normal mode is designated for high-speed operating mode. Slow mode is designated for low-speed mode in order to save power consumption. At Standby mode, NY8BE64A will stop almost all operations except Timer0/Timer1/Timer4/ Timer5/WDT in order to wake-up periodically. At Halt mode, NY8BE64A will sleep until external event or WDT trigger IC to wake-up. The block diagram of four operating modes is described in the following figure.



Figure 40 Four Operating Modes

#### 3.22.1 Normal Mode

After any Reset Event is occurred and Reset Process is completed, NY8BE64A will begin to execute program under Normal mode or Slow mode. Which mode is selected after Reset Process is determined by the Startup Clock configuration word. If Startup Clock=fast, NY8BE64A will enter Normal mode, if Startup Clock=Slow, NY8BE64A will enter Slow mode. At Normal mode, F<sub>HOSC</sub> is selected as system oscillation in order to provide highest performance and its power consumption will be the largest among four operating modes. After power on or any reset trigger is released, NY8BE64A will enter Normal mode after reset process is completed.

- Instruction execution is based on F<sub>HOSC</sub> and all peripheral modules may be active according to corresponding module enable bit.
- The FLOSC is still active and running.
- IC can switch to Slow mode by writing 0 to register bit SELHOSC (OSCCR[0]).
- IC can switch to Standby mode or Halt mode by programming register bits OPMD[1:0] (OSCCR[3:2]).
- For real time clock applications, the NY8BE64A can run in normal mode, at the same time the low-frequency clock Low Oscillator Frequency connects to Timer0 clock. This is made possible by setting LCKTM0 to 1 and corresponding configuration word Timer0 source setting to 1.

#### 3.22.2 Slow Mode

NY8BE64A will enter Slow mode by writing 0 to register bit SELHOSC. At Slow mode,  $F_{LOSC}$  is selected as system oscillation in order to save power consumption but still keep IC running. However,  $F_{HOSC}$  will not be disabled automatically by NY8BE64A. Therefore user can write 0 to register bit STPHOSC (OSCCR[1]) in slow mode to reduce power consumption further. But it is noted that it is forbidden to enter slow mode and stop  $F_{HOSC}$  at the same time, one must enter slow mode first, then disable  $F_{HOSC}$ , or the program may hang on.

- Instruction execution is based on FLOSC and all peripheral modules may be active according to corresponding module enable bit.
- FHOSC can be disabled by writing 1 to register bit STPHOSC.
- IC can switch to Standby mode or Halt mode by programming register bits OPMD[1:0].
- IC can switch to Normal mode by writing 1 to SELHOSC.

#### 3.22.3 Standby Mode

NY8BE64A will enter Standby mode by writing 10b to register bits OPMD[1:0]. At Standby mode, however,  $F_{HOSC}$  will not be disabled automatically by NY8BE64A and user has to enter slow mode and write 1 to register bit STPHOSC in order to stop  $F_{HOSC}$  oscillation. Most of NY8BE64A peripheral modules are disabled but Timer can be still active if register bit T0EN/T1EN/T4EN/T5EN is set to 1. Therefore NY8BE64A can wake-up after Timer0/Timer1/Timer4/Timer5 is expired. The expiration period is determined by the register TMR0/TMR1[9:0]/TMR4[9:0]/TMR5[9:0],  $F_{INST}$  and other configurations for Timer0/Timer1/Timer4/Timer5.

- Instruction execution is stop and some peripheral modules may be active according to corresponding module enable bit.
- FHOSC can be disabled by writing 1 to register bit STPHOSC.
- The FLOSC is still active and running.
- IC can wake-up from Standby mode if any of (a) Timer0/Timer1/Timer4/Timer5 (overflow/underflow) interrupt, (b) WDT timeout interrupt, (c) PA/PB input change interrupt, (d) INT external interrupt is happened, (e) LVD interrupt, (f) Comparator output status change interrupt or (g) ADC end-of-convert interrupt.
- After wake-up from Standby mode, IC will return to Normal mode if SELHOSC=1, IC will return to Slow mode if SELHOSC=0.
- It is not recommended to change oscillator mode (normal to slow / slow to normal) and enter standby mode at the same time.

#### 3.22.4 Halt Mode

NY8BE64A will enter Halt mode by executing instruction SLEEP or writing 01b to register bits OPMD[1:0]. After entering Halt mode, register bit /PD (STATUS[3]) will be clear to 0, register bit /TO (STATUS[4]) will be set to 1 and WDT will be clear but keep running.

At Halt mode, all of peripheral modules are disabled, instruction execution is stop and NY8BE64A can only wake-up by some specific events. Therefore, Halt mode is the most power saving mode provided by NY8BE64A.

- Instruction execution is stop and all peripheral modules are disabled.
- FHOSC and FLOSC are both disabled automatically.
- IC can wake-up from Halt mode if any of (a) WDT timeout interrupt, (b) PA/PB input change interrupt or (c) INT or external interrupt is happened.
- After wake-up from Halt mode, IC will return to Normal mode if SELHOSC=1, IC will return to Slow mode if SELHOSC=0.

### Note: Users can change STPHOSC and enter Halt mode in the same instruction.

• It is not recommended to change oscillator mode (normal to slow or slow to normal) and enter halt mode at the same time.

#### 3.22.5 Wake-up Stable Time

The wake-up stable time of Halt mode is determined by Configuration word: High Oscillator Frequency or Low Oscillator Frequency. If one of E\_HXT, E\_XT and E\_LXT is selected, the wake-up period would be  $512*F_{OSC}$ . And if no XT mode are selected,  $16*F_{OSC}$  would be set as wake up period. On the other hand, there is no need of wake-up stable time for Standby mode because either  $F_{HOSC}$  or  $F_{LOSC}$  is still running at Standby mode.

Before NY8BE64A enter Standby mode or Halt mode, user may execute instruction ENI. At this condition, NY8BE64A will branch to address 0x008 in order to execute interrupt service routine after wake-up. If instruction DISI is executed before entering Standby mode or Halt mode, the next instruction will be executed after wake-up.

### 3.22.6 Summary of Operating Mode

The summary of four operating modes is described in the following table.

| Mode                                            | Normal              | Slow                | Standby                                                                                                                                                                                       | Halt                                                   |
|-------------------------------------------------|---------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| F <sub>HOSC</sub>                               | Enabled             | STPHOSC             | STPHOSC                                                                                                                                                                                       | Disabled                                               |
| FLOSC                                           | Enabled             | Enabled             | Enabled                                                                                                                                                                                       | Disabled                                               |
| Instruction Execution                           | Executing           | Executing           | Stop                                                                                                                                                                                          | Stop                                                   |
| Timer0/1/2/3                                    | TxEN                | TxEN                | TxEN                                                                                                                                                                                          | Disabled                                               |
| WDT                                             | Option and<br>WDTEN | Option and<br>WDTEN | Option and WDTEN                                                                                                                                                                              | Option and WDTEN                                       |
| Other Modules Module enable bit Module enable b |                     | Module enable bit   | Module enable bit                                                                                                                                                                             | All disabled                                           |
| Wake-up Source                                  | -                   | -                   | <ul> <li>Timer0/1/4/5 overflow</li> <li>WDT timeout</li> <li>PA/PB input change</li> <li>INT0/1/2</li> <li>LVD interrupt</li> <li>Comparator interrupt</li> <li>ADC end-of-convert</li> </ul> | - WDT timeout<br>- PA/PB input<br>change<br>- INT0/1/2 |

Table 35 Summary of Operating Modes

### 3.23 Reset Process

NY8BE64A will enter Reset State and start Reset Process when one of following Reset Event is occurred:

- Power-On Reset (POR) is occurred when VDD rising is detected.
- Low-Voltage Reset (LVR) is occurred when operating V<sub>DD</sub> is below pre-defined voltage.
- Pin RSTb is low state.
- WDT timeout reset.

Moreover, value of all registers will be initialized to their initial value or unchanged if its initial value is unknown. The status bits /TO and /PD could be initialized according to which event causes reset. The /TO and /PD value and its associated event is summarized in the table below.

| Event                         | /ТО       | /PD       |
|-------------------------------|-----------|-----------|
| POR, LVR                      | 1         | 1         |
| RSTb reset from non-Halt mode | unchanged | unchanged |

| Event                        | /ТО | /PD |
|------------------------------|-----|-----|
| RSTb reset from Halt mode    | 1   | 1   |
| WDT reset from non-Halt mode | 0   | 1   |
| WDT reset from Halt mode     | 0   | 0   |
| SLEEP executed               | 1   | 0   |
| CLRWDT executed              | 1   | 1   |

Table 36 Summary of /TO & /PD Value and its Associated Event

After Reset Event is released, NY8BE64A will start Reset Process. It will wait certain amount of period for oscillation stable no matter what kind of oscillator is adopted. This period is called power-up reset time and is determined by three-bit configuration words which can be 140us, 4.5ms, 18ms, 72ms or 288ms. After power-up reset time, NY8BE64A will wait for further oscillator start-up time (OST) before it starts to execute program. OST=1 clock cycle of F<sub>osc</sub> if the previous power-up time is 140us, OST=16 clock cycles of F<sub>osc</sub> if the previous power-up time is 4.5ms, 18ms, 72ms or 288ms.



Figure 41 Block diagram of on-chip reset circuit

For slow V<sub>DD</sub> power-up, it is recommended to use RSTb reset, as the following figure.

- It is recommended the R value should be not greater than 40KΩ.
- The R1 value=100Ω to 1KΩ will prevent high current, ESD or Electrical overstress flowing into reset pin.
- The diode helps discharge quickly when power down.



Figure 42 Block Diagram of Reset Application

#### 3.24 SPI MODE

Features of the SPI include:

- Full-duplex operation
- Four programmable master mode frequencies
- Serial clock with programmable polarity and phase
- End of transmission interrupt flag
- Write collision error flag
- Bus contention error flag

NY8BE64A will enter SPI MODE by writing SIMCR[7]=1. It includes four line SPI interface if SIMCR[4]=1, and It includes three line SPI interface if SIMCR[4]=0.

The communication is full duplex and operates as a slave/master type, where the device can be either master or slave. The device is master If SIMCR[5]=1, it is slave if SIMCR[5]=0 The SPI interface is a full duplex synchronous serial data link. It is a four line interface with pin names SCK, MISO,MOSI and SSBEN. When choose three line interface, SSBEN is omitted, no matter master or slave are always enable.

Only a master SPI can initiate transmissions. Software begins the transmission from a master SPI by writing to the SPI data register (SIMDR). The SIMDR does not buffer data being transmitted from the SPI. Data written to the SIMDR goes directly into the shift register and begins the transmission immediately under the control of the serial clock. The transmission ends after eight cycles of the serial clock when the SPI flag (SPIF) becomes set. At the same time that SPIF becomes set, the data shifted into the master SPI from the receiving device transfers to the SIMDR. The SIMDR buffers data being received by the SPI. Before the master SPI sends the next byte, software must clear the SPIF bit by reading the SPCR and then read or write the SIMDR.

In a slave SPI, data enters the shift register under the control of the serial clock from the master SPI. After a byte enters the shift register of a slave SPI, it transfers to the SIMDR. To prevent an overrun condition, slave software must then read the byte in the SIMDR before another byte enters the shift register and is ready to transfer to the SIMDR.

Read SPCR ,and then read or write SIMDR will clear SPIF and WCOL .

Read SPCR , and then write SPCR will clear MODF

Ver. 1.0

2022/06/30

Figure 40~42 show examples how to work when master connect with slave .



Figure 43 Single Master/Slave



Figure 44 Single Master and Multi Slaves

## NY8BE64A



Figure 45 Multi Masters and Multi Slaves

### 3.24.1 Serial Clock Polarity and Phase

There are four kind of type to accommodate the different serial communication requirements of peripheral devices, depending upon the configurations of the CPOL (SPCR[3])bit and CKEG(SPCR[2]) bit.



Figure 46 Shows how the CPOL and CKEG bits affect the clock/data timing.

There are four kind of different SPI master clock rate , configuration by SPCR[1:0] (SPR[1:0]) , SPR[1:0]=00/01/10/11 will choose system clock/2 , system clock /4 , system clock /16 , system clock/32. User must set up SPCR[3:0] firstly , and then enable SPI module by set SIMCR[7]=1 , otherwise hardware errors will happen .

The following picture is SPI flow chart



#### 3.24.2 SPI error Conditions

These conditions produce SPI system errors:

- (1) MODF (Mode fault error) is happened if PB7/SSBEN is at logic 0 when in master mode .
- (2) Writing to the SPDR during a transmission causes a write-collision error and sets the WCOL bit in the SPCR The error does not affect the transmission of the previously written byte, but the byte that caused the error is lost.
- (3) Failing to read the SPDR before the next incoming byte sets the SPIF bit

### 3.25 IIC MODE

NY8BE64A will enter IIC mode by writing SIMCR=1. the IIC mode standard is a two wire bus. This two-wire bus minimizes the interconnection between devices and eliminates the need for address decoders, having the advantage of less PCB routing and economic hardware structure. IIC mode is suitable for applications requiring communications in a short distance among a number of devices.

IIC mode has the following feature

- Multi-master operation
- 32 software programmable serial clock frequencies
- Software selectable acknowledge bit
- Interrupt driven byte-by-byte data transfer
- Arbitration lost driven interrupt
- Calling address identification interrupt
- · Generate/detect the start, stop and acknowledge signals
- Repeated START signal generation
- Bus busy detection

The following figure is IIC mode function block.



The following figure is a example for IIC operation. One master device and one slave device. SDA and SCK need pull high resistor.



#### 3.25.1 IIC MODE protocol

A standard communication is composed of four parts, they are (1) START (2)slave address transfer (3) data transfer (4) STOP .



#### 3.25.2 IIC MODE operating

NY8BE64A will enter IIC mode by writing SIMCR=1.The device will enter master mode if SIMCR[5](MSTA)=1, and The device will enter slave mode if SIMCR[5](MSTA)=0.

Upon reset, SIMCR[5] is cleared. When this bit is changed from 0 to 1, a START signal is generated on the bus, and the master mode is selected. When this bit is changed from 1 to 0, a STOP signal is generated and the operation mode changes from master to slave.

MCR[4]=1, IIC MODE is set for transmit, otherwise MCR[4]=0, IIC MODE is set for receive mode.

Each time , we want to TX/RX data , firstly we go to clear MSR[1](MIF) . And then Clear MSTA to 0 if MAL=1.

In Master/TX mode, after transmit 8 bit of data, will read MSR[0] to check receiving 9th clock sending acknowledge or not . if receiving acknowledge bit, then continues to write SIMDR , otherwise generating STOP signal to terminal communication .

In master/RX mode, set TXAK=0 and receive data, it will send acknowledge signal at 9th clock bit. If last 2 byte of data have been read from SIMDR, and then set TXAK=1. If last bye have been read from SIMDR, then generate STOP signal.

In Slave mode, check MSR[6] (MASS) if it is first byte . If MSR[6](MASS)=1 ,then continue to check if SRW is high or low . IF SRW is high , then set MCR[4](MTX)=1 to enter TX mode and write data to SIMDR ,else SRW is low, then set MCR[4](MTX)=0 to RX mode and dummy read SIMDR .

In Slave/TX mode, after sending 8 bit of data, then read MSR[0](RXAK) to check if receiving 9th clock sending acknowledge or not. If receiving acknowledge bit, then continuing to write SIMDR, otherwise set RX mode and dummy read SIMDR.

The following diagram show the suggested flow.

## Nyquest 🚺



### 3.25.3 Arbitration Lost

This interface circuit is a true multi-master system which allows more than one master to be connected. If two or more masters try to control the bus at the same time, a clock synchronization procedure determines the bus clock. The clock low period is equal to the longest clock low period among the masters; and the clock high period is the shortest among the masters. A data arbitration procedure determines the priority. A master will lose arbitration if it transmits a logic "1" while the others transmit logic "0", the losing master will immediately switch over to slave receive mode and stops its data and clock outputs. The transition from master to slave mode will not generate a STOP condition. Meanwhile, a software bit will be set by hardware to indicate loss of arbitration.

### 3.26 UART

The programmable asynchronous communications interface (UART) megafunction provides data formatting and control to a serial communication channel.

The megafunction has select, read/write, interrupt and bus interface logic features that allow data transfers over an 8-bit bi-directional parallel data bus system. With proper formatting and error checking, the megafunction can transmit and receive serial data, supporting asynchronous operation.

- Full double buffering
- Asynchronous operation
- > Independently controlled Transmit, Line Status and Receive Interrupts
- > Programmable data word length (5 8 bit), parity and stop bits
- > Parity, overrun and framing error checking
- Programmable Baud Rate Generator allows division of any reference clock by 1 to (2<sup>16</sup>-1) and generates an internal 16 X Clock
- False start bit detection
- > Automatic break generation and detection
- Internal diagnostic capabilities

The transmitter section is composed of a Transmit Holding Register (THR) and a Transmit Shift Register (TSR). Writing to THR will transfer the contents of the data bus (DIN 7-0) to the Transmit Holding Register every time that the THR or TSR is empty. This write operation should be done when Transmit Holding Register Empty (THRE) is set

This register contains the assembled received data. On the falling edge of the start bit, the receiver section starts its operations. The start bit is valid if the RXDATA is still low at the middle sample of Start bit, thus preventing the receiver from assembling a false data character

The Line Control Register is used to specify the data communication format. The break feature, parity, stop bits and word length can be changed by writing to the appropriate bits in LSR.

### 3.27 On-Chip Debug (OCD)

### 3.27.1 Function Description

NY8BE64A is embedded in an on-chip debugger(OCD) providing developers with a low cost method for debugging user code. The OCD gives debug capability of complete program flow control with 3 hardware address breakpoints, 1 conditional register break, single step, free running, and non-intrusive commands for memory access. The OCD system does not occupy any locations in the memory map and does not share any on-chip peripherals.

The OCD system uses a two-wire serial interface, SCL and SDA, to establish communication between the target device and the controlling debugger host. SDA is an input/output pin for debug data transfer and SCL is an input pin for synchronization with SDA. The NY8BE64A also use SCL and SDA as control pins to write and read MTP.

#### 3.27.2 Limitation of OCD

NY8BE64A is a fully-featured microcontroller that multiplexes several functions on its limited I/O pins. Some device functionality must be sacrificed to provide resources for OCD system. The OCD has the following limitations:

1. The SCL/SDA pins are physically located on the same pin PC1/PC0 or PA3/PA2. Therefore, neither its I/O function nor shared multi-functions can be emulated.

2. System clock cannot be turned off because OCD uses this clock to monitor its internal status: When the system is in halt mode, it is invalid to perform ram/registers accesses because parts of the device may not be clocked. A read access could return garbage or a write access might not succeed. But the following accesses are not effected by the system halt : Read current program address , current PCL, current break condition and current halt status.

### 4. Instruction Set

NY8BE64A provides 55 powerful instructions for all kinds of applications.

| Inst.    | 0     | Ρ      | Operation                    | Cyc.   | Flag  | Inst.                   | C    | Ρ       | Operation                   | Cyc.     | Flag     |
|----------|-------|--------|------------------------------|--------|-------|-------------------------|------|---------|-----------------------------|----------|----------|
| inst.    | 1     | 2      |                              | oyc.   | i lug |                         | 1    | 2       |                             | eye.     | - Tug    |
| Arithmet | ic Ir | าstrเ  | ictions                      | T      | 1     | Arithmetic Instructions |      | uctions | Γ                           | <b>-</b> |          |
| ANDAR    | R     | d      | dest = ACC & R               | 1      | Z     | ADDAR                   | R    | d       | dest = R + ACC              | 1        | Z, DC, C |
| IORAR    | R     | d      | dest = ACC   R               | 1      | Z     | SUBAR                   | R    | d       | dest = R + (~ACC)           | 1        | Z, DC, C |
| XORAR    | R     | d      | dest = ACC $\oplus$ R        | 1      | Z     | ADCAR                   | R    | d       | dest = R + ACC + C          | 1        | Z, DC, C |
| ANDIA    | i     |        | ACC = ACC & i                | 1      | Z     | SBCAR                   | R    | d       | dest = R + (~ACC) + C       | 1        | Z, DC, C |
| IORIA    | i     |        | ACC = ACC   i                | 1      | Z     | ADDIA                   | i    |         | ACC = i + ACC               | 1        | Z, DC, C |
| XORIA    | i     |        | ACC = ACC $\oplus$ i         | 1      | Z     | SUBIA                   | i    |         | ACC = i + (~ACC)            | 1        | Z, DC, C |
| RRR      | R     | d      | Rotate right R               | 1      | С     | ADCIA                   | i    |         | ACC = i + ACC + C           | 1        | Z, DC, C |
| RLR      | R     | d      | Rotate left R                | 1      | С     | SBCIA                   | i    |         | ACC = i + (~ACC) + C        | 1        | Z, DC, C |
| BSR      | R     | bit    | Set bit in R                 | 1      | -     | DAA                     |      |         | Decimal adjust for ACC      | 1        | С        |
| BCR      | R     | bit    | Clear bit in R               | 1      | -     | CMPAR                   | R    |         | Compare R with ACC          | 1        | Z, C     |
| INCR     | R     | d      | Increase R                   | 1      | Z     | CLRA                    |      |         | Clear ACC                   | 1        | Z        |
| DECR     | R     | d      | Decrease R                   | 1      | Z     | CLRR                    |      |         | Clear R                     | 1        | Z        |
| COMR     | R     | d      | dest = ~R                    | 1      | Z     | Other Ins               | truc | ctio    | ns                          |          |          |
| Conditio | nal   | Insti  | ructions                     |        |       | NOP                     |      |         | No operation 1              |          | -        |
| BTRSC    | R     | bit    | Test bit in R, skip if clear | 1 or 2 | -     | SLEEP                   |      |         | Go into Halt mode           | 1        | /TO, /PD |
| BTRSS    | R     | bit    | Test bit in R, skip if set   | 1 or 2 | -     | CLRWDT                  |      |         | Clear Watch-Dog Timer       | 1        | /TO, /PD |
| INCRSZ   | R     | d      | Increase R, skip if 0        | 1 or 2 | -     | ENI                     |      |         | Enable interrupt            | 1        | -        |
| DECRSZ   | R     | d      | Decrease R, skip if 0        | 1 or 2 | -     | DISI                    |      |         | Disable interrupt           | 1        | -        |
| Data Tra | nsfe  | er Ins | structions                   |        |       | INT                     |      |         | Software Interrupt          | 3        | -        |
| MOVAR    | R     |        | Move ACC to R                | 1      | -     | RET                     |      |         | Return from subroutine      | 2        | -        |
| MOVR     | R     | d      | Move R                       | 1      | Z     | DETIE                   |      |         | Return from interrupt and   | 2        |          |
| MOVIA    | i     |        | Move immediate to ACC        | 1      | -     | RETIE                   |      |         | enable interrupt            | 2        | -        |
| SWAPR    | R     | d      | Swap halves R                | 1      | -     | DETIA                   |      |         | Return, place immediate in  |          |          |
| IOST     | F     |        | Load ACC to F-page SFR       | 1      | -     | RETIA                   |      | i       | ACC                         | 2        | -        |
| IOSTR    | F     |        | Move F-page SFR to ACC       | 1      | -     | CALLA                   |      |         | Call subroutine by ACC      | 2        | -        |
| SFUN     | S     |        | Load ACC to S-page SFR       | 1      | -     | GOTOA                   |      |         | unconditional branch by ACC | 2        | -        |
| SFUNR    | S     |        | Move S-page SFR to ACC       | 1      | -     | LCALL                   | а    | dr      | Call subroutine(2K)         | 2        | -        |
| TFUN     | Т     |        | Load ACC to T-page SFR       | 1      | -     | LGOTO                   | а    | dr      | unconditional branch(2K)    | 2        | -        |
| TFUNR    | Т     |        | Move T-page SFR to ACC       | 1      | -     | FCALL                   | а    | dr      | Call subroutine (4K)        | 2        | -        |
| TOMD     |       |        | Load ACC to T0MD             | 1      | -     | FGOTO                   | а    | dr      | unconditional branch(4K)    | 2        | -        |
| TOMDR    |       |        | Move T0MD to ACC             | 1      | -     |                         |      |         |                             |          |          |
| TABLEA   |       |        | Read ROM                     | 2      | -     |                         |      |         |                             |          |          |

#### Table 37 Instruction Set

ACC: Accumulator.

adr: immediate address.

bit: bit address within an 8-bit register R.

- C: Carry/Borrow bit
  - C=1, carry is occurred for addition instruction or borrow is **NOT** occurred for subtraction instruction.

C=0, carry is not occurred for addition instruction or borrow IS occurred for subtraction instruction.

d: Destination

If d is "0", the result is stored in the ACC.

If d is "1", the result is stored back in register R.

DC: Digital carry flag.

dest: Destination.

F: F-page SFR, F is 0x5 ~ 0xF.

i: 8-bit immediate data.

- PC: Program Counter.
- PCHBUF: High Byte Buffer of Program Counter.
  - /PD: Power down flag bit

/PD=1, after power-up or after instruction CLRWDT is executed.

/PD=0, after instruction SLEEP is executed.

Prescaler: Prescaler0 dividing rate.

- R: R-page SFR, R is 0x0 ~0x7F.
- S: S-page SFR, S is 0x0 ~ 0x15.
- T0MD: T0MD register.
- TBHP: The high-Byte at target address in ROM.

TBHD: Store the high-Byte data at target address in ROM.

/TO: Time overflow flag bit

/TO=1, after power-up or after instruction CLRWDT or SLEEP is executed.

/TO=0, WDT timeout is occurred.

WDT: Watchdog Timer Counter.

Z: Zero flag

| ADCAR            | Add ACC and R with Carry                                                                                                              | ADDAR            | Add ACC and R                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | ADCAR R, d                                                                                                                            | Syntax:          | ADDAR R, d                                                                                                                          |
| Operand:         | 0 R 127<br>d = 0, 1.                                                                                                                  | Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                      |
| Operation:       | R + ACC + C dest                                                                                                                      | Operation:       | ACC + R $\rightarrow$ dest                                                                                                          |
| Status affected: | Z, DC, C                                                                                                                              | Status affected: | Z, DC, C                                                                                                                            |
| Description:     | Add the contents of ACC and register R with Carry. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R. | Description:     | Add the contents of ACC and R.<br>If d is 0, the result is stored in<br>ACC. If d is 1, the result is stored<br>back to R.          |
| Cycle            | 1                                                                                                                                     | Cycle:           | 1                                                                                                                                   |
| Example:         | ADCAR R, d<br>before executing instruction:<br>ACC=0x12, R=0x34, C=1, d=1,<br>after executing instruction:<br>R=0x47, ACC=0x12, C=0.  | Example:         | ADDAR R, d<br>before executing instruction:<br>ACC=0x12, R=0x34,C=1, d=1,<br>after executing instruction:<br>R=0x46, ACC=0x12, C=0. |

| ADCIA            | Add ACC and Immediate with Carry                                                                                     | ADDIA            | Add ACC and Immediate                                                                                                |
|------------------|----------------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------|
| Syntax:          | ADCIA i                                                                                                              | Syntax:          | ADDIA i                                                                                                              |
| Operand:         | 0 i < 255                                                                                                            | Operand:         | 0 i < 255                                                                                                            |
| Operation:       | ACC + i + C ACC                                                                                                      | Operation:       | ACC + i ACC                                                                                                          |
| Status affected: | Z, DC, C                                                                                                             | Status affected: | Z, DC, C                                                                                                             |
| Description:     | Add the contents of ACC and the 8-bit immediate data i with Carry. The result is placed in ACC.                      | Description:     | Add the contents of ACC with the 8-bit immediate data i. The result is placed in ACC.                                |
| Cycle:           | 1                                                                                                                    | Cycle:           | 1                                                                                                                    |
| Example:         | ADCIA i<br>before executing instruction:<br>ACC=0x12, i=0x34, C=1,<br>after executing instruction:<br>ACC=0x47, C=0. | Example:         | ADDIA i<br>before executing instruction:<br>ACC=0x12, i=0x34, C=1,<br>after executing instruction:<br>ACC=0x46, C=0. |

| ANDAR            | AND ACC and R                                                                                                                   | BCR              | Clear Bit in R                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------|
| Syntax:          | ANDAR R, d                                                                                                                      | Syntax:          | BCR R, bit                                                                                           |
| Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                  | Operand:         | $0 \stackrel{\leq}{=} R \stackrel{\leq}{=} 127$<br>0 $\stackrel{\leq}{=}$ bit $\stackrel{\leq}{=} 7$ |
| Operation:       | ACC & R $\rightarrow$ dest                                                                                                      | Operation:       | $0 \rightarrow R[bit]$                                                                               |
| Status affected: | Z                                                                                                                               | Status affected: |                                                                                                      |
| Description:     | The content of ACC is AND'ed with R. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R.         | Description:     | Clear the bit <sup>th</sup> position in R.                                                           |
|                  |                                                                                                                                 | Cycle:           | 1                                                                                                    |
|                  |                                                                                                                                 | Example:         | BCR R, B2                                                                                            |
| Cycle:           | 1                                                                                                                               |                  | before executing instruction:<br>R=0x5A, B2=0x3,                                                     |
| Example:         | ANDAR R, d<br>before executing instruction:<br>ACC=0x5A, R=0xAF, d=1.<br>after executing instruction:<br>R=0x0A, ACC=0x5A, Z=0. |                  | after executing instruction:<br>R=0x52.                                                              |

| ANDIA            | AND Immediate with ACC                                                                                          |
|------------------|-----------------------------------------------------------------------------------------------------------------|
| Syntax:          | ANDIA i                                                                                                         |
| Operand:         | 0 <sup>&lt;</sup> /2 i < 255                                                                                    |
| Operation:       | ACC & i → ACC                                                                                                   |
| Status affected: | Z                                                                                                               |
| Description:     | The content of ACC register is                                                                                  |
|                  | AND'ed with the 8-bit immediate                                                                                 |
|                  | data i. The result is placed in ACC.                                                                            |
| Cycle:           | 1                                                                                                               |
| Example:         | ANDIA i<br>before executing instruction:<br>ACC=0x5A, i=0xAF,<br>after executing instruction:<br>ACC=0x0A, Z=0. |

| BSR              | Set Bit in R                                                                                             |
|------------------|----------------------------------------------------------------------------------------------------------|
| Syntax:          | BSR R, bit                                                                                               |
| Operand:         | $0 \le R \le 127$<br>$0 \le bit \le 7$                                                                   |
| Operation:       | $1 \rightarrow R[bit]$                                                                                   |
| Status affected: |                                                                                                          |
| Description:     | Set the bit <sup>th</sup> position in R.                                                                 |
| Cycle:           | 1                                                                                                        |
| Example:         | BSR R, B2<br>before executing instruction:<br>R=0x5A, B2=0x2,<br>after executing instruction:<br>R=0x5E. |

| BTRSC              | Test Bit in R and Skip if Clear                                                                                                                                                                                                                                               | CALLA            | Call Subroutine                                                                                                                                                          |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:            | BTRSC R, bit                                                                                                                                                                                                                                                                  | Syntax:          | CALLA                                                                                                                                                                    |
| Operand:           | 0 <sup>≤</sup> R <sup>≤</sup> 127                                                                                                                                                                                                                                             | Operand:         |                                                                                                                                                                          |
|                    | $0 \leq \text{bit} \leq 7$                                                                                                                                                                                                                                                    | Operation:       | PC + 1 $\rightarrow$ Top of Stack                                                                                                                                        |
| Operation:         | Skip next instruction, if R[bit] = 0.                                                                                                                                                                                                                                         |                  | $\{TBHP, ACC\} \rightarrow PC$                                                                                                                                           |
| Status affected:   |                                                                                                                                                                                                                                                                               | Status affected: |                                                                                                                                                                          |
| Description:       | If R[bit] = 0, the next instruction<br>which is already fetched is<br>discarded and a NOP is executed<br>instead. Therefore it makes this<br>instruction a two-cycle instruction.                                                                                             | Description:     | The return address (PC + 1) is<br>pushed onto top of Stack. The<br>contents of TBHP[2:0] is loaded<br>into PC[10:8] and ACC is loaded<br>into PC[7:0].                   |
| Cueles             | 1 or 2(akin)                                                                                                                                                                                                                                                                  | Cycle:           | 2                                                                                                                                                                        |
| Cycle:<br>Example: | 1 or 2(skip)<br>BTRSC R, B2<br>Instruction1<br>Instruction2<br>before executing instruction:<br>R=0x5A, B2=0x2,<br>after executing instruction:<br>because R[B2]=0, instruction1<br>will not be executed, the program<br>will start execute instruction from<br>instruction2. | Example:         | CALLA<br>before executing instruction:<br>TBHP=0x02, ACC=0x34. PC=A0.<br>Stack pointer=1.<br>after executing instruction:<br>PC=0x234, Stack[1]=A0+1, Stack<br>pointer=2 |

| BTRSS            | Test Bit in R and Skip if Set                                                                                                                                                                                                                                 | CLRA                   | Clear ACC                                               |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------------------------------------------|
| Syntax:          | BTRSS R, bit                                                                                                                                                                                                                                                  | Syntax:                | CLRA                                                    |
| Operand:         | $0 \le R \le 127$<br>$0 \le bit \le 7$                                                                                                                                                                                                                        | Operand:<br>Operation: | <br>00h→ACC                                             |
| Operation:       | Skip next instruction, if R[bit] = 1.                                                                                                                                                                                                                         | Status affected:       | 1→Z<br>Z                                                |
| Status affected: |                                                                                                                                                                                                                                                               | Description:           | ACC is clear and Z is set to 1.                         |
| Description:     | If R[bit] = 1, the next instruction<br>which is already fetched is                                                                                                                                                                                            | Cycle:                 | 1                                                       |
|                  | discarded and a NOP is executed<br>instead. Therefore it makes this<br>instruction a two-cycle instruction.                                                                                                                                                   | Example:               | CLRA<br>before executing instruction:<br>ACC=0x55, Z=0. |
| Cycle:           | 1 or 2(skip)                                                                                                                                                                                                                                                  |                        | after executing instruction:<br>ACC=0x00, Z=1.          |
| Example:         | BTRSS R, B2<br>Instruction2<br>Instruction3<br>before executing instruction:<br>R=0x5A, B2=0x3,<br>after executing instruction:<br>because R[B2]=1, instruction2<br>will not be executed, the program<br>will start execute instruction from<br>instruction3. |                        | , 100 0, 10 1.                                          |

# (W) Nyquest

| CLRR                   | Clear R                                                                          | COMR             | Complement R                                                                                                            |
|------------------------|----------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------|
| Syntax:                | CLRR R                                                                           | Syntax:          | COMR R, d                                                                                                               |
| Operand:<br>Operation: | 0 $\stackrel{\leq}{\rightarrow}$ R $\stackrel{\leq}{\rightarrow}$ 127<br>00h → R | Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                          |
|                        | 1→Z                                                                              | Operation:       | ~R → dest                                                                                                               |
| Status affected:       | Z                                                                                | Status affected: | Z                                                                                                                       |
| Description:           | The content of R is clear and Z is set to 1.                                     | Description:     | The content of R is complemented.<br>If d is 0, the result is stored in ACC.<br>If d is 1, the result is stored back to |
| Cycle:                 | 1                                                                                |                  | R.                                                                                                                      |
| Example:               | CLRR R<br>before executing instruction:                                          | Cycle:           | 1                                                                                                                       |
|                        | R=0x55, Z=0.<br>after executing instruction:<br>R=0x00, Z=1.                     | Example:         | COMR, d<br>before executing instruction:<br>R=0xA6, d=1, Z=0.<br>after executing instruction:<br>R=0x59, Z=0.           |

| CLRWDT           | Clear Watch-Dog Timer                                                                                 | CMPAR                          | Compare ACC and R                                                                                                        |
|------------------|-------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | CLRWDT                                                                                                | Syntax:                        | CMPAR R                                                                                                                  |
| Operand:         |                                                                                                       | Operand:                       | 0 <sup>≤</sup> R <sup>≤</sup> 127                                                                                        |
| Operation:       | $00h \rightarrow WDT$ ,                                                                               | Operation:<br>Status affected: | R - ACC → (No restore)<br>Z, C                                                                                           |
| Status affected: | 00h → WDT prescaler<br>$1 \rightarrow /TO$<br>$1 \rightarrow /PD$<br>/TO, /PD                         | Description:                   | Compare ACC and R by<br>subtracting ACC from R with 2's<br>complement representation. The<br>content of ACC and R is not |
| Description:     | Executing CLRWDT will reset<br>WDT, Prescaler0 if it is assigned to<br>WDT. Moreover, status bits /TO | Cycle:                         | changed.                                                                                                                 |
|                  | and /PD will be set to 1.                                                                             | Example:                       | CMPAR R                                                                                                                  |
| Cycle:           | 1                                                                                                     |                                | before executing instruction:<br>R=0x34, ACC=12, Z=0, C=0.                                                               |
| Example:         | CLRWDT<br>before executing instruction:<br>/TO=0<br>after executing instruction:<br>/TO=1             |                                | after executing instruction:<br>R=0x34, ACC=12, Z=0, C=1.                                                                |

| DAA              | Convert ACC Data Format from<br>Hexadecimal to Decimal                                                                                                                                                                                                                         | DECRSZ           | Decrease R, Skip if 0                                                                                                                                                                                                                                                                            |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | DAA                                                                                                                                                                                                                                                                            | Syntax:          | DECRSZ R, d                                                                                                                                                                                                                                                                                      |
| Operand:         |                                                                                                                                                                                                                                                                                | Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127                                                                                                                                                                                                                                                                |
| Operation:       | $ACC(hex) \rightarrow ACC(dec)$                                                                                                                                                                                                                                                |                  | d = 0, 1.                                                                                                                                                                                                                                                                                        |
| Status affected: | С                                                                                                                                                                                                                                                                              | Operation:       | R - 1 →dest,                                                                                                                                                                                                                                                                                     |
| Description:     | Convert ACC data format from                                                                                                                                                                                                                                                   |                  | Skip if result = 0                                                                                                                                                                                                                                                                               |
|                  | hexadecimal to decimal after addition operation and restore                                                                                                                                                                                                                    | Status affected: |                                                                                                                                                                                                                                                                                                  |
|                  | result to ACC. DAA instruction<br>must be placed immediately after<br>addition operation if decimal format<br>is required. Please note that<br>interrupt should be disabled before<br>addition instruction and enabled<br>after DAA instruction to avoid<br>unexpected result. | Description:     | Decrease R first. If d is 0, the<br>result is stored in ACC. If d is 1,<br>the result is stored back to R.<br>If result is 0, the next instruction<br>which is already fetched is<br>discarded and a NOP is executed<br>instead. Therefore it makes this<br>instruction a two-cycle instruction. |
| Cycle:           | 1                                                                                                                                                                                                                                                                              | Cycle:           | 1 or 2(skip)                                                                                                                                                                                                                                                                                     |
| Example:         | DISI<br>ADDAR R,d<br>DAA<br>ENI<br>before executing instruction:<br>ACC=0x28, R=0x25, d=0.<br>after executing instruction:<br>ACC=0x53, C=0.                                                                                                                                   | Example:         | DECRSZ R, d<br>instruction2<br>instruction3<br>before executing instruction:<br>R=0x1, d=1, Z=0.<br>after executing instruction:<br>R=0x0, Z=1, and instruction will<br>skip instruction2 execution<br>because the operation result is<br>zero.                                                  |

| DECR               | Decrease R                                                                                                           | DISI             | Disable Interrupt Globally                                                                |
|--------------------|----------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------|
| Syntax:            | DECR R, d                                                                                                            | Syntax:          | DISI                                                                                      |
| Operand:           | 0 <sup>≤</sup> R <sup>≤</sup> 127                                                                                    | Operand:         |                                                                                           |
|                    | d = 0, 1.                                                                                                            | Operation:       | Disable Interrupt, $0 \rightarrow GIE$                                                    |
| Operation:         | R - 1 → dest                                                                                                         | Status affected: |                                                                                           |
| Status affected:   | Z                                                                                                                    | Description:     | GIE is clear to 0 in order to disable                                                     |
| Description:       | Decrease R. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R.                       | Cycle:           | all interrupt requests.<br>1                                                              |
| Cycle:<br>Example: | 1<br>DECR R, d<br>before executing instruction:<br>R=0x01, d=1, Z=0.<br>after executing instruction:<br>R=0x00, Z=1. | Example:         | DISI<br>before executing instruction:<br>GIE=1,<br>After executing instruction:<br>GIE=0. |

| ENI                    | Enable Interrupt Globally                                       | FGOTO            | Unconditional Branch                                                                                           |
|------------------------|-----------------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------|
| Syntax:                | ENI                                                             | Syntax:          | FGOTO adr                                                                                                      |
| Operand:               |                                                                 | Operand:         | $0 \leq adr \leq 4095$                                                                                         |
| Operation:             | Enable Interrupt, 1 $\rightarrow$ GIE                           | Operation:       | adr $\rightarrow$ PC[11:0].                                                                                    |
| Status affected:       |                                                                 | Status affected: |                                                                                                                |
| Description:<br>Cycle: | GIE is set to 1 in order to enable all interrupt requests.<br>1 | Description:     | LGOTO is an unconditional branch<br>instruction. The 12-bit immediate<br>address adr is loaded into            |
| Example:               | ENI<br>before executing instruction:                            | Cycle:           | PC[11:0].<br>2                                                                                                 |
| GIE=0,                 | After executing instruction:                                    | Example:         | FGOTO Level<br>before executing instruction:<br>PC=A0.<br>after executing instruction:<br>PC=address of Level. |

| FCALL            | Call Subroutine                                                                                                                                               | GOTOA            | Unconditional Branch                                                                                        |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------|
| Syntax:          | FCALL adr                                                                                                                                                     | Syntax:          | GOTOA                                                                                                       |
| Operand:         | 0 $\leq$ adr $\leq$ 4095                                                                                                                                      | Operand:         |                                                                                                             |
| Operation:       | PC + 1 $\rightarrow$ Top of Stack,                                                                                                                            | Operation:       | $TBHP, ACC \rightarrow PC$                                                                                  |
|                  | $adr \rightarrow PC[11:0]$                                                                                                                                    | Status affected: |                                                                                                             |
| Status affected: |                                                                                                                                                               | Description:     | GOTOA is an unconditional branch                                                                            |
| Description:     | The return address (PC + 1) is<br>pushed onto top of Stack. The<br>12-bit immediate address adr is                                                            |                  | instruction. The content of TBHP[2:0] is loaded into PC[10:8] and ACC is loaded into PC[7:0].               |
|                  | loaded into PC[11:0].                                                                                                                                         | Cycle:           | 2                                                                                                           |
| Cycle:           | 2                                                                                                                                                             | Example:         | GOTOA                                                                                                       |
| Example:         | FCALL SUB<br>before executing instruction:<br>PC=A0. Stack level=1<br>after executing instruction:<br>PC=address of SUB, Stack[1]=<br>A0+1, Stack pointer =2. |                  | before executing instruction:<br>PC=A0. TBHP=0x02,<br>ACC=0x34.<br>after executing instruction:<br>PC=0x234 |

## NY8BE64A

| INCR             | Increase R                                                                                         | INT              | Software Interrupt                                                                                        |
|------------------|----------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------|
| Syntax:          | INCR R, d                                                                                          | Syntax:          | INT                                                                                                       |
| Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127                                                                  | Operand:         |                                                                                                           |
|                  | d = 0, 1.                                                                                          | Operation:       | PC + 1 $\rightarrow$ Top of Stack,                                                                        |
| Operation:       | R + 1 → dest.                                                                                      |                  | 001h→PC                                                                                                   |
| Status affected: | Z                                                                                                  | Status affected: |                                                                                                           |
| Description:     | Increase R. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R.     | Description:     | Software interrupt. First, return<br>address (PC + 1) is pushed onto<br>the Stack. The address 0x001 is   |
| Cycle:           | 1                                                                                                  |                  | loaded into PC[10:0].                                                                                     |
| Example:         | INCR R, d                                                                                          | Cycle:           | 3                                                                                                         |
|                  | before executing instruction:<br>R=0xFF, d=1, Z=0.<br>after executing instruction:<br>R=0x00, Z=1. | Example:         | INT<br>before executing instruction:<br>PC=address of INT code<br>after executing instruction:<br>PC=0x01 |

\_

| INCRSZ           | Increase R, Skip if 0                                                                                                                                                                                                                                                                            |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | INCRSZ R, d                                                                                                                                                                                                                                                                                      |
| Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                                                                                                                                                                                   |
| Operation:       | R + 1 → dest,<br>Skip if result = 0                                                                                                                                                                                                                                                              |
| Status affected: |                                                                                                                                                                                                                                                                                                  |
| Description:     | Increase R first. If d is 0, the result<br>is stored in ACC. If d is 1, the result<br>is stored back to R.<br>If result is 0, the next instruction<br>which is already fetched is<br>discarded and a NOP is executed<br>instead. Therefore it makes this<br>instruction a two-cycle instruction. |
| Cycle:           | 1 or 2(skip)                                                                                                                                                                                                                                                                                     |
| Example:         | <ul> <li>INCRSZ R, d<br/>instruction2,<br/>instruction3.</li> <li>before executing instruction:<br/>R=0xFF, d=1, Z=0.</li> <li>after executing instruction:<br/>R=0x00, Z=1. And the program<br/>will skip instruction2 execution<br/>because the operation result is<br/>zero.</li> </ul>       |

| IORAR            | OR ACC with R                                                                                                                        |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | IORAR R, d                                                                                                                           |
| Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                       |
| Operation:       | ACC   R → dest                                                                                                                       |
| Status affected: | Z                                                                                                                                    |
| Description:     | OR ACC with R. If d is 0, the result<br>is stored in ACC. If d is 1, the<br>result is stored back to R.                              |
| Cycle:           | 1                                                                                                                                    |
| Example:         | IORAR R, d<br>before executing instruction:<br>R=0x50, ACC=0xAA, d=1, Z=0.<br>after executing instruction:<br>R=0xFA, ACC=0xAA, Z=0. |

| IORIA            | OR Immediate with ACC                                                                                                | IOSTR            | Move F-page SFR to ACC                                                                                  |
|------------------|----------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------|
| Syntax:          | IORIA i                                                                                                              | Syntax:          | IOSTR F                                                                                                 |
| Operand:         | 0 <sup>≤</sup> i < 255                                                                                               | Operand:         | 5 <sup>≤</sup> F <sup>≤</sup> 15                                                                        |
| Operation:       | ACC∣i→ACC                                                                                                            | Operation:       | F-page SFR $\rightarrow$ ACC                                                                            |
| Status affected: | Z                                                                                                                    | Status affected: |                                                                                                         |
| Description:     | OR ACC with 8-bit immediate data                                                                                     | Description:     | Move F-page SFR F to ACC.                                                                               |
|                  | i. The result is stored in ACC.                                                                                      | Cycle:           | 1                                                                                                       |
| Cycle:           | 1                                                                                                                    | Example:         | IOSTR F                                                                                                 |
| Example:         | IORIA i<br>before executing instruction:<br>i=0x50, ACC=0xAA, Z=0.<br>after executing instruction:<br>ACC=0xFA, Z=0. |                  | before executing instruction:<br>F=0x55, ACC=0xAA.<br>after executing instruction:<br>F=0x55, ACC=0x55. |

| 1067                                                                   | Load E name SED from ACC                  | LCALL                                                                                                                                                         | Call Subroutine                                              |
|------------------------------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| IOST                                                                   | Load F-page SFR from ACC                  | Syntax:                                                                                                                                                       | LCALL adr                                                    |
| Syntax:                                                                | IOST F                                    | Operand:                                                                                                                                                      | $0 \le adr \le 2047$                                         |
| Operand:                                                               | 5 <sup>≤</sup> F <sup>≤</sup> 15          | Operation:                                                                                                                                                    |                                                              |
| Operation:                                                             | ACC → F-page SFR                          | operation.                                                                                                                                                    | PC + 1 → Top of Stack,<br>adr → PC[10:0]                     |
| Status affected:                                                       |                                           | Status affected:                                                                                                                                              |                                                              |
| Description:                                                           | F-page SFR F is loaded by content of ACC. | Description:                                                                                                                                                  | The return address (PC + 1) is pushed onto top of Stack. The |
| Cycle:                                                                 | 1                                         |                                                                                                                                                               | 11-bit immediate address adr is loaded into PC[10:0].        |
| Example:                                                               | IOST F                                    | Cueles                                                                                                                                                        | 2                                                            |
|                                                                        | before executing instruction:             | Cycle:                                                                                                                                                        | 2                                                            |
| F=0x55, ACC=0xAA.<br>after executing instruction:<br>F=0xAA, ACC=0xAA. | Example:                                  | LCALL SUB<br>before executing instruction:<br>PC=A0. Stack level=1<br>after executing instruction:<br>PC=address of SUB, Stack[1]=<br>A0+1, Stack pointer =2. |                                                              |

| LGOTO   | Uncondit | tional Branch |
|---------|----------|---------------|
| Syntax: | LGOTO    | adr           |

## NY8BE64A

| LGOTO            | Unconditional Branch                                                                                           | MOVIA            | Move Immediate to ACC                                                                                      |
|------------------|----------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------|
| Operand:         | $0 \leq adr \leq 2047$                                                                                         | Syntax:          | MOVIA i                                                                                                    |
| Operation:       | $adr \rightarrow PC[10:0].$                                                                                    | Operand:         | 0 <sup>&lt;</sup> /2 i < 255                                                                               |
| Status affected: |                                                                                                                | Operation:       | i→ACC                                                                                                      |
| Description:     | LGOTO is an unconditional branch                                                                               | Status affected: |                                                                                                            |
| Description.     | instruction. The 11-bit immediate<br>address adr is loaded into<br>PC[10:0].                                   | Description:     | The content of ACC is loaded with 8-bit immediate data i.                                                  |
| Cycle:           | 2                                                                                                              | Cycle:           | 1                                                                                                          |
| Example:         | LGOTO Level<br>before executing instruction:<br>PC=A0.<br>after executing instruction:<br>PC=address of Level. | Example:         | MOVIA i<br>before executing instruction:<br>i=0x55, ACC=0xAA.<br>after executing instruction:<br>ACC=0x55. |

| MOVAR                          | Move ACC to R                                                                                                      |                  |                                                                                                                                                                                               |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                        | MOVAR R                                                                                                            | MOVR             | Move R to ACC or R                                                                                                                                                                            |
| Operand:                       | 0 <sup>≤</sup> R <sup>≤</sup> 127                                                                                  | Syntax:          | MOVR R, d                                                                                                                                                                                     |
| Operation:<br>Status affected: | ACC→R<br>                                                                                                          | Operand:         | $0 \le R \le 127$<br>d = 0, 1.                                                                                                                                                                |
| Description:                   | Move content of ACC to R.                                                                                          | Operation:       | u – 0, 1.<br>R→dest                                                                                                                                                                           |
| Cycle:                         | 1                                                                                                                  | Status affected: | Z                                                                                                                                                                                             |
| Example:                       | MOVAR R<br>before executing instruction:<br>R=0x55, ACC=0xAA.<br>after executing instruction:<br>R=0xAA, ACC=0xAA. | Description:     | The content of R is move to destination. If d is 0, destination is ACC. If d is 1, destination is R and it can be used to check whether R is zero according to status flag Z after execution. |
|                                |                                                                                                                    | Cycle:           | 1                                                                                                                                                                                             |
|                                |                                                                                                                    | Example:         | MOVR R, d<br>before executing instruction:<br>R=0x0, ACC=0xAA, Z=0, d=0.<br>after executing instruction:                                                                                      |

Ver. 1.0

# (W) Nyquest

## NY8BE64A

| NOP                | No Operation                                       | RETIA            | Return with Data in ACC                                                                                  |
|--------------------|----------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------|
| Syntax:            | NOP                                                | Syntax:          | RETIA i                                                                                                  |
| Operand:           |                                                    | Operand:         | 0 <sup>&lt;</sup> /2 i < 255                                                                             |
| Operation:         | No operation.                                      | Operation:       | $i \rightarrow ACC$ ,                                                                                    |
| Status affected:   |                                                    |                  | Top of Stack $\rightarrow$ PC                                                                            |
| Description:       | No operation.                                      | Status affected: |                                                                                                          |
| Cycle:<br>Example: | 1<br>NOP<br>before executing instruction:<br>PC=A0 | Description:     | ACC is loaded with 8-bit<br>immediate data i and PC is loaded<br>from top of Stack as return<br>address. |
|                    | after executing instruction:<br>PC=A0+1            | Cycle:           | 2                                                                                                        |
|                    |                                                    | Example:         | RETIA i<br>before executing instruction:<br>Stack pointer =2. i=0x55,<br>ACC=0xAA.                       |

| RETIE            | Return from Interrupt and<br>Enable Interrupt Globally                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | RETIE                                                                                                                                      |
| Operand:         |                                                                                                                                            |
| Operation:       | Top of Stack → PC<br>1 → GIE                                                                                                               |
| Status affected: |                                                                                                                                            |
| Description:     | The PC is loaded from top of Stack<br>as return address and GIE is set to<br>1.                                                            |
| Cycle:           | 2                                                                                                                                          |
| Example:         | RETIE<br>before executing instruction:<br>GIE=0, Stack level=2.<br>after executing instruction:<br>GIE=1, PC=Stack[2], Stack<br>pointer=1. |

| RET              | Return from Subroutine                                                                                                |
|------------------|-----------------------------------------------------------------------------------------------------------------------|
|                  |                                                                                                                       |
| Syntax:          | RET                                                                                                                   |
| Operand:         |                                                                                                                       |
| Operation:       | Top of Stack $ ightarrow$ PC                                                                                          |
| Status affected: |                                                                                                                       |
| Description:     | PC is loaded from top of Stack as return address.                                                                     |
| Cycle:           | 2                                                                                                                     |
| Example:         | RET<br>before executing instruction:<br>Stack level=2.<br>after executing instruction:<br>PC=Stack[2], Stack level=1. |

after executing instruction:

PC=Stack[2], Stack pointer =1. ACC=0x55.

| RLR              | Rotate Left R Through Carry                                                                                                                                     |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | RLR R, d                                                                                                                                                        |
| Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                                                  |
| Operation:       | C → dest[0], R[7] → C,<br>R[6:0] → dest[7:1]                                                                                                                    |
| C b7             | R           b6         b5         b4         b3         b2         b1         b0                                                                                |
| Status affected: | С                                                                                                                                                               |
| Description:     | The content of R is rotated one bit<br>to the left through flag Carry. If d is<br>0, the result is placed in ACC. If d<br>is 1, the result is stored back to R. |
| Cycle:           | 1                                                                                                                                                               |
| Example:         | RLR R, d<br>before executing instruction:<br>R=0xA5, d=1, C=0.<br>after executing instruction:<br>R=0x4A, C=1.                                                  |

| RRR              | Rotate Right R Through Carry                                                                                                                                     |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | RRR R, d                                                                                                                                                         |
| Operand:         | $0 \le R \le 127$<br>d = 0, 1.                                                                                                                                   |
| Operation:       | $C \rightarrow dest[7], R[7:1] \rightarrow dest[6:0], R[0] \rightarrow C$                                                                                        |
| C<br>b7          | R           b6         b5         b4         b3         b2         b1         b0                                                                                 |
| Status affected: | С                                                                                                                                                                |
| Description:     | The content of R is rotated one bit to<br>the right through flag Carry. If d is 0,<br>the result is placed in ACC. If d is 1,<br>the result is stored back to R. |
| Cycle:           | 1                                                                                                                                                                |
| Example:         | RRR R, d<br>before executing instruction:<br>R=0xA5, d=1, C=0.<br>after executing instruction:<br>R=0x52, C=1.                                                   |

| SBCAR            | Subtract ACC and Carry from R                                                                                                                                    |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | SBCAR R, d                                                                                                                                                       |
| Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                                                   |
| Operation:       | $R + (\sim ACC) + C \rightarrow dest$                                                                                                                            |
| Status affected: | Z, DC, C                                                                                                                                                         |
| Description:     | Subtract ACC and Carry from R<br>with 2's complement<br>representation. If d is 0, the result<br>is placed in ACC. If d is 1, the<br>result is stored back to R. |
| Cycle:           | 1                                                                                                                                                                |
| Example:         | SBCAR R, d                                                                                                                                                       |
|                  | <ul> <li>(a) before executing instruction:<br/>R=0x05, ACC=0x06, d=1,<br/>C=0,<br/>after executing instruction:<br/>R=0xFE, C=0. (-2)</li> </ul>                 |
|                  | <ul> <li>(b) before executing instruction:<br/>R=0x05, ACC=0x06, d=1,<br/>C=1,<br/>after executing instruction:<br/>R=0xFF, C=0. (-1)</li> </ul>                 |
|                  | <ul> <li>(c) before executing instruction:<br/>R=0x06, ACC=0x05, d=1,<br/>C=0,</li> <li>after executing instruction:<br/>R=0x00, C=1. (-0), Z=1.</li> </ul>      |
|                  | (d) before executing instruction:<br>R=0x06, ACC=0x05, d=1,<br>C=1,<br>after executing instruction:<br>R=0x1, C=1. (+1)                                          |

## NY8BE64A

| SBCIA            | Subtract ACC and Carry from Immediate                                                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | SBCIA i                                                                                                                                                        |
| Operand:         | 0 <sup>&lt;</sup> /2 i < 255                                                                                                                                   |
| Operation:       | i + (~ACC) + C $\rightarrow$ dest                                                                                                                              |
| Status affected: | Z, DC, C                                                                                                                                                       |
| Description:     | Subtract ACC and Carry from 8-bit<br>immediate data i with 2's<br>complement representation. The<br>result is placed in ACC.                                   |
| Cycle:           | 1                                                                                                                                                              |
| Example:         | SBCIA i<br>(a) before executing instruction:<br>i=0x05, ACC=0x06, C=0,<br>after executing instruction:<br>ACC=0xFE, C=0. (-2)                                  |
|                  | (b) before executing instruction:<br>i=0x05, ACC=0x06, C=1,<br>after executing instruction:<br>ACC=0xFF, C=0. (-1)                                             |
|                  | <ul> <li>(c) before executing instruction:</li> <li>i=0x06, ACC=0x05, C=0,</li> <li>after executing instruction:</li> <li>ACC=0x00, C=1. (-0), Z=1.</li> </ul> |
|                  | (d) before executing instruction:<br>i=0x06, ACC=0x05, C=1,<br>after executing instruction:<br>ACC=0x1, C=1. (+1)                                              |

| SFUNR            | Move S-page SFR to ACC                                                                                             |
|------------------|--------------------------------------------------------------------------------------------------------------------|
| Syntax:          | SFUNR S                                                                                                            |
| Operand:         | 0 <sup>≤</sup> S <sup>≤</sup> 21                                                                                   |
| Operation:       | S-page SFR $\rightarrow$ ACC                                                                                       |
| Status affected: |                                                                                                                    |
| Description:     | Move S-page SFR S to ACC.                                                                                          |
| Cycle:           | 1                                                                                                                  |
| Example:         | SFUNR S<br>before executing instruction:<br>S=0x55, ACC=0xAA.<br>after executing instruction:<br>S=0x55, ACC=0x55. |

| SLEEP            | Enter Halt Mode                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------|
| Syntax:          | SLEEP                                                                                                    |
| Operand:         |                                                                                                          |
| Operation:       | 00h → WDT,<br>00h → WDT prescaler<br>1 → /TO<br>0 → /PD                                                  |
| Status affected: | /TO, /PD                                                                                                 |
| Description:     | WDT and Prescaler0 are clear to<br>0. /TO is set to 1 and /PD is clear<br>to 0.<br>IC enter Halt mode.   |
| Cycle:           | 1                                                                                                        |
| Example:         | SLEEP<br>before executing instruction:<br>/PD=1, /TO=0.<br>after executing instruction:<br>/PD=0, /TO=1. |

| SFUN             | Load S-page SFR from ACC                                                                                          |
|------------------|-------------------------------------------------------------------------------------------------------------------|
| Syntax:          | SFUN S                                                                                                            |
| Operand:         | 0 <sup>≤</sup> S <sup>≤</sup> 21                                                                                  |
| Operation:       | ACC $\rightarrow$ S-page SFR                                                                                      |
| Status affected: |                                                                                                                   |
| Description:     | S-page SFR S is loaded by content of ACC.                                                                         |
| Cycle:           | 1                                                                                                                 |
| Example:         | SFUN S<br>before executing instruction:<br>S=0x55, ACC=0xAA.<br>after executing instruction:<br>S=0xAA, ACC=0xAA. |

# (W) Nyquest

| Subtract ACC from R                                                                                                                                                                                                                            | SWAPR                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Swap High/Low Nibble in R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SUBAR R, d                                                                                                                                                                                                                                     | Syntax:                                                                                                                                                                                                                                                                                                                                                                                                                                               | SWAPR R, d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                                                                                                                                 | Operand:                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| R – ACC → dest<br>Z, DC, C                                                                                                                                                                                                                     | Operation:                                                                                                                                                                                                                                                                                                                                                                                                                                            | R[3:0] → dest[7:4].<br>R[7:4] → dest[3:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Subtract ACC from R with 2's                                                                                                                                                                                                                   | Status affected:                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| complement representation. If d is 0, the result is placed in ACC. If d is 1, the result is stored back to R.                                                                                                                                  | Description:                                                                                                                                                                                                                                                                                                                                                                                                                                          | The high nibble and low nibble of<br>R is exchanged. If d is 0, the result<br>is placed in ACC. If d is 1, the<br>result is stored back to R.                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                | Cycle:                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <ul> <li>(a) before executing instruction:<br/>R=0x05, ACC=0x06, d=1,<br/>after executing instruction:<br/>R=0xFF, C=0. (-1)</li> <li>(b) before executing instruction:<br/>R=0x06, ACC=0x05, d=1,<br/>after executing instruction:</li> </ul> | Example:                                                                                                                                                                                                                                                                                                                                                                                                                                              | SWAPR R, d<br>before executing instruction:<br>R=0xA5, d=1.<br>after executing instruction:<br>R=0x5A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                | SUBAR R, d<br>$0 \leq R \leq 127$<br>d = 0, 1.<br>$R - ACC \rightarrow dest$<br>Z, DC, C<br>Subtract ACC from R with 2's<br>complement representation. If d is<br>0, the result is placed in ACC. If d<br>is 1, the result is stored back to R.<br>1<br>SUBAR R, d<br>(a) before executing instruction:<br>R=0x05, ACC=0x06, d=1,<br>after executing instruction:<br>R=0xFF, C=0. (-1)<br>(b) before executing instruction:<br>R=0x06, ACC=0x05, d=1, | SUBARR, dSyntax: $0 \leq R \leq 127$<br>$d = 0, 1.$ Operand: $R - ACC \rightarrow dest$<br>Z, DC, COperation:SubtractACC from R with 2's<br>complement representation. If d is<br>0, the result is placed in ACC. If d<br>is 1, the result is stored back to R.Status affected:<br>Description:1SUBARR, d1SUBARCycle:<br>Example:1SUBARR, d(a) before executing instruction:<br>R=0x05, ACC=0x06, d=1,<br>after executing instruction:<br>R=0x06, ACC=0x05, d=1,<br>after executing instruction:<br>R=0x06, ACC=0x05, d=1,<br>after executing instruction:Cycle:<br>Example: |

|                  |                                                                                                                                           | TABLEA           | Read ROM data                                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| SUBIA            | Subtract ACC from Immediate                                                                                                               | Syntax:          | TABLEA                                                                                                                                                |
| Syntax:          | SUBIA i                                                                                                                                   | Operand:         |                                                                                                                                                       |
| Operand:         | 0 <sup>≤</sup> i < 255                                                                                                                    | Operation:       | ROM data{ TBHP, ACC } [7:0]                                                                                                                           |
| Operation:       | i-ACC→ACC                                                                                                                                 | oporation        | $\rightarrow$ ACC                                                                                                                                     |
| Status affected: | Z, DC, C                                                                                                                                  |                  | ROM data{TBHP, ACC} [13:8]                                                                                                                            |
| Description:     | Subtract ACC from 8-bit immediate                                                                                                         |                  | →TBHD.                                                                                                                                                |
|                  | data i with 2's complement representation. The result is placed                                                                           | Status affected: |                                                                                                                                                       |
|                  | in ACC.                                                                                                                                   | Description:     | The 8 least significant bits of ROM                                                                                                                   |
| Cycle:           | 1                                                                                                                                         |                  | pointed by {TBHP[2:0], ACC} is<br>placed to ACC.<br>The 6 most significant bits of ROM<br>pointed by {TBHP[2:0], ACC} is<br>placed to TBHD[5:0].      |
| Example:         | SUBIA i                                                                                                                                   |                  |                                                                                                                                                       |
| ·                | (a) before executing instruction:                                                                                                         |                  |                                                                                                                                                       |
|                  | i=0x05, ACC=0x06.                                                                                                                         | Cycle:           | 2                                                                                                                                                     |
|                  | after executing instruction:<br>ACC=0xFF, C=0. (-1)                                                                                       | Example:         | TABLEA                                                                                                                                                |
|                  | <ul> <li>(b) before executing instruction:<br/>i=0x06, ACC=0x05, d=1,<br/>after executing instruction:<br/>ACC=0x01, C=1. (+1)</li> </ul> |                  | before executing instruction:<br>TBHP=0x02, CC=0x34.<br>TBHD=0x01.<br>ROM data[0x234]= 0x35AA<br>after executing instruction:<br>TBHD=0x35, ACC=0xAA. |

| TFUN             | Load T-page SFR from ACC                                                                                |                  |                                                                                                             |
|------------------|---------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------|
| Syntax:          | TFUN T                                                                                                  | TOMD             | Load ACC to T0MD                                                                                            |
| Operand:         | о ≤ т ≤ <b>14</b>                                                                                       | Syntax:          | T0MD                                                                                                        |
| Operation:       | ACC $\rightarrow$ T-page SFR                                                                            | Operand:         |                                                                                                             |
| Status affected: |                                                                                                         | Operation:       | ACC→T0MD                                                                                                    |
| Description:     | T-page SFR T is loaded by content                                                                       | Status affected: |                                                                                                             |
| Cycle:           | of ACC.                                                                                                 | Description:     | The content of T0MD is loaded by ACC.                                                                       |
| Example:         | '<br>TFUN T                                                                                             | Cycle:           | 1                                                                                                           |
|                  | before executing instruction:<br>T=0x55, ACC=0xAA.<br>after executing instruction:<br>T=0xAA, ACC=0xAA. | Example:         | T0MD<br>before executing instruction:<br>T0MD=0x55, ACC=0xAA.<br>after executing instruction:<br>T0MD=0xAA. |

| TFUNR            | Move T-page SFR to ACC                                                                                             | T0MDR            | Move T0MD to ACC                                                                                          |
|------------------|--------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------|
| Syntax:          | TFUNR T                                                                                                            | Syntax:          | TOMDR                                                                                                     |
| Operand:         | 0 <sup>≤</sup> T <sup>≤</sup> 14                                                                                   | Operand:         |                                                                                                           |
| Operation:       | T-page SFR $\rightarrow$ ACC                                                                                       | Operation:       | TOMD→ACC                                                                                                  |
| Status affected: |                                                                                                                    | Status affected: |                                                                                                           |
| Description:     | Move T-page SFR T to ACC.                                                                                          | Description:     | Move the content of T0MD to ACC.                                                                          |
| Cycle:           | 1                                                                                                                  | Cycle:           | 1                                                                                                         |
| Example:         | TFUNR T<br>before executing instruction:<br>T=0x55, ACC=0xAA.<br>after executing instruction:<br>T=0x55, ACC=0x55. | Example:         | T0MDR<br>before executing instruction<br>T0MD=0x55, ACC=0xAA.<br>after executing instruction<br>ACC=0x55. |

| XORAR            | Exclusive-OR ACC with R                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------|
| Syntax:          | XORAR R, d                                                                                                        |
| Operand:         | 0 <sup>≤</sup> R <sup>≤</sup> 127<br>d = 0, 1.                                                                    |
| Operation:       | ACC $\oplus$ R $\rightarrow$ dest                                                                                 |
| Status affected: | Z                                                                                                                 |
| Description:     | Exclusive-OR ACC with R. If d is 0,<br>the result is placed in ACC. If d is<br>1, the result is stored back to R. |
| Cycle:           | 1                                                                                                                 |
| Example:         | XORAR R, d<br>before executing instruction:<br>R=0xA5, ACC=0xF0, d=1.<br>after executing instruction:<br>R=0x55.  |

| XORIA            | Exclusive-OR Immediate with ACC                                                                            |
|------------------|------------------------------------------------------------------------------------------------------------|
| Syntax:          | XORIA i                                                                                                    |
| Operand:         | 0 $\leq$ i < 255                                                                                           |
| Operation:       | ACC ⊕ i→ACC                                                                                                |
| Status affected: | Z                                                                                                          |
| Description:     | Exclusive-OR ACC with 8-bit<br>immediate data i. The result is<br>stored in ACC.                           |
| Cycle:           | 1                                                                                                          |
| Example:         | XORIA i<br>before executing instruction:<br>i=0xA5, ACC=0xF0.<br>after executing instruction:<br>ACC=0x55. |

## 5. Configuration Words

| Item | Name                        | Options                                                                                                                                      |
|------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | High Oscillator Frequency   | 1. I_HRC 2. E_HXT 3. E_XT                                                                                                                    |
| 2    | Low Oscillator Frequency    | 1. I_LRC 2. E_LXT                                                                                                                            |
| 3    | High IRC Frequency          | 1. 1MHz 2. 2MHz 3. 4MHz                                                                                                                      |
| _    | 5                           | 4.       8MHz       5.       16MHz       6.       20MHz         1.       6MHz $F_{HOSC} \leq 8MHz$ 2. $8MHz < F_{HOSC} \leq 10MHz$           |
| 4    | High Crystal Oscillator     | 1. $OWHZ < PHOSC \ge OWHZ$ 2. $OWHZ < PHOSC \ge TOWHZ$ 3. $10MHz < F_{HOSC} \le 12MHz$ 4. $12MHz < F_{HOSC} \le 16MHz$                       |
| 4    | Thigh Grystal Oscillator    | 5. $16MHz < F_{HOSC} \leq 20MHz$                                                                                                             |
| 5    | Instruction Clock           | 1. 2 oscillator period 2. 4 oscillator period                                                                                                |
| 6    | WDT                         | 1. Watchdog Enable (Software control)                                                                                                        |
| 0    |                             | 2. Watchdog Disable (Always disable)                                                                                                         |
| 7    | WDT Event                   | 1. Watchdog Reset     2. Watchdog Interrupt                                                                                                  |
| 8    | Timer0 Source               | 1. EX_CKI0     2. Low Oscillator (I_LRC/E_LXT)                                                                                               |
| 9    | PA.5                        | 1. PA.5 is I/O         2. PA.5 is reset                                                                                                      |
| 10   | PA.7                        | 1. PA.7 is I/O2. PA.7 is instruction clock output                                                                                            |
| 11   | IR Output Pin               | 1. PB1 2. PA3                                                                                                                                |
| 12   | Startup Time                | 1. 140us 2. 4.5ms 3. 18ms 4. 72ms 5. 288ms                                                                                                   |
| 13   | WDT Time Base               | 1. 3.5ms 2. 15ms 3. 60ms 4. 250ms                                                                                                            |
| 14   | Noise Filter (High_EFT)     | 1. Enable     2. Disable                                                                                                                     |
| 15   | LVR Setting                 | <ol> <li>Register Control</li> <li>Register Control + Halt mode Off</li> <li>Always On</li> <li>Operation mode On + Halt mode Off</li> </ol> |
|      |                             | 1. 1.6V 2. 1.8V 3. 2.0V 4. 2.2V 5. 2.4V                                                                                                      |
| 16   | LVR Voltage                 | 6. 2.7V 7. 3.0V 8. 3.3V 9. 3.6V 10. 4.2V                                                                                                     |
| 17   | VDD Voltage                 | 1. 3.0V 2. 4.5V 3. 5.0V                                                                                                                      |
| 18   | PWM1 Output Pin             | 1. PB1 2. PB4                                                                                                                                |
| 19   | PWM2 Output Pin             | 1. PB3 2. PB5                                                                                                                                |
| 20   | PWM3 Output Pin             | 1. PA2 2. PA7                                                                                                                                |
| 21   | Sink current type           | 1. Normal 2. Large 3. Constant                                                                                                               |
| 22   | Comparator Input pin select | 1. Enable 2. Disable                                                                                                                         |
| 23   | Read Output Data            | 1. I/O Port 2. Register                                                                                                                      |
| 24   | E_LXT Backup Control        | 1. Auto Off 2. Register Off                                                                                                                  |
| 25   | EX_CKI0 to Inst. Clock      | 1. Sync 2. Async                                                                                                                             |
| 26   | Startup Clock               | 1. Fast (I_HRC/E_HXT/E_XT) 2. Slow (I_LRC/E_LXT)                                                                                             |
| 27   | Input High Voltage (VIH)    | 1. 0.7VDD 2. 0.5VDD                                                                                                                          |
| 28   | Input Low Voltage (V⊾)      | 1. 0.3VDD 2. 0.2VDD                                                                                                                          |
| 29   | VREFH Pin                   | 1. PA0 2. PB1                                                                                                                                |

| Item | Name           | Options       | ;   |
|------|----------------|---------------|-----|
| 30   | INT0 Input Pin | 1. PB5 2.     | PA4 |
| 31   | INT1 Input Pin | 1. PB1 2.     | PA3 |
| 32   | INT2 Input Pin | 1. Disable 2. | PA5 |

### 6. Electrical Characteristics

### 6.1 Absolute Maximum Rating

| Symbol              | Parameter             | Parameter Rated Value          |    |  |  |
|---------------------|-----------------------|--------------------------------|----|--|--|
| $V_{DD}$ - $V_{SS}$ | Supply voltage        | -0.5 ~ +6.0                    | V  |  |  |
| Vin                 | Input voltage         | $V_{SS}$ -0.3V ~ $V_{DD}$ +0.3 | V  |  |  |
| Тор                 | Operating Temperature | -40 ~ +85                      | °C |  |  |
| Tst                 | Storage Temperature   | -40 ~ +125                     | °C |  |  |

#### 6.2 DC Characteristics

(All refer  $F_{INST}=F_{HOSC}/4$ ,  $F_{HOSC}=16MHz@I_HRC$ , WDT enabled, ambient temperature  $T_A=25^{\circ}C$  unless otherwise specified.)

| Symbol          | Parameter           | V <sub>DD</sub>       | Min. | Тур. | Max.     | Unit | Condition                               |
|-----------------|---------------------|-----------------------|------|------|----------|------|-----------------------------------------|
|                 |                     |                       | 3.3  |      |          |      | FINST=16MHz @ I_HRC/2                   |
|                 |                     |                       | 2.4  |      |          |      | FINST=20MHz @ I_HRC/4                   |
| V <sub>DD</sub> | Operating voltage   |                       | 2.2  | 5.   | 5.5      | V    | FINST= 8MHz @I_HRC/2                    |
|                 |                     |                       | 2.0  |      |          |      | FINST= 4MHz @ I_HRC/2                   |
|                 |                     |                       | 2.0  |      |          |      | FINST= 32KHz @ I_LRC/2                  |
|                 |                     | 5V                    | 4.0  |      |          | V    |                                         |
|                 |                     | 3V                    | 2.4  |      |          | v    | RSTb (0.8 V <sub>DD</sub> )             |
| Mar             | Innut high voltage  | 5V                    | 3.5  |      |          | V    | All other I/O pins, EX_CKI0/1, INT0/1/2 |
| Vін             | Input high voltage  | 3V                    | 2.1  |      |          | v    | CMOS option (0.7 V <sub>DD</sub> )      |
|                 |                     | 5V                    | 2.5  |      |          | V    | All other I/O pins, EX_CKI0/1           |
|                 |                     | 3V                    | 1.5  |      |          | v    | TTL option (0.5 VDD)                    |
|                 |                     | 5V                    |      |      | 1.0      | V    |                                         |
|                 |                     | 3V                    |      |      | 0.6      | v    | RSTb (0.2 V <sub>DD</sub> )             |
| V               | Innut low voltorio  | 5V                    |      |      | 1.5      | v    | All other I/O pins, EX CKI0/1, INT0/1/2 |
| VIL             | Input low voltage   | 3V                    |      |      | 0.9      |      | CMOS option (0.3 $V_{DD}$ )             |
|                 |                     | 5V                    |      |      | 1.0      | v    | All other I/O pins, EX_CKI0/1           |
|                 |                     | 3V                    |      |      | 0.6      | v    | TTL option (0.2 V <sub>DD</sub> )       |
| I <sub>ОН</sub> | Output high current | 5V                    |      | 1.7  |          | mA   | V <sub>OH</sub> =4.0V                   |
| IOH             | (Small Current)     | 3V                    |      | 0.9  |          | ША   | V <sub>OH</sub> =2.0V                   |
| I <sub>ОН</sub> | Output high current | 5V                    |      | 16.7 |          |      | V <sub>OH</sub> =4.0V                   |
| IOH             | (Normal Current)    | 3V                    |      | 9.7  |          |      | V <sub>OH</sub> =2.0V                   |
| la              | Output low current  | 5V                    |      | 7.2  |          | mA   | V <sub>OL</sub> =1.0V                   |
| Iol             | (Small current)     | 3V                    |      | 4.0  |          | ШA   | VOL-1.0V                                |
| Iol             | Output low current  | 5V                    |      | 24.7 |          | mA   | V <sub>0L</sub> =1.0V                   |
| IOL             | (Normal current)    | 3V                    |      | 14.6 |          | ША   | VOL-1.0V                                |
| Le:             | Output low current  | 5V                    |      | 50   |          | mA   | V <sub>0L</sub> =1.0V                   |
| Iol             | (Large current)     | arge current) 3V 34.5 |      | ША   | VOL-1.0V |      |                                         |
|                 |                     |                       |      |      |          | m ^  |                                         |
|                 |                     |                       |      |      |          | mA   |                                         |
|                 |                     | Normal Mode           |      |      | nal Mode |      |                                         |
| I <sub>OP</sub> | Operating current   | 5V                    |      |      |          | mA   |                                         |

|  | Nyquest |
|--|---------|
|--|---------|

| Symbol            | Parameter          | V <sub>DD</sub> | Min. | Тур. | Max. | Unit | Condition                                    |
|-------------------|--------------------|-----------------|------|------|------|------|----------------------------------------------|
|                   |                    | 3V              |      |      |      |      |                                              |
|                   |                    | 5V              |      | 2.32 |      | mA   |                                              |
|                   |                    | 3V              |      | 1.31 |      | ШA   | FHOSC=20MHz @ I_HRC/4 & E_HXT/4              |
|                   |                    | 5V              |      | 2.95 |      | mA   |                                              |
|                   |                    | 3V              |      | 1.65 |      |      | F <sub>HOSC</sub> =16MHz @ I_HRC/2 & E_HXT/2 |
|                   |                    | 5V              |      | 1.95 |      | mA   |                                              |
|                   |                    | 3V              |      | 1.11 |      | ША   | FHOSC=16MHz @ I_HRC/4 & E_HXT/4              |
|                   |                    | 5V              |      | 1.73 |      | mA   |                                              |
|                   |                    | 3V              |      | 0.99 |      | ma   | FHOSC=8MHz @ I_HRC/2 & E_HXT/2               |
|                   |                    | 5V              |      | 1.22 |      | m /  |                                              |
|                   |                    | 3V              |      | 0.71 |      | mA   | F <sub>HOSC</sub> =8MHz @ I_HRC/4 & E_HXT/4  |
|                   |                    | 5V              |      | 1.11 |      |      |                                              |
|                   |                    | 3V              |      | 0.66 |      | mA   | FHOSC=4MHz @ I_HRC/2 & E_XT/2                |
|                   |                    | 5V              |      | 0.83 |      |      |                                              |
|                   |                    | 3V              |      | 0.52 |      | mA   | FHOSC=4MHz @ I_HRC/4 & E_XT/4                |
|                   |                    | 5V              |      | 0.61 |      | mA   |                                              |
|                   |                    | 3V              |      | 0.41 |      |      | F <sub>HOSC</sub> =1MHz @ I_HRC/2 & E_XT/2   |
|                   |                    | 5V              |      | 0.53 |      | m /  |                                              |
|                   |                    | 3V              |      | 0.37 |      | mA   | F <sub>HOSC</sub> =1MHz @ I_HRC/4 & E_XT/4   |
|                   |                    | Slow Mode       |      |      |      |      | ow Mode                                      |
|                   |                    | 5V              |      | 8.0  |      | uA   | F <sub>Hosc</sub> disabled,                  |
|                   |                    | 3V              |      | 6.0  |      |      | FLOSC=32KHz @ I_LRC/2 & E_LXT/2              |
|                   |                    | 5V              |      | 5.3  |      |      | Fноsc disabled,                              |
|                   |                    | 3V              |      | 4.3  |      | uA   | FLOSC=32KHz @ I_LRC/4 & E_LXT/4              |
|                   | Chan dhu aurrant   | 5V              |      | 2.7  |      |      | Standby mode, FHOSC disabled,                |
| I <sub>STB</sub>  | Standby current    | 3V              |      | 1.5  |      | uA   | F <sub>LOSC</sub> =32KHz @ I_LRC/4           |
|                   | Halt current       | 5V              |      |      | 0.5  | uA   | Lielt mode WDT dischlod                      |
|                   |                    | 3V              |      |      | 0.2  |      | Halt mode, WDT disabled.                     |
| I <sub>HALT</sub> |                    | 5V              |      |      | 5.0  |      | Holt mode, WDT enchad                        |
|                   |                    | 3V              |      |      | 3.0  | uA   | Halt mode, WDT enabled.                      |
| Devi              | Pull-High resistor | 5V              |      | 50   |      | ΚΩ   | Dull Llink register (A/ith suit DAC)         |
|                   |                    | 3V              |      | 90   |      |      | Pull-High resistor (Without PA5)             |
| Rрн               |                    | 5V              |      | 80   |      | KΩ   | Dull Llink register (DAC)                    |
|                   |                    | 3V              |      | 80   |      |      | Pull-High resistor (PA5)                     |
| Rpl               | Pull-Low resistor  | 5V              |      | 50   |      | KΩ   | Pull-Low resistor                            |
|                   |                    | 3V              |      | 90   |      |      |                                              |

### 6.3 Comparator / LVD Characteristics

#### ( $V_{DD}$ =5V, $V_{SS}$ =0V, $T_A$ =25°C unless otherwise specified.)

| Symbol           | Parameter                         | Min. | Тур. | Max. | Unit | Condition                         |
|------------------|-----------------------------------|------|------|------|------|-----------------------------------|
| VIVR             | Comparator input voltage range    |      |      | 5    | V    | F <sub>HOSC</sub> =1MHz           |
| T <sub>ENO</sub> | Comparator enable to output valid |      | 20   |      | ms   | F <sub>HOSC</sub> =1MHz           |
| Ico              | Operating current of comparator   |      | 250  |      | uA   | F <sub>HOSC</sub> =1MHz, P2V mode |
| Ilvd             | Operating current of LVD          |      | 300  |      | uA   | F <sub>HOSC</sub> =1MHz, LVD=4.3V |
| Elvd             | LVD voltage error                 |      |      | 3    | %    | F <sub>HOSC</sub> =1MHz, LVD=4.3V |

### 6.4 ADC Characteristics

(V\_DD=5V, V\_SS=0V, T\_A=25°C unless otherwise specified.)

| Symbol            | Parameter                                     | Min.                  | Тур.            | Max.            | Unit    | Condition                                         |
|-------------------|-----------------------------------------------|-----------------------|-----------------|-----------------|---------|---------------------------------------------------|
| Vrefh             | VREFH input voltage                           | 2V                    |                 | V <sub>DD</sub> | V       | Ext. reference voltage                            |
| $V_{REF4}$        | Int. 4V reference voltage, $V_{DD}$ =5V       | 3.95                  | 4               | 4.05            | V       |                                                   |
| V <sub>REF3</sub> | Int. 3V reference voltage, VDD=5V             | 2.95                  | 3               | 3.05            | V       |                                                   |
| V <sub>REF2</sub> | Int. 2V reference voltage, VDD=5V             | 1.95                  | 2               | 2.05            | V       |                                                   |
| V <sub>REF</sub>  | Int. $V_{DD}$ reference voltage, $V_{DD}$ =5V |                       | $V_{\text{DD}}$ |                 | V       |                                                   |
|                   | Internal reference supply voltage             | V <sub>REF</sub> +0.5 |                 | -               | V       | Minimum supply voltage                            |
|                   | ADC analog input voltage                      | 0                     |                 | $V_{REFH}$      | V       |                                                   |
|                   | ADC enable time                               | 256                   |                 |                 | us      | Ready to start convert after set ADENB="1".       |
| IOP(ADC)          | ADC current consumption                       |                       | 0.3             |                 | mA      |                                                   |
| ADCLK             | ADC Clock Frequency                           |                       |                 | 1M              | Hz      |                                                   |
| ADCYCLE           | ADC Conversion Cycle Time                     | 16                    |                 |                 | 1/ADCLK | SHCLK=2 ADC clock                                 |
| ADCsample         | ADC Sampling Rate                             |                       |                 | 125             | K/sec   | V <sub>DD</sub> =5V                               |
| DNL               | Differential Nonlinearity                     | ±1                    |                 |                 | LSB     |                                                   |
| INL               | Integral Nonlinearity                         | ±2                    |                 |                 | LSB     | V <sub>DD</sub> =5.0V, AVREFH=5V,<br>FADSMP=62.5K |
| NMC               | No Missing Code                               | 10                    | 11              | 12              | Bits    |                                                   |

### 6.5 Characteristic Graph

6.5.1 Frequency vs. V<sub>DD</sub> of I\_HRC and I\_LRC



### 6.5.2 Frequency vs. Temperature of I\_HRC and I\_LRC



### 6.5.5 Low Dropout Regulator vs. V<sub>DD</sub>



### 6.5.6 Low Dropout Regulator vs. Temperature



### 6.5.7 Pull High Resistor vs. V<sub>DD</sub>



6.5.8 Pull High Resistor vs. Temperature



## $\textbf{6.5.9} \quad \textbf{V}_{\text{IH}}/\textbf{V}_{\text{IL}} \text{ vs. } \textbf{V}_{\text{DD}}$



### 6.5.10 $V_{IH}/V_{IL}$ vs. Temperature



## 6.6 Recommended Operating Voltage

Recommended Operating Voltage (Temperature range: -40°C ~ +85°C)

| Frequency            | Min. Voltage | Max. Voltage | LVR: default (25°C) | LVR: Recommended<br>(-40°C ~ +85°C) |
|----------------------|--------------|--------------|---------------------|-------------------------------------|
| 16M/2T               | 3.3V         | 5.5V         | 3.6V                | 3.6V                                |
| 20M/4T               | 2.4V         | 5.5V         | 2.7V                | 3.0V                                |
| 16M/4T               | 2.2V         | 5.5V         | 2.4V                | 2.7V                                |
| 8M/2T                | 2.2V         | 5.5V         | 2.4V                | 2.7V                                |
| $\leq$ 6M/(2T or 4T) | 2.0V         | 5.5V         | 2.2V                | 2.4V                                |

#### 6.7 LVR vs. Temperature



#### 6.8 LVD vs. Temperature



## 7. Package Dimension

7.1 16-Pin Plastic SOP (150 mil)



### 7.2 20-Pin Plastic SOP (300 mil)



## 8. Ordering Information

| P/N         | Package Type | Pin Count | Package Width | Shipping               |
|-------------|--------------|-----------|---------------|------------------------|
| NY8BE64AS16 | SOP          | 16        | 150 mil       | Tube: 50 pcs per Tube  |
| NY8BE64AS20 | SOP          | 20        | 300 mil       | Tube: 35 pcs per Tube. |