14 I/O + 5-channel PWM 8-bit EPROM-Based MCU Version 1.0 Sept. 5, 2025 ATW TECHNOLOGY CO. reserves the right to change this document without prior notice. Information provided by ATW is believed to be accurate and reliable. However, ATW makes no warranty for any errors which may appear in this document. Contact ATW to obtain the latest version of device specifications before placing your orders. No responsibility is assumed by ATW for any infringement of patent or other rights of third parties which may result from its use. In addition, ATW 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 ATW. # **Revision History** | Version | Date | Description | Modified Page | |---------|------------|-----------------|---------------| | 1.0 | 2025/09/05 | Formal release. | - | # **Table of Contents** | 1. | | | | | |----|-----|---------|-------------------------------------------------------------------------|----| | | 1.1 | 功能 | | 7 | | | 1.2 | AT8A5 | 54E1, AT8A54E 與 AT8A54D 的主要差異 | 9 | | 1. | Gei | neral D | Description | 10 | | | 1.1 | Featur | res | 10 | | | 1.2 | Major | Differences Table Between AT8A54E1, AT8A54E and AT8A54D | 12 | | | | | Diagram | | | | | | signment | | | | | | escription | | | | | | | | | 2. | Me | mory C | Organization | 16 | | | 2.1 | Progra | am Memory | 16 | | | 2.2 | Data N | Леmory | 17 | | 3. | Fur | nction | Description | 21 | | | 3.1 | R-pag | e Special Function Register | 21 | | | | 3.1.1 | INDF (Indirect Addressing Register) | 21 | | | | 3.1.2 | TMR0 (Timer0 Register) | 21 | | | | 3.1.3 | PCL (Low Byte of PC[10:0]) | 21 | | | | 3.1.4 | STATUS (Status Register) | | | | | 3.1.5 | FSR (Register File Selection Register) | | | | | 3.1.6 | PortA (PortA Data Register) | | | | | 3.1.7 | PortB (PortB Data Register) | | | | | 3.1.8 | PCON (Power Control Register) | | | | | 3.1.9 | BWUCON (PortB Wake-up Control Register) | | | | | | PCHBUF (High Byte of PC) | | | | | | ABPLCON (PortA/PortB Pull-Low Resistor Control Register) | | | | | | BPHCON (PortB Pull-High Resistor Control Register) | | | | | | INTE (Interrupt Elag Register) | | | | | | INTF (Interrupt Flag Register) AWUCON (PortA Wake-up Control Register) | | | | | | INTEDG (Interrupt Edge Register) | | | | | | TMRH (Timer High Byte Register) | | | | | 0.1.17 | Time Tright Dyte (Cegloter) | 21 | | | | RFC (RFC Register) | | |-----|--------|--------------------------------------------------------|----| | | 3.1.19 | TM34RH (Timer3 High Byte Register) | 28 | | | 3.1.20 | INTE2 (Interrupt Enable and Flag 2nd. Register) | 29 | | 3.2 | TOMD | Register | 29 | | 3.3 | F-page | e Special Function Register | 30 | | | 3.3.1 | IOSTA (PortA I/O Control Register) | | | | 3.3.2 | IOSTB (PortB I/O Control Register) | | | | 3.3.3 | APHCON (PortA Pull-High Resistor Control Register) | 31 | | | 3.3.4 | PS0CV (Prescaler0 Counter Value Register) | 31 | | | 3.3.5 | BODCON (PortB Open-Drain Control Register) | 31 | | | 3.3.6 | CMPCR (Comparator voltage select Control Register) | 31 | | | 3.3.7 | PCON1 (Power Control Register1) | 32 | | 3.4 | S-page | e Special Function Register | 33 | | | 3.4.1 | TMR1 (Timer1 Register) | | | | 3.4.2 | T1CR1 (Timer1 Control Register1) | | | | 3.4.3 | T1CR2 (Timer1 Control Register2) | | | | 3.4.4 | PWM1DUTY (PWM1 Duty Register) | 35 | | | 3.4.5 | PS1CV (Prescaler1 Counter Value Register) | | | | 3.4.6 | BZ1CR (Buzzer1 Control Register) | 36 | | | 3.4.7 | IRCR (IR Control Register) | 36 | | | 3.4.8 | TBHP (Table Access High Byte Address Pointer Register) | | | | 3.4.9 | TBHD (Table Access High Byte Data Register) | 37 | | | 3.4.10 | TMR2 (Timer2 Register) | 38 | | | 3.4.11 | P2CR1 (PWM2 Control Register1) | 38 | | | 3.4.12 | T2CR2 (Timer2 Control Register2) | 39 | | | 3.4.13 | PWM2DUTY (PWM2 Duty Register) | 40 | | | | PS2CV (Prescaler2 Counter Value Register) | | | | 3.4.15 | OSCCR (Oscillation Control Register) | 40 | | | 3.4.16 | TMR3 (Timer3 Register) | 41 | | | 3.4.17 | T3CR1 (Timer3 Control Register1) | 41 | | | 3.4.18 | T3CR2 (Timer3 Control Register2) | 42 | | | 3.4.19 | PWM3DUTY (PWM3 Duty Register) | 43 | | | 3.4.20 | PS3CV (Prescaler3 Counter Value Register) | 43 | | | 3.4.21 | P4CR1 (PWM4 Control Register1) | 43 | | | 3.4.22 | PWM4DUTY (PWM4 Duty Register) | 43 | | | 3.4.23 | CCPCON (CCP Control Register) | 44 | | | 3.4.24 PWMDB (Dead band control Register) | 45 | |-------|----------------------------------------------------|----| | | 3.4.25 P5CR1 (PWM5 Control Register1) | 45 | | | 3.4.26 PWM5DUTY (PWM5 Duty Register) | 45 | | | 3.4.27 PWM5RH (PWM5 High Byte Register) | 46 | | 3.5 | I/O Port | 46 | | | 3.5.1 Block Diagram of IO Pins | 48 | | 3.6 | Timer0 | 59 | | 3.7 | Timer1 / PWM1 / Buzzer1 | 60 | | 3.8 | Timer2 / PWM2 | 63 | | 3.9 | Timer3 / PWM3 | | | | ) PWM4 | | | | I PWM5 | | | | 2 CCP Mode | | | 3.12 | 3.12.1 Capture Mode | | | | 3.12.2 Compare Mode | | | | 3.12.3 CCP PWM Mode | | | 3 13 | 3 RFC Mode | | | | 4 IR Carrier | | | | 5 Comparator-Related Functions | | | J. 13 | 3.15.1 Function Overview | | | | 3.15.2 Voltage Comparator | | | | 3.15.3 Comparator Reference Voltage (Vref) | | | | 3.15.4 Low Voltage Detector (LVD) | | | | 3.15.5 LVD Interrupt | 78 | | 3.16 | 3 Watch-Dog Timer (WDT) | | | 3.17 | 7 Interrupt | 79 | | | 3.17.1 Timer0 Overflow Interrupt | | | | 3.17.2 Timer1 Underflow Interrupt | | | | 3.17.3 Timer2 underflow interrupt or CCP interrupt | 80 | | | 3.17.4 Timer3 Underflow Interrupt | | | | 3.17.5 WDT Timeout Interrupt | 80 | | | 3.17.6 PA/PB Input Change Interrupt | 80 | | | 3.17.7 External 0 Interrupt | | | | 3.17.8 External 1 Interrupt | 80 | | | 3.17.9 LVD Interrupt | | |----|----------------------------------------------|-----| | | 3.18 Oscillation Configuration | 81 | | | 3.19 Operating Mode | 83 | | | 3.19.1 Normal Mode | | | | 3.19.2 Slow Mode | 85 | | | 3.19.3 Standby Mode | | | | 3.19.4 Halt Mode | 86 | | | 3.19.5 Wake-up Stable Time | 87 | | | 3.19.6 Summary of Operating Mode | 87 | | | 3.20 Reset Process | 88 | | 4. | Instruction Set | 90 | | 5. | Configuration Words | 106 | | 6. | Electrical Characteristics | 108 | | | 6.1 Absolute Maximum Rating | 108 | | | 6.2 DC Characteristics | 108 | | | 6.3 OSC Characteristics | | | | 6.4 Comparator / LVD Characteristics | 110 | | | 6.5 Characteristic Graph | 110 | | | 6.5.1 Frequency vs. V <sub>DD</sub> of I_HRC | | | | 6.5.2 Frequency vs. Temperature of I_HRC | 111 | | | 6.5.3 Frequency vs. V <sub>DD</sub> of I_LRC | 111 | | | 6.5.4 Frequency vs. Temperature of I_LRC | 111 | | | 6.5.5 Pull High Resistor vs. VDD | | | | 6.5.6 Pull Low Resistor vs. VDD | | | | 6.6 Recommended LVR Voltage | 113 | | | 6.7 LVR vs. Temperature | 113 | | 7. | Die Pad Diagram | 114 | | 8. | Package Dimension | 115 | | | 8.1 8-Pin Plastic SOP (150 mil) | | | | 8.2 16-Pin Plastic SOP (150 mil) | | | 9. | Ordering Information | | | | ~·~~·~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | | #### 1. 概述 AT8A54E1 是以EPROM作為記憶體的 8 位元微控制器,專為多組PWM的應用設計。例如燈控,遙控車應用。採用 CMOS製程並同時提供客戶低成本、高性能、及高性價比等顯著優勢。AT8A54E1 核心建立在RISC精簡指令集架構 可以很容易地做編輯和控制,共有 55 條指令。除了少數指令需要 2 個時序,大多數指令都是 1 個時序即能完成,可 以讓使用者輕鬆地以程式控制完成不同的應用。因此非常適合各種中低記憶容量但又複雜的應用。 在I/O的資源方面,AT8A54E1 有 14 根彈性的雙向I/O腳,每個I/O腳都有單獨的暫存器控制為輸入或輸出腳。而且每一個I/O腳位都有附加的程式控制功能如上拉或下拉電阻或開漏極(Open-Drain)輸出。此外針對紅外線搖控的產品方面,AT8A54E1 內建了可選擇頻率的紅外載波發射口。 AT8A54E1 有三組計時器,可用系統頻率當作一般的計時的應用或者從外部訊號觸發來計數。另外AT8A54E1 提供 5 組 10 位元解析度的PWM輸出,1 組蜂鳴器輸出可用來驅動馬達、LED、或蜂鳴器等等。 AT8A54E1 採用雙時鐘機制,高速振盪或者低速振盪都可以分別選擇內部RC振盪或外部Crystal輸入。在雙時鐘機制下,AT8A54E1 可選擇多種工作模式如正常模式(Normal)、慢速模式(Slow mode)、待機模式(Standby mode) 與睡眠模式(Halt mode)可節省電力消耗延長電池壽命。並且微控制器在使用內部RC高速振盪時,低速振盪可以同時使用外部精準的Crystal計時。可以維持高速處理同時又能精準計算真實時間。 在省電的模式下如待機模式(Standby mode) 與睡眠模式(Halt mode)中,有多種事件可以觸發中斷喚醒AT8A54E1 進入正常操作模式(Normal) 或 慢速模式(Slow mode) 來處理突發事件。 AT8A54E1 的PWM1/PWM2/PWM3/PWM4/PWM5 其計數器來源可不經除級。 #### 1.1 功能 - 寬廣的工作電壓: - > 3.3V ~ 5.5V @ 20MHz/2T • - > 1.8V ~ 5.5V @ 4MHz/4T - 寬廣的工作温度:-40°C~85°C。 - 2Kx14 bits EPROM ∘ - 128 bytes SRAM ∘ - 14 根可分別單獨控制輸入輸出方向的I/O腳(GPIO)、PA[7:0]、PB[5:0]。 - PA[5:0] 及 PB[3:0] 可選擇輸入時使用內建下拉電阻。 - PA[7: 0] 及 PB[5:0] 可選擇輸入時使用上拉電阻,另外PA3 提供高阻抗上拉電阻選項供選擇。 - PB[5:0]及PA[5] 可選擇開漏極輸出(Open-Drain)。 - 8 層程式堆棧(Stack)。 - 存取資料有直接或間接定址模式。 - 一組 8 位元上數計時器(Timer0)包含可程式化的頻率預除線路。 - 三組 10 位元下數計時器(Timer1, 2, 3)可選重複載入或連續下數計時。Timer可設定頻率預除或頻率不經除級。 - 五個 10 位元脈衝寬度調變(PWM1, 2, 3, 4, 5), PWM3/4/5 共用Timer3。 - 一個蜂鳴器輸出(BZ1)。 - 38/57KHz紅外線載波頻率可供選擇,同時載波之極性也可以根據數據作選擇。 - 內建準確的低電壓偵測電路(LVD)。 - 內建準確的電壓比較器(Voltage Comparator)。 - 內建上電復位電路(POR)。 - 內建低壓復位功能(LVR)。 - 內建看門狗計時(WDT),可由程式韌體控制開關。 - 內建電阻頻率轉換器(RFC)功能。 - 雙時鐘機制,系統可以隨時切換高速振盪或者低速振盪。 - ▶ 高速振盪: E\_HXT (超過 6MHz外部高速石英振盪) E\_XT (455K~6MHz外部石英振盪) I\_HRC (1~20MHz內部高速RC振盪) - ➤ 低速振盪: E\_LXT (32KHz外部低速石英振盪) I\_LRC (內部 32KHz低速RC振盪) - 四種工作模式可隨系統需求調整電流消耗:正常模式(Normal)、慢速模式(Slow mode)、待機模式(Standby mode) 與 睡眠模式(Halt mode)。 8 - 八種硬體中斷: - ➤ Timer0 溢位中斷。 - ➤ Timer1 借位中斷。 - ➤ Timer2 借位中斷或CCP 中斷。 - ➤ Timer3 借位中斷。 - ➤ WDT 中斷。 - ▶ PA/PB 輸入狀態改變中斷。 - ▶ 兩組外部中斷輸入。 - ▶ 低電壓偵測中斷。 - AT8A54E1 在待機模式(Standby mode)下的八種喚醒中斷: - ➤ Timer0 溢位中斷。 - ➤ Timer1 借位中斷。 - ➤ Timer2 借位中斷或CCP 中斷。 - ➤ Timer3 借位中斷。 - ➤ WDT 中斷。 - ▶ PA/PB 輸入狀態改變中斷。 - ▶ 兩組外部中斷輸入。 - ▶ 低電壓偵測中斷。 - AT8A54E1 在睡眠模式(Halt mode)下的四種喚醒中斷: - > WDT 中斷。 - ▶ PA/PB 輸入狀態改變中斷。 - ▶ 兩組外部中斷輸入。 # 1.2 AT8A54E1, AT8A54E 與 AT8A54D 的主要差異 | Item | Function | AT8A54E1 | AT8A54E | AT8A54D | |--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------|-------------------|----------------------------| | 1 | PortA input pull-high resistor | PA[7:0] | PA[7:0] | PA[7:6], PA[4:0] | | 2 | PortA input pull-low resistor | PA[5:0] | PA[5:0] | PA[5], PA[3:0] | | 3 | Low Voltage Detector(LVD) voltage level | 16 voltage levels | 16 voltage levels | 8 voltage levels | | 4 | Comparator structure | shared with LVD | shared with LVD | rail-to-rail<br>comparator | | 5 | PortA, PortB wake-up default status | default: disable | default: disable | default: enable | | 6 | Input Voltage Schmitt Trigger | Enable/Disable | Enable/Disable | | | 7 | PA[3] Pull-High resistor | 1M ohm @ VDD=3V | | | | 8 | Timer1's clock source is from internal high frequency (16M, 20MHz) | V | ~~ | | | 9 Recommended Operating Voltage AT8A54E1 & AT8A54E LVR default and recommended are lower than AT8A54D. | | | | ommended voltage | 9 ## 1. General Description AT8A54E1 is an EPROM based 8-bit MCU tailored for I/O based applications like light control and remote car application. AT8A54E1 adopts advanced CMOS technology to provide customers remarkable solution with low cost, high performance. RISC architecture is applied to AT8A54E1 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, AT8A54E1 is very suitable for those applications that are sophisticated but compact program size is required. As AT8A54E1 address I/O type applications, it can provide 14 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, AT8A54E1 has built-in infrared (IR) carrier generator with selectable IR carrier frequency and polarity for applications which demand remote control feature. AT8A54E1 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, AT8A54E1 provides 5 sets of 10-bit resolution Pulse Width Modulation (PWM) output and 1 set of buzzer output in order to drive motor/LED and buzzer. AT8A54E1 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, AT8A54E1 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 AT8A54E1 operates in Standby mode and Halt mode, kinds of event will issue interrupt requests and can wake-up AT8A54E1 to enter Normal mode and Slow mode in order to process urgent events. AT8A54E1 PWM1/ PWM2/ PWM3/ PWM4/ PWM5 can use internal high frequency (16M, 20MHz) as the clock source. #### 1.1 Features - Wide operating voltage range: - > 3.3V ~ 5.5V @ 20MHz/2T • - > 1.8V ~ 5.5V @ 4MHz/4T - Wide operating temperature: -40°C ~ 85°C. - 2K x 14 bits EPROM. - 128 bytes SRAM. - 14 general purpose I/O pins (GPIO), PA[7:0], PB[5:0], with independent direction control. 10 - PA[5:0] and PB[3:0] have features of Pull-Low resistor for input pin, PA3 also provide alternative option for high-impedance pull-up resistor. - PA[7: 0] and PB[5:0] have features of Pull-High resistor. - PB[5:0] and PA[5] has features of Open-Drain output. - 8-level hardware Stack. - Direct and indirect addressing modes for data access. - One 8-bit up-count timer (Timer0) with programmable prescaler. - Five 10-bit reload or continuous down-count timers (Timer1, 2, 3). Timer1/2/3 can be configured with a frequency pre-scaler or operate without frequency pre-scaler. - Five 10-bit resolution PWM (PWM1, 2, 3, 4, 5) output. PWM3/4/5 use Timer3. - 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 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) 11 - 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. - Eight hardware interrupt events: - Timer0 overflow interrupt. - > Timer1 underflow interrupt. - > Timer2 underflow interrupt or CCP interrupt - > Timer3 underflow interrupt. - > WDT timeout interrupt. - > PA/PB input change interrupt. - > 2 set External interrupt. - > LVD interrupt. - Eight interrupt events to wake-up AT8A54E1 from Standby mode: - > Timer0 overflow interrupt. - > Timer1 underflow interrupt. - > Timer2 underflow interrupt or CCP interruptTimer3 underflow interrupt. - > WDT timeout interrupt. - > PA/PB input change interrupt. - > 2 set External interrupt. - > LVD interrupt. - Four interrupt events to wake-up AT8A54E1 from Halt mode: - > WDT timeout interrupt. - > PA/PB input change interrupt. - > 2 set External interrupt. ## 1.2 Major Differences Table Between AT8A54E1, AT8A54E and AT8A54D | Item | Function | AT8A54E1 | AT8A54E | AT8A54D | |------|--------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------|----------------------------| | 1 | PortA input pull-high resistor | PA[7:0] | PA[7:0] | PA[7:6], PA[4:0] | | 2 | PortA input pull-low resistor | PA[5:0] | PA[5:0] | PA[5], PA[3:0] | | 3 | Low Voltage Detector(LVD) voltage level | 16 voltage levels | 16 voltage levels | 8 voltage levels | | 4 | Comparator structure | shared with LVD | shared with LVD | rail-to-rail<br>comparator | | 5 | PortA, PortB wake-up default status | default: disable | default: disable | default: enable | | 6 | Input Voltage Schmitt Trigger | Enable/Disable | Enable/Disable | | | 7 | PA[3] Pull-High resistor | 1M ohm @ VDD=3V | | | | 8 | Timer1's clock source is from internal high frequency (16M, 20MHz) | V | | | | 9 | Recommended Operating Voltage | AT8A54E1 & AT8A54E LVR default and recommended voltage are lower than AT8A54D. | | | 12 ## 1.3 Block Diagram ## 1.4 Pin Assignment AT8A54E1 provides two kinds of package type which are SOP16 and SOP8 package. Figure 1 Package pin assignment 13 # 1.5 Pin Description | Pin Name | I/O | Description | |-----------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PA0/ PWM2<br>CMP+ | I/O | PA0 is bidirectional I/O pin, and can be comparator analog input pins. PA0 can be the output of PWM2. PA0 can be comparator non-inverse input. | | PA1/ PWM5/<br>EX_CKI1<br>CMP- | I/O | PA1 is bidirectional I/O pin, and can be comparator analog input pins. PA1 can be the output of PWM5. Moreover, it can be Timer3 clock source EX_CKI1. PA1 can be comparator inverse input. | | PA2/ PWM4/<br>INT1/ SDI<br>CMP+ | I/O | PA2 is a bidirectional I/O pin, and can be comparator analog input pin. PA2 can be the output of PWM4. PA2 can be the input pin of external interrupt INT1. PA2 can be programming pad SDI. PA2 can be comparator non-inverse input. | | PA3/ PWM3//HLH<br>SDO<br>P1D/CMP- | I/O | PA3 is a bidirectional I/O pin, and can be comparator analog input pin. PA3 can be the output of PWM3 PA3 can be High-level hold function pin PA3 can be programming pad SDO. PA3 can be P1D output in CCP mode PA3 can be comparator inverse input. | | PA4/ PWM1/<br>EX_CKI0/ SCK<br>P1A | I/O | PA4 is a bidirectional I/O pin. PA4 can be the output of PWM1 PA4 can be the Timer0,1 clock source EX_CKI0. PA4 can be programming pad SCK. PA4 can be P1A output in CCP mode | | PA5/ RSTb/ Vpp<br>P1B | I/O | PA5 is a bidirectional I/O pin or open-drain output pin. PA5 can be the reset pin RSTb. If this pin is more than 7.75V, it also can make AT8A54E1 enter EPROM programming mode. PA5 can be P1B output in CCP mode | | PA6/ Xin / PWM5 | I/O | PA6 is a bidirectional I/O pin. PA6 can be the input pin of crystal oscillator Xin. PA6 can be the output of PWM5. | | PA7/ Xout / PWM2<br>P1C | I/O | PA7 is a bidirectional I/O pin. PA7 can be the output pin of crystal oscillator Xout. PA7 also can be output of instruction clock. PA7 can be the output of PWM2. PA7 can be P1C output in CCP mode | | PB0/ PWM5/ INT0 | I/O | PB0 is a bidirectional I/O pin. PB0 can be the output of PWM5. PB0 can be the input pin of external interrupt INT0. | | PB1/ IR/ INT1 | I/O | PB1 is a bidirectional I/O pin. If IR mode is enabled, this pin is IR carrier output. PB1 can be the input pin of external interrupt INT1. | | PB2/ PWM2 | 1/0 | PB2 is a bidirectional I/O pin. PB2 can be the output of PWM2. | | PB3/ PWM1/ BZ1/<br>SDO<br>CMPO | I/O | PB3 is a bidirectional I/O pin. PB3 can be the output of Buzzer1 or PWM1 PB3 can be programming pad SDO. PB3 can be comparator output | 14 | Pin Name | I/O | Description | | |-----------|-----|--------------------------------------------------------------|--| | PB4/ PWM3 | I/O | PB4 is bidirectional I/O pin. PB4 can be the output of PWM3. | | | PB5/ PWM4 | I/O | PB5 is bidirectional I/O pin. PB5 can be the output of PWM4. | | | VDD | Р | Positive power supply. | | | VSS | Р | Ground. | | ## 2. Memory Organization AT8A54E1 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 AT8A54E1 is 2K words. Therefore, the Program Counter (PC) is 11-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. AT8A54E1 provides instruction CALL, GOTOA, CALLA to address 256 location of program space. AT8A54E1 provides instruction GOTO to address 512 location of program space. AT8A54E1 also provides instructions LCALL and LGOTO 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. AT8A54E1 program ROM address 0x7FE~0x7FF are reserved space, if user tries to write code in these addresses will get unexpected false functions. AT8A54E1 program ROM address 0x00E~0x00F are preset rolling code can be released and used as normal program space. Figure 2 Program Memory Address Mapping 16 #### 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 3 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. Figure 4 Direct Addressing Mode of Data Memory Access 17 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 0x20 to 0x3F of Bank 1. Other bank in address from 0x20 to 0x7F are mapped back as the Table 1 shows. The AT8A54E1 register name and address mapping of R-page SFR are described in the following table. | Status [7:6] Address | 00<br>(Bank 0) | 01<br>(Bank 1) | 10<br>(Bank 2) | 11<br>(Bank 3) | |----------------------|----------------|----------------|--------------------|----------------| | 0x0 | INDF | | | | | 0x1 | TMR0 | | | | | 0x2 | PCL | | | | | 0x3 | STATUS | | | | | 0x4 | FSR | | | | | 0x5 | PORTA | | | | | 0x6 | PORTB | | | | | 0x7 | - | | | | | 0x8 | PCON | | | | | 0x9 | BWUCON | | | | | 0xA | PCHBUF | | | | | 0xB | ABPLCON | | | | | 0xC | BPHCON | | | | | 0xD | - | The | same mapping as Ba | ank 0 | | 0xE | INTE | | | | | 0xF | INTF | | | | | 0x10 | - | | | | | 0x11 | - | | | | | 0x12 | - , ^ | | | | | 0x13 | | | | | | 0x14 | | | | | | 0x15 | AWUCON | | | | | 0x16 | - | | | | | 0x17 | - | | | | | 0x18 | INTEDG | | | | | 0x19 | TMRH | | | | | 0x1A | - | | | | | Status [7:6] Address | 00<br>(Bank 0) | 01<br>(Bank 1) | 10<br>(Bank 2) | 11<br>(Bank 3) | |----------------------|-----------------------------|----------------------------------|--------------------|--------------------| | 0x1B | RFC | The control of Book 6 | | Dank O | | 0x1C | TM34RH | The same mapping as Bank 0 | | | | 0x1D ~ 0x1E | - | - | | | | 0x1F | INTE2 | INTE2 The same mapping as Bank 0 | | Bank 0 | | 0x20 ~ 0x3F | General Purpose<br>Register | General Purpose<br>Register | Mapped to<br>bank0 | Mapped to<br>Bank1 | | 0x40 ~ 0x7F | General Purpose<br>Register | Mapped to<br>bank0 | Mapped to<br>bank0 | Mapped to<br>bank0 | 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. STATUS[7:6] bank select bits are ignored while F-page and S-page register is accessed. The register name and address mapping of F-page and S-page are depicted in the following table. | | T | | |----------------------|------------|------------| | SFR Category Address | F-page SFR | S-page SFR | | 0x0 | - | TMR1 | | 0x1 | - | T1CR1 | | 0x2 | - | T1CR2 | | 0x3 | - | PWM1DUTY | | 0x4 | - | PS1CV | | 0x5 | IOSTA | BZ1CR | | 0x6 | IOSTB | IRCR | | 0x7 | - | TBHP | | 0x8 | - | TBHD | | 0x9 | APHCON | TMR2 | | 0xA | PS0CV | T2CR1 | | 0xB | - | T2CR2 | | 0xC | BODCON | PWM2DUTY | | 0xD | - | PS2CV- | | 0xE | CMPCR | - | | 0xF | PCON1 | OSCCR | | 0x10 | | TMR3 | | 0x11 | - | T3CR1 | | 0x12 | - | T3CR2 | | 0x13 | - | PWM3DUTY | | 0x14 | - | PS3CV | | 0x15 | - | - | | 0x16 | - | P4CR1 | 19 | SFR Category Address | F-page SFR | S-page SFR | |----------------------|------------|------------| | 0x17 | - | - | | 0x18 | - | PWM4DUTY | | 0x19 | - | CCPCON | | 0x1A | - | PWMDB | | 0x1B | - | P5CR1 | | 0x1C | - | - | | 0x1D | -1 | PWM5DUTY | | 0x1E | - | - | | 0x1F | - | PWM5RH | Table 2 F-page and S-page SFR Address Mapping ## 3. Function Description This chapter will describe the detailed operations of AT8A54E1. #### 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 | | | | INDI | <b>-</b> [7:0] | | | | | | R/W Proper | ty | | | | R | /W | | | | | | Initial Value | | , | | | XXX | (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[10: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 | | | | Ţ. | 0x | 00 | | | | The register PCL is the least significant byte (LSB) of 11-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[10:8], is not directly accessible. Update of PC[10:8] must be done through register PCHBUF. For GOTO instruction, PC[8:0] is from instruction word and PC[10:9] is loaded from PCHBUF[2:1]. For CALL instruction, PC[7:0] is from instruction word and PC[10:8] is loaded from PCHBUF[2:0]. Moreover the next PC address, i.e. PC+1, will push onto top of Stack. For LGOTO instruction, PC[10:0] is from instruction word. For LCALL instruction, PC[10: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 | BK1 | BK0 | 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 | | lı | 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 /PD=1, after power-up or after instruction CLRWDT is executed. #### /PD=0, after instruction SLEEP is executed. /TO: Time overflow flag bit /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[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. (\*1) can be cleared by sleep instruction. (\*2) can be set by clrwdt instruction. GP7: General purpose read/write register bit. #### 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 | 1 | | R/W | | | | | | | | | | Initial Value | | 0 | X X X X X X X | | | | | | | | 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 xxxxxxxx, 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 | GP7 | GP6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | | | i | R/W Property | | | | | R/ | W | | | | | | | Initial Value | | Data lat | Data latch value is xxxxxxxx, read value is xxxxxxxx port value(PB5~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. GP7~6: general purpose registers. #### 3.1.8 PCON (Power Control Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |------|---------------|-------|-------|--------|-------|--------|-------|-------|------|------| | PCON | R | 8x0 | WDTEN | /PLPA4 | LVDEN | /PHPA5 | LVREN | CMPEN | GP1 | GP0 | | F | R/W Property | у | | | | R/W | | | | | | | Initial Value | | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | GP1, GP0: General read/write register bits. **CMPEN:** Enable/disable Comparator. CMPEN=1, enable comparator. CMPEN=0, disable comparator. 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.9 BWUCON (PortB Wake-up Control Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |--------|-------------|-------|------|------|-------|-------|-------|-------|-------|-------| | BWUCON | R | 0x9 | - | - | WUPB5 | WUPB4 | WUPB3 | WUPB2 | WUPB1 | WUPB0 | | R/\ | N Property | | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | In | itial Value | | X | Χ | 0 | 0 | 0 | 0 | 0 | 0 | **WUPBx:** Enable/disable PBx wake-up function, $0 \le x \le 5$ . WUPBx=1, enable PBx wake-up function. WUPBx=0, disable PBx wake-up function. ## 3.1.10 PCHBUF (High Byte of PC) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |--------|--------------|-------|--------|----------|------|------|------|------|--------|------| | PCHBUF | R | 0xA | BIASEN | XSPD_STP | | - | | PC | HBUF[2 | 2:0] | | R | W Property | | R/W | W | | - | | | R/W | | | lı | nitial Value | | 0 | 0 | | Х | | | • | | **PCHBUF[2:0]:** Buffer of the 10<sup>th</sup> ~ 8<sup>th</sup> bit of PC. **XSPD\_STP:** Write 1 to stop crystal 32.768K speed-up function, write-only. BIASEN: Comparator / LVD module bias enable. BIASEN=1, comparator/LVD bias is enabled. BIASEN=0, comparator/LVD bias is not enabled by BIASEN signal. ## 3.1.11 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 F | Property | У | | | | R/ | W | | | | | Initia | l 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.12 BPHCON (PortB Pull-High Resistor Control Register) | Nam | е | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |------|---------------|----------|-------|------|------|--------|--------|--------|--------|--------|--------| | BPHC | ON | R | 0xC | - | - | /PHPB5 | /PHPB4 | /PHPB3 | /PHPB2 | /PHPB1 | /PHPB0 | | | R/W Property | | | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | | Initial Value | | | | X | 1 | 1 | 1 | 1 | 1 | 1 | **/PHPBx:** Disable/enable PBx Pull-High resistor, $0 \le x \le 5$ . /PHPBx=1, disable PBx Pull-High resistor. /PHPBx=0, enable PBx Pull-High resistor. ## 3.1.13 INTE (Interrupt Enable Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|--------------|-------|--------|-----------|----------------|-------|------|--------|-------|------| | INTE | R | 0xE | INT1IE | WDTI<br>E | T2IE/<br>CCPIE | LVDIE | T1IE | INT0IE | PABIE | TOIE | | | R/W Property | , | R/W | Initial Value | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **T0IE:** 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. **T2IE/CCPIE:** When CCP capture or compare mode is enabled, this interrupt is used as CCP interrupt enable bits, otherwise it is T2 underflow interrupt enable bit. T2IE=1, enable interrupt. T2IE=0, disable 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.14 INTF (Interrupt Flag Register) | Name | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |----------------------|-------------|-------|--------|-------|----------------|-------|------|--------|-------|------| | INTF | R | 0xF | INT1IF | WDTIF | T2IF/<br>CCPIE | LVDIF | T1IF | INT0IF | PABIF | TOIF | | R | /W Proper | ty | R/W | Initial Value(note*) | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | T0IF: 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. **T2IF/CCPIF:** When CCP capture or compare mode is enabled, this interrupt is used as CCP interrupt flag bits, otherwise it is T2 underflow interrupt flag bit T2IF=1, interrupt is occurred. T2IF=0 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.15 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 I | Property | у | R/W | Initia | ıl 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.16 INTEDG (Interrupt Edge Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |--------|----------|-------|------|------|------|------|--------|--------|--------|--------| | INTEDG | R | 0x18 | - | - | EIS1 | EIS0 | INT1G1 | INT1G0 | INT0G1 | INT0G0 | | R | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | | | lı | Х | Х | 0 | 0 | 0 | 1 | 0 | 1 | | | EIS1: External interrupt 1 select bit EIS1=1, PB1/PA2 is external interrupt 1. EIS1=0, PB1/PA2 is GPIO. EIS0: External interrupt 0 select bit EIS0=1, PB0 is external interrupt 0. EIS0=0, PB0 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. #### 3.1.17 TMRH (Timer High Byte Register) | Name | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |------|-------------|-------|-------|-------|-------|-------|---------------|---------------|---------------|---------------| | TMRH | R | 0x19 | TMR29 | TMR28 | TMR19 | TMR18 | PWM2<br>DUTY9 | PWM2<br>DUTY8 | PWM1<br>DUTY9 | PWM1<br>DUTY8 | | R/W | / Proper | ty | R/W | Init | ial Valu | е | X | X | Х | Х | Х | Х | Х | Х | TMR29~8: Timer2 MSB 2 bits. Write these 2 bits will overwrite the 10-bit Timer2 load value of bit 9 and 8. Read these 2 bits will get the Timer2 bit9-8 current value. **TMR19~8:** 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.18 RFC (RFC Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|--------------|-------|-------|------|------|------|------|------|--------|------| | RFC | R | 0x1B | RFCEN | - | - | - | | PSEI | L[3:0] | | | F | R/W Property | | R/W | - | - | - | R/W | | | | | Initial Value | | | 0 | X | Х | Х | 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 | |-----------|---------| | | MOTAB | | 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 | Table 3 RFC pad select ## 3.1.19 TM34RH (Timer3 High Byte Register) | Name | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |--------|---------------|-------|------|------|-------|-------|---------------|---------------|---------------|---------------| | TM34RH | R | 0x1C | - | ì | TMR39 | TMR38 | PWM4<br>DUTY9 | PWM4<br>DUTY8 | PWM3<br>DUTY9 | PWM3<br>DUTY8 | | R/W | Property | У | | , | R/W | R/W | R/W | R/W | R/W | R/W | | Initi | Initial Value | | X | X | X | Х | Х | Х | Х | Х | **TMR39~8:** Timer3 MSB 2 bits. Write these 2 bits will overwrite the 10-bit Timer3 load value of bit 9 and 8.Read these 2 bits will get the Timer3 bit9-8 current value. PWM3DUTY9~8: PWM3 duty data MSB 2 bits. **PWM4DUTY9~8:** PWM4 duty data MSB 2 bits. ## 3.1.20 INTE2 (Interrupt Enable and Flag 2nd. Register) | Name | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------|-------------|-------|------|------|------|------|------|------|------|------| | INTE2 | R | 0x1F | - | ı | - | T3IF | ı | ı | ı | T3IE | | R/V | V Propei | rty | ı | - | - | R/W | ı | ı | ı | R/W | | lni | tial Valu | е | - | - | - | 0 | - | - | - | 0 | T3IF: Timer3 underflow interrupt flag bit. T3IF=1, Timer3 underflow interrupt is occurred. T3IF must be clear by firmware. T3IE: Timer3 underflow interrupt enable bit. T3IE=1, enable Timer3 underflow interrupt. T3IE=0, disable Timer3 underflow interrupt. ## 3.2 T0MD Register TOMD is a readable/writeable register which is only accessed by instruction TOMD / TOMDR. | Name | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |----------------------|-------------|-------|--------|------|------|------|--------|------|---------|------| | T0MD | F | - | LCKTM0 | GP6 | T0CS | T0CE | PS0WDT | PS | SOSEL[2 | :0] | | R/W Property | | | | | | R/W | | | | | | Initial Value(note*) | | 0 | 0 | 1 | 1 | 1 | | 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 timer 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 F<sub>INST</sub> 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 | | R/W Property | | R/W | | Initial Value | | | 1 | 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 | - | - | IOPB5 | IOPB4 | IOPB3 | IOPB2 | IOPB1 | IOPB0 | | R/W Property | | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | | Initial Value | | | Х | Х | 1 | 1 | 1 | 1 | 1 | 1 | **IOPBx:** PBx I/O mode selection, $0 \le x \le 5$ . IOPBx=1, PBx is input mode. IOPBx=0, PBx is output mode. ## 3.3.3 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 | | | 1 | | 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.4 PS0CV (Prescaler0 Counter Value Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | | |----------------|---------------|-------|------|------------|------|------|------|------|------|------|--| | PS0CV | F | 0xA | | PS0CV[7:0] | | | | | | | | | R/W Property R | | | | | | | | | | | | | | Initial Value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | While reading PS0CV, it will get current value of Prescaler0 counter. #### 3.3.5 BODCON (PortB Open-Drain Control Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|----------|-------|------|------|-------|-------|-------|-------|-------|-------| | BODCON | F | 0xC | | - | ODPB5 | ODPB4 | ODPB3 | ODPB2 | ODPB1 | ODPB0 | | R/W Property | | | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | Initial Value | | | X | Х | 0 | 0 | 0 | 0 | 0 | 0 | **ODPBx:** Enable/disable open-drain of PBx, $0 \le x \le 5$ . ODPBx=1, enable open-drain of PBx. ODPBx=0, disable open-drain of PBx. ### 3.3.6 CMPCR (Comparator voltage select Control Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |------------------|---------------|-------|------|---------|---------|----------|------|------|------|------| | CMPCR | F | 0xE | GP7 | RBIAS_H | RBIAS_L | CMPF_INV | PS1 | PS0 | NS1 | NS0 | | 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.15.3) Note: RBIAS\_L and RBIAS\_H MUST be set as "00" before sleep mode or halt mode to prevent current leakage. ## 3.3.7 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 | | R/W Property | | | R/W <sup>(1*)</sup> | R | R/W | R/W | R/W | R/W | R/W | R/W | | Initial Value | | | 0 | Х | 1 | 1 | 1 | 1 | 0 | 1 | T0EN: Enable/disable Timer0. T0EN=1, enable Timer0. T0EN=0, disable Timer0. LVDS3~0: Select one of the 16 LVD voltage. | RBIAS[H:L] | LVDS[3:0] | Voltage | |------------|-----------|---------| | 00 | 0000 | 1.9V | | 00 | 0001 | 2.0V | | 00 | 0010 | 2.2V | | 00 | 0011 | 2.4V | | 00 | 0100 | 2.6V | | RBIAS[H:L] | LVDS[3:0] | Voltage | |------------|-----------|---------| | 00 | 0101 | 2.8V | | 00 | 0110 | 2.9V | | 00 | 0111 | 3.0V | | 00 | 1000 | 3.15V | | 00 | 1001 | 3.30V | | 00 | 1010 | 3.45V | | 00 | 1011 | 3.60V | | 00 | 1100 | 3.75V | | 00 | 1101 | 3.90V | | 00 | 1110 | 4.05V | | 00 | 1111 | 4.15V | Table 5 LVD voltage select **LVDOUT:** Low voltage detector output, read-only. GIE: Global interrupt enable bit. GIE=1, enable all unmasked interrupts. GIE=0, disable all interrupts. GP5, GP1: General purpose read/write register. (1\*): set by instruction ENI, clear by instruction DISI, read by instruction IOSTR. ## 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 | | | XXXXXXX | | | | | | | | 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 | ı | ı | TM1_HRC | T10S | T1RL | T1EN | | RΛ | N Prope | rty | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | In | Initial Value | | 0 | 0 | Х | Х | 0 | 0 | 0 | 0 | 33 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. **T10S:** 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. When underflow is reached, 0x3FF is reloaded and continues down-count. | | 0 | 1 | Timer1 will count from reload value down to 0x00. When underflow is reached, reload value is reloaded and continues to down-count. | | 1 | Х | Timer1 will count from initial value down to 0x00. When underflow is reached, Timer1 will stop down-count. | Table 6 Timer1 Functionality **TM1\_HRC:** Timer1 clock source from Internal High frequency(I\_HRCx1) TM1 HRC=1: Enable. Timer1 clock source from Internal High frequency(I HRCx1) TM1 HRC=0: Disable. Timer1 clock source from CPU operating clock. Note: When Timer By Passed prescaler (TMx HRC=1), it's V<sub>LVR</sub> will be higher. **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 PB3 or PA4. PWM10EN=0, PB3 or PA4 is GPIO. ## 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 | PS | :0] | | | | R/W Property | | / | 1 | R/W | R/W | R/W | R/W R/W I | | R/W | | Initial Value | | X | X | 1 | 1 | 1 | 1 | 1 | 1 | | This register is used to configure Timer1 functionality. PS1SEL[2:0]: Prescaler1 dividing rate selection. | 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 7 Prescaler1 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 | | | | | | | li | nitial Value | | 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 | | R | | | | | | | | | | Initial Value | 1 | 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 | - | , | | BZ1FSEL[3:0] | | | | | | R/W Property | | W | - | - | - | W | | | | | Initial Value | | | 0 | X | X | Х | 1 | 1 | 1 | 1 | BZ1FSEL[3:0]: Frequency selection of BZ1 output. | D745051 (2.01 | BZ1 Frequen | cy Selection | |---------------|-------------------|---------------| | BZ1FSEL[3:0] | Clock Source | Dividing Rate | | 0000 | | 1:2 | | 0001 | | 1:4 | | 0010 | Proceeders output | 1:8 | | 0011 | | 1:16 | | 0100 | Prescaler1 output | 1:32 | | 0101 | | 1:64 | | 0110 | | 1:128 | | 0111 | | 1:256 | | 1000 | | Timer1 bit 0 | | 1001 | | Timer1 bit 1 | | 1010 | | Timer1 bit 2 | | 1011 | Time and acutocut | Timer1 bit 3 | | 1100 | Timer1 output | Timer1 bit 4 | | 1101 | | Timer1 bit 5 | | 1110 | | Timer1 bit 6 | | 1111 | | Timer1 bit 7 | Table 8 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 | | | 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.18) can be used as IR clock source. - 2. Division ratio for different oscillation type. | OSC. Type | 57KHz | 38KHz | Conditions | |----------------|----------------|-------|----------------------------------------------------------------------------------| | High IRC(4MHz) | RC(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 9 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 | | - | - | | - | TBHP2 | TBHP1 | TBHP0 | | F | R/W Property | | - | <b>A</b> - | | - | - | R/W | R/W | R/W | | Initial Value | | | X | X | X | Х | Х | Х | Х | Х | When instruction CALLA, GOTOA or TABLEA is executed, the target address is constituted by TBHP[2:0] and ACC. ACC is the Low Byte of PC[10:0] and TBHP[2:0] is the high byte of PC[10: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 | | | 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 TMR2 (Timer2 Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |------|---------------|-------|------|-----------|------|------|------|------|------|------| | TMR2 | 8 | 0x9 | | TMR2[7:0] | | | | | | | | | R/W Property | , | | R/W | | | | | | | | | Initial Value | | | XXXXXXXX | | | | | | | When reading register TMR2, it will obtain current value of 10-bit down-count Timer2 at TMR2[7:0]. When writing register TMR2, it will write data from TMRH[7:6] and Timer2 reload register to Timer2[9:0] current content. ### 3.4.11 P2CR1 (PWM2 Control Register1) | Name | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------|-------------|-------|---------|---------|------|------|---------|------|------|------| | T2CR1 | S | 0xA | PWM2OEN | PWM2OAL | ı | ı | TM2_HRC | T2OS | T2RL | T2EN | | R/V | V Prope | erty | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | In | itial Valu | ıe | 0 | 0 | Х | Х | 0 | 0 | 0 | 0 | **T2EN:** Enable/disable Timer2. T2EN=1, enable Timer2. T2EN=0, disable Timer2. T2RL: Configure Timer2 down-count mechanism while Non-Stop mode is selected (T2OS=0). T2RL=1, initial value is reloaded from reload register TMR2. T2RL=0, continuous down-count from 0x3FF when underflow is occurred. **T2OS:** Configure Timer2 operating mode while underflow is reached. T2OS=1, One-Shot mode. Timer2 will count once from the initial value to 0x00. T2OS=0, Non-Stop mode. Timer2 will keep down-count after underflow. | T2OS | T2RL | Timer2 Down-Count Functionality | | | | | | | |------|------|----------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | 0 | Timer2 will count from reload value down to 0x00. | | | | | | | | U | U | When underflow is reached, 0x3FF is reloaded and continues down-count. | | | | | | | | 0 | 1 | Timer2 will count from reload value down to 0x00. | | | | | | | | U | ı | When underflow is reached, reload value is reloaded and continues to down-count. | | | | | | | | 1 | ., | Timer2 will count from initial value down to 0x00. | | | | | | | | 1 | X | When underflow is reached, Timer2 will stop down-count. | | | | | | | Table 10 Timer2 Functionality TM2\_HRC:Timer2 clock source from Internal High frequency(I\_HRCx1) TM2\_HRC=1 Enable ,Timer2 clock source from Internal High frequency(I\_HRCx1). TM2\_HRC=0 Disable ,Timer2 clock source from CPU operating clock. Note: When Timer By Passed prescaler(TMx\_HRC=1),it's minimum operating LVR voltage will be higher. 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 PB2, PA7 or PA0. PWM2OEN=0, PB2, PA7 or PA0 is GPIO. #### 3.4.12 T2CR2 (Timer2 Control Register2) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|----------------------------|-------|-------------|------|------|------|------|------|------|------| | T2CR2 | CR2 S 0xB T2CS T2CE /PS2EN | | PS2SEL[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 | | This register is used to configure Timer2 functionality. Bit[2:0] PS2SEL[2:0]: Prescaler2 dividing rate selection. | PS2SEL[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 11 Prescaler2 Dividing Rate Note: Always set PS2SEL[2:0] at /PS2EN=1, or interrupt may be falsely triggered. Bit3 /PS2EN: Disable/enable Prescaler2. /PS2EN=1, disable Prescaler2. /PS2EN=0, enable Prescaler2. Bit4 T2CE: Timer2 external clock edge selection. T2CE=1, Timer2 will decrease one while high-to-low transition occurs on pin EX CKI1. T2CE=0, Timer2 will decrease one while low-to-high transition occurs on pin EX CKI1. Bit5 T2CS: Timer2 clock source selection. T2CS=1, External clock on pin EX\_CKI1 is selected. T2CS=0, Instruction clock is selected. # 3.4.13 PWM2DUTY (PWM2 Duty Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |----------|--------------|---------------|------|------|------|------|------|------|------|------| | PWM2DUTY | | PWM2DUTY[7:0] | | | | | | | | | | RΛ | R/W Property | | | R/W | | | | | | | | In | itial Value | | | | XXXX | XXXX | | | | | 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.14 PS2CV (Prescaler2 Counter Value Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | | | | |-------|---------------|-------|------|------|------------|------|------|------|------|------|--|--|--| | PS2CV | PS2CV S 0xD | | | | PS2CV[7:0] | | | | | | | | | | | R/W Property | | | | | F | 3 | | | | | | | | | Initial Value | | | | 1 | 1 | 1 | 1 | 1 | 1 | | | | While reading PS2CV, it will get current value of Prescaler2 counter. # 3.4.15 OSCCR (Oscillation Control Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------|--------------|-------|------|--------|------|------|------|--------|---------|---------| | OSCCR | S | 0xF | ı | CMPOEN | | ı | ОРМІ | D[1:0] | STPHOSC | SELHOSC | | R | W Property | | 1 | R/W | - | - | R/ | W | R/W | R/W | | lı | nitial Value | | Χ | 0 | Х | Χ | 0 | 0 | 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, F<sub>HOSC</sub> 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 12 Selection of Operating Mode by OPMD[1:0] 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. CMPOEN: Enable/disable comparator output to PB3. CMPOEN=1, Enable comparator output to PB3. CMPOEN=0, Disable comparator output to PB3. #### 3.4.16 TMR3 (Timer3 Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | | | | |------|---------------|-------|------|-----------|------|------|------|------|------|------|--|--|--| | TMR3 | S | 0x10 | | TMR3[7:0] | | | | | | | | | | | | R/W Property | | | | | R/ | W | | | | | | | | | Initial Value | | | XXXXXXX | | | | | | | | | | When reading register TMR3, it will obtain current value of 10-bit down-count Timer3 at TMR3[7:0]. When writing register TMR3, it will write data from TM34RH[5:4] and Timer3 reload register to Timer3[9:0] current content. ### 3.4.17 T3CR1 (Timer3 Control Register1) | Name | SFR<br>Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------|---------------|-------|---------|---------|------|------|-------------|------|------|------| | T3CR1 | S | 0x11 | PWM30EN | PWM3OAL | ı | ı | TM3_<br>HRC | T3OS | T3RL | T3EN | | R/\ | N Prope | erty | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | In | Initial Value | | 0 | 0 | Х | Х | 0 | 0 | 0 | 0 | This register is used to configure Timer3 functionality. T3EN: Enable/disable Timer3. T3EN=1, enable Timer3. T3EN=0, disable Timer3. T3RL: Configure Timer3 down-count mechanism while Non-Stop mode is selected (T3OS=0). T3RL=1, initial value is reloaded from reload register TMR3. T3RL=0, continuous down-count from 0x3FF when underflow is occurred. **T3OS:** Configure Timer3 operating mode while underflow is reached. T3OS=1, One-Shot mode. Timer3 will count once from the initial value to 0x00. T3OS=0, Non-Stop mode. Timer3 will keep down-count after underflow. | T3OS | T3RL | Timer3 Down-Count Functionality | |------|------|-------------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | Timer3 will count from reload value down to 0x00. When underflow is reached, 0x3FF is reloaded and continues down-count. | | 0 | 1 | Timer3 will count from reload value down to 0x00. When underflow is reached, reload value is reloaded and continues to down-count. | | 1 | x | Timer3 will count from initial value down to 0x00. When underflow is reached, Timer3 will stop down-count. | Table 13 Timer3 Functionality 41 TM3 HRC: Timer3 clock source from Internal High frequency(I HRCx1). TM3 HRC=1 Enable Timer3 clock source from Internal High frequency(I HRCx1) TM3\_HRC=0 Disable ,Timer3 clock source from CPU operating clock **PWM3OAL:** Define PWM3 output active state. PWM3OAL=1, PWM3 output is active low. PWM3OAL=0, PWM3 output is active high. PWM30EN: Enable/disable PWM3 output. PWM3OEN=1, PWM3 output will be present on PA3 or PB4. PWM30EN=0, PA3 or PB4 is GPIO. # 3.4.18 T3CR2 (Timer3 Control Register2) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------|---------------|-------|------|------|------|------|--------|------|------|------| | T3CR2 | S | 0x12 | - | - | T3CS | T3CE | /PS3EN | PS | :0] | | | F | R/W Property | | 1 | - | R/W | R/W | R/W | R/W | R/W | | | | Initial Value | | X | Х | 1 | 1 | 1 | 1 1 | | 1 | This register is used to configure Timer3 functionality. PS3SEL[2:0]: Prescaler3 dividing rate selection. | PS3SEL[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 14 Prescaler3 Dividing Rate Note: Always set PS3SEL[2:0] at /PS3EN=1, or interrupt may be falsely triggered. /PS3EN: Disable/enable Prescaler3. /PS3EN=1, disable Prescaler3. /PS3EN=0, enable Prescaler3. T3CE: Timer3 external clock edge selection. T3CE=1, Timer3 will decrease one while high-to-low transition occurs on pin EX\_CKI1. T3CE=0, Timer3 will decrease one while low-to-high transition occurs on pin EX\_CKI1. 42 T3CS: Timer3 clock source selection. T3CS=1, External clock on pin EX CKI1 is selected. T3CS=0, Instruction clock is selected. # 3.4.19 PWM3DUTY (PWM3 Duty Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | | | | |----------|---------------|-------|---------------|------|------|----------|------|------|------|------|--|--|--| | PWM3DUTY | S | 0x13 | PWM3DUTY[7:0] | | | | | | | | | | | | R | /W Property | | W | | | | | | | | | | | | I | Initial Value | | | | | XXXXXXXX | | | | | | | | The reload value of 10-bit Timer3 stored on registers TM34RH[5:4] and TMR3[7:0] is used to define the PWM3 frame rate, and registers TM34RH[1:0] and PWM3DUTY[7:0] is used to define the duty cycle of PWM3. # 3.4.20 PS3CV (Prescaler3 Counter Value Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | | |-------|---------------|-------|------|-----------------|------|------|------|------|------|------|--| | PS3CV | S | 0x14 | | PS3CV[7:0] | | | | | | | | | | R/W Property | | | R | | | | | | | | | | Initial Value | | 1 | 1 1 1 1 1 1 1 1 | | | | | | | | While reading PS3CV, it will get current value of Prescaler3 counter. # 3.4.21 P4CR1 (PWM4 Control Register1) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------|---------------|-------|---------|---------|------|------|------|------|------|------| | P4CR1 | S | 0x16 | PWM40EN | PWM4OAL | - | | - | ı | ı | ı | | R | /W Property | | R/W | R/W | - | - | - | • | • | • | | | Initial Value | | 0 | 0 | Х | Х | X | Х | Х | Х | **PWM4OAL:** Define PWM4 output active state. PWM4OAL=1, PWM4 output is active low. PWM4OAL=0, PWM4 output is active high. PWM40EN: Enable/disable PWM4 output. PWM4OEN=1, PWM4 output will be present on PA2 or PB5. PWM4OEN=0, PA2 or PB5 is GPIO. # 3.4.22 PWM4DUTY (PWM4 Duty Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | | |----------|---------------|-------|---------------|----------|------|------|------|------|------|------|--| | PWM4DUTY | S | 0x18 | PWM4DUTY[7:0] | | | | | | | | | | R | /W Property | perty | | | | | | | | | | | I | Initial Value | | | XXXXXXXX | | | | | | | | The reload value of 10-bit Timer3 stored on registers TM34RH[5:4] and TMR3[7:0] is used to define the PWM4 frame rate, and registers TM34RH[3:2] and PWM4DUTY[7:0] is used to define the duty cycle of PWM4. 43 ### 3.4.23 CCPCON (CCP Control Register) | Name | SFR<br>Type | Addr | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|-------------|------|--------|--------|-------|-------|-------|-------|-------|-------| | CCPCON | S | 0x19 | PWM2M1 | PWM2M0 | FBCH1 | FBCH0 | ССРМ3 | CCPM2 | CCPM1 | ССРМ0 | | R/W Property | | | R/W | Initial Value | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | CCPM[3:2]=00/01/10: Capture or compare mode. PB2 is capture input or compare output. # CCPM[3:2]=11: PWM2M1~0 = 00 $\rightarrow$ PWM single output. PWM2M1 $\sim$ 0 = 01 $\rightarrow$ PWM Full-Bridge output forward. PWM2M1~0 = 10 $\rightarrow$ PWM Half-bridge output. PWM2M1 $\sim$ 0 = 11 $\rightarrow$ PWM Full-Bridge output reverse. T2IF/CCPIF=1, interrupt is occurred. Note: T2IF/CCPIF must be clear by firmware. #### CCPM[3:0]: 0000 = CCP 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 4<sup>th</sup> rising edge. 0111 = Capture mode, capture at every 16<sup>th</sup> rising edge. 1000 = Compare mode, set output and interrupt on match. 1001 = Compare mode, clear output and interrupt on match. 1010 = Compare mode, only interrupt on match. 1011 = Compare mode, trigger ADC and interrupt on match. 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. Note: P1A is PA0, P1B is PA5, P1C is PA7, P1D is PA4. FBCH1~0: Full band change direction gap 00 = 1 CPU cycle. 01 = 4 CPU cycle. 1x = 16 CPU cycle. Note: Compare/Capture mode step: - a. Set timer2 operating mode: set T1OS/T1RL, set T2EN = PWM2OEN = 0. - b. Set timer1 clock source, timer1 prescaler. - c. Set timer1 / timer2 reload/initial value. - d. Set pwm1duty / pwm2duty. - e. Enable compare / capture mode. - f. Disable compare / capture mode before update pwm / timer data. #### 3.4.24 PWMDB (Dead band control Register) | Name | SFR<br>Type | Addr | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|--------------|------|------|------|------|------|------|------|------|------| | PWMDB | S | 0x1A | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | R/W | R/W Property | | R/W | Initial Value | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DB[7:0] Define the dead band width of the CCP PWM mode. The dead band unit is in CPU cycle. $td = F_{INST} * (DB[7:0])$ ### 3.4.25 P5CR1 (PWM5 Control Register1) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------|--------------|-------|---------|---------|------|------|------|------|------|------| | P5CR1 | S | 0x1B | PWM50EN | PWM5OAL | - | - | - | - | - | - | | R | /W Property | | R/W | R/W | - | 1 | | - | - | - | | ı | nitial Value | | 0 | 0 | Х | Х | X | X | Х | Х | **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 PB0, PA6 or PA1. PWM50EN=0, PB0, PA6 or PA1 is GPIO. #### 3.4.26 PWM5DUTY (PWM5 Duty Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|----------|-------|---------------|------|------|------|------|------|------|------| | PWM5DUTY | S | 0x1D | PWM5DUTY[7:0] | | | | | | | | | R/W Property | | | W | | | | | | | | | Initial Value | | | XXXXXXX | | | | | | | | The reload value of 10-bit Timer3 stored on registers TM34RH[5:4] and TMR3[7:0] is used to define the PWM5 frame rate, and registers PWM5RH[1:0] and PWM5DUTY[7:0] is used to define the duty cycle of PWM5. 45 #### 3.4.27 PWM5RH (PWM5 High Byte Register) | Name | SFR Type | Addr. | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |---------------|----------|-------|------|------|------|------|------|------|---------------|---------------| | PWM5RH | S | 0x1F | - | - | - | - | - | - | PWM5<br>DUTY9 | PWM5D<br>UTY8 | | R/W Property | | | | - | - | - | 1 | ı | R/W | R/W | | Initial Value | | | X | X | Х | Х | Х | Χ | Х | Х | PWM5DUTY9~8: PWM5 duty data MSB 2 bits. #### 3.5 I/O Port AT8A54E1 provides 14 I/O pins which are PA[7:0] and PB[5:0]. User can read/write these I/O pins through registers PORTA and PORTB 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[5:0] define the input/output direction of PB[5: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, 4:0] and PCON[4] 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[5:0] are used to enable or disable Pull-High resistor of PB[5:0]. Register ABPLCON[7:4] are used to enable or disable Pull-Low resistor of PB[3: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[5:0] determine PB[5:0] is Open-Drain or not. The summary of Pad I/O feature is listed in the table below. | Feature | | PA[4:0] | PA[7:6] | PA[5] | PB[3:0] | PB[5:4] | |---------|--------------------|---------|---------|-------|---------|---------| | Innut | Pull-High Resistor | V | V | V | V | V | | Input | Pull-Low Resistor | V | X | V | V | X | | Output | Open-Drain | Х | X | V | V | V | Table 15 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[5: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 two external interrupt provided by AT8A54E1. When register bit EIS0 (INTEDG[4]) is set to 1, PB0 is used as input pin for external interrupt 0. When register bit EIS1 (INTEDG[5]) is set to 1, PB1 is used as input pin for external interrupt 1. Note: When PB0 or PB1 is both set as level change operation and external interrupt, the external interrupt will have higher priority, and the PB0 or PB1 level change operation will be disabled. But PB5~PB2 level change function are not affected. AT8A54E1 provides IR carrier generation output. It is depended both on register bit IREN (IRCR[0]) and carrier output will be present on PB1 pad. When IREN=1, the IR sink current=20mA. When IREN=0, the IR carrier will not be generated. 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 AT8A54E1 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. PA1 can be Timer3 external clock source EX\_CKI1 if T3CS =1. Moreover, PB3 or PA4 can be PWM1 output If T1CR1[7] PWM10EN=1. PB3 can be Buzzer1 output if BZ1CR[7] BZ1EN=1. The output priority of PB3 is PWM1 output > Buzzer1 output. 47 PB2, PA7 or PA0 can be PWM2 output If P2CR1[7] PWM2OEN=1. # 3.5.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. VNEN: enable pad to comparator inverting input. CMPVP, CMPVN: comparator non-inverting and inverting input. RD\_TYPE: select read pin or read latch. Figure 5 Block Diagram of PA2&PA0 48 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 Timer 3. Figure 6 Block Diagram of PA1 49 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. HLH\_ENB: select pull-high resistor. Figure 7 Block Diagram of PA3 WRITE\_EN: write data to pad. READ\_EN: read pad. PULLUP\_ENB: enable Pull-High. PULLDOWN\_EN: enable Pull-Low. RD\_TYPE: select read pin or read latch. EX\_CKI0: external clock for Timer0, 1. Figure 8 Block Diagram of PA4 51 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. RD\_TYPE: select read pin or read latch. OD\_EN: enable open-Drain. RSTPAD\_EN=1 will disable output high/low OD\_EN: will disable output high Figure 9 Block Diagram of PA5 52 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 10 Block Diagram of PA6, PA7 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. EIS0: external interrupt function enable. INTEDG[1:0]: external interrupt edge select. EX\_INT0: external interrupt signal. WUB: port B wake-up enable. SET\_PBIF: port B wake-up flag. Figure 11 Block Diagram of PB0 54 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. EIS1: external interrupt function enable. INTEDG[3:2]: external interrupt edge select. EX\_INT1: external interrupt signal. WUB: port B wake-up enable. SET\_PBIF: port B wake-up flag. Figure 12 Block Diagram of PB1 55 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 13 Block Diagram of PB2 56 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 14 Block Diagram of PB3 WRITE\_EN: write data to pad. READ\_EN: read pad. OD\_EN: enable open-Drain. PULLUP\_ENB: enable Pull-High. 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 PB4, PB5 #### 3.6 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 15) | Timer0 clock source | T0CS | LCKTM0 | Timer0 source | Low Oscillator Frequency | |---------------------|------|--------|---------------|--------------------------| | Instruction clock | 0 | X | X | X | | EX CKIO | 4 | 0 | Х | V | | EX_CKI0 | I | Х | 0 | X | | E_LXT | 1 | 1 | 1 | 1 | | I_LRC | 1 | 1 | 1 | 0 | Table 16 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. 59 The block diagram of Timer0 and WDT is shown in the figure below. Figure 16 Block Diagram of Timer0 and WDT #### 3.7 Timer1 / PWM1 / Buzzer1 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 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 17 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 (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 18 Timer1 Timing Chart The PWM1 output can be available on I/O pin PB3 or PA4 when register bit PWM10EN (T1CR1[7]) is set to 1. Moreover, PB3 or PA4 will become output pin automatically. The active state of PWM1 output is determined by register bit PWM10AL (T1CR1[6]). When PWM10AL is 1, PWM1 output is active low. When PWM10AL 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 19 PWM1 Block Diagram The Buzzer1 output (BZ1) can be available on I/O pin PB3 when register bit BZ1EN (BZ1CR[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. 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 20 Buzzer1 Block Diagram Note: When PWM1 and Buzzer1 are both enabled, PWM1 will have the higher priority for PB3 output. #### 3.8 Timer2 / PWM2 Timer2 is an 10-bit down-count timer with Prescaler1 whose dividing rate is programmable. The output of Timer2 can be used to generate PWM2 output. Timer2 builds in auto-reload function and Timer2 reload register stores reload data with double buffers. When user write Timer2 reload register, write Timer2 MSB 2 bits(TMRH[7:6]) first and write TMR2 second, Timer2 reload register will be updated to Timer2 counter after Timer2 overflow occurs when T2EN=1. If T2EN=0, Timer2 reload register will be updated to Timer2 counter after write TMR2 immediately. A read to the Timer2 will show the content of the Timer2 current count value. The block diagram of Timer2 is shown in the figure below. Figure 21 Block Diagram of Timer2 The operation of Timer2 can be enabled or disabled by register bit T2EN (T2CR1[0]). After Timer2 is enabled, its clock source can be instruction clock or pin EX\_CKI1 which is determined by register bit T2CS (T2CR2[5]). When T2CS is 1, EX\_CKI1 is selected as clock source. When T2CS is 0, instruction clock is selected as clock source. When EX\_CKI1 is selected, the active edge to decrease Timer2 is determined by register bit T2CE (T2CR2[4]). When T2CE is 1, high-to-low transition on EX\_CKI1 will decrease Timer2. When T2CE is 0, low-to-high transition on EX\_CKI1 will decrease Timer2. The selected clock source can be divided further by Prescaler2 before it is applied to Timer2. Prescaler2 is enabled by writing 0 to register bit /PS2EN (T2CR2[3]) and the dividing rate is from 1:2 to 1:256 determined by register bits PS2SEL[2:0] (T2CR2[2:0]). Current value of Prescaler2 can be obtained by reading register PS2CV. Timer2 provides two kinds of operating mode: one is One-Shot mode and the other is Non-Stop mode. When register bit T2OS (T2CR1[2]) is 1, One-Shot mode is selected. Timer2 will count down once from initial value stored on register TMR2[9:0] to 0x00, i.e. underflow is occurred. When register bit T2OS (T2CR1[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 T2RL (T2CR1[1]). When T2RL is 1, the initial value stored on register TMR2[9:0] will be restored and start next down-count from this initial value. When T2RL is 0, Timer2 will start next down-count from 0x3FF. When Timer2 is underflow, the register bit T2IF (INTF[5]) will be set to 1 to indicate Timer2 underflow event is occurred. If register bit T2IE (INTE[5]) and GIE are both set to 1, interrupt request will occur and interrupt service routine will be executed. T2IF will not be clear until firmware writes 0 to T2IF. The timing chart of Timer2 is shown in the following figure. Figure 22 Timer2 Timing Chart The PWM2 output can be available on I/O pin PB2, PA7 or PA0 when register bit PWM2OEN (P2CR1[7]) is set to 1. Moreover, PB2, PA7 or PA0 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]. Besides, user needs to set P2CR1 (T1EN, T1RL, T1OS data is as the same as T1CR1) because PWM2 and PWM1 are both shared with Timer1. 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. 64 Figure 23 PWM2 Block Diagram #### 3.9 Timer3 / PWM3 Timer3 is an 10-bit down-count timer with Prescaler3 whose dividing rate is programmable. The output of Timer3 can be used to generate PWM3 output. Timer3 builds in auto-reload function and Timer3 reload register stores reload data with double buffers. When users write Timer3 reload register, write Timer3 MSB 2 bits(TM34RH[5:4]) first and write TMR3 second, Timer3 reload register will be updated to Timer3 counter after Timer3 overflow occurs when T3EN=1. If T3EN=0, Timer3 reload register will be updated to Timer3 counter after write TMR3 immediately. A read to the Timer3 will show the content of the Timer3 current count value. The block diagram of Timer3 is shown in the figure below. Figure 24 Block Diagram of Timer3 The operation of Timer3 can be enabled or disabled by register bit T3EN (T3CR1[0]). After Timer3 is enabled, its clock source can be instruction clock or pin EX\_CKI1 which is determined by register bit T3CS (T3CR2[5]). When T3CS is 1, EX\_CKI1 is selected as clock source. When T3CS is 0, instruction clock is selected as clock source. When EX\_CKI1 is selected, the active edge to decrease Timer3 is determined by register bit T3CE (T3CR2[4]). When T3CE is 1, high-to-low transition on EX\_CKI1 will decrease Timer3. When T3CE is 0, low-to-high transition on EX\_CKI1 will decrease Timer3. The selected clock source can be divided further by Prescaler3 before it is applied to Timer3. Prescaler3 is enabled by writing 0 to register bit /PS3EN (T3CR2[3]) and the dividing rate is from 1:2 to 1:256 determined by register bits PS3SEL[2:0] (T3CR2[2:0]). Current value of Prescaler3 can be obtained by reading register PS3CV. Timer3 provides two kinds of operating mode: one is One-Shot mode and the other is Non-Stop mode. When register bit T3OS (T3CR1[2]) is 1, One-Shot mode is selected. Timer3 will count down once from initial value stored on register TMR3[9:0] to 0x00, i.e. underflow is occurred. When register bit T3OS (T3CR1[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 T3RL (T3CR1[1]). When T3RL is 1, the initial value stored on register TMR3[9:0] will be restored and start next down-count from this initial value. When T3RL is 0, Timer3 will start next down-count from 0x3FF. When Timer3 is underflow, the register bit T3IF (INTE2[4]) will be set to 1 to indicate Timer3 underflow event is occurred. If register bit T3IE (INTE2[0]) and GIE are both set to 1, interrupt request will occur and interrupt service routine will be executed. T3IF will not be clear until firmware writes 0 to T3IF. The timing chart of Timer3 is shown in the following figure. Figure 25 Timer3 Timing Chart 66 The PWM3 output can be available on I/O pin PA3 or PB4 when register bit PWM3OEN (T3CR1[7]) is set to 1. Moreover, PA3 or PB4 will become output pin automatically. The active state of PWM3 output is determined by register bit PWM3OAL (T3CR1[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 TM34RH[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 Timer3 input clocks. The frame rate is determined by TM34RH[5:4], TMR3[7:0] initial value. Therefore, PWM3DUTY value must be less than or equal to TMR3[9:0]. When user write PWM3DUTY, write PWM3DUTY[9:8] MSB 2 bits(TM34RH[1:0]) first and write PWM3DUTY[7:0] second, PWM3 duty register will be updated after Timer3 overflow occurs. The block diagram of PWM3 is illustrated in the following figure. Figure 26 PWM3 Block Diagram #### 3.10 PWM4 The PWM4 output can be available on I/O pin PB5 or PA2 when register bit PWM4OEN (P4CR1[7]) is set to 1. Moreover, PB5 or PA2 will become output pin automatically. The active state of PWM4 output is determined by register bit PWM4OAL (P4CR1[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 register TM34RH[3:2],PWM4DUTY[7:0]. When PWM4DUTY is 0, PWM4 output will be never active. When PWM4DUTY is 0x3FF, PWM4 output will be active for 1023 Timer3 input clocks. The frame rate is determined by TM34RH[5:4],TMR3[7:0] initial value. Therefore, PWM4DUTY value must be less than or equal to TMR3[9:0]. Besides, user needs to set P4CR1 (T3EN, T3RL, T3OS data is as the same as T3CR1) because PWM4 and PWM3 are both shared with Timer3. When user write PWM4DUTY, write PWM4DUTY[9:8] MSB 2 bits(TM34RH[3:2]) first and write PWM4DUTY[7:0] second, PWM4 duty register will be updated after Timer3 overflow occurs. The block diagram of PWM4 is illustrated in the following figure. 67 Figure 27 PWM4 Block Diagram #### 3.11 PWM5 The PWM5 output can be available on I/O pin PA1, PA6 or PB0 when register bit PWM5OEN (P5CR1[7]) is set to 1. Moreover, PA1, PA6 or PB0 will become output pin automatically. The active state of PWM5 output is determined by register bit PWM5OAL (P5CR1[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 register PWM5RH[1:0],PWM5DUTY[7:0]. When PWM5DUTY is 0, PWM5 output will be never active. When PWM5DUTY is 0x3FF, PWM5 output will be active for 1023 Timer3 input clocks. The frame rate is determined by TM34RH[5:4],TMR3[7:0] initial value. Therefore, PWM5DUTY value must be less than or equal to TMR3[9:0]. Besides, user needs to set P5CR1 (T3EN, T3RL, T3OS data is as the same as T3CR1) because PWM5 and PWM3 are both shared with Timer3. When user write PWM5DUTY, write PWM5DUTY[9:8] MSB 2 bits(PWM5RH[1:0]) first and write PWM5DUTY[7:0] second, PWM5 duty register will be updated after Timer3 overflow occurs. The block diagram of PWM5 is illustrated in the following figure. 68 Figure 28 PWM5 Block Diagram #### 3.12 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 AT8A54E1 is in CCP mode, related timer/PWM functions are disabled. | CCP mode | CCP register/timer | Shared Timers | Shared Registers | | |-----------------|-----------------------|------------------------------------------|------------------|--| | Capture/Compare | CCPL | - | PWM1DUTY[7:0] | | | Capture/Compare | ССРН | - | PWM2DUTY[7:0] | | | PWM | PWMDUTY | - | PWM2DUTY[9:0] | | | PWM | PWMDB | - | - | | | Capture/Compare | Capture/Compare timer | Timer2[7:0] (MSB) +<br>Timer1[7:0] (LSB) | - | | | PWM PWM timer | | Timer2[9:0] | - | | ### 3.12.1 Capture Mode In capture mode, CCPRH:CCPRL (That is, PWM2DUTY[7:0]:PWM1DUTY[7:0]) captures the 16-bit value of capture timer register when an event occurs on pin P1A (PA4). An event is defined as: 69 - every falling edge - every rising edge - every 4<sup>th</sup> rising edge - every 16<sup>th</sup> rising edge Prescaler 1 / 4 / 16 PWM2DUTY[7:0] PWM1DUTY[7:0] and Capture Enable TMR2[7:0] TMR1[7:0] 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 P1A(PA4) 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.12.2 Compare Mode In compare mode, the 16-bit CCPR (That is, PWM2DUTY[7:0]:PWM1DUTY[7:0]) register value is constantly compared against the compare timer value. When a match occurs, the CCP1 (PA4) pin is: 70 - 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 (PA0) 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.12.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(PA4), P1B(PA5), P1C(PA7) and P1D(PA3). The PWM period and duty are specified by Timer2[9:0] and PWM2DUTY[9:0] registers. Register PWM2M[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 (PA4) pin is used as PWM output. PA4 must be set as output. In Half-Bridge mode, P1A (PA4) pin has the PWM output signal, P1B (PA5) pin has the complementary PWM output signal. In this mode, PA4 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, timer2 is a 10-bit down counter, P1A is PWM2 output, P1B is PWM2 complementary output. AT point B, Timer2 value is equal to PWM2DUTY. At point D, Timer2 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(PA4) is continuously activated and P1D(PA3) is modulated. In the Reverse mode, P1C (PA7) is continuously activated and P1B(PA5) is modulated. In this mode, PA4, PA5, PA7 and PA3 must be set as outputs. The following timing diagram shows Full-Bridge Forward and Reverse condition. #### 3.13 RFC Mode AT8A54E1 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 14 AT8A54E1 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<sub>IH</sub> 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 29 RFC Block Diagram #### 3.14 IR Carrier The IR carrier will be generated after register bit IREN (IRCR[0]) is set to 1. Moreover, PB1 will become output pin automatically. When IREN is clear to 0, PB1 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 AT8A54E1 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 output data. When register bit IRCSEL (IRCR[2]) is 1, IR carrier will be present on pin PB1 when its output data is 0. When register bit IRCSEL 73 (IRCR[2]) is 0, IR carrier will be present on pin PB1 when its output data is 1. The polarity of IR carrier is shown in the following figure. Figure 30 Polarity of IR Carrier vs. Output Data ## 3.15 Comparator-Related Functions ## 3.15.1 Function Overview - Voltage Comparator; - Low Voltage Detection (LVD); - Built-in resistor voltage divider module to monitor power supply voltage VDD; - LVD interrupt ### 3.15.2 Voltage Comparator AT8A54E1 provides voltage comparator and internal reference voltage with various analog comparing mode. The comparator non-inverting and inverting input can share with GPIO. CMPEN (register PCON[2]) 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 31 Comparator block diagram 74 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 17 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 18 Inverting input select ## Comparator output can be polled by PCON1[6]. 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 PB1 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.15.3 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 64 voltage levels. When VDD level falls below Vref voltage, LVD flag will go from high to low, and set the register bit LVDIF=1. And when the comparator result differs from the previous value, a comparator interrupt is generated. This interrupt request will be serviced if LVDIE and GIE are set to 1. 75 Figure 32 Vref hardware connection & LVD block diagram The **Vref** is determined by RBIAS\_H, RBIAS\_L and LVDS[3:0]. The LVDS[3:0] is used to select one out of 64 reference voltages, the table shown below. | | Condition | | | | | | |-----------|------------------|----------------------|------------------|------------------|--|--| | | | V <sub>IN-</sub> = \ | Vref(V) | | | | | LVRS[3:0] | RBIAS[H:L]=[0:0] | RBIAS[H:L]=[1:0] | RBIAS[H:L]=[0:1] | RBIAS[H:L]=[1:1] | | | | 1111 | 0.145 | 0.233 | 0.053 | 0.092 | | | | 1110 | 0.148 | 0.239 | 0.058 | 0.099 | | | | 1101 | 0.154 | 0.252 | 0.063 | 0.109 | | | | 1100 | 0.160 | 0.258 | 0.071 | 0.122 | | | | 1011 | 0.167 | 0.268 | 0.078 | 0.134 | | | | 1010 | 0.174 | 0.281 | 0.086 | 0.149 | | | | 1001 | 0.182 | 0.289 | 0.095 | 0.164 | | | | 1000 | 0.191 | 0.308 | 0.110 | 0.181 | | | | 0111 | 0.199 | 0.321 | 0.118 | 0.204 | | | | 0110 | 0.207 | 0.333 | 0.127 | 0.218 | | | | 0101 | 0.215 | 0.346 | 0.131 | 0.226 | | | | 0100 | 0.230 | 0.371 | 0.148 | 0.256 | | | | 0011 | 0.250 | 0.403 | 0.170 | 0.293 | | | | 0010 | 0.273 | 0.440 | 0.196 | 0.338 | | | | 0001 | 0.301 | 0.484 | 0.226 | 0.390 | | | | 0000 | 0.316 | 0.509 | 0.244 | 0.419 | | | Table 19 The reference voltage Vref selection table Note: The deviation of Vref is ±0.1V. Note: RBIAS\_L and RBIAS\_H MUST be set as "00" before sleep mode or halt mode to prevent current leakage. Based on an internal reference voltage (Vref) generated by a series resistor divider, the comparator can be used to monitor the supply voltage. When the inverting input is set to the internal bandgap reference (0.65V) and the non-inverting input is connected to the internal resistor divider output (Vref), the comparator compares the supply voltage against the configured threshold. The figure 32 is Vref hardware connection & LVD block diagram. - The comparator output is 0 when the supply voltage is below the threshold. - The comparator output is 1 when the supply voltage is above the threshold. ## 3.15.4 Low Voltage Detector (LVD) AT8A54E1 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 PCON1[6]. The following table is LVD voltage select table. | RBIAS[H:L] | LVDS[3:0] | Voltage | |------------|-----------|---------| | 00 | 0000 | 1.9V | | 00 | 0001 | 2.0V | | 00 | 0010 | 2.2V | | 00 | 0011 | 2.4V | | 00 | 0100 | 2.6V | | 00 | 0101 | 2.8V | | 00 | 0110 | 2.9V | | 00 | 0111 | 3.0V | | 00 | 1000 | 3.15V | | 00 | 1001 | 3.30V | | 00 | 1010 | 3.45V | | 00 | 1011 | 3.60V | | 00 | 1100 | 3.75V | | 00 | 1101 | 3.90V | | 00 | 1110 | 4.05V | | 00 | 1111 | 4.15V | Table 20 LVD voltage select 77 #### Note: The hysteresis voltage (from low to high) of LVD is about 0.1V. In battery charging applications (detected voltage is from low to high). 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(@Fhosc=1MHz) to get correct LVD status by PCON1[6] ### 3.15.5 LVD Interrupt When VDD level falls below LVD voltage, LVD flag will go from high to low, and set the register bit LVDIF=1. And when the comparator result differs from the previous value, a comparator interrupt is generated. This interrupt request will be serviced if LVDIE and GIE are set to 1. ## 3.16 Watch-Dog Timer (WDT) There is an on-chip free-running oscillator in AT8A54E1 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 AT8A54E1 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 AT8A54E1 and dividing rate is from 1:2 to 1:256 if WDT time-out will interrupt AT8A54E1. 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. 78 ### 3.17 Interrupt AT8A54E1 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 8 hardware interrupts: - Timer0 overflow interrupt. - Timer1 underflow interrupt. - Timer2 underflow interrupt or CCP interrupt - Timer3 underflow interrupt. - WDT timeout interrupt. - PA/PB input change interrupt. - External 0 interrupt. - External 1 interrupt - LVD 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 AT8A54E1 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 AT8A54E1 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 AT8A54E1 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.17.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.17.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.17.3 Timer2 underflow interrupt or CCP interrupt Timer2 underflow (from 0x3FF to 0x00) or CCP will set register bit T2IF/CCPIF. This interrupt request will be serviced if T2IE/CCPIE and GIE are set to 1. ## 3.17.4 Timer3 Underflow Interrupt Timer3 underflow (from 0x3FF to 0x00) will set register bit T3IF. This interrupt request will be serviced if T3IE and GIE are set to 1. ## 3.17.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.17.6 PA/PB Input Change Interrupt When PAx, $0 \le x \le 7$ , PBy, $0 \le y \le 5$ 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 PB0 or PB1 is both set as level change interrupt and external interrupt, the external interrupt enable EIS0 or EIS1=1 will disable PB0 or PB1 level change operation. ## 3.17.7 External 0 Interrupt According to the configuration of EIS0=1 and INTEDG, the selected active edge on I/O pin PB0 will set register bit INT0IF and this interrupt request will be served if INT0IE and GIE are set to 1. #### 3.17.8 External 1 Interrupt According to the configuration of EIS1=1 and INTEDG, the selected active edge on I/O pin PB1 will set register bit INT1IF and this interrupt request will be served if INT1IE and GIE are set to 1. ## 3.17.9 LVD Interrupt When $V_{DD}$ level falls below LVD voltage, LVD flag will go 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.18 Oscillation Configuration Because AT8A54E1 is a dual-clock IC, there are high oscillation (F<sub>HOSC</sub>) and low oscillation (F<sub>LOSC</sub>) that can be selected as system oscillation (F<sub>OSC</sub>). The oscillators which could be used as F<sub>HOSC</sub> 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<sub>LOSC</sub> are internal low RC oscillator (I\_LRC) and external low crystal oscillator (E\_LXT). Figure 33 Oscillation Configuration of AT8A54E1 There are two configuration words to determine which oscillator will be used as F<sub>HOSC</sub>. When I\_HRC is selected as F<sub>HOSC</sub>, 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<sub>HOSC</sub> required external crystal whose frequency ranges from 8MHz to 20MHz, E\_HXT is recommended. If F<sub>HOSC</sub> 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<sub>LOSC</sub>. When I\_LRC is selected, its frequency is centered on 32768Hz. If F<sub>LOSC</sub> 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 81 output pin and input pin. PA7 is crystal output pin (Xout) and PA6 is crystal input pin (Xin). The dual-clock combinations of F<sub>HOSC</sub> and F<sub>LOSC</sub> 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 21 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 | Crystal Frequency (Hz) | 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 22 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 AT8A54E1 crystal pad built-in capacitance, which is about 5pF. For example, for crystal CL=12.5P, C1=C2=20pF is recommended. 82 Figure 34 Connection for External Crystal Oscillation Either F<sub>HOSC</sub> or F<sub>LOSC</sub> can be selected as system oscillation F<sub>OSC</sub> according to the value of register bit SELHOSC (OSCCR[0]). When SELHOSC is 1, F<sub>HOSC</sub> is selected as F<sub>OSC</sub>. When SELHOSC is 0, F<sub>LOSC</sub> is selected as F<sub>OSC</sub>. Once F<sub>OSC</sub> is determined, the instruction clock F<sub>INST</sub> can be F<sub>OSC</sub>/2 or F<sub>OSC</sub>/4 according to value of a configuration word. ## 3.19 Operating Mode AT8A54E1 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, AT8A54E1 will stop almost all operations except Timer0/Timer1/Timer2/Timer3 WDT in order to wake-up periodically. At Halt mode, AT8A54E1 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 35 Four Operating Modes #### 3.19.1 Normal Mode After any Reset Event is occurred and Reset Process is completed, AT8A54E1 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, AT8A54E1 will enter Normal mode, if Startup Clock=Slow, AT8A54E1 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, AT8A54E1 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 AT8A54E1 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.19.2 Slow Mode AT8A54E1 will enter Slow mode by writing 0 to register bit SELHOSC. At Slow mode, FLOSC is selected as system oscillation in order to save power consumption but still keep IC running. However, FHOSC will not be disabled automatically by AT8A54E1. 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 FHOSC at the same time, one must enter slow mode first, then disable FHOSC, 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]. 85 IC can switch to Normal mode by writing 1 to SELHOSC. ## 3.19.3 Standby Mode AT8A54E1 will enter Standby mode by writing 10b to register bits OPMD[1:0]. At Standby mode, however, FHOSC will not be disabled automatically by AT8A54E1 and user has to enter slow mode and write 1 to register bit STPHOSC in order to stop FHOSC oscillation. Most of AT8A54E1 peripheral modules are disabled but Timer can be still active if register bit T0EN/T1EN/T3EN is set to 1. Therefore AT8A54E1 can wake-up after Timer0/Timer1/Timer2/Timer3 is expired. The expiration period is determined by the register TMR0/TMR1[9:0]/TMR3[9:0], FINST and other configurations for Timer0/Timer1/Timer2/Timer3. - Instruction execution is stop and some peripheral modules may be active according to corresponding module enable bit. - F HOSC can be disabled by writing 1 to register bit STPHOSC. - The F<sub>LOSC</sub> is still active and running. - IC can wake-up from Standby mode if any of the following conditions: - (a) Timer0/Timer1/Timer2/Timer3 (overflow/underflow) interrupt - (b) WDT timeout interrupt - (c) PA/PB input change interrupt - (d) INT0/INT1 external interrupt is happened. - (e) LVD 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.19.4 Halt Mode AT8A54E1 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 AT8A54E1 can only wake-up by some specific events. Therefore, Halt mode is the most power saving mode provided by AT8A54E1. 86 - Instruction execution is stop and all peripheral modules are disabled. - F<sub>HOSC</sub> and F<sub>LOSC</sub> are both disabled automatically. - IC can wake-up from Halt mode if any of the following conditions: - (a) WDT timeout interrupt - (b) PA/PB input change interrupt - (c) INTO/INT1 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.19.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\*Fosc. And if no XT mode are selected, 16\*Fosc 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 Fhosc or Flosc is still running at Standby mode. Before AT8A54E1 enter Standby mode or Halt mode, user may execute instruction ENI. At this condition, AT8A54E1 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.19.6 Summary of Operating Mode The summary of four operating modes is described in the following table. | Mode | Normal | Slow | Standby | Halt | |-----------------------|---------------------|---------------------|----------------------------------------------------------------------------------------------------|---------------------------------------------------| | Fhosc | Enabled | STPHOSC | STPHOSC | Disabled | | F <sub>LOSC</sub> | Enabled | Enabled | Enabled | Disabled | | Instruction Execution | Executing | Executing | Stop | Stop | | Timer0/12//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 bit | Module enable bit | All disabled | | Wake-up Source | | - | - Timer0/12//3<br>overflow<br>- WDT timeout<br>- PA/PB input change<br>- INT0/1<br>- LVD interrupt | - WDT timeout<br>- PA/PB input change<br>- INT0/1 | Table 23 Summary of Operating Modes #### 3.20 Reset Process AT8A54E1 will enter Reset State and start Reset Process when one of following Reset Event is occurred: - Power-On Reset (POR) is occurred when V<sub>DD</sub> 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 | | 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 24 Summary of /TO & /PD Value and its Associated Event After Reset Event is released, AT8A54E1 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, AT8A54E1 will wait for further oscillator start-up time (OST) before it starts to execute program. OST=1 clock cycle of Fosc if the previous power-up time is 140us, OST=16 clock cycles of Fosc if the previous power-up time is 4.5ms, 18ms, 72ms or 288ms. Figure 36 Block diagram of on-chip reset circuit 88 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 37 Block Diagram of Reset Application # 4. Instruction Set AT8A54E1 provides 55 powerful instructions for all kinds of applications. | lunt | 0 | Р | Onenation | 0 | Fla. | |------------|--------|---------------|------------------------------|--------|------| | Inst. | 1 | 1 2 Operation | | Cyc. | Flag | | Arithmetic | Ins | truct | tions | | | | ANDAR | R | d | dest = ACC & R | 1 | Z | | IORAR | R | d | dest = ACC R | 1 | Z | | XORAR | R | d | dest = ACC ⊕ R | 1 | Z | | ANDIA | i | | ACC = ACC & i | 1 | Z | | IORIA | i | | ACC = ACC i | 1 | Z | | XORIA | i | | ACC = ACC ⊕ i | 1 | Z | | RRR | R | d | Rotate right R | 1 | С | | RLR | R | d | Rotate left R | 1 | С | | BSR | R | bit | Set bit in R | 1 | - | | BCR | R | bit | Clear bit in R | 1 | - | | INCR | R | d | Increase R | 1 | Z | | DECR | R | d | Decrease R | 1 | Z | | COMR | R | d | dest = ~R | 1 | Z | | Conditiona | al In: | struc | ctions | | | | BTRSC | R | bit | Test bit in R, skip if clear | 1 or 2 | - | | BTRSS | R | bit | Test bit in R, skip if set | 1 or 2 | - | | INCRSZ | R | d | Increase R, skip if 0 | 1 or 2 | - | | DECRSZ | R | d | Decrease R, skip if 0 | 1 or 2 | - | | Data Trans | sfer | Instr | ructions | | | | MOVAR | R | | Move ACC to R | 1 | - | | MOVR | R | d | Move R | 1 | Z | | MOVIA | i | | Move immediate to ACC | 1 | - | | SWAPR | R | d | Swap halves R | 1 | - | | IOST | F | | Load ACC to F-page SFR | 1 | - | | IOSTR | F | | Move F-page SFR to ACC | 1 | | | SFUN | S | | Load ACC to S-page SFR | 1 | - | | SFUNR | S | | Move S-page SFR to ACC | 1 | - | | TOMD | | | Load ACC to T0MD | 1 | - | | T0MDR | | | Move T0MD to ACC | 1 | - | | TABLEA | | | Read ROM | 2 | _ | | Arithmetic Instructions | Inst. | 0 | Р | Operation Cus | | e Flog | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------|------|-----------------------------|------|----------|--| | ADDAR R d dest = R + ACC 1 Z, DC, C SUBAR R d dest = R + (~ACC) 1 Z, DC, C ADCAR R d dest = R + (~ACC) + C 1 Z, DC, C SBCAR R d dest = R + (~ACC) + C 1 Z, DC, C ADDIA i ACC = i + (ACC) + C 1 Z, DC, C SUBIA i ACC = i + (ACC) + C 1 Z, DC, C ADCIA i ACC = i + (ACC) + C 1 Z, DC, C SBCIA i ACC = i + (ACC) + C 1 Z, DC, C SBCIA i ACC = i + (ACC) + C 1 Z, DC, C SBCIA i ACC = i + (ACC) + C 1 Z, DC, C SBCIA i ACC = i + (ACC) + C 1 Z, DC, C CALRA Decimal adjust for ACC 1 Z, C CLRA Clear ACC 1 Z CLRA Clear ACC 1 Z CLRWDT Clear R | inst. | 1 | 2 | Operation | Cyc. | Flag | | | SUBAR R d dest = R + (~ACC) 1 Z, DC, C ADCAR R d dest = R + ACC + C 1 Z, DC, C SBCAR R d dest = R + (~ACC) + C 1 Z, DC, C ADDIA i ACC = I + ACC 1 Z, DC, C SUBIA i ACC = I + ACC + C 1 Z, DC, C ADCIA i ACC = I + ACC + C 1 Z, DC, C SBCIA i ACC = I + ACC + C 1 Z, DC, C SBCIA i ACC = I + (~ACC) + C 1 Z, DC, C SBCIA i ACC = I + (~ACC) + C 1 Z, DC, C SBCIA i ACC = I + (~ACC) + C 1 Z, DC, C SBCIA i ACC = I + (~ACC) + C 1 Z, DC, C SBCIA i ACC = I + ACC + C 1 Z, DC, C CBALA Clear ACC 1 Z, C CLRA Clear ACC 1 Z CLAR Clear ACC | Arithmetic | Ins | truc | tions | | | | | ADCAR R d dest = R + ACC + C 1 Z, DC, C SBCAR R d dest = R + (~ACC) + C 1 Z, DC, C ADDIA i ACC = I + ACC 1 Z, DC, C SUBIA i ACC = I + ACC + C 1 Z, DC, C ADCIA i ACC = I + ACC + C 1 Z, DC, C SBCIA i ACC = I + (~ACC) + C 1 Z, DC, C SBCIA i ACC = I + (~ACC) + C 1 Z, DC, C SBCIA i ACC = I + (~ACC) + C 1 Z, DC, C SBCIA i ACC = I + ACC + C 1 Z, DC, C SBCIA i ACC = I + ACC + C 1 Z, DC, C SBCIA i ACC = I + ACC + C 1 Z, DC, C CMPAR R Compare R with ACC 1 Z, C CLRA Clear ACC 1 Z C CLRW Do operation 1 Z TO, (PD CLRWDT Cle | ADDAR | R | d | dest = R + ACC | 1 | Z, DC, C | | | SBCAR R d dest = R + (~ACC) + C 1 Z, DC, C ADDIA i ACC = I + ACC 1 Z, DC, C SUBIA i ACC = i + (~ACC) 1 Z, DC, C ADCIA i ACC = i + (~ACC) + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C CBCIA COLORDA DECIMAL ACC 1 Z, DC, C CLRA Clear ACC 1 Z CLRA Clear ACC 1 Z CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Disable interrupt 1 - | SUBAR | R | d | dest = R + (~ACC) | 1 | Z, DC, C | | | ADDIA i ACC = I + ACC 1 Z, DC, C SUBIA i ACC = i + (~ACC) 1 Z, DC, C ADCIA i ACC = i + ACC + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C BBCIA i ACC = i + (~ACC) + C 1 Z, DC, C DAA Decimal adjust for ACC 1 C CMPAR R Compare R with ACC 1 Z, C CLRA Clear ACC 1 Z CLRR Clear R 1 Z Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RETI Return from subroutine 2 - RETIE Return from interrupt and enable interrupt RETI Return from interrupt and enable interrupt RETIA i Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - | ADCAR | R | d | dest = R + ACC + C | 1 | Z, DC, C | | | SUBIA i ACC = i + (~ACC) 1 Z, DC, C ADCIA i ACC = i + ACC + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C DAA Decimal adjust for ACC 1 C CMPAR R Compare R with ACC 1 Z, C CLRA Clear ACC 1 Z CLRA Clear ACC 1 Z CLRR 1 Z D Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIA i Return, place immediate in ACC 2 - | SBCAR | R | d | dest = R + (~ACC) + C | 1 | Z, DC, C | | | ADCIA i ACC = i + ACC + C 1 Z, DC, C SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C DAA Decimal adjust for ACC 1 C CMPAR R Compare R with ACC 1 Z, C CLRA Clear ACC 1 Z CLRR Clear R 1 Z Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt RETIA i Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - | ADDIA | i | | ACC = I + ACC | 1 | Z, DC, C | | | SBCIA i ACC = i + (~ACC) + C 1 Z, DC, C DAA Decimal adjust for ACC 1 C CMPAR R Compare R with ACC 1 Z, C CLRA Clear ACC 1 Z Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt 2 - RETIA i Return, place immediate in ACC 2 - CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - | SUBIA | i | | ACC = i + (~ACC) | 1 | Z, DC, C | | | DAA Decimal adjust for ACC 1 C. CMPAR R Compare R with ACC 1 Z, C. CLRA Clear ACC 1 Z CLRR Clear R 1 Z Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - | ADCIA | i | | ACC = i + ACC + C | 1 | Z, DC, C | | | CMPAR R Compare R with ACC 1 Z, C CLRA Clear ACC 1 Z CLRR Clear R 1 Z Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt RETIE Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - CALL adr Call subroutine 2 - CALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - | SBCIA | i | | ACC = i + (~ACC) + C | 1 | Z, DC, C | | | CLRA Clear ACC 1 Z CLRR Clear R 1 Z Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt 2 - RETIA i Return, place immediate in ACC 2 - CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - GOTO adr Call subroutine 2 - LCALL adr Call subroutine 2 - | DAA | | | Decimal adjust for ACC | 1 | С | | | CLRR Clear R 1 Z Other Instructions NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt RETIE Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine | CMPAR | R | | Compare R with ACC | 1 | Z, C | | | NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt I Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | CLRA | | | Clear ACC | 1 | Z | | | NOP No operation 1 - SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt RETIA i Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | CLRR | | | Clear R | 1 | Z | | | SLEEP Go into Halt mode 1 /TO, /PD CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 3 - INT Software Interrupt 2 - RET Return from subroutine 2 - RETIE Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - CALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - | Other Insti | ructi | ions | | | | | | CLRWDT Clear Watch-Dog Timer 1 /TO, /PD ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt RETIA i Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - | NOP | | | No operation | 1 | - | | | ENI Enable interrupt 1 - DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt 2 - RETIA i Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | SLEEP | | | Go into Halt mode | 1 | /TO, /PD | | | DISI Disable interrupt 1 - INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt 2 - RETIA i Return, place immediate in ACC 2 - CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | CLRWDT | | | Clear Watch-Dog Timer | 1 | /TO, /PD | | | INT Software Interrupt 3 - RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt 2 - RETIA i Return, place immediate in ACC 2 - CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | ENI | | | Enable interrupt | 1 | - | | | RET Return from subroutine 2 - RETIE Return from interrupt and enable interrupt 2 - RETIA i Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | DISI | | | Disable interrupt | 1 | - | | | RETIE Return from interrupt and enable interrupt Return, place immediate in ACC CALLA Call subroutine by ACC CALL GOTOA unconditional branch by ACC CALL adr Call subroutine 2 - | INT | | | Software Interrupt | 3 | - | | | RETIE enable interrupt 2 - Return, place immediate in ACC CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | RET | | | Return from subroutine | 2 | - | | | enable interrupt RETIA i Return, place immediate in ACC CALLA Call subroutine by ACC CALL GOTOA unconditional branch by ACC CALL adr Call subroutine 2 - CALL adr Call subroutine 2 - LCALL adr Call subroutine 2 - CALL adr Call subroutine 2 - CALL adr Call subroutine 2 - CALL adr Call subroutine 2 - | DETIE | | | Return from interrupt and | 0 | | | | RETIA i ACC 2 - CALLA Call subroutine by ACC 2 - GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | REIIE | | | enable interrupt | 2 | - | | | ACC CALLA Call subroutine by ACC 2 GOTOA unconditional branch by ACC CALL adr Call subroutine 2 GOTO adr unconditional branch 2 LCALL adr Call subroutine 2 - | DETIA | | | Return, place immediate in | • | | | | GOTOA unconditional branch by ACC 2 - CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | RETIA | i | | ACC | 2 | - | | | CALL adr Call subroutine 2 - GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | CALLA | С | | Call subroutine by ACC | 2 | - | | | GOTO adr unconditional branch 2 - LCALL adr Call subroutine 2 - | GOTOA | | | unconditional branch by ACC | 2 | - | | | LCALL adr Call subroutine 2 - | CALL | a | dr | Call subroutine | 2 | - | | | | GOTO | а | dr | unconditional branch | 2 | - | | | LGOTO adr unconditional branch 2 - | LCALL | a | dr | Call subroutine | 2 | - | | | | LGOTO | a | dr | unconditional branch | 2 | - | | Table 25 Instruction Set 90 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 \sim 0x1F$ . 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. 91 /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 \le R \le 127$<br>d = 0, 1. | Operand: | $0 \le R \le 127$<br>d = 0, 1. | | Operation: | $R + ACC + C \rightarrow dest$ | Operation: | ACC + R → 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 | Description: | Add the contents of ACC and R. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R. | | Cycle | R.<br>1 | Cycle: | 1 | | Example: | ADCAR R, d before executing instruction: ACC=0x12, R=0x34, C=1, d=1, after executing instruction: R=0x47, ACC=0x12, C=0. | Example: | ADDAR R, d before executing instruction: ACC=0x12, R=0x34,C=1, d=1, after executing instruction: 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 \le i < 255$ | | Operation: | $ACC + i + C \rightarrow ACC$ | Operation: | $ACC + i \rightarrow 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 | Description: | Add the contents of ACC with the 8-bit immediate data i. The result is placed in ACC. | | 0 1 | ACC. | Cycle: | 1 | | Cycle: | 1 | Example: | ADDIA i | | Example: | ADCIA i before executing instruction: ACC=0x12, i=0x34, C=1, after executing instruction: ACC=0x47, C=0. | | before executing instruction: ACC=0x12, i=0x34, C=1, after executing instruction: ACC=0x46, C=0. | | ANDAR | AND ACC and R | |------------------|---------------------------------------------------------------------------------------------------------------------------| | Syntax: | ANDAR R, d | | Operand: | $0 \le R \le 127$<br>d = 0, 1. | | Operation: | ACC & R → dest | | Status affected: | Z | | 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. | | Cycle: | 1 | | Example: | ANDAR R, d before executing instruction: ACC=0x5A, R=0XaF, d=1. after executing instruction: R=0x0A, ACC=0x5A, Z=0. | | BCR | Clear Bit in R | |------------------|----------------------------------------------------------------------------------------------| | Syntax: | BCR R, bit | | Operand: | $0 \le R \le 127$ $0 \le bit \le 7$ | | Operation: | $0 \rightarrow R[bit]$ | | Status affected: | | | Description: | Clear the bit <sup>th</sup> position in R. | | Cycle: | 1 | | Example: | BCR R, B2 before executing instruction: R=0x5A, B2=0x3, after executing instruction: R=0x52. | | ANDIA | AND Immediate with ACC | |------------------|-----------------------------------------------------------------------------------------------------------| | Syntax: | ANDIA i | | Operand: | $0 \le 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 before executing instruction: ACC=0x5A, i=0XaF, after executing instruction: ACC=0x0A, Z=0. | | BSR | Set Bit in R | |------------------|----------------------------------------------------------------------------------------------| | Syntax: | BSR R, bit | | Operand: | $ 0 \le R \le 127 \\ 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 before executing instruction: R=0x5A, B2=0x2, after executing instruction: R=0x5E. | | BTRSC | Test Bit in R and Skip if Clear | CALL | Call Subroutine | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | BTRSC R, bit | Syntax: | CALL adr | | Operand: | $0 \le R \le 127$ $0 \le bit \le 7$ | Operand: | 0 ≤ adr < 255 | | Operation: | Skip next instruction, if R[bit] = 0. | Operation: | PC + 1 $\rightarrow$ Top of Stack<br>{PCHBUF, adr} $\rightarrow$ PC | | Status affected: | - | Status affected: | | | Description: | If R[bit] = 0, the next instruction which is already fetched is discarded and a NOP is executed instead. Therefore it makes this instruction a two-cycle instruction. | Description: | The return address (PC + 1) is pushed onto top of Stack. The 8-bit immediate address adr is loaded into PC[7:0] and PCHBUF[2:0] is loaded into PC[10:8]. | | Cycle: | 1 or 2(skip) | Cycle: | 2 | | Example: | BTRSC R, B2 Instruction1 Instruction2 before executing instruction: R=0x5A, B2=0x2, after executing instruction: because R[B2]=0, instruction1 will not be executed, the program will start execute instruction from instruction2. | Example: | CALL SUB before executing instruction: PC=A0. Stack pointer=1 after executing instruction: PC=address of SUB, Stack[1] = A0+1, Stack pointer=2. | | BTRSS | Test Bit in R and Skip if Set | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | BTRSS R, bit | | Operand: | $\begin{array}{l} 0 \leq R \leq 127 \\ 0 \leq \text{bit} \leq 7 \end{array}$ | | Operation: | Skip next instruction, if R[bit] = 1. | | Status affected: | | | Description: | If R[bit] = 1, the next instruction which is already fetched is discarded and a NOP is executed instead. Therefore it makes this instruction a two-cycle instruction. | | Cycle: | 1 or 2(skip) | | Example: | BTRSS R, B2 Instruction2 Instruction3 before executing instruction: R=0x5A, B2=0x3, after executing instruction: because R[B2]=1, instruction2 will not be executed, the program will start execute instruction from instruction3. | | CALLA | Call Subroutine | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | CALLA | | Operand: | | | Operation: | PC + 1 $\rightarrow$ Top of Stack<br>{TBHP, ACC} $\rightarrow$ PC | | Status affected: | J | | Description: | The return address (PC + 1) is pushed onto top of Stack. The contents of TBHP[2:0] is loaded into PC[10:8] and ACC is loaded into PC[7:0]. | | Cycle: | 2 | | Example: | CALLA before executing instruction: TBHP=0x02, ACC=0x34. PC=A0. Stack pointer=1. after executing instruction: PC=0x234, Stack[1]=A0+1, Stack pointer=2 | | CLRA | Clear ACC | CLRWDT | Clear Watch-Dog Timer | |--------------------|-------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------| | Syntax: | CLRA | Syntax: | CLRWDT | | Operand: | | Operand: | | | Operation: | $ 00h \rightarrow ACC \\ 1 \rightarrow Z $ | Operation: | 00h → WDT,<br>00h → WDT prescaler | | Status affected: | Z | | 1 → /TO<br>1 → /PD | | Description: | ACC is clear and Z is set to 1. | Status affected: | /TO, /PD | | Cycle:<br>Example: | Cycle: 1 Example: CLRA before executing instruction: | Description: | Executing CLRWDT will reset WDT, Prescaler0 if it is assigned to WDT. Moreover, status bits /TO and /PD will be set to 1. | | | after executing instruction: ACC=0x00, Z=1. | Cycle: | 1 | | | AGG-0X00, Z=1. | Example: | CLRWDT before executing instruction: /TO=0 after executing instruction: /TO=1 | | CLRR | Clear R | COMR | Complement R | |-------------------------------|--------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------| | Syntax: | CLRR R | Syntax: | COMR R, d | | Operand: | $0 \le R \le 127$ | Operand: | $0 \le R \le 127$ | | Operation: | 00h → R | | d = 0, 1. | | | $1 \rightarrow Z$ | Operation: | ~R → dest | | Status | Z | Status affected: | Z | | affected: Description: Cycle: | The content of R is clear and Z is set to 1. | Description: | The content of R is complemented. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R. | | Example: | CLRR R | Cycle: | 1 | | p.o. | before executing instruction: R=0x55, Z=0. after executing instruction: R=0x00, Z=1. | Example: | COMR, d before executing instruction: R=0XA6, d=1, Z=0. after executing instruction: R=0x59, Z=0. | | CMPAR | Compare ACC and R | DECR | Decrease R | |-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | Syntax: | CMPAR R | Syntax: | DECR R, d | | Operand: | $0 \le R \le 127$ | Operand: | 0 ≤ R ≤ 127 | | Operation: | R— ACC → (No restore) | | d = 0, 1. | | Status affected: | Z, C | Operation: | R 1 → dest | | Description: | Compare ACC and R by | Status affected: | Z | | subtracting ACC from R with 2's complement representation. The content of ACC and R is not changed. | 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: | 1 | | Cycle: | 1 | Example: | DECR R, d | | Example: | CMPAR R before executing instruction: R=0x34, ACC=12, Z=0, C=0. after executing instruction: R=0x34, ACC=12, Z=0, C=1. | · | before executing instruction:<br>R=0x01, d=1, Z=0.<br>after executing instruction:<br>R=0x00, Z=1. | | DAA | Convert ACC Data Format from Hexadecimal | DECRSZ | Decrease R, Skip if 0 | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | DAA | Syntax: | DECRSZ R, d | | Operand: | | Operand: | 0 ≤ R ≤ 127 | | Operation: | $ACC(hex) \rightarrow ACC(dec)$ | | d = 0, 1. | | Status affected: | С | Operation: | $R-1 \rightarrow 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 must be placed immediately after addition operation if decimal format is required. Please note that interrupt should be disabled before addition instruction and enabled after DAA instruction to avoid unexpected result. | Description: | Decrease R first. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R. If result is 0, the next instruction which is already fetched is discarded and a NOP is executed instead. Therefore it makes this instruction a two-cycle instruction. | | Cycle: | 1 | Cycle: | 1 or 2(skip) | | Example: | DISI ADDAR R,d DAA ENI before executing instruction: ACC=0x28, R=0x25, d=0. after executing instruction: ACC=0x53, C=0. | Example: | DECRSZ R, d instruction2 instruction3 before executing instruction: R=0x1, d=1, Z=0. after executing instruction: R=0x0, Z=1, and instruction will skip instruction2 execution because the operation result is zero. | | DISI | Disable Interrupt Globally | GOTO | Unconditional Branch | |------------------|---------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------| | Syntax: | DISI | Syntax: | GOTO adr | | Operand: | | Operand: | 0 ≤ adr < 511 | | Operation: | Disable Interrupt, 0 → GIE | Operation: | {PCHBUF, adr} → PC | | Status affected: | - 4 | Status affected: | | | Description: | GIE is clear to 0 in order to disable all interrupt requests. | Description: | GOTO is an unconditional branch instruction. The 9-bit immediate | | Cycle: | 1 | | address adr is loaded into PC[8:0] and PCHBUF[2:1] is | | Example: | DISI | | loaded into PC[10:9]. | | | before executing instruction: GIE=1, | Cycle: | 2 | | | After executing instruction: GIE=0. | Example: | GOTO Level before executing instruction: PC=A0. after executing instruction: PC=address of Level. | | ENI | Enable Interrupt Globally | GOTOA | Unconditional Branch | |---------------------------|------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------| | Syntax: | ENI | Syntax: | GOTOA | | Operand: | | Operand: | | | Operation: | Enable Interrupt, $1 \rightarrow GIE$ | Operation: | $\{TBHP, ACC\} \rightarrow PC$ | | Status | | Status affected: | <del>-</del> | | affected:<br>Description: | GIE is set to 1 in order to enable all interrupt requests. | Description: | GOTOA is an unconditional branch instruction. The content of TBHP[2:0] is loaded into | | Cycle: | 1 | | PC[10:8] and ACC is loaded into PC[7:0]. | | Example: | ENI | Cycle: | 2 | | | before executing instruction: GIE=0, | Example: | GOTOA | | | After executing instruction: GIE=1. | | before executing instruction: PC=A0. TBHP=0x02, ACC=0x34. | | | | | after executing instruction: | | INCR | Increase R | INT | Software Interrupt | |------------------|------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------| | Syntax: | INCR R, d | Syntax: | INT | | Operand: | $0 \le R \le 127$<br>d = 0, 1. | Operand: | DC + 1 > Top of Stock | | Operation: | R + 1 → dest. | Operation: | PC + 1 → Top of Stack,<br>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 address (PC + 1) is pushed onto the Stack. The address 0x001 is | | Cycle: | 1 | | loaded into PC[10:0]. | | Example: | INCR R, d | Cycle: | 3 | | | before executing instruction: R=0XfF, d=1, Z=0. after executing instruction: R=0x00, Z=1. | Example: | INT before executing instruction: PC=address of INT code after executing instruction: PC=0x01 | | INCRSZ | Increase R, Skip if 0 | IORAR | OR ACC with R | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | Syntax: | INCRSZ R, d | Syntax: | IORAR R, d | | Operand: | $0 \le R \le 127$<br>d = 0, 1. | Operand: | $0 \le R \le 127$<br>d = 0, 1. | | Operation: | $R + 1 \rightarrow dest$ , | Operation: | ACC R → dest | | | Skip if result = 0 | Status affected: | Z | | Status<br>affected:<br>Description: | Increase R first. If d is 0, the result | Description: | OR ACC with R. If d is 0, the result is stored in ACC. If d is 1, the result is stored back to R. | | · | is stored in ACC. If d is 1, the result is stored back to R. | Cycle: | 1 | | If result is stored back to R. If result is 0, the next instruction which is already fetched is discarded and a NOP is executed instead. Therefore it makes this instruction a two-cycle instruction. | Example: | IORAR R, d before executing instruction: R=0x50, ACC=0XaA, d=1, Z=0. after executing instruction: | | | Cycle: | 1 or 2(skip) | | R=0XfA, ACC=0XaA, Z=0. | | Example: | instruction2, instruction3. before executing instruction: R=0XfF, d=1, Z=0. after executing instruction: R=0x00, Z=1. And the program will skip instruction2 execution because the operation result is zero. | | | | IORIA | OR Immediate with ACC | IOSTR | Move F-page SFR to ACC | |------------------|----------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------| | Syntax: | IORIA i | Syntax: | IOSTR F | | Operand: | $0 \le i < 255$ | Operand: | $5 \leq F \leq 15$ | | Operation: | ACC i→ACC | Operation: | F-page SFR → ACC | | Status affected: | Z | Status affected: | | | | OR ACC with 8-bit immediate | Description: | Move F-page SFR F to ACC. | | | data i. The result is stored in ACC. | Cycle: | 1 | | Cycle: | 1 | Example: | IOSTR F | | Example: | IORIA i before executing instruction: i=0x50, ACC=0XaA, Z=0. after executing instruction: ACC=0XfA, Z=0. | | before executing instruction:<br>F=0x55, ACC=0XaA.<br>after executing instruction:<br>F=0x55, ACC=0x55. | | Load F-page SFR from ACC | LCALL | Call Subroutine | |----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IOST F | Syntax: | LCALL adr | | 5 ≤ F≤ 15 | Operand: | $0 \le adr \le 2047$ | | ACC → F-page SFR | Operation: | PC + 1 → Top of Stack, | | | | $adr \rightarrow PC[10:0]$ | | F-page SFR F is loaded by | Status affected: | - | | content of ACC. | Description: | The return address (PC + 1) is | | 1 | | pushed onto top of Stack. The 11-bit immediate address adr is | | IOST F | | loaded into PC[10:0]. | | before executing instruction:<br>F=0x55, ACC=0XaA. | Cycle: | 2 | | after executing instruction: | Example: | LCALL SUB | | F=0XaA, ACC=0XaA. | | before executing instruction: PC=A0. Stack level=1 after executing instruction: PC=address of SUB, Stack[1]= A0+1, Stack pointer =2. | | | IOST F 5 ≤ F≤ 15 ACC→F-page SFR F-page SFR F is loaded by content of ACC. 1 IOST F before executing instruction: F=0x55, ACC=0XaA. | IOST F Syntax: $5 \le F \le 15$ Operand: ACC → F-page SFR Operation: Status affected: F-page SFR F is loaded by content of ACC. Description: 1 IOST F before executing instruction: Example: | | LGOTO | Unconditional Branch | |---------------------|---------------------------------------------------------------------------------------------------------| | Syntax: | LGOTO adr | | Operand: | $0 \le adr \le 2047$ | | Operation: | $adr \rightarrow PC[10:0].$ | | Status<br>affected: | - | | Description: | LGOTO is an unconditional branch instruction. The 11-bit immediate address adr is loaded into PC[10:0]. | | Cycle: | 2 | | Example: | LGOTO Level before executing instruction: PC=A0. after executing instruction: PC=address of Level. | | MOVIA | Move Immediate to ACC | |------------------|------------------------------------------------------------------------------------------------| | Syntax: | MOVIA i | | Operand: | $0 \leq i < 255$ | | Operation: | $i \rightarrow ACC$ | | Status affected: | | | Description: | The content of ACC is loaded with 8-bit immediate data i. | | Cycle: | 1 | | Example: | MOVIA i before executing instruction: i=0x55, ACC=0XaA. after executing instruction: ACC=0x55. | | MOVAR | Move ACC to R | |---------------------|--------------------------------------------------------------------------------------------------------| | Syntax: | MOVAR R | | Operand: | $0 \le R \le 127$ | | Operation: | $ACC \rightarrow R$ | | Status<br>affected: | | | Description: | Move content of ACC to R. | | Cycle: | 1 | | Example: | MOVAR R before executing instruction: R=0x55, ACC=0XaA. after executing instruction: R=0XaA, ACC=0XaA. | | Syntax: | MOVR R, d | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Operand: | $0 \le R \le 127$<br>d = 0, 1. | | Operation: | R→dest | | Status affected: | Z | | 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 before executing instruction: R=0x0, ACC=0XaA, Z=0, d=0. after executing instruction: R=0x0, ACC=0x00, Z=1. | Move R to ACC or R MOVR | NOP | No Operation | RETIA | Return with Data in ACC | |--------------------|--------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | NOP | Syntax: | RETIA i | | Operand: | - | Operand: | $0 \le i < 255$ | | Operation: | No operation. | Operation: | $i \rightarrow ACC$ , | | Status affected: | | | Top of Stack $\rightarrow$ PC | | Description: | No operation. | Status affected: | | | Cycle:<br>Example: | | Description: | ACC is loaded with 8-bit immediate data i and PC is loaded from top of Stack as return address. | | | NOP | Cycle: | 2 | | | before executing instruction: PC=A0 after executing instruction: PC=A0+1 | Example: | RETIA i before executing instruction: GIE=0, Stack pointer =2. i=0x55, ACC=0XaA. after executing instruction: GIE=1, PC=Stack[2], Stack pointer =1. ACC=0x55. | | RETIE | Return from Interrupt and Enable Interrupt Globally | RET | Return from Subroutine | |------------------|-----------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------| | Syntax: | RETIE | Syntax: | RET | | Operand: | | Operand: | <u>-</u> | | Operation: | Top of Stack $\rightarrow$ PC | Operation: | Top of Stack $\rightarrow$ PC | | <b>.</b> | 1 → GIE | Status affected: | - | | Status affected: | | Description: | PC is loaded from top of Stack | | Description: | The PC is loaded from top of Stack as return address and GIE is set to 1. | Cycle: | as return address. | | | 15 561 10 1. | | _ | | Cycle: | 2 | Example: | RET | | Example: | RETIE before executing instruction: GIE=0, Stack level=2. after executing instruction: GIE=1, PC=Stack[2], Stack pointer=1. | | before executing instruction: Stack level=2. after executing instruction: PC=Stack[2], Stack level=1. | | RLR | Rotate Left R Through Carry | |------------|--------------------------------------------------------------------------------| | Syntax: | RLR R, d | | Operand: | $0 \le R \le 127$<br>d = 0, 1. | | Operation: | $C \rightarrow dest[0], R[7] \rightarrow C,$<br>$R[6:0] \rightarrow dest[7:1]$ | | C | | | | | | | | | | |---|----|----|----|----|----|----|----|----|---| | | | | | F | ? | | | | | | | b7 | b6 | b5 | b4 | b3 | b2 | bl | ь0 | • | Status C affected: Description: The content of R is rotated one bit to the left through flag Carry. If d is 0, the result is placed in ACC. If d is 1, the result is stored back to R. Cycle: 1 Example: RLR R, d before executing instruction: R=0XA5, d=1, C=0. after executing instruction: R=0x4A, C=1. ## RRR Rotate Right R Through Carry Syntax: RRR R, d Operand: $0 \le R \le 127$ d = 0, 1. Operation: $C \rightarrow \text{dest}[7], R[7:1] \rightarrow \text{dest}[6:0],$ $R[0] \rightarrow C$ Status C affected: Description: The content of R is rotated one bit to the right through flag Carry. If d is 0, the result is placed in ACC. If d is 1, the result is stored back to R. Cycle: 1 Example: RRR R, d before executing instruction: R=0XA5, d=1, C=0. after executing instruction: R=0x52, C=1. | SBCAR | Subtract ACC and Carry from R | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | SBCAR R, d | | Operand: | $0 \le R \le 127$<br>d = 0, 1. | | Operation: | $R + (\sim ACC) + C \rightarrow dest$ | | Status affected: | Z, DC, C | | Description: | Subtract ACC and Carry from R with 2's complement representation. If d is 0, the result is placed in ACC. If d is 1, the result is stored back to R. | | Cycle: | 1 | | Example: | SBCAR R, d | | | (a) before executing instruction: R=0x05, ACC=0x06, d=1, C=0, after executing instruction: R=0XfE, C=0. (-2) | | | (b) before executing instruction: R=0x05, ACC=0x06, d=1, C=1, after executing instruction: R=0XfF, C=0. (-1)I) before executing instruction: R=0x06, ACC=0x05, d=1, C=0, after executing instruction: R=0x00, C=1. (-0), Z=1. (d) before executing instruction: R=0x06, ACC=0x05, d=1, C=1. | | | after executing instruction: | R=0x1, C=1. (+1) | SBCIA | Subtract ACC and Carry from Immediate | SFUNR | Move S-page SFR to ACC | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------| | Syntax: | SBCIA i | Syntax: | SFUNR S | | Operand: | 0 ≤ i < 255 | Operand: | $0 \le S \le 31$ | | Operation: | i + (~ACC) + C → dest | Operation: | S-page SFR → ACC | | Status affected: | Z, DC, C | Status affected: | | | Description: | Subtract ACC and Carry from 8-bit immediate data i with 2's complement representation. The result is placed in ACC. | Description: Cycle: Example: | Move S-page SFR S to ACC. 1 SFUNR S before executing instruction: | | Cycle:<br>Example: | SBCIA i (a) before executing instruction: i=0x05, ACC=0x06, C=0, after executing instruction: ACC=0xFE, C=0. (-2) (b) before executing instruction: i=0x05, ACC=0x06, C=1, after executing instruction: ACC=0xFF, C=0. (-1) (c) before executing instruction: i=0x06, ACC=0x05, C=0, after executing instruction: ACC=0x00, C=1. (-0), Z=1. | | S=0x55, ACC=0xAA. after executing instruction: S=0x55, ACC=0x55. | | | (d) before executing instruction: | SLEEP | Enter Halt Mode | | | i=0x06, ACC=0x05, C=1,<br>after executing instruction:<br>ACC=0x1, C=1. (+1) | Syntax: Operand: Operation: | SLEEP 00h $\rightarrow$ WDT, 00h $\rightarrow$ WDT prescaler 1 $\rightarrow$ /TO 0 $\rightarrow$ /PD | | SFUN | Load S-page SFR from ACC | Status affected: | /TO, /PD | | Syntax: | SFUN S | Description: | WDT and Prescaler0 are clear | | Operand: | 0 ≤ S ≤ 31 | | to 0. /TO is set to 1 and /PD is clear to 0. | | Operation: | ACC → S-page SFR | | IC enter Halt mode. | | Status affected: | - | Cycle: | 1 | | Description: Cycle: Example: | S-page SFR S is loaded by content of ACC. 1 SFUN S | Example: | SLEEP before executing instruction: /PD=1, /TO=0. after executing instruction: | | | before executing instruction:<br>S=0x55, ACC=0xAA.<br>after executing instruction:<br>S=0xAA, ACC=0xAA. | | /PD=0, /TO=1. | | SUBAR | Subtract ACC from R | SWAPR | Swap High/Low Nibble in R | | | |---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------|--|--| | Syntax: | SUBAR R, d | Syntax: | SWAPR R, d | | | | Operand: | $0 \le R \le 127$<br>d = 0, 1. | Operand: | $0 \le R \le 127$<br>d = 0, 1. | | | | Operation:<br>Status | $R - ACC \rightarrow dest$<br>Z, DC, C | Operation: | $R[3:0] \rightarrow dest[7:4].$ $R[7:4] \rightarrow dest[3:0]$ | | | | affected:<br>Description: | Subtract ACC from R with 2's complement representation. If d is 0, the result is placed in ACC. If d | Status affected:<br>Description: | <br>The high nibble and low nibble<br>of R is exchanged. If d is 0, the | | | | Cycle: | is 1, the result is stored back to R. | | result is placed in ACC. If d is 1, the result is stored back to R. | | | | Example: | SBCAR R, d | Cycle: | 1 | | | | | (a) before executing instruction: R=0x05, ACC=0x06, d=1, after executing instruction: R=0xFF, C=0. (-1) (b) before executing instruction: R=0x06, ACC=0x05, d=1, after executing instruction: R=0x01, C=1. (+1) | Example: | SWAPR R, d before executing instruction: R=0xA5, d=1. after executing instruction: R=0x5A. | | | | SUBIA | Subtract ACC from Immediate | TABLEA | Read ROM data | |---------------------|-------------------------------------------------------------|------------------|---------------------------------------------------------| | Syntax: | SUBIA i | Syntax: | TABLEA | | Operand: | $0 \leq i < 255$ | Operand: | - | | Operation: | $i-ACC \rightarrow ACC$ | Operation: | ROM data{ TBHP, ACC } [7:0] | | Status<br>affected: | Z, DC, C | | → ACC<br>ROM data{TBHP, ACC} [13:8] | | Description: | Subtract ACC from 8-bit immediate | | → TBHD. | | | data i with 2's complement representation. The result is | Status affected: | | | | placed in ACC. | Description: | The 8 least significant bits of | | Cycle: | 1 | | ROM pointed by {TBHP[2:0], ACC} is placed to ACC. | | Example: | SUBIAi | | The 6 most significant bits of | | | (a) before executing instruction: i=0x05, ACC=0x06. | | ROM pointed by {TBHP[2:0], ACC} is placed to TBHD[5:0]. | | | after executing instruction: | Cycle: | 2 | | | ACC=0xFF, C=0. (-1) | Example: | TABLEA | | | (b) before executing instruction:<br>i=0x06, ACC=0x05, d=1, | | before executing instruction: TBHP=0x02, ACC=0x34. | | | after executing instruction: ACC=0x01, C=1. (+1) | | TBHD=0x01.<br>ROM data[0x234]= 0x35AA | | | | | after executing instruction: TBHD=0x35, ACC=0xAA. | | T0MD | Load ACC to T0MD | XORAR | Exclusive-OR ACC with R | | |------------------|--------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------|--| | Syntax: | TOMD | Syntax: | XORAR R, d | | | Operand: | | Operand: | $0 \le R \le 127$ | | | Operation: | $ACC \rightarrow TOMD$ | Operation: | d = 0, 1. | | | Status affected: | | | ACC⊕R→dest | | | Description: | The content of T0MD is loaded | Status affected: | Z | | | Description. | by ACC. | Description: | Exclusive-OR ACC with R. If d is 0, the result is placed in | | | Cycle: | 1 | | ACC. If d is 1, the result is | | | Example: | TOMD | | stored back to R. | | | | before executing instruction: | Cycle: | 1 | | | | T0MD=0x55, ACC=0xAA. after executing instruction: t0MD=0xAA. | Example: | XORAR R, d before executing instruction: R=0xA5, ACC=0xF0, d=1. after executing instruction: R=0x55. | | | T0MDR | Move T0MD to ACC | XORIA | Exclusive-OR Immediate with ACC | | |------------------------|---------------------------------------------------------|--------------------|-------------------------------------------------------------------------------------------------|--| | Syntax: | T0MDR | Syntax: | XORIA i | | | Operand: | | Operand: | $0 \le i < 255$ | | | Operation: | $TOMD \rightarrow ACC$ | Operation: | $ACC \oplus i \rightarrow ACC$ | | | Status<br>affected: | | Status affected: | Z | | | Description:<br>Cycle: | Move the content of T0MD to ACC. | Description: | Exclusive-OR ACC with 8-bit immediate data i. The result is stored in ACC. | | | Example: | T0MDR before executing instruction T0MD=0x55, ACC=0xAA. | Cycle:<br>Example: | 1<br>XORIA i | | | | after executing instruction ACC=0x55. | | before executing instruction:<br>i=0xA5, ACC=0xF0.<br>after executing instruction:<br>ACC=0x55. | | # 5. Configuration Words | Manaa | Outions | |---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Options | | High Oscillator Frequency | 1. I_HRC 2. E_HXT 3. E_XT | | Low Oscillator Frequency | 1. I_LRC 2. E_LXT | | High IRC Frequency | 1. 1MHz 2. 2MHz 3. 4MHz 4. 8MHz 5. 16MHz 6. 20MHz | | High Crystal Oscillator | $ \begin{array}{llllllllllllllllllllllllllllllllllll$ | | Instruction Clock | 1. 2 oscillator period 2. 4 oscillator period | | WDT | Watchdog Enable (Software control) Watchdog Disable (Always disable) | | WDT Event | Watchdog Reset | | Timer0 Source | 1. EX_CKI0 2. Low Oscillator (I_LRC/E_LXT) | | PA.5 | 1. PA.5 is I/O 2. PA.5 is reset | | PA.7 | 1. PA.7 is instruction clock output 2. PA.7 is I/O | | Startup Time | 1. 140us 2. 4.5ms 3. 18ms 4. 72ms 5. 288ms | | WDT Time Base | 1. 3.5ms 2. 15ms 3. 60ms 4. 250ms | | LVR Setting | Register Control 2. LVR Always On | | LVR Voltage | 1. 1.6V 2. 1.8V 3. 2.0V 4. 2.2V 5. 2.4V 6. 2.7V 7. 3.0V 8. 3.3V 9. 3.6V 10. 4.2V | | VDD Voltage | 1. 3.0V 2. 4.5V 3. 5.0V | | Analog Input pin select | 1. Enable 2. Disable | | Read Output Data | 1. I/O Port 2. Register | | E_LXT Backup Control | 1. Auto Off 2. Register Off | | EX_CKI0 to Inst. Clock | 1. Sync 2. Async | | Startup Clock | 1. Fast (I_HRC/E_HXT/E_XT) 2. Slow (I_LRC/E_LXT) | | PWM1 Output Pin | 1. PB3 2. PA4 | | PWM2 Output Pin | 1. PB2 2. PA0 | | PWM3 Output Pin | 1. PB4 2. PA3 | | PWM4 Output Pin | 1. PB5 2. PA2 | | PWM5 Output Pin | 1. PB0 2. PA1 | | Input Schmitt Trigger | 1 Enable 2. Disable (1/2 VDD) | | Input High Voltage (VIH) | 1. 0.7VDD 2. 0.5VDD | | Input Low Voltage (VIL) | 1. 0.3VDD 2. 0.2VDD | | | High IRC Frequency High Crystal Oscillator Instruction Clock WDT WDT Event Timer0 Source PA.5 PA.7 Startup Time WDT Time Base LVR Setting LVR Voltage VDD Voltage Analog Input pin select Read Output Data E_LXT Backup Control EX_CKI0 to Inst. Clock Startup Clock PWM1 Output Pin PWM2 Output Pin PWM3 Output Pin PWM4 Output Pin PWM5 Output Pin Input Schmitt Trigger Input High Voltage (VIH) | | Item | Name | Options | |------|------------------------|----------------------| | 29 | INT1 pad select | 1. PB1 2. PA2 | | 30 | High-level hold select | 1. Enable 2. Disable | | 31 | PWM2 Output Pin1 | 1. PA7 2. PB2 or PA0 | | 32 | PWM5 Output Pin1 | 1. PA6 2. PB0 or PA1 | Table 26 Configuration Words ## 6. Electrical Characteristics # 6.1 Absolute Maximum Rating | Symbol | Parameter | Rated Value | Unit | |-----------------------------------|-----------------------|---------------------------------|------| | V <sub>DD</sub> - V <sub>SS</sub> | Supply voltage | -0.5 ~ +6.0 | V | | V <sub>IN</sub> | Input voltage | Vss-0.3V ~ V <sub>DD</sub> +0.3 | V | | Top | Operating Temperature | -40 ~ +85 | °C | | Tst | Storage Temperature | -40 ~ +125 | °C | ## 6.2 DC Characteristics (All refer F<sub>INST</sub>=F<sub>HOSC</sub>/4, F<sub>HOSC</sub>=16MHz@I\_HRC, WDT enabled, ambient temperature T<sub>A</sub>=25°C unless otherwise specified.) | Symbol | Parameter | V <sub>DD</sub> | Min. | Тур. | Max. | Unit | Condition | |-----------------------------|---------------------|-----------------|------|------|------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | 3.3 | | | | F <sub>INST</sub> =10MHz @ I_HRC 20MHz/2T | | | | | 2.7 | | | | F <sub>INST</sub> =8MHz @ I_HRC & E_HXT 16MHz/2T | | | | | 2.2 | | | | F <sub>INST</sub> =5MHz @ I_HRC 20MHz/4T | | | | | 2.0 | | | | F <sub>INST</sub> =4MHz @ E_HXT 16MHz/4T & 8MHz/2T | | $V_{\text{DD}}$ | Operating voltage | | 2.0 | | 5.5 | V | F <sub>INST</sub> =4MHz @ I_HRC 8MHz/2T | | | | | 1.8 | | | | F <sub>INST</sub> =2MHz @ I_HRC & E_HXT 8MHz/4T | | | | | 1.8 | | | | F <sub>INST</sub> =2MHz @ I_HRC & E_XT 4MHz/2T | | | | | 1.8 | | | | F <sub>INST</sub> =1MHz @ I_HRC & E_XT 4MHz/4T | | | | | 1.8 | | | | Finst=8KHz @ I_LRC & E_LXT 32KHz/4T | | | | 5V | 4.0 | I | | <b>\</b> | RSTb (0.8 V <sub>DD</sub> ) | | | | 3V | 2.4 | | | V | 1.31b (0.0 Vbb) | | $V_{IH}$ | Input high voltage | 5V | 3.5 | | | V | All other I/O pins, EX_CKI, INT 0.7 V <sub>DD</sub> | | VIH I IIIput TiigiT Voitage | 3V | 2.1 | | | V | All other 1/0 pins, EX_ONI, INT 0.7 VDD | | | | | 5V | 2.5 | | | - V | All other I/O pins, EX CKI 0.5 V <sub>DD</sub> | | | | 3V | 1.5 | | | | THE OTHER THE PRINCE PARTY OF THE T | | | | 5V | | | 1.0 | V | RSTb (0.2 V <sub>DD</sub> ) | | | | 3V | | | 0.6 | V | 1.01b (0.2 Vbb) | | VIL | Input low voltage | 5V | | - | 1.5 | V | All other I/O pins, EX_CKI, INT 0.3 V <sub>DD</sub> | | V IL | input low voltage | 3V | | | 0.9 | V | All other 1/0 pins, EX_ORI, INT 0.3 VDD | | | | 5V | - | \ | 1.0 | V | All other I/O pins, EX_CKI 0.2 V <sub>DD</sub> | | | | 3V | - | | 0.6 | V | All other 1/0 pins, EX_ON 0.2 Vbb | | Іон | Output high current | 5V | | 18 | | mA | V <sub>OH</sub> =4.0V | | IOH | Output High current | 3V | | 10 | | шд | V <sub>OH</sub> =2.0V | | loL | Output low current | 5V | | 41 | | mA | V <sub>OL</sub> =1.0V | | IUL | Catput low current | 3V | | 26 | | 111/ | VOL 1.0 V | | $I_{IR}$ | IR sink current | 5V | | 43 | | mΔ | V <sub>OL</sub> =1.0V, IR | | IIR I'N SINK CUTTENT | IR sink current 3V | 3V | | 27 | | mA | VOL- 1.0 V, IIX | 108 | Symbol | Parameter | V <sub>DD</sub> | Min. | Тур. | Max. | Unit | Condition | | |-----------------|-----------------------|-----------------|------|------------|------|------|---------------------------------------------------------------------------------|--| | - J | | | | 71 | | | Normal Mode | | | | | 5V | | 2.4 | | | Normal Mode | | | | | 3V | | 3.1<br>1.4 | | mA | F <sub>HOSC</sub> =20MHz @ I_HRC/2 & E_HXT/2 | | | | | 5V | | 2.1 | | | | | | | | 3V | | 0.9 | | mΑ | F <sub>HOSC</sub> =20MHz @ I_HRC/4 & E_HXT/4 | | | | | 5V | | 2.6 | | | | | | | | 3V | | 1.1 | | mA | F <sub>HOSC</sub> =16MHz @ I_HRC/2 & E_HXT/2 | | | | | 5V | | 1.8 | | | | | | | | 3V | | 0.8 | | mA | F <sub>HOSC</sub> =16MHz @ I_HRC/4 & E_HXT/4 | | | | | 5V | | 1.6 | | | 5 01 11 0 1 11 D 10 0 5 5 1 11 17 10 | | | | | 3V | | 0.7 | | mA | F <sub>HOSC</sub> =8MHz @ I_HRC/2 & E_HXT/2 | | | | | 5V | | 1.2 | | ^ | 5 0MU- O LUDO/4 8 5 LIVT/4 | | | | | 3V | | 0.5 | | mA | FHOSC=8MHz @ I_HRC/4 & E_HXT/4 | | | | | 5V | | 1.2 | | mΛ | F4MH7 @ I HBC/2 8 E YT/2 | | | las | Operating current | 3V | | 0.5 | | mA | F <sub>HOSC</sub> =4MHz @ I_HRC/2 & E_XT/2 | | | I <sub>OP</sub> | Operating current | 5V | | 1.0 | | mA | F <sub>HOSC</sub> =4MHz @ I HRC/4 & E XT/4 | | | | | 3V | | 0.4 | | | 1 HOSC-41VII 12 @ 1_1 11 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | | | 5V | | 0.9 | | mA | F <sub>HOSC</sub> =1MHz @ I_HRC/2 & E_XT/2 | | | | | 3V | | 0.4 | | | 111030 111112 @ 1_1110/2 & 2_511/2 | | | | | 5V | | 8.0 | | mA | F <sub>HOSC</sub> =1MHz @ I_HRC/4 & E_XT/4 | | | | | 3V | | 0.3 | | | | | | | | Slow Mode | | | | | | | | | | 5V | | 6.9 | | uA | F <sub>HOSC</sub> disabled, | | | | | 3V | | 3.0 | | uA | FLOSC=32KHz @ I_LRC/2 | | | | | 5V | | 7.9 | | uA | F <sub>HOSC</sub> disabled, | | | | | 3V | | 3.2 | | | FLOSC=32KHz @ E_LXT/2. | | | | | 5V | | 4.8 | | uA | FHOSC disabled, | | | | | 3V | | 2.0 | | | FLOSC=32KHz @ I_LRC/4 | | | | | 5V | | 5.8 | | uA | F <sub>HOSC</sub> disabled,<br>F <sub>LOSC</sub> =32KHz @ E_LXT/4. | | | | | 3V<br>5V | | 3.2 | | | | | | Іѕтв | Standby current | 3V | | 1.2 | | uA | Standby mode, F <sub>HOSC</sub> disabled,<br>F <sub>LOSC</sub> =32KHz @ I LRC/4 | | | | | 5V | | | 0.5 | | | | | | | 3V | | - | 0.2 | uA | Halt mode, WDT disabled. | | | IHALT | Halt current | 5V | - | | 5.0 | | | | | | | 3V | | - | 3.0 | uA | Halt mode, WDT enabled. | | | | | 5V | | 50 | | | | | | | Dall III and a second | 3V | | 100 | | ΚΩ | Pull-High resistor | | | R <sub>PH</sub> | Pull-High resistor | 5V | | 0.5 | | | DAO High importance Dall on a circle | | | | | 3V | | 1 | | ΜΩ | PA3 High-impedance Pull-up resistor | | | D- | Dull Low resista- | 5V | | 50 | | KO. | Pull Low register | | | R <sub>PL</sub> | Pull-Low resistor | 3V | | 100 | | ΚΩ | Pull-Low resistor | | ## 6.3 OSC Characteristics (Measurement conditions V<sub>DD</sub> Voltage, T<sub>A</sub> Temperature are equal to programming conditions.) | Parameter | Min. | Тур. | Max. | Unit | Condition | |----------------------------|------|------|------|------|---------------------------------------| | I_HRC deviation by socket | | | ±1 | % | Socket installed directly on writer. | | I_HRC deviation by handler | | | ±3 | % | Handler condition with correct setup. | | I_LRC deviation by handler | | | ±5 | % | | # 6.4 Comparator / LVD Characteristics (V<sub>DD</sub>=5V, V<sub>SS</sub>=0V, T<sub>A</sub>=25°C unless otherwise specified.) | Symbol | Parameter | Min. | Тур. | Max. | Unit | Condition | |------------------|-----------------------------------|------|------|------|------|-----------------------------------| | V <sub>IVR</sub> | Comparator input voltage range | 0 | | 5 | V | F <sub>HOSC</sub> =1MHz | | T <sub>ENO</sub> | Comparator enable to output valid | | 20 | | us | F <sub>HOSC</sub> =1MHz | | Ico | Operating current of comparator | | 135 | | uA | F <sub>HOSC</sub> =1MHz, P2V mode | | I <sub>LVD</sub> | Operating current of LVD | | 150 | | uA | F <sub>HOSC</sub> =1MHz, LVD=4.3V | | ELVD | LVD voltage error | | | 3 | % | F <sub>HOSC</sub> =1MHz, LVD=4.3V | # 6.5 Characteristic Graph # 6.5.1 Frequency vs. VDD of I\_HRC # 6.5.2 Frequency vs. Temperature of I\_HRC # 6.5.3 Frequency vs. V<sub>DD</sub> of I\_LRC ## 6.5.4 Frequency vs. Temperature of I\_LRC # 6.5.5 Pull High Resistor vs. VDD # 6.5.6 Pull Low Resistor vs. VDD # 6.6 Recommended LVR Voltage | Frequency | LVR default Setting | LVR Setting (Min.) | | | |-----------|---------------------|--------------------|--|--| | 20M/2T | 3.3V | 3.3V | | | | 16M/2T | 2.7V | 2.7V | | | | 20M/4T | 2.2V | 2.2V | | | | 16M/4T | 2.0V | 2.0V | | | | 8M/4T | 1.8V | 1.8V | | | | 4M/4T | 1.8V | 1.8V | | | Bypass Prescaler (TM1\_HRC=1) | Frequency | LVR : Recommended Bypass Prescaler | |-----------|------------------------------------| | 20M/2T | 3.3V @ I_HRC=20MHz | | 16M/2T | 2.7V @ I_HRC=16MHz | | 20M/4T | 2.7V @ I_HRC=20MHz | | 16M/4T | 2.4V @ I_HRC=16MHz | | 8M/4T | 2.4V @ I_HRC=8MHz | | 4M/4T | 2.4V @ I_HRC=4MHz | # 6.7 LVR vs. Temperature # 7. Die Pad Diagram ## 8. Package Dimension ## 8.1 8-Pin Plastic SOP (150 mil) ## 8.2 16-Pin Plastic SOP (150 mil) # 9. Ordering Information | P/N | Package Type | Pin Count | Package Width | Shipping | |-------------|--------------|-----------|---------------|-------------------------------------------------------| | AT8A54E1 | Die | | | | | AT8A54E1S8 | SOP | 8 | 150 mil | Tape & Reel: 2.5K pcs per Reel Tube: 100 pcs per Tube | | AT8A54E1S16 | SOP | 16 | 150 mil | Tape & Reel: 2.5K pcs per Reel Tube: 50 pcs per Tube |